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.
Files changed (191) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +105 -680
  3. package/bin/pomera-ai-commander.js +62 -62
  4. package/core/__init__.py +65 -65
  5. package/core/app_context.py +482 -482
  6. package/core/async_text_processor.py +421 -421
  7. package/core/backup_manager.py +655 -655
  8. package/core/backup_recovery_manager.py +1033 -1033
  9. package/core/content_hash_cache.py +508 -508
  10. package/core/context_menu.py +313 -313
  11. package/core/data_validator.py +1066 -1066
  12. package/core/database_connection_manager.py +744 -744
  13. package/core/database_curl_settings_manager.py +608 -608
  14. package/core/database_promera_ai_settings_manager.py +446 -446
  15. package/core/database_schema.py +411 -411
  16. package/core/database_schema_manager.py +395 -395
  17. package/core/database_settings_manager.py +1507 -1507
  18. package/core/database_settings_manager_interface.py +456 -456
  19. package/core/dialog_manager.py +734 -734
  20. package/core/efficient_line_numbers.py +510 -510
  21. package/core/error_handler.py +746 -746
  22. package/core/error_service.py +431 -431
  23. package/core/event_consolidator.py +511 -511
  24. package/core/mcp/__init__.py +43 -43
  25. package/core/mcp/protocol.py +288 -288
  26. package/core/mcp/schema.py +251 -251
  27. package/core/mcp/server_stdio.py +299 -299
  28. package/core/mcp/tool_registry.py +2372 -2345
  29. package/core/memory_efficient_text_widget.py +711 -711
  30. package/core/migration_manager.py +914 -914
  31. package/core/migration_test_suite.py +1085 -1085
  32. package/core/migration_validator.py +1143 -1143
  33. package/core/optimized_find_replace.py +714 -714
  34. package/core/optimized_pattern_engine.py +424 -424
  35. package/core/optimized_search_highlighter.py +552 -552
  36. package/core/performance_monitor.py +674 -674
  37. package/core/persistence_manager.py +712 -712
  38. package/core/progressive_stats_calculator.py +632 -632
  39. package/core/regex_pattern_cache.py +529 -529
  40. package/core/regex_pattern_library.py +350 -350
  41. package/core/search_operation_manager.py +434 -434
  42. package/core/settings_defaults_registry.py +1087 -1087
  43. package/core/settings_integrity_validator.py +1111 -1111
  44. package/core/settings_serializer.py +557 -557
  45. package/core/settings_validator.py +1823 -1823
  46. package/core/smart_stats_calculator.py +709 -709
  47. package/core/statistics_update_manager.py +619 -619
  48. package/core/stats_config_manager.py +858 -858
  49. package/core/streaming_text_handler.py +723 -723
  50. package/core/task_scheduler.py +596 -596
  51. package/core/update_pattern_library.py +168 -168
  52. package/core/visibility_monitor.py +596 -596
  53. package/core/widget_cache.py +498 -498
  54. package/mcp.json +51 -61
  55. package/package.json +61 -57
  56. package/pomera.py +7482 -7482
  57. package/pomera_mcp_server.py +183 -144
  58. package/requirements.txt +32 -0
  59. package/tools/__init__.py +4 -4
  60. package/tools/ai_tools.py +2891 -2891
  61. package/tools/ascii_art_generator.py +352 -352
  62. package/tools/base64_tools.py +183 -183
  63. package/tools/base_tool.py +511 -511
  64. package/tools/case_tool.py +308 -308
  65. package/tools/column_tools.py +395 -395
  66. package/tools/cron_tool.py +884 -884
  67. package/tools/curl_history.py +600 -600
  68. package/tools/curl_processor.py +1207 -1207
  69. package/tools/curl_settings.py +502 -502
  70. package/tools/curl_tool.py +5467 -5467
  71. package/tools/diff_viewer.py +1071 -1071
  72. package/tools/email_extraction_tool.py +248 -248
  73. package/tools/email_header_analyzer.py +425 -425
  74. package/tools/extraction_tools.py +250 -250
  75. package/tools/find_replace.py +1750 -1750
  76. package/tools/folder_file_reporter.py +1463 -1463
  77. package/tools/folder_file_reporter_adapter.py +480 -480
  78. package/tools/generator_tools.py +1216 -1216
  79. package/tools/hash_generator.py +255 -255
  80. package/tools/html_tool.py +656 -656
  81. package/tools/jsonxml_tool.py +729 -729
  82. package/tools/line_tools.py +419 -419
  83. package/tools/markdown_tools.py +561 -561
  84. package/tools/mcp_widget.py +1417 -1417
  85. package/tools/notes_widget.py +973 -973
  86. package/tools/number_base_converter.py +372 -372
  87. package/tools/regex_extractor.py +571 -571
  88. package/tools/slug_generator.py +310 -310
  89. package/tools/sorter_tools.py +458 -458
  90. package/tools/string_escape_tool.py +392 -392
  91. package/tools/text_statistics_tool.py +365 -365
  92. package/tools/text_wrapper.py +430 -430
  93. package/tools/timestamp_converter.py +421 -421
  94. package/tools/tool_loader.py +710 -710
  95. package/tools/translator_tools.py +522 -522
  96. package/tools/url_link_extractor.py +261 -261
  97. package/tools/url_parser.py +204 -204
  98. package/tools/whitespace_tools.py +355 -355
  99. package/tools/word_frequency_counter.py +146 -146
  100. package/core/__pycache__/__init__.cpython-313.pyc +0 -0
  101. package/core/__pycache__/app_context.cpython-313.pyc +0 -0
  102. package/core/__pycache__/async_text_processor.cpython-313.pyc +0 -0
  103. package/core/__pycache__/backup_manager.cpython-313.pyc +0 -0
  104. package/core/__pycache__/backup_recovery_manager.cpython-313.pyc +0 -0
  105. package/core/__pycache__/content_hash_cache.cpython-313.pyc +0 -0
  106. package/core/__pycache__/context_menu.cpython-313.pyc +0 -0
  107. package/core/__pycache__/data_validator.cpython-313.pyc +0 -0
  108. package/core/__pycache__/database_connection_manager.cpython-313.pyc +0 -0
  109. package/core/__pycache__/database_curl_settings_manager.cpython-313.pyc +0 -0
  110. package/core/__pycache__/database_promera_ai_settings_manager.cpython-313.pyc +0 -0
  111. package/core/__pycache__/database_schema.cpython-313.pyc +0 -0
  112. package/core/__pycache__/database_schema_manager.cpython-313.pyc +0 -0
  113. package/core/__pycache__/database_settings_manager.cpython-313.pyc +0 -0
  114. package/core/__pycache__/database_settings_manager_interface.cpython-313.pyc +0 -0
  115. package/core/__pycache__/dialog_manager.cpython-313.pyc +0 -0
  116. package/core/__pycache__/efficient_line_numbers.cpython-313.pyc +0 -0
  117. package/core/__pycache__/error_handler.cpython-313.pyc +0 -0
  118. package/core/__pycache__/error_service.cpython-313.pyc +0 -0
  119. package/core/__pycache__/event_consolidator.cpython-313.pyc +0 -0
  120. package/core/__pycache__/memory_efficient_text_widget.cpython-313.pyc +0 -0
  121. package/core/__pycache__/migration_manager.cpython-313.pyc +0 -0
  122. package/core/__pycache__/migration_test_suite.cpython-313.pyc +0 -0
  123. package/core/__pycache__/migration_validator.cpython-313.pyc +0 -0
  124. package/core/__pycache__/optimized_find_replace.cpython-313.pyc +0 -0
  125. package/core/__pycache__/optimized_pattern_engine.cpython-313.pyc +0 -0
  126. package/core/__pycache__/optimized_search_highlighter.cpython-313.pyc +0 -0
  127. package/core/__pycache__/performance_monitor.cpython-313.pyc +0 -0
  128. package/core/__pycache__/persistence_manager.cpython-313.pyc +0 -0
  129. package/core/__pycache__/progressive_stats_calculator.cpython-313.pyc +0 -0
  130. package/core/__pycache__/regex_pattern_cache.cpython-313.pyc +0 -0
  131. package/core/__pycache__/regex_pattern_library.cpython-313.pyc +0 -0
  132. package/core/__pycache__/search_operation_manager.cpython-313.pyc +0 -0
  133. package/core/__pycache__/settings_defaults_registry.cpython-313.pyc +0 -0
  134. package/core/__pycache__/settings_integrity_validator.cpython-313.pyc +0 -0
  135. package/core/__pycache__/settings_serializer.cpython-313.pyc +0 -0
  136. package/core/__pycache__/settings_validator.cpython-313.pyc +0 -0
  137. package/core/__pycache__/smart_stats_calculator.cpython-313.pyc +0 -0
  138. package/core/__pycache__/statistics_update_manager.cpython-313.pyc +0 -0
  139. package/core/__pycache__/stats_config_manager.cpython-313.pyc +0 -0
  140. package/core/__pycache__/streaming_text_handler.cpython-313.pyc +0 -0
  141. package/core/__pycache__/task_scheduler.cpython-313.pyc +0 -0
  142. package/core/__pycache__/visibility_monitor.cpython-313.pyc +0 -0
  143. package/core/__pycache__/widget_cache.cpython-313.pyc +0 -0
  144. package/core/mcp/__pycache__/__init__.cpython-313.pyc +0 -0
  145. package/core/mcp/__pycache__/protocol.cpython-313.pyc +0 -0
  146. package/core/mcp/__pycache__/schema.cpython-313.pyc +0 -0
  147. package/core/mcp/__pycache__/server_stdio.cpython-313.pyc +0 -0
  148. package/core/mcp/__pycache__/tool_registry.cpython-313.pyc +0 -0
  149. package/tools/__pycache__/__init__.cpython-313.pyc +0 -0
  150. package/tools/__pycache__/ai_tools.cpython-313.pyc +0 -0
  151. package/tools/__pycache__/ascii_art_generator.cpython-313.pyc +0 -0
  152. package/tools/__pycache__/base64_tools.cpython-313.pyc +0 -0
  153. package/tools/__pycache__/base_tool.cpython-313.pyc +0 -0
  154. package/tools/__pycache__/case_tool.cpython-313.pyc +0 -0
  155. package/tools/__pycache__/column_tools.cpython-313.pyc +0 -0
  156. package/tools/__pycache__/cron_tool.cpython-313.pyc +0 -0
  157. package/tools/__pycache__/curl_history.cpython-313.pyc +0 -0
  158. package/tools/__pycache__/curl_processor.cpython-313.pyc +0 -0
  159. package/tools/__pycache__/curl_settings.cpython-313.pyc +0 -0
  160. package/tools/__pycache__/curl_tool.cpython-313.pyc +0 -0
  161. package/tools/__pycache__/diff_viewer.cpython-313.pyc +0 -0
  162. package/tools/__pycache__/email_extraction_tool.cpython-313.pyc +0 -0
  163. package/tools/__pycache__/email_header_analyzer.cpython-313.pyc +0 -0
  164. package/tools/__pycache__/extraction_tools.cpython-313.pyc +0 -0
  165. package/tools/__pycache__/find_replace.cpython-313.pyc +0 -0
  166. package/tools/__pycache__/folder_file_reporter.cpython-313.pyc +0 -0
  167. package/tools/__pycache__/folder_file_reporter_adapter.cpython-313.pyc +0 -0
  168. package/tools/__pycache__/generator_tools.cpython-313.pyc +0 -0
  169. package/tools/__pycache__/hash_generator.cpython-313.pyc +0 -0
  170. package/tools/__pycache__/html_tool.cpython-313.pyc +0 -0
  171. package/tools/__pycache__/huggingface_helper.cpython-313.pyc +0 -0
  172. package/tools/__pycache__/jsonxml_tool.cpython-313.pyc +0 -0
  173. package/tools/__pycache__/line_tools.cpython-313.pyc +0 -0
  174. package/tools/__pycache__/list_comparator.cpython-313.pyc +0 -0
  175. package/tools/__pycache__/markdown_tools.cpython-313.pyc +0 -0
  176. package/tools/__pycache__/mcp_widget.cpython-313.pyc +0 -0
  177. package/tools/__pycache__/notes_widget.cpython-313.pyc +0 -0
  178. package/tools/__pycache__/number_base_converter.cpython-313.pyc +0 -0
  179. package/tools/__pycache__/regex_extractor.cpython-313.pyc +0 -0
  180. package/tools/__pycache__/slug_generator.cpython-313.pyc +0 -0
  181. package/tools/__pycache__/sorter_tools.cpython-313.pyc +0 -0
  182. package/tools/__pycache__/string_escape_tool.cpython-313.pyc +0 -0
  183. package/tools/__pycache__/text_statistics_tool.cpython-313.pyc +0 -0
  184. package/tools/__pycache__/text_wrapper.cpython-313.pyc +0 -0
  185. package/tools/__pycache__/timestamp_converter.cpython-313.pyc +0 -0
  186. package/tools/__pycache__/tool_loader.cpython-313.pyc +0 -0
  187. package/tools/__pycache__/translator_tools.cpython-313.pyc +0 -0
  188. package/tools/__pycache__/url_link_extractor.cpython-313.pyc +0 -0
  189. package/tools/__pycache__/url_parser.cpython-313.pyc +0 -0
  190. package/tools/__pycache__/whitespace_tools.cpython-313.pyc +0 -0
  191. package/tools/__pycache__/word_frequency_counter.cpython-313.pyc +0 -0
@@ -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