pomera-ai-commander 0.1.0 → 1.2.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -21
- package/README.md +105 -680
- package/bin/pomera-ai-commander.js +62 -62
- package/core/__init__.py +65 -65
- package/core/app_context.py +482 -482
- package/core/async_text_processor.py +421 -421
- package/core/backup_manager.py +655 -655
- package/core/backup_recovery_manager.py +1033 -1033
- package/core/content_hash_cache.py +508 -508
- package/core/context_menu.py +313 -313
- package/core/data_validator.py +1066 -1066
- package/core/database_connection_manager.py +744 -744
- package/core/database_curl_settings_manager.py +608 -608
- package/core/database_promera_ai_settings_manager.py +446 -446
- package/core/database_schema.py +411 -411
- package/core/database_schema_manager.py +395 -395
- package/core/database_settings_manager.py +1507 -1507
- package/core/database_settings_manager_interface.py +456 -456
- package/core/dialog_manager.py +734 -734
- package/core/efficient_line_numbers.py +510 -510
- package/core/error_handler.py +746 -746
- package/core/error_service.py +431 -431
- package/core/event_consolidator.py +511 -511
- package/core/mcp/__init__.py +43 -43
- package/core/mcp/protocol.py +288 -288
- package/core/mcp/schema.py +251 -251
- package/core/mcp/server_stdio.py +299 -299
- package/core/mcp/tool_registry.py +2372 -2345
- package/core/memory_efficient_text_widget.py +711 -711
- package/core/migration_manager.py +914 -914
- package/core/migration_test_suite.py +1085 -1085
- package/core/migration_validator.py +1143 -1143
- package/core/optimized_find_replace.py +714 -714
- package/core/optimized_pattern_engine.py +424 -424
- package/core/optimized_search_highlighter.py +552 -552
- package/core/performance_monitor.py +674 -674
- package/core/persistence_manager.py +712 -712
- package/core/progressive_stats_calculator.py +632 -632
- package/core/regex_pattern_cache.py +529 -529
- package/core/regex_pattern_library.py +350 -350
- package/core/search_operation_manager.py +434 -434
- package/core/settings_defaults_registry.py +1087 -1087
- package/core/settings_integrity_validator.py +1111 -1111
- package/core/settings_serializer.py +557 -557
- package/core/settings_validator.py +1823 -1823
- package/core/smart_stats_calculator.py +709 -709
- package/core/statistics_update_manager.py +619 -619
- package/core/stats_config_manager.py +858 -858
- package/core/streaming_text_handler.py +723 -723
- package/core/task_scheduler.py +596 -596
- package/core/update_pattern_library.py +168 -168
- package/core/visibility_monitor.py +596 -596
- package/core/widget_cache.py +498 -498
- package/mcp.json +51 -61
- package/package.json +61 -57
- package/pomera.py +7482 -7482
- package/pomera_mcp_server.py +183 -144
- package/requirements.txt +32 -0
- package/tools/__init__.py +4 -4
- package/tools/ai_tools.py +2891 -2891
- package/tools/ascii_art_generator.py +352 -352
- package/tools/base64_tools.py +183 -183
- package/tools/base_tool.py +511 -511
- package/tools/case_tool.py +308 -308
- package/tools/column_tools.py +395 -395
- package/tools/cron_tool.py +884 -884
- package/tools/curl_history.py +600 -600
- package/tools/curl_processor.py +1207 -1207
- package/tools/curl_settings.py +502 -502
- package/tools/curl_tool.py +5467 -5467
- package/tools/diff_viewer.py +1071 -1071
- package/tools/email_extraction_tool.py +248 -248
- package/tools/email_header_analyzer.py +425 -425
- package/tools/extraction_tools.py +250 -250
- package/tools/find_replace.py +1750 -1750
- package/tools/folder_file_reporter.py +1463 -1463
- package/tools/folder_file_reporter_adapter.py +480 -480
- package/tools/generator_tools.py +1216 -1216
- package/tools/hash_generator.py +255 -255
- package/tools/html_tool.py +656 -656
- package/tools/jsonxml_tool.py +729 -729
- package/tools/line_tools.py +419 -419
- package/tools/markdown_tools.py +561 -561
- package/tools/mcp_widget.py +1417 -1417
- package/tools/notes_widget.py +973 -973
- package/tools/number_base_converter.py +372 -372
- package/tools/regex_extractor.py +571 -571
- package/tools/slug_generator.py +310 -310
- package/tools/sorter_tools.py +458 -458
- package/tools/string_escape_tool.py +392 -392
- package/tools/text_statistics_tool.py +365 -365
- package/tools/text_wrapper.py +430 -430
- package/tools/timestamp_converter.py +421 -421
- package/tools/tool_loader.py +710 -710
- package/tools/translator_tools.py +522 -522
- package/tools/url_link_extractor.py +261 -261
- package/tools/url_parser.py +204 -204
- package/tools/whitespace_tools.py +355 -355
- package/tools/word_frequency_counter.py +146 -146
- package/core/__pycache__/__init__.cpython-313.pyc +0 -0
- package/core/__pycache__/app_context.cpython-313.pyc +0 -0
- package/core/__pycache__/async_text_processor.cpython-313.pyc +0 -0
- package/core/__pycache__/backup_manager.cpython-313.pyc +0 -0
- package/core/__pycache__/backup_recovery_manager.cpython-313.pyc +0 -0
- package/core/__pycache__/content_hash_cache.cpython-313.pyc +0 -0
- package/core/__pycache__/context_menu.cpython-313.pyc +0 -0
- package/core/__pycache__/data_validator.cpython-313.pyc +0 -0
- package/core/__pycache__/database_connection_manager.cpython-313.pyc +0 -0
- package/core/__pycache__/database_curl_settings_manager.cpython-313.pyc +0 -0
- package/core/__pycache__/database_promera_ai_settings_manager.cpython-313.pyc +0 -0
- package/core/__pycache__/database_schema.cpython-313.pyc +0 -0
- package/core/__pycache__/database_schema_manager.cpython-313.pyc +0 -0
- package/core/__pycache__/database_settings_manager.cpython-313.pyc +0 -0
- package/core/__pycache__/database_settings_manager_interface.cpython-313.pyc +0 -0
- package/core/__pycache__/dialog_manager.cpython-313.pyc +0 -0
- package/core/__pycache__/efficient_line_numbers.cpython-313.pyc +0 -0
- package/core/__pycache__/error_handler.cpython-313.pyc +0 -0
- package/core/__pycache__/error_service.cpython-313.pyc +0 -0
- package/core/__pycache__/event_consolidator.cpython-313.pyc +0 -0
- package/core/__pycache__/memory_efficient_text_widget.cpython-313.pyc +0 -0
- package/core/__pycache__/migration_manager.cpython-313.pyc +0 -0
- package/core/__pycache__/migration_test_suite.cpython-313.pyc +0 -0
- package/core/__pycache__/migration_validator.cpython-313.pyc +0 -0
- package/core/__pycache__/optimized_find_replace.cpython-313.pyc +0 -0
- package/core/__pycache__/optimized_pattern_engine.cpython-313.pyc +0 -0
- package/core/__pycache__/optimized_search_highlighter.cpython-313.pyc +0 -0
- package/core/__pycache__/performance_monitor.cpython-313.pyc +0 -0
- package/core/__pycache__/persistence_manager.cpython-313.pyc +0 -0
- package/core/__pycache__/progressive_stats_calculator.cpython-313.pyc +0 -0
- package/core/__pycache__/regex_pattern_cache.cpython-313.pyc +0 -0
- package/core/__pycache__/regex_pattern_library.cpython-313.pyc +0 -0
- package/core/__pycache__/search_operation_manager.cpython-313.pyc +0 -0
- package/core/__pycache__/settings_defaults_registry.cpython-313.pyc +0 -0
- package/core/__pycache__/settings_integrity_validator.cpython-313.pyc +0 -0
- package/core/__pycache__/settings_serializer.cpython-313.pyc +0 -0
- package/core/__pycache__/settings_validator.cpython-313.pyc +0 -0
- package/core/__pycache__/smart_stats_calculator.cpython-313.pyc +0 -0
- package/core/__pycache__/statistics_update_manager.cpython-313.pyc +0 -0
- package/core/__pycache__/stats_config_manager.cpython-313.pyc +0 -0
- package/core/__pycache__/streaming_text_handler.cpython-313.pyc +0 -0
- package/core/__pycache__/task_scheduler.cpython-313.pyc +0 -0
- package/core/__pycache__/visibility_monitor.cpython-313.pyc +0 -0
- package/core/__pycache__/widget_cache.cpython-313.pyc +0 -0
- package/core/mcp/__pycache__/__init__.cpython-313.pyc +0 -0
- package/core/mcp/__pycache__/protocol.cpython-313.pyc +0 -0
- package/core/mcp/__pycache__/schema.cpython-313.pyc +0 -0
- package/core/mcp/__pycache__/server_stdio.cpython-313.pyc +0 -0
- package/core/mcp/__pycache__/tool_registry.cpython-313.pyc +0 -0
- package/tools/__pycache__/__init__.cpython-313.pyc +0 -0
- package/tools/__pycache__/ai_tools.cpython-313.pyc +0 -0
- package/tools/__pycache__/ascii_art_generator.cpython-313.pyc +0 -0
- package/tools/__pycache__/base64_tools.cpython-313.pyc +0 -0
- package/tools/__pycache__/base_tool.cpython-313.pyc +0 -0
- package/tools/__pycache__/case_tool.cpython-313.pyc +0 -0
- package/tools/__pycache__/column_tools.cpython-313.pyc +0 -0
- package/tools/__pycache__/cron_tool.cpython-313.pyc +0 -0
- package/tools/__pycache__/curl_history.cpython-313.pyc +0 -0
- package/tools/__pycache__/curl_processor.cpython-313.pyc +0 -0
- package/tools/__pycache__/curl_settings.cpython-313.pyc +0 -0
- package/tools/__pycache__/curl_tool.cpython-313.pyc +0 -0
- package/tools/__pycache__/diff_viewer.cpython-313.pyc +0 -0
- package/tools/__pycache__/email_extraction_tool.cpython-313.pyc +0 -0
- package/tools/__pycache__/email_header_analyzer.cpython-313.pyc +0 -0
- package/tools/__pycache__/extraction_tools.cpython-313.pyc +0 -0
- package/tools/__pycache__/find_replace.cpython-313.pyc +0 -0
- package/tools/__pycache__/folder_file_reporter.cpython-313.pyc +0 -0
- package/tools/__pycache__/folder_file_reporter_adapter.cpython-313.pyc +0 -0
- package/tools/__pycache__/generator_tools.cpython-313.pyc +0 -0
- package/tools/__pycache__/hash_generator.cpython-313.pyc +0 -0
- package/tools/__pycache__/html_tool.cpython-313.pyc +0 -0
- package/tools/__pycache__/huggingface_helper.cpython-313.pyc +0 -0
- package/tools/__pycache__/jsonxml_tool.cpython-313.pyc +0 -0
- package/tools/__pycache__/line_tools.cpython-313.pyc +0 -0
- package/tools/__pycache__/list_comparator.cpython-313.pyc +0 -0
- package/tools/__pycache__/markdown_tools.cpython-313.pyc +0 -0
- package/tools/__pycache__/mcp_widget.cpython-313.pyc +0 -0
- package/tools/__pycache__/notes_widget.cpython-313.pyc +0 -0
- package/tools/__pycache__/number_base_converter.cpython-313.pyc +0 -0
- package/tools/__pycache__/regex_extractor.cpython-313.pyc +0 -0
- package/tools/__pycache__/slug_generator.cpython-313.pyc +0 -0
- package/tools/__pycache__/sorter_tools.cpython-313.pyc +0 -0
- package/tools/__pycache__/string_escape_tool.cpython-313.pyc +0 -0
- package/tools/__pycache__/text_statistics_tool.cpython-313.pyc +0 -0
- package/tools/__pycache__/text_wrapper.cpython-313.pyc +0 -0
- package/tools/__pycache__/timestamp_converter.cpython-313.pyc +0 -0
- package/tools/__pycache__/tool_loader.cpython-313.pyc +0 -0
- package/tools/__pycache__/translator_tools.cpython-313.pyc +0 -0
- package/tools/__pycache__/url_link_extractor.cpython-313.pyc +0 -0
- package/tools/__pycache__/url_parser.cpython-313.pyc +0 -0
- package/tools/__pycache__/whitespace_tools.cpython-313.pyc +0 -0
- package/tools/__pycache__/word_frequency_counter.cpython-313.pyc +0 -0
package/tools/hash_generator.py
CHANGED
|
@@ -1,256 +1,256 @@
|
|
|
1
|
-
"""
|
|
2
|
-
Hash Generator Module - Cryptographic hash generation
|
|
3
|
-
|
|
4
|
-
This module provides hash generation functionality for text content
|
|
5
|
-
for the Pomera AI Commander application.
|
|
6
|
-
|
|
7
|
-
Features:
|
|
8
|
-
- MD5 hash
|
|
9
|
-
- SHA-1 hash
|
|
10
|
-
- SHA-256 hash
|
|
11
|
-
- SHA-512 hash
|
|
12
|
-
- CRC32 checksum
|
|
13
|
-
- Uppercase/lowercase output option
|
|
14
|
-
"""
|
|
15
|
-
|
|
16
|
-
import tkinter as tk
|
|
17
|
-
from tkinter import ttk
|
|
18
|
-
import hashlib
|
|
19
|
-
import zlib
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
class HashGeneratorProcessor:
|
|
23
|
-
"""Hash generator processor with multiple algorithm support."""
|
|
24
|
-
|
|
25
|
-
ALGORITHMS = {
|
|
26
|
-
"md5": ("MD5", lambda data: hashlib.md5(data).hexdigest()),
|
|
27
|
-
"sha1": ("SHA-1", lambda data: hashlib.sha1(data).hexdigest()),
|
|
28
|
-
"sha256": ("SHA-256", lambda data: hashlib.sha256(data).hexdigest()),
|
|
29
|
-
"sha512": ("SHA-512", lambda data: hashlib.sha512(data).hexdigest()),
|
|
30
|
-
"crc32": ("CRC32", lambda data: format(zlib.crc32(data) & 0xffffffff, '08x')),
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
@staticmethod
|
|
34
|
-
def generate_hash(text, algorithm, uppercase=False):
|
|
35
|
-
"""Generate hash for the given text using specified algorithm."""
|
|
36
|
-
if algorithm not in HashGeneratorProcessor.ALGORITHMS:
|
|
37
|
-
return f"Unknown algorithm: {algorithm}"
|
|
38
|
-
|
|
39
|
-
data = text.encode('utf-8')
|
|
40
|
-
name, hash_func = HashGeneratorProcessor.ALGORITHMS[algorithm]
|
|
41
|
-
result = hash_func(data)
|
|
42
|
-
|
|
43
|
-
if uppercase:
|
|
44
|
-
result = result.upper()
|
|
45
|
-
|
|
46
|
-
return result
|
|
47
|
-
|
|
48
|
-
@staticmethod
|
|
49
|
-
def generate_all_hashes(text, algorithms, uppercase=False):
|
|
50
|
-
"""Generate hashes for all specified algorithms."""
|
|
51
|
-
if not text:
|
|
52
|
-
return "No input text provided."
|
|
53
|
-
|
|
54
|
-
data = text.encode('utf-8')
|
|
55
|
-
results = []
|
|
56
|
-
results.append("=" * 70)
|
|
57
|
-
results.append("HASH RESULTS")
|
|
58
|
-
results.append("=" * 70)
|
|
59
|
-
results.append(f"Input Length: {len(text)} characters, {len(data)} bytes")
|
|
60
|
-
results.append("")
|
|
61
|
-
|
|
62
|
-
for algo in algorithms:
|
|
63
|
-
if algo in HashGeneratorProcessor.ALGORITHMS:
|
|
64
|
-
name, hash_func = HashGeneratorProcessor.ALGORITHMS[algo]
|
|
65
|
-
hash_value = hash_func(data)
|
|
66
|
-
if uppercase:
|
|
67
|
-
hash_value = hash_value.upper()
|
|
68
|
-
results.append(f"{name}:")
|
|
69
|
-
results.append(f" {hash_value}")
|
|
70
|
-
results.append("")
|
|
71
|
-
|
|
72
|
-
results.append("=" * 70)
|
|
73
|
-
return '\n'.join(results)
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
class HashGeneratorWidget(ttk.Frame):
|
|
77
|
-
"""Widget for hash generator tool."""
|
|
78
|
-
|
|
79
|
-
def __init__(self, parent, app):
|
|
80
|
-
super().__init__(parent)
|
|
81
|
-
self.app = app
|
|
82
|
-
self.processor = HashGeneratorProcessor()
|
|
83
|
-
|
|
84
|
-
# Algorithm checkboxes
|
|
85
|
-
self.algo_vars = {
|
|
86
|
-
"md5": tk.BooleanVar(value=True),
|
|
87
|
-
"sha1": tk.BooleanVar(value=False),
|
|
88
|
-
"sha256": tk.BooleanVar(value=True),
|
|
89
|
-
"sha512": tk.BooleanVar(value=False),
|
|
90
|
-
"crc32": tk.BooleanVar(value=False),
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
self.uppercase = tk.BooleanVar(value=False)
|
|
94
|
-
|
|
95
|
-
self.create_widgets()
|
|
96
|
-
self.load_settings()
|
|
97
|
-
|
|
98
|
-
def create_widgets(self):
|
|
99
|
-
"""Creates the widget interface."""
|
|
100
|
-
# Algorithms frame
|
|
101
|
-
algo_frame = ttk.LabelFrame(self, text="Hash Algorithms", padding=10)
|
|
102
|
-
algo_frame.pack(fill=tk.X, padx=5, pady=5)
|
|
103
|
-
|
|
104
|
-
algo_labels = {
|
|
105
|
-
"md5": "MD5 (128-bit)",
|
|
106
|
-
"sha1": "SHA-1 (160-bit)",
|
|
107
|
-
"sha256": "SHA-256 (256-bit)",
|
|
108
|
-
"sha512": "SHA-512 (512-bit)",
|
|
109
|
-
"crc32": "CRC32 (32-bit checksum)",
|
|
110
|
-
}
|
|
111
|
-
|
|
112
|
-
for algo, label in algo_labels.items():
|
|
113
|
-
ttk.Checkbutton(algo_frame, text=label,
|
|
114
|
-
variable=self.algo_vars[algo],
|
|
115
|
-
command=self.on_setting_change).pack(anchor=tk.W)
|
|
116
|
-
|
|
117
|
-
# Options frame
|
|
118
|
-
options_frame = ttk.LabelFrame(self, text="Options", padding=10)
|
|
119
|
-
options_frame.pack(fill=tk.X, padx=5, pady=5)
|
|
120
|
-
|
|
121
|
-
ttk.Checkbutton(options_frame, text="Uppercase Output",
|
|
122
|
-
variable=self.uppercase,
|
|
123
|
-
command=self.on_setting_change).pack(anchor=tk.W)
|
|
124
|
-
|
|
125
|
-
# Generate button
|
|
126
|
-
ttk.Button(self, text="Generate Hashes",
|
|
127
|
-
command=self.generate).pack(pady=10)
|
|
128
|
-
|
|
129
|
-
def load_settings(self):
|
|
130
|
-
"""Load settings from the application."""
|
|
131
|
-
settings = self.app.settings.get("tool_settings", {}).get("Hash Generator", {})
|
|
132
|
-
|
|
133
|
-
algorithms = settings.get("algorithms", ["md5", "sha256"])
|
|
134
|
-
for algo in self.algo_vars:
|
|
135
|
-
self.algo_vars[algo].set(algo in algorithms)
|
|
136
|
-
|
|
137
|
-
self.uppercase.set(settings.get("uppercase", False))
|
|
138
|
-
|
|
139
|
-
def save_settings(self):
|
|
140
|
-
"""Save current settings to the application."""
|
|
141
|
-
if "Hash Generator" not in self.app.settings["tool_settings"]:
|
|
142
|
-
self.app.settings["tool_settings"]["Hash Generator"] = {}
|
|
143
|
-
|
|
144
|
-
algorithms = [algo for algo, var in self.algo_vars.items() if var.get()]
|
|
145
|
-
|
|
146
|
-
self.app.settings["tool_settings"]["Hash Generator"].update({
|
|
147
|
-
"algorithms": algorithms,
|
|
148
|
-
"uppercase": self.uppercase.get()
|
|
149
|
-
})
|
|
150
|
-
|
|
151
|
-
self.app.save_settings()
|
|
152
|
-
|
|
153
|
-
def on_setting_change(self, *args):
|
|
154
|
-
"""Handle setting changes."""
|
|
155
|
-
self.save_settings()
|
|
156
|
-
|
|
157
|
-
def generate(self):
|
|
158
|
-
"""Generate hashes for the input text."""
|
|
159
|
-
active_input_tab = self.app.input_tabs[self.app.input_notebook.index(self.app.input_notebook.select())]
|
|
160
|
-
input_text = active_input_tab.text.get("1.0", tk.END).rstrip('\n')
|
|
161
|
-
|
|
162
|
-
algorithms = [algo for algo, var in self.algo_vars.items() if var.get()]
|
|
163
|
-
|
|
164
|
-
if not algorithms:
|
|
165
|
-
result = "Please select at least one hash algorithm."
|
|
166
|
-
else:
|
|
167
|
-
result = HashGeneratorProcessor.generate_all_hashes(
|
|
168
|
-
input_text,
|
|
169
|
-
algorithms,
|
|
170
|
-
self.uppercase.get()
|
|
171
|
-
)
|
|
172
|
-
|
|
173
|
-
active_output_tab = self.app.output_tabs[self.app.output_notebook.index(self.app.output_notebook.select())]
|
|
174
|
-
active_output_tab.text.config(state="normal")
|
|
175
|
-
active_output_tab.text.delete("1.0", tk.END)
|
|
176
|
-
active_output_tab.text.insert("1.0", result)
|
|
177
|
-
active_output_tab.text.config(state="disabled")
|
|
178
|
-
|
|
179
|
-
self.app.update_all_stats()
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
class HashGenerator:
|
|
183
|
-
"""Main class for Hash Generator integration."""
|
|
184
|
-
|
|
185
|
-
def __init__(self):
|
|
186
|
-
self.processor = HashGeneratorProcessor()
|
|
187
|
-
|
|
188
|
-
def create_widget(self, parent, app):
|
|
189
|
-
"""Create and return the Hash Generator widget."""
|
|
190
|
-
return HashGeneratorWidget(parent, app)
|
|
191
|
-
|
|
192
|
-
def get_default_settings(self):
|
|
193
|
-
"""Return default settings for Hash Generator."""
|
|
194
|
-
return {
|
|
195
|
-
"algorithms": ["md5", "sha256"],
|
|
196
|
-
"uppercase": False
|
|
197
|
-
}
|
|
198
|
-
|
|
199
|
-
def process_text(self, input_text, settings):
|
|
200
|
-
"""Process text and return hashes."""
|
|
201
|
-
return HashGeneratorProcessor.generate_all_hashes(
|
|
202
|
-
input_text,
|
|
203
|
-
settings.get("algorithms", ["md5", "sha256"]),
|
|
204
|
-
settings.get("uppercase", False)
|
|
205
|
-
)
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
# BaseTool-compatible wrapper (for future migration)
|
|
209
|
-
try:
|
|
210
|
-
from tools.base_tool import BaseTool
|
|
211
|
-
from typing import Dict, Any, Optional, Callable
|
|
212
|
-
|
|
213
|
-
class HashGeneratorV2(BaseTool):
|
|
214
|
-
"""
|
|
215
|
-
BaseTool-compatible version of HashGenerator.
|
|
216
|
-
"""
|
|
217
|
-
|
|
218
|
-
TOOL_NAME = "Hash Generator"
|
|
219
|
-
TOOL_DESCRIPTION = "Generate MD5, SHA-1, SHA-256, SHA-512, and CRC32 hashes"
|
|
220
|
-
TOOL_VERSION = "2.0.0"
|
|
221
|
-
|
|
222
|
-
def __init__(self):
|
|
223
|
-
super().__init__()
|
|
224
|
-
self._processor = HashGeneratorProcessor()
|
|
225
|
-
|
|
226
|
-
def process_text(self, input_text: str, settings: Dict[str, Any]) -> str:
|
|
227
|
-
"""Process text and return hashes."""
|
|
228
|
-
return HashGeneratorProcessor.generate_all_hashes(
|
|
229
|
-
input_text,
|
|
230
|
-
settings.get("algorithms", ["md5", "sha256"]),
|
|
231
|
-
settings.get("uppercase", False)
|
|
232
|
-
)
|
|
233
|
-
|
|
234
|
-
def create_ui(self,
|
|
235
|
-
parent,
|
|
236
|
-
settings: Dict[str, Any],
|
|
237
|
-
on_setting_change_callback: Optional[Callable] = None,
|
|
238
|
-
apply_tool_callback: Optional[Callable] = None):
|
|
239
|
-
"""Create the Hash Generator UI using the existing widget."""
|
|
240
|
-
self._settings = settings.copy()
|
|
241
|
-
self._on_setting_change = on_setting_change_callback
|
|
242
|
-
self._apply_callback = apply_tool_callback
|
|
243
|
-
# Use existing widget implementation
|
|
244
|
-
return None # Widget created separately
|
|
245
|
-
|
|
246
|
-
@classmethod
|
|
247
|
-
def get_default_settings(cls) -> Dict[str, Any]:
|
|
248
|
-
"""Return default settings for Hash Generator."""
|
|
249
|
-
return {
|
|
250
|
-
"algorithms": ["md5", "sha256"],
|
|
251
|
-
"uppercase": False
|
|
252
|
-
}
|
|
253
|
-
|
|
254
|
-
except ImportError:
|
|
255
|
-
# BaseTool not available
|
|
1
|
+
"""
|
|
2
|
+
Hash Generator Module - Cryptographic hash generation
|
|
3
|
+
|
|
4
|
+
This module provides hash generation functionality for text content
|
|
5
|
+
for the Pomera AI Commander application.
|
|
6
|
+
|
|
7
|
+
Features:
|
|
8
|
+
- MD5 hash
|
|
9
|
+
- SHA-1 hash
|
|
10
|
+
- SHA-256 hash
|
|
11
|
+
- SHA-512 hash
|
|
12
|
+
- CRC32 checksum
|
|
13
|
+
- Uppercase/lowercase output option
|
|
14
|
+
"""
|
|
15
|
+
|
|
16
|
+
import tkinter as tk
|
|
17
|
+
from tkinter import ttk
|
|
18
|
+
import hashlib
|
|
19
|
+
import zlib
|
|
20
|
+
|
|
21
|
+
|
|
22
|
+
class HashGeneratorProcessor:
|
|
23
|
+
"""Hash generator processor with multiple algorithm support."""
|
|
24
|
+
|
|
25
|
+
ALGORITHMS = {
|
|
26
|
+
"md5": ("MD5", lambda data: hashlib.md5(data).hexdigest()),
|
|
27
|
+
"sha1": ("SHA-1", lambda data: hashlib.sha1(data).hexdigest()),
|
|
28
|
+
"sha256": ("SHA-256", lambda data: hashlib.sha256(data).hexdigest()),
|
|
29
|
+
"sha512": ("SHA-512", lambda data: hashlib.sha512(data).hexdigest()),
|
|
30
|
+
"crc32": ("CRC32", lambda data: format(zlib.crc32(data) & 0xffffffff, '08x')),
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
@staticmethod
|
|
34
|
+
def generate_hash(text, algorithm, uppercase=False):
|
|
35
|
+
"""Generate hash for the given text using specified algorithm."""
|
|
36
|
+
if algorithm not in HashGeneratorProcessor.ALGORITHMS:
|
|
37
|
+
return f"Unknown algorithm: {algorithm}"
|
|
38
|
+
|
|
39
|
+
data = text.encode('utf-8')
|
|
40
|
+
name, hash_func = HashGeneratorProcessor.ALGORITHMS[algorithm]
|
|
41
|
+
result = hash_func(data)
|
|
42
|
+
|
|
43
|
+
if uppercase:
|
|
44
|
+
result = result.upper()
|
|
45
|
+
|
|
46
|
+
return result
|
|
47
|
+
|
|
48
|
+
@staticmethod
|
|
49
|
+
def generate_all_hashes(text, algorithms, uppercase=False):
|
|
50
|
+
"""Generate hashes for all specified algorithms."""
|
|
51
|
+
if not text:
|
|
52
|
+
return "No input text provided."
|
|
53
|
+
|
|
54
|
+
data = text.encode('utf-8')
|
|
55
|
+
results = []
|
|
56
|
+
results.append("=" * 70)
|
|
57
|
+
results.append("HASH RESULTS")
|
|
58
|
+
results.append("=" * 70)
|
|
59
|
+
results.append(f"Input Length: {len(text)} characters, {len(data)} bytes")
|
|
60
|
+
results.append("")
|
|
61
|
+
|
|
62
|
+
for algo in algorithms:
|
|
63
|
+
if algo in HashGeneratorProcessor.ALGORITHMS:
|
|
64
|
+
name, hash_func = HashGeneratorProcessor.ALGORITHMS[algo]
|
|
65
|
+
hash_value = hash_func(data)
|
|
66
|
+
if uppercase:
|
|
67
|
+
hash_value = hash_value.upper()
|
|
68
|
+
results.append(f"{name}:")
|
|
69
|
+
results.append(f" {hash_value}")
|
|
70
|
+
results.append("")
|
|
71
|
+
|
|
72
|
+
results.append("=" * 70)
|
|
73
|
+
return '\n'.join(results)
|
|
74
|
+
|
|
75
|
+
|
|
76
|
+
class HashGeneratorWidget(ttk.Frame):
|
|
77
|
+
"""Widget for hash generator tool."""
|
|
78
|
+
|
|
79
|
+
def __init__(self, parent, app):
|
|
80
|
+
super().__init__(parent)
|
|
81
|
+
self.app = app
|
|
82
|
+
self.processor = HashGeneratorProcessor()
|
|
83
|
+
|
|
84
|
+
# Algorithm checkboxes
|
|
85
|
+
self.algo_vars = {
|
|
86
|
+
"md5": tk.BooleanVar(value=True),
|
|
87
|
+
"sha1": tk.BooleanVar(value=False),
|
|
88
|
+
"sha256": tk.BooleanVar(value=True),
|
|
89
|
+
"sha512": tk.BooleanVar(value=False),
|
|
90
|
+
"crc32": tk.BooleanVar(value=False),
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
self.uppercase = tk.BooleanVar(value=False)
|
|
94
|
+
|
|
95
|
+
self.create_widgets()
|
|
96
|
+
self.load_settings()
|
|
97
|
+
|
|
98
|
+
def create_widgets(self):
|
|
99
|
+
"""Creates the widget interface."""
|
|
100
|
+
# Algorithms frame
|
|
101
|
+
algo_frame = ttk.LabelFrame(self, text="Hash Algorithms", padding=10)
|
|
102
|
+
algo_frame.pack(fill=tk.X, padx=5, pady=5)
|
|
103
|
+
|
|
104
|
+
algo_labels = {
|
|
105
|
+
"md5": "MD5 (128-bit)",
|
|
106
|
+
"sha1": "SHA-1 (160-bit)",
|
|
107
|
+
"sha256": "SHA-256 (256-bit)",
|
|
108
|
+
"sha512": "SHA-512 (512-bit)",
|
|
109
|
+
"crc32": "CRC32 (32-bit checksum)",
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
for algo, label in algo_labels.items():
|
|
113
|
+
ttk.Checkbutton(algo_frame, text=label,
|
|
114
|
+
variable=self.algo_vars[algo],
|
|
115
|
+
command=self.on_setting_change).pack(anchor=tk.W)
|
|
116
|
+
|
|
117
|
+
# Options frame
|
|
118
|
+
options_frame = ttk.LabelFrame(self, text="Options", padding=10)
|
|
119
|
+
options_frame.pack(fill=tk.X, padx=5, pady=5)
|
|
120
|
+
|
|
121
|
+
ttk.Checkbutton(options_frame, text="Uppercase Output",
|
|
122
|
+
variable=self.uppercase,
|
|
123
|
+
command=self.on_setting_change).pack(anchor=tk.W)
|
|
124
|
+
|
|
125
|
+
# Generate button
|
|
126
|
+
ttk.Button(self, text="Generate Hashes",
|
|
127
|
+
command=self.generate).pack(pady=10)
|
|
128
|
+
|
|
129
|
+
def load_settings(self):
|
|
130
|
+
"""Load settings from the application."""
|
|
131
|
+
settings = self.app.settings.get("tool_settings", {}).get("Hash Generator", {})
|
|
132
|
+
|
|
133
|
+
algorithms = settings.get("algorithms", ["md5", "sha256"])
|
|
134
|
+
for algo in self.algo_vars:
|
|
135
|
+
self.algo_vars[algo].set(algo in algorithms)
|
|
136
|
+
|
|
137
|
+
self.uppercase.set(settings.get("uppercase", False))
|
|
138
|
+
|
|
139
|
+
def save_settings(self):
|
|
140
|
+
"""Save current settings to the application."""
|
|
141
|
+
if "Hash Generator" not in self.app.settings["tool_settings"]:
|
|
142
|
+
self.app.settings["tool_settings"]["Hash Generator"] = {}
|
|
143
|
+
|
|
144
|
+
algorithms = [algo for algo, var in self.algo_vars.items() if var.get()]
|
|
145
|
+
|
|
146
|
+
self.app.settings["tool_settings"]["Hash Generator"].update({
|
|
147
|
+
"algorithms": algorithms,
|
|
148
|
+
"uppercase": self.uppercase.get()
|
|
149
|
+
})
|
|
150
|
+
|
|
151
|
+
self.app.save_settings()
|
|
152
|
+
|
|
153
|
+
def on_setting_change(self, *args):
|
|
154
|
+
"""Handle setting changes."""
|
|
155
|
+
self.save_settings()
|
|
156
|
+
|
|
157
|
+
def generate(self):
|
|
158
|
+
"""Generate hashes for the input text."""
|
|
159
|
+
active_input_tab = self.app.input_tabs[self.app.input_notebook.index(self.app.input_notebook.select())]
|
|
160
|
+
input_text = active_input_tab.text.get("1.0", tk.END).rstrip('\n')
|
|
161
|
+
|
|
162
|
+
algorithms = [algo for algo, var in self.algo_vars.items() if var.get()]
|
|
163
|
+
|
|
164
|
+
if not algorithms:
|
|
165
|
+
result = "Please select at least one hash algorithm."
|
|
166
|
+
else:
|
|
167
|
+
result = HashGeneratorProcessor.generate_all_hashes(
|
|
168
|
+
input_text,
|
|
169
|
+
algorithms,
|
|
170
|
+
self.uppercase.get()
|
|
171
|
+
)
|
|
172
|
+
|
|
173
|
+
active_output_tab = self.app.output_tabs[self.app.output_notebook.index(self.app.output_notebook.select())]
|
|
174
|
+
active_output_tab.text.config(state="normal")
|
|
175
|
+
active_output_tab.text.delete("1.0", tk.END)
|
|
176
|
+
active_output_tab.text.insert("1.0", result)
|
|
177
|
+
active_output_tab.text.config(state="disabled")
|
|
178
|
+
|
|
179
|
+
self.app.update_all_stats()
|
|
180
|
+
|
|
181
|
+
|
|
182
|
+
class HashGenerator:
|
|
183
|
+
"""Main class for Hash Generator integration."""
|
|
184
|
+
|
|
185
|
+
def __init__(self):
|
|
186
|
+
self.processor = HashGeneratorProcessor()
|
|
187
|
+
|
|
188
|
+
def create_widget(self, parent, app):
|
|
189
|
+
"""Create and return the Hash Generator widget."""
|
|
190
|
+
return HashGeneratorWidget(parent, app)
|
|
191
|
+
|
|
192
|
+
def get_default_settings(self):
|
|
193
|
+
"""Return default settings for Hash Generator."""
|
|
194
|
+
return {
|
|
195
|
+
"algorithms": ["md5", "sha256"],
|
|
196
|
+
"uppercase": False
|
|
197
|
+
}
|
|
198
|
+
|
|
199
|
+
def process_text(self, input_text, settings):
|
|
200
|
+
"""Process text and return hashes."""
|
|
201
|
+
return HashGeneratorProcessor.generate_all_hashes(
|
|
202
|
+
input_text,
|
|
203
|
+
settings.get("algorithms", ["md5", "sha256"]),
|
|
204
|
+
settings.get("uppercase", False)
|
|
205
|
+
)
|
|
206
|
+
|
|
207
|
+
|
|
208
|
+
# BaseTool-compatible wrapper (for future migration)
|
|
209
|
+
try:
|
|
210
|
+
from tools.base_tool import BaseTool
|
|
211
|
+
from typing import Dict, Any, Optional, Callable
|
|
212
|
+
|
|
213
|
+
class HashGeneratorV2(BaseTool):
|
|
214
|
+
"""
|
|
215
|
+
BaseTool-compatible version of HashGenerator.
|
|
216
|
+
"""
|
|
217
|
+
|
|
218
|
+
TOOL_NAME = "Hash Generator"
|
|
219
|
+
TOOL_DESCRIPTION = "Generate MD5, SHA-1, SHA-256, SHA-512, and CRC32 hashes"
|
|
220
|
+
TOOL_VERSION = "2.0.0"
|
|
221
|
+
|
|
222
|
+
def __init__(self):
|
|
223
|
+
super().__init__()
|
|
224
|
+
self._processor = HashGeneratorProcessor()
|
|
225
|
+
|
|
226
|
+
def process_text(self, input_text: str, settings: Dict[str, Any]) -> str:
|
|
227
|
+
"""Process text and return hashes."""
|
|
228
|
+
return HashGeneratorProcessor.generate_all_hashes(
|
|
229
|
+
input_text,
|
|
230
|
+
settings.get("algorithms", ["md5", "sha256"]),
|
|
231
|
+
settings.get("uppercase", False)
|
|
232
|
+
)
|
|
233
|
+
|
|
234
|
+
def create_ui(self,
|
|
235
|
+
parent,
|
|
236
|
+
settings: Dict[str, Any],
|
|
237
|
+
on_setting_change_callback: Optional[Callable] = None,
|
|
238
|
+
apply_tool_callback: Optional[Callable] = None):
|
|
239
|
+
"""Create the Hash Generator UI using the existing widget."""
|
|
240
|
+
self._settings = settings.copy()
|
|
241
|
+
self._on_setting_change = on_setting_change_callback
|
|
242
|
+
self._apply_callback = apply_tool_callback
|
|
243
|
+
# Use existing widget implementation
|
|
244
|
+
return None # Widget created separately
|
|
245
|
+
|
|
246
|
+
@classmethod
|
|
247
|
+
def get_default_settings(cls) -> Dict[str, Any]:
|
|
248
|
+
"""Return default settings for Hash Generator."""
|
|
249
|
+
return {
|
|
250
|
+
"algorithms": ["md5", "sha256"],
|
|
251
|
+
"uppercase": False
|
|
252
|
+
}
|
|
253
|
+
|
|
254
|
+
except ImportError:
|
|
255
|
+
# BaseTool not available
|
|
256
256
|
pass
|