atomicshop 2.18.2__py3-none-any.whl → 2.18.4__py3-none-any.whl

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.

Potentially problematic release.


This version of atomicshop might be problematic. Click here for more details.

atomicshop/__init__.py CHANGED
@@ -1,4 +1,4 @@
1
1
  """Atomic Basic functions and classes to make developer life easier"""
2
2
 
3
3
  __author__ = "Den Kras"
4
- __version__ = '2.18.2'
4
+ __version__ = '2.18.4'
@@ -98,7 +98,6 @@ def thread_worker_main(
98
98
  raw_bytes: bytes,
99
99
  client_message: ClientMessage):
100
100
  nonlocal protocol
101
- nonlocal protocol3
102
101
 
103
102
  # Parsing the raw bytes as HTTP.
104
103
  request_http_parsed, is_http_request, request_parsing_error = (
@@ -120,9 +119,6 @@ def thread_worker_main(
120
119
  auto_parsed = response_http_parsed
121
120
  network_logger.info(
122
121
  f"HTTP Response Parsed: Status: {response_http_parsed.code}")
123
- protocol3 = auto_parsed.headers.get('Sec-WebSocket-Protocol', None)
124
- if protocol3:
125
- client_message.protocol3 = protocol3
126
122
  elif protocol == 'Websocket':
127
123
  client_message.protocol2 = 'Frame'
128
124
  auto_parsed = parse_websocket(raw_bytes)
@@ -137,12 +133,16 @@ def thread_worker_main(
137
133
  auto_parsed,
138
134
  client_message: ClientMessage):
139
135
  nonlocal protocol
136
+ nonlocal protocol3
140
137
 
141
138
  if protocol == 'HTTP':
142
139
  if auto_parsed and hasattr(auto_parsed, 'headers') and 'Upgrade' in auto_parsed.headers:
143
140
  if auto_parsed.headers['Upgrade'] == 'websocket':
144
141
  protocol = 'Websocket'
145
142
  client_message.protocol2 = 'Handshake'
143
+ protocol3 = auto_parsed.headers.get('Sec-WebSocket-Protocol', None)
144
+ if protocol3:
145
+ client_message.protocol3 = protocol3
146
146
 
147
147
  network_logger.info(f'Protocol upgraded to Websocket')
148
148
 
@@ -171,7 +171,7 @@ def thread_worker_main(
171
171
 
172
172
  # If it's the first cycle and the protocol is Websocket, then we'll create the HTTP Handshake
173
173
  # response automatically.
174
- if protocol == 'Websocket' and client_receive_count == 0:
174
+ if protocol == 'Websocket' and client_receive_count == 1:
175
175
  responses: list = list()
176
176
  responses.append(
177
177
  websocket_parse.create_byte_http_response(client_message.request_raw_bytes))
@@ -240,11 +240,12 @@ def thread_worker_main(
240
240
  return
241
241
 
242
242
  client_message.response_auto_parsed = parse_http(client_message.request_raw_bytes, client_message)
243
+ # This is needed for each cycle that is not HTTP, but its protocol maybe set by HTTP, like websocket.
243
244
  if protocol != '':
244
245
  client_message.protocol = protocol
245
246
 
246
247
  # Parse websocket frames only if it is not the first protocol upgrade request.
247
- if protocol == 'Websocket' and client_receive_count != 0:
248
+ if protocol == 'Websocket' and client_receive_count != 1:
248
249
  client_message.request_auto_parsed = parse_websocket(client_message.request_raw_bytes)
249
250
 
250
251
  # Custom parser, should parse HTTP body or the whole message if not HTTP.
@@ -65,7 +65,8 @@ def mitm_server(config_file_path: str):
65
65
  # Main function should return integer with error code, 0 is successful.
66
66
  # Since listening server is infinite, this will not be reached.
67
67
  # After modules import - we check for python version.
68
- check_python_version_compliance(minimum_version='3.12')
68
+ if not check_python_version_compliance(minor_version='3.12'):
69
+ return 1
69
70
 
70
71
  # Import the configuration file.
71
72
  result = config_static.load_config(config_file_path)
@@ -1,4 +1,5 @@
1
1
  import sys
2
+ from typing import Union
2
3
 
3
4
  from .print_api import print_api
4
5
 
@@ -43,23 +44,46 @@ def check_if_version_object_is_tuple_or_string(version_object: any,
43
44
 
44
45
 
45
46
  # noinspection PyUnusedLocal
46
- def check_python_version_compliance(minimum_version: any,
47
- maximum_version: any = None,
48
- **kwargs) -> bool:
47
+ def check_python_version_compliance(
48
+ minimum_version: Union[str, tuple] = None,
49
+ maximum_version: Union[str, tuple] = None,
50
+ minor_version: Union[str, tuple] = None,
51
+ **kwargs
52
+ ) -> bool:
49
53
  """
50
54
  Python version check. Should be executed before importing external libraries, since they depend on Python version.
51
55
 
52
56
  :param minimum_version: Can be string ('3.10') or tuple of integers ((3, 10)).
53
57
  :param maximum_version: Can be string ('3.10') or tuple of integers ((3, 10)).
54
58
  If maximum version is not specified, it will be considered as all versions above the minimum are compliant.
59
+ :param minor_version: Can be string ('3.10') or tuple of integers ((3, 10)).
60
+ If minor version is specified, it will be considered as all the versions with the same major, minor version
61
+ are compliant. Example: if minor_version is '3.10', then all the versions with '3.10.x' are compliant.
55
62
  :return:
56
63
  """
57
64
 
58
- # Check 'minimum_version' object for string or tuple and get the tuple.
59
- minimum_version_scheme: tuple = check_if_version_object_is_tuple_or_string(minimum_version, **kwargs)
65
+ if not minimum_version and not maximum_version and not minor_version:
66
+ raise ValueError("At least one of the version parameters should be passed.")
67
+
68
+ if minor_version and (minimum_version or maximum_version):
69
+ raise ValueError("Minor version should be passed alone.")
70
+
71
+ # Check objects for string or tuple and get the tuple.
72
+ if minimum_version:
73
+ minimum_version_scheme: tuple = check_if_version_object_is_tuple_or_string(minimum_version, **kwargs)
74
+ else:
75
+ minimum_version_scheme = tuple()
60
76
  # If 'maximum_version' object was passed, check it for string or tuple and get the tuple.
61
77
  if maximum_version:
62
78
  maximum_version_scheme: tuple = check_if_version_object_is_tuple_or_string(maximum_version, **kwargs)
79
+ else:
80
+ maximum_version_scheme = tuple()
81
+
82
+ # If 'minor_version' object was passed, check it for string or tuple and get the tuple.
83
+ if minor_version:
84
+ minor_version_scheme: tuple = check_if_version_object_is_tuple_or_string(minor_version, **kwargs)
85
+ else:
86
+ minor_version_scheme = tuple()
63
87
 
64
88
  # Get current python version.
65
89
  python_version_full: str = get_current_python_version_string()
@@ -67,24 +91,37 @@ def check_python_version_compliance(minimum_version: any,
67
91
  message = f"[*] Current Python Version: {python_version_full}"
68
92
  print_api(message, logger_method='info', **kwargs)
69
93
 
70
- # if 'maximum_version' passed and current python version is later or equals to the minimum and earlier than
71
- # maximum version required.
72
- if maximum_version:
94
+ if minor_version_scheme:
95
+ # Check if current python version is later or equals to the minimum required version.
96
+ if sys.version_info[:2] != minor_version_scheme:
97
+ message = f"[!!!] YOU NEED TO INSTALL ANY PYTHON " \
98
+ f"[{'.'.join(str(i) for i in minor_version_scheme)}] version, " \
99
+ f"to work properly."
100
+ print_api(message, error_type=True, logger_method='critical', **kwargs)
101
+
102
+ return False
103
+ elif minimum_version_scheme and maximum_version_scheme:
73
104
  if not sys.version_info >= minimum_version_scheme or not sys.version_info < maximum_version_scheme:
74
105
  message = f"[!!!] YOU NEED TO INSTALL AT LEAST PYTHON " \
75
- f"{'.'.join(str(i) for i in minimum_version_scheme)}, " \
76
- f"AND EARLIER THAN {'.'.join(str(i) for i in maximum_version_scheme)}, " \
77
- f"to work properly. Unhandled exceptions are inevitable!"
106
+ f"[{'.'.join(str(i) for i in minimum_version_scheme)}], " \
107
+ f"AND EARLIER THAN [{'.'.join(str(i) for i in maximum_version_scheme)}], " \
108
+ f"to work properly."
78
109
  print_api(message, error_type=True, logger_method='critical', **kwargs)
79
110
 
80
111
  return False
81
- # If 'maximum_version' wasn't passed.
82
- else:
83
- # Check if current python version is later or equals to the minimum required version.
112
+ elif minimum_version_scheme and not maximum_version_scheme:
84
113
  if not sys.version_info >= minimum_version_scheme:
85
114
  message = f"[!!!] YOU NEED TO INSTALL AT LEAST PYTHON " \
86
- f"{'.'.join(str(i) for i in minimum_version_scheme)}, " \
87
- f"to work properly. Unhandled exceptions are inevitable!"
115
+ f"[{'.'.join(str(i) for i in minimum_version_scheme)}], " \
116
+ f"to work properly."
117
+ print_api(message, error_type=True, logger_method='critical', **kwargs)
118
+
119
+ return False
120
+ elif not minimum_version_scheme and maximum_version_scheme:
121
+ if not sys.version_info < maximum_version_scheme:
122
+ message = f"[!!!] YOU NEED TO INSTALL EARLIER THAN PYTHON " \
123
+ f"[{'.'.join(str(i) for i in maximum_version_scheme)}], " \
124
+ f"to work properly."
88
125
  print_api(message, error_type=True, logger_method='critical', **kwargs)
89
126
 
90
127
  return False
@@ -133,11 +133,11 @@ class WebsocketFrameParser:
133
133
  elif current_frame.opcode == Opcode.BINARY:
134
134
  return current_frame.data, 'BINARY'
135
135
  elif current_frame.opcode == Opcode.CLOSE:
136
- return None, 'CLOSE'
136
+ return current_frame.data, 'CLOSE'
137
137
  elif current_frame.opcode == Opcode.PING:
138
- return None, 'PING'
138
+ return current_frame.data, 'PING'
139
139
  elif current_frame.opcode == Opcode.PONG:
140
- return None, 'PONG'
140
+ return current_frame.data, 'PONG'
141
141
  else:
142
142
  raise WebsocketParseWrongOpcode("Received unknown frame with opcode:", current_frame.opcode)
143
143
 
@@ -239,7 +239,7 @@ def create_websocket_frame(
239
239
  return frame_bytes
240
240
 
241
241
 
242
- def is_frame_masked(frame_bytes):
242
+ def is_frame_masked(frame_bytes: bytes):
243
243
  """
244
244
  Determine whether a WebSocket frame is masked.
245
245
 
@@ -103,7 +103,7 @@ def analyze_log_file(log_file: str):
103
103
 
104
104
  for plugin in PLUGIN_LIST:
105
105
  if f'{FINISHED_INSTALLING_STRINGS[0]} {plugin} {FINISHED_INSTALLING_STRINGS[1]}' not in log_content:
106
- message = (f'Error: [{plugin}] installation failed.\n'
106
+ message = (f'Error: [{plugin}] plugin missing in the log. Installation failed.\n'
107
107
  f'Check the log file: {log_file}\n'
108
108
  f'Exiting...')
109
109
  print_api.print_api(message, color='red')
@@ -33,7 +33,7 @@ class MongoDBInstallationError(Exception):
33
33
 
34
34
 
35
35
  def get_latest_mongodb_download_url(
36
- no_rc_version: bool = True,
36
+ rc_version: bool = True,
37
37
  major_specific: int = None
38
38
  ):
39
39
  response = requests.get(MONGODB_DOWNLOAD_PAGE_URL)
@@ -48,7 +48,7 @@ def get_latest_mongodb_download_url(
48
48
  windows_urls: list = []
49
49
  for url in urls_in_page:
50
50
  if 'windows' in url and 'x86_64' in url and url.endswith('.msi'):
51
- if no_rc_version and '-rc' in url:
51
+ if not rc_version and '-rc' in url:
52
52
  continue
53
53
  windows_urls.append(url)
54
54
 
@@ -68,109 +68,144 @@ def get_latest_mongodb_download_url(
68
68
 
69
69
  def parse_args():
70
70
  parser = argparse.ArgumentParser(description='Install MongoDB Community Server.')
71
+ # Mutually exclusive group for 'ir' and 'er'
72
+ group = parser.add_mutually_exclusive_group()
73
+ group.add_argument(
74
+ '-er', '--exclude-rc',
75
+ action='store_true',
76
+ help='Install latest version, but exclude release candidate versions.'
77
+ )
78
+ group.add_argument(
79
+ '-ir', '--include-rc',
80
+ action='store_true',
81
+ help='Install the latest version of MongoDB including release candidates.'
82
+ )
83
+
84
+ # Optional arguments
71
85
  parser.add_argument(
72
- '-nr', '--no-rc', action='store_true', help='Do not download release candidate versions.')
73
- parser.add_argument(
74
- '-m', '--major', type=int, help='Download the latest version of the specified major version.')
86
+ '-c', '--compass',
87
+ action='store_true',
88
+ help='Install MongoDB Compass.'
89
+ )
75
90
  parser.add_argument(
76
- '-c', '--compass', action='store_true', help='Install MongoDB Compass.')
91
+ '-m', '--major',
92
+ type=int,
93
+ help='Download the latest version of the specified major version.'
94
+ )
77
95
  parser.add_argument(
78
- '-f', '--force', action='store_true', help='Force the installation even if MongoDB is already installed.')
96
+ '-f', '--force',
97
+ action='store_true',
98
+ help='Force the installation even if MongoDB is already installed.'
99
+ )
100
+
101
+ args = parser.parse_args()
102
+
103
+ # Validation logic: At least one of '-nr', '-ir', or '-c' must be provided
104
+ if not (args.no_rc or args.include_rc or args.compass):
105
+ parser.error("At least one of '-nr', '-ir', or '-c' must be specified.")
79
106
 
80
- return parser.parse_args()
107
+ return args
81
108
 
82
109
 
83
- def download_install_latest_main(
84
- no_rc_version: bool = False,
110
+ def download_install_process(
111
+ rc_version: bool = False,
112
+ no_rc_version: bool = True,
85
113
  major_specific: int = None,
86
114
  compass: bool = False,
87
115
  force: bool = False
88
- ):
116
+ ) -> int:
89
117
  """
90
118
  Download and install the latest version of MongoDB Community Server.
119
+
120
+ :param rc_version: bool, if True, the latest RC version will be downloaded.
91
121
  :param no_rc_version: bool, if True, the latest non-RC version will be downloaded.
92
122
  :param major_specific: int, if set, the latest version of the specified major version will be downloaded.
93
123
  :param compass: bool, if True, MongoDB Compass will be installed.
94
124
  :param force: bool, if True, MongoDB will be installed even if it is already installed.
95
- :return:
125
+ :return: int, 0 if successful, 1 if failed.
96
126
  """
97
127
 
98
- args = parse_args()
99
-
100
- # Set the args only if they were used.
101
- if args.no_rc:
102
- no_rc_version = args.no_rc
103
- if args.major:
104
- major_specific = args.major
105
- if args.compass:
106
- compass = args.compass
107
- if args.force:
108
- force = args.force
109
-
110
128
  if not permissions.is_admin():
111
129
  print_api("This function requires administrator privileges.", color='red')
112
130
  return 1
113
131
 
114
- if mongo_infra.is_service_running():
115
- print_api("MongoDB service is running - already installed.", color='blue')
116
-
117
- if not force:
118
- return 0
119
- else:
120
- print_api("MongoDB is service is not running.")
121
-
122
- mongo_is_installed: Union[str, None] = mongo_infra.is_installed()
123
- if mongo_infra.is_installed():
124
- message = f"MongoDB is installed in: {mongo_is_installed}\n" \
125
- f"The service is not running. Fix the service or use the 'force' parameter to reinstall."
126
- print_api(message, color='yellow')
127
-
128
- if not force:
129
- return 0
130
-
131
- print_api("Fetching the latest MongoDB download URL...")
132
- mongo_installer_url = get_latest_mongodb_download_url(no_rc_version=no_rc_version, major_specific=major_specific)
133
-
134
- print_api(f"Downloading MongoDB installer from: {mongo_installer_url}")
135
- installer_file_path: str = web.download(mongo_installer_url)
136
-
137
- print_api("Installing MongoDB...")
138
- try:
139
- msiw.install_msi(
140
- installer_file_path,
141
- silent_no_gui=True,
142
- no_restart=True,
143
- terminate_required_processes=True,
144
- create_log_near_msi=True,
145
- scan_log_for_errors=True,
146
- additional_args='ADDLOCAL="ServerService"'
147
- )
148
- except msiw.MsiInstallationError as e:
149
- print_api(f'{e} Exiting...', color='red')
132
+ if rc_version and no_rc_version:
133
+ print_api("Both 'rc_version' and 'no_rc_version' cannot be True at the same time.", color='red')
150
134
  return 1
151
135
 
152
- # Check if MongoDB is installed.
153
- message: str = ''
154
- mongo_is_installed = mongo_infra.is_installed()
155
- if not mongo_is_installed:
156
- message += "MongoDB Executable not found.\n"
136
+ if not (rc_version or no_rc_version) and not compass:
137
+ print_api("At least one of 'rc_version', 'no_rc_version', or 'compass' must be True.", color='red')
138
+ return 1
157
139
 
158
- if not mongo_infra.is_service_running():
159
- message += "MongoDB service is not running.\n"
140
+ # If we need to install mongo db.
141
+ if rc_version or no_rc_version:
142
+ if rc_version:
143
+ download_rc_version: bool = True
144
+ elif no_rc_version:
145
+ download_rc_version: bool = False
146
+ else:
147
+ raise ValueError("Invalid value for 'rc_version' and 'no_rc_version'.")
160
148
 
161
- if message:
162
- message += f"MSI Path: {installer_file_path}"
163
- print_api(message, color='red')
164
- return 1
165
- else:
166
- success_message: str = f"MongoDB installed successfully to: {mongo_is_installed}\n" \
167
- f"Service is running."
168
- print_api(success_message, color='green')
149
+ if mongo_infra.is_service_running():
150
+ print_api("MongoDB service is running - already installed. Use [-f] to reinstall.", color='blue')
169
151
 
170
- # Clean up the installer file
171
- if os.path.exists(installer_file_path):
172
- os.remove(installer_file_path)
173
- print_api("Cleaned up the installer file.")
152
+ if not force:
153
+ return 0
154
+ else:
155
+ print_api("MongoDB is service is not running.")
156
+
157
+ mongo_is_installed: Union[str, None] = mongo_infra.is_installed()
158
+ if mongo_infra.is_installed():
159
+ message = f"MongoDB is installed in: {mongo_is_installed}\n" \
160
+ f"The service is not running. Fix the service or use the 'force' parameter to reinstall."
161
+ print_api(message, color='yellow')
162
+
163
+ if not force:
164
+ return 0
165
+
166
+ print_api("Fetching the latest MongoDB download URL...")
167
+ mongo_installer_url = get_latest_mongodb_download_url(rc_version=download_rc_version, major_specific=major_specific)
168
+
169
+ print_api(f"Downloading MongoDB installer from: {mongo_installer_url}")
170
+ installer_file_path: str = web.download(mongo_installer_url)
171
+
172
+ print_api("Installing MongoDB...")
173
+ try:
174
+ msiw.install_msi(
175
+ installer_file_path,
176
+ silent_no_gui=True,
177
+ no_restart=True,
178
+ terminate_required_processes=True,
179
+ create_log_near_msi=True,
180
+ scan_log_for_errors=True,
181
+ additional_args='ADDLOCAL="ServerService"'
182
+ )
183
+ except msiw.MsiInstallationError as e:
184
+ print_api(f'{e} Exiting...', color='red')
185
+ return 1
186
+
187
+ # Check if MongoDB is installed.
188
+ message: str = ''
189
+ mongo_is_installed = mongo_infra.is_installed()
190
+ if not mongo_is_installed:
191
+ message += "MongoDB Executable not found.\n"
192
+
193
+ if not mongo_infra.is_service_running():
194
+ message += "MongoDB service is not running.\n"
195
+
196
+ if message:
197
+ message += f"MSI Path: {installer_file_path}"
198
+ print_api(message, color='red')
199
+ return 1
200
+ else:
201
+ success_message: str = f"MongoDB installed successfully to: {mongo_is_installed}\n" \
202
+ f"Service is running."
203
+ print_api(success_message, color='green')
204
+
205
+ # Clean up the installer file
206
+ if os.path.exists(installer_file_path):
207
+ os.remove(installer_file_path)
208
+ print_api("Cleaned up the installer file.")
174
209
 
175
210
  if not compass:
176
211
  return 0
@@ -189,3 +224,21 @@ def download_install_latest_main(
189
224
  print_api("Cleaned up the Compass installer file.")
190
225
 
191
226
  return 0
227
+
228
+
229
+ def download_install_latest_main() -> int:
230
+ """
231
+ Download and install the latest version of MongoDB Community Server.
232
+
233
+ :return: int, 0 if successful, 1 if failed.
234
+ """
235
+
236
+ args = parse_args()
237
+
238
+ return download_install_process(
239
+ rc_version=args.include_rc,
240
+ no_rc_version=args.exclude_rc,
241
+ major_specific=args.major,
242
+ compass=args.compass,
243
+ force=args.force
244
+ )
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: atomicshop
3
- Version: 2.18.2
3
+ Version: 2.18.4
4
4
  Summary: Atomic functions and classes to make developer life easier
5
5
  Author: Denis Kras
6
6
  License: MIT License
@@ -1,4 +1,4 @@
1
- atomicshop/__init__.py,sha256=EPl1ua1q9CfR8reaw61h0P-bol2bj9D-p6to1iUifSY,123
1
+ atomicshop/__init__.py,sha256=85MhliVqiJ5CTAxGKQv7PfsSM76Jo4Xtu8UHYW8DdFA,123
2
2
  atomicshop/_basics_temp.py,sha256=6cu2dd6r2dLrd1BRNcVDKTHlsHs_26Gpw8QS6v32lQ0,3699
3
3
  atomicshop/_create_pdf_demo.py,sha256=Yi-PGZuMg0RKvQmLqVeLIZYadqEZwUm-4A9JxBl_vYA,3713
4
4
  atomicshop/_patch_import.py,sha256=ENp55sKVJ0e6-4lBvZnpz9PQCt3Otbur7F6aXDlyje4,6334
@@ -28,7 +28,7 @@ atomicshop/pbtkmultifile_argparse.py,sha256=aEk8nhvoQVu-xyfZosK3ma17CwIgOjzO1erX
28
28
  atomicshop/print_api.py,sha256=q9dAQCASk3pHp_PtYIpr6iZmRcW_lvrV_gPPNwTMRsw,11152
29
29
  atomicshop/process.py,sha256=PeLvyixXaCfftdUF3oMbohI1L4MdLtvQVDx2V1Tz_Rk,16662
30
30
  atomicshop/python_file_patcher.py,sha256=-uhbUX-um5k-If_XXuOfCr8wMzZ3QE6h9N8xGWw6W_o,5486
31
- atomicshop/python_functions.py,sha256=zJg4ogUwECxrDD7xdDN5JikIUctITM5lsyabr_ZNsRw,4435
31
+ atomicshop/python_functions.py,sha256=BPZ3sv5DgQs6Xrl3nIMdPABRpgrau3XSrsnDIz-LEwY,6175
32
32
  atomicshop/question_answer_engine.py,sha256=7nM6kGDSFjQNi87b87-kP9lYM0vTjBHn1rEQGNAfdGA,825
33
33
  atomicshop/queues.py,sha256=Al0fdC3ZJmdKfv-PyBeIck9lnfLr82BYchvzr189gsI,640
34
34
  atomicshop/scheduling.py,sha256=MvF20M6uU0Kh_CQn2ERxMTLvvF-ToBrdMhXNrKxYFj8,4682
@@ -46,7 +46,7 @@ atomicshop/uuids.py,sha256=JSQdm3ZTJiwPQ1gYe6kU0TKS_7suwVrHc8JZDGYlydM,2214
46
46
  atomicshop/venvs.py,sha256=D9lwOoObkYoRx-weuoAmbvN-RdSHhVm4DE9TVl-utAs,903
47
47
  atomicshop/virtualization.py,sha256=LPP4vjE0Vr10R6DA4lqhfX_WaNdDGRAZUW0Am6VeGco,494
48
48
  atomicshop/web.py,sha256=GLdTXgMxg1_0UQaXC4bOvARVyuFg7SPIeJdsCHV8rNE,11662
49
- atomicshop/websocket_parse.py,sha256=bkOwiXCNw5bQg1J4KOG7es5kUGysyX2NdfFFVBceSzg,16662
49
+ atomicshop/websocket_parse.py,sha256=aLHWyKqaYqEn_MRBWm2L6rIl6QPmqbVrjEXE_rBzwCw,16711
50
50
  atomicshop/a_installs/ubuntu/docker_rootless.py,sha256=9IPNtGZYjfy1_n6ZRt7gWz9KZgR6XCgevjqq02xk-o0,281
51
51
  atomicshop/a_installs/ubuntu/docker_sudo.py,sha256=JzayxeyKDtiuT4Icp2L2LyFRbx4wvpyN_bHLfZ-yX5E,281
52
52
  atomicshop/a_installs/ubuntu/elastic_search_and_kibana.py,sha256=yRB-l1zBxdiN6av-FwNkhcBlaeu4zrDPjQ0uPGgpK2I,244
@@ -127,11 +127,11 @@ atomicshop/file_io/xmls.py,sha256=zh3SuK-dNaFq2NDNhx6ivcf4GYCfGM8M10PcEwDSpxk,21
127
127
  atomicshop/mitm/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
128
128
  atomicshop/mitm/config_static.py,sha256=HIzxyMEj7DZksYvJsN5VuKpB-_HSVvuR6U59ztS9gi0,7871
129
129
  atomicshop/mitm/config_toml_editor.py,sha256=2p1CMcktWRR_NW-SmyDwylu63ad5e0-w1QPMa8ZLDBw,1635
130
- atomicshop/mitm/connection_thread_worker.py,sha256=d7XMZoXbXm9IUywg-IIVApad-NKpSdErLWgHtK8A4F4,26623
130
+ atomicshop/mitm/connection_thread_worker.py,sha256=Of-QmuIbUO8Qd1N_BXdGQk2TnPpZd2z-Pxrj0wyq9S8,26758
131
131
  atomicshop/mitm/import_config.py,sha256=0Ij14aISTllTOiWYJpIUMOWobQqGofD6uafui5uWllE,9272
132
132
  atomicshop/mitm/initialize_engines.py,sha256=NWz0yBErSrYBn0xWkJDBcHStBJ-kcsv9VtorcSP9x5M,8258
133
133
  atomicshop/mitm/message.py,sha256=mNo4Lphr_Jo6IlNX5mPJzABpogWGkjOhwI4meAivwHw,2987
134
- atomicshop/mitm/mitm_main.py,sha256=AxmqUiDHgfzqmIF8v2GZxlEKth6_AMaYcqAxziWMG0U,23430
134
+ atomicshop/mitm/mitm_main.py,sha256=Uko4lFG96ZeZ1yVJD5CT4c48NhfX_Hu1g0-THEiZfAc,23454
135
135
  atomicshop/mitm/recs_files.py,sha256=ZAAD0twun-FtmbSniXe3XQhIlawvANNB_HxwbHj7kwI,3151
136
136
  atomicshop/mitm/shared_functions.py,sha256=0lzeyINd44sVEfFbahJxQmz6KAMWbYrW5ou3UYfItvw,1777
137
137
  atomicshop/mitm/statistic_analyzer.py,sha256=5_sAYGX2Xunzo_pS2W5WijNCwr_BlGJbbOO462y_wN4,27533
@@ -233,7 +233,7 @@ atomicshop/wrappers/factw/fact_extractor/__init__.py,sha256=47DEQpj8HBSa-_TImW-5
233
233
  atomicshop/wrappers/factw/fact_extractor/docker_image.py,sha256=2FyYjnw8gxFNwISQ83OwH-iGivkFi6EAluyCZ0loHEQ,2501
234
234
  atomicshop/wrappers/factw/fact_extractor/get_extractor.py,sha256=2mfOAftHIlCcGt1s7MWdq7DsDCuI6wX3MtvcEZ4SK-0,756
235
235
  atomicshop/wrappers/factw/install/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
236
- atomicshop/wrappers/factw/install/install_after_restart.py,sha256=cr8E9BAEdpJXJ1VdyXr85byU0PvE3tPV0uPALQOmiKg,4318
236
+ atomicshop/wrappers/factw/install/install_after_restart.py,sha256=4dHn2XMbYaPJlhRCmZqqwsgHQBlG2mT7aW50pQCPtp4,4345
237
237
  atomicshop/wrappers/factw/install/pre_install_and_install_before_restart.py,sha256=GFsO9MTH0czKoxkiPJtjalilUwsmFLBCcx9Znv37S4M,5945
238
238
  atomicshop/wrappers/factw/postgresql/__init__.py,sha256=xMBn2d3Exo23IPP2F_9-SXmOlhFbwWDgS9KwozSTjA0,162
239
239
  atomicshop/wrappers/factw/postgresql/analysis.py,sha256=2Rxzy2jyq3zEKIo53z8VkjuslKE_i5mq2ZpmJAvyd6U,716
@@ -260,7 +260,7 @@ atomicshop/wrappers/loggingw/loggingw.py,sha256=uLY7DJS-3xIYQBRvI--9eFvdcnvsWSXm
260
260
  atomicshop/wrappers/loggingw/reading.py,sha256=sCNlgqLNH5XdKqOOjjEox7CvViMHzs6h7-hwCnx4NKk,17566
261
261
  atomicshop/wrappers/mongodbw/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
262
262
  atomicshop/wrappers/mongodbw/install_mongodb_ubuntu.py,sha256=pmI9AwWJ2cv5h8GionSpSJkllg6kfp0M381pk6y4Y5U,4015
263
- atomicshop/wrappers/mongodbw/install_mongodb_win.py,sha256=3ZPqrXxj3lC-PnAKGXclylLuOqsbyXYeUpb5iGjdeUU,6626
263
+ atomicshop/wrappers/mongodbw/install_mongodb_win.py,sha256=64EUQYx7VuMC3ndO2x3nSErh5NZ_BsqMwGvPcybfC-Q,8499
264
264
  atomicshop/wrappers/mongodbw/mongo_infra.py,sha256=IjEF0jPzQz866MpTm7rnksnyyWQeUT_B2h2DA9ryAio,2034
265
265
  atomicshop/wrappers/mongodbw/mongodbw.py,sha256=IkEw86QFyVRU-5p5s6_6yupvSxmaQxr59GKNgSEkAm4,52617
266
266
  atomicshop/wrappers/nodejsw/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
@@ -319,8 +319,8 @@ atomicshop/wrappers/socketw/ssl_base.py,sha256=kmiif84kMhBr5yjQW17p935sfjR5JKG0L
319
319
  atomicshop/wrappers/socketw/statistics_csv.py,sha256=fgMzDXI0cybwUEqAxprRmY3lqbh30KAV-jOpoFKT-m8,3395
320
320
  atomicshop/wrappers/winregw/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
321
321
  atomicshop/wrappers/winregw/winreg_network.py,sha256=zZQfps-CdODQaTUADbHAwKHr5RUg7BLafnKWBbKaLN4,8728
322
- atomicshop-2.18.2.dist-info/LICENSE.txt,sha256=lLU7EYycfYcK2NR_1gfnhnRC8b8ccOTElACYplgZN88,1094
323
- atomicshop-2.18.2.dist-info/METADATA,sha256=jeXe5N1uxADb9T7GA5B10ENn-cmKa6WN6RywG1h3WgY,10499
324
- atomicshop-2.18.2.dist-info/WHEEL,sha256=GJ7t_kWBFywbagK5eo9IoUwLW6oyOeTKmQ-9iHFVNxQ,92
325
- atomicshop-2.18.2.dist-info/top_level.txt,sha256=EgKJB-7xcrAPeqTRF2laD_Np2gNGYkJkd4OyXqpJphA,11
326
- atomicshop-2.18.2.dist-info/RECORD,,
322
+ atomicshop-2.18.4.dist-info/LICENSE.txt,sha256=lLU7EYycfYcK2NR_1gfnhnRC8b8ccOTElACYplgZN88,1094
323
+ atomicshop-2.18.4.dist-info/METADATA,sha256=Eabxa6pWlDm-BYBMU-rJ_YCVnxKylpxEYJ2GmbskdZM,10499
324
+ atomicshop-2.18.4.dist-info/WHEEL,sha256=GJ7t_kWBFywbagK5eo9IoUwLW6oyOeTKmQ-9iHFVNxQ,92
325
+ atomicshop-2.18.4.dist-info/top_level.txt,sha256=EgKJB-7xcrAPeqTRF2laD_Np2gNGYkJkd4OyXqpJphA,11
326
+ atomicshop-2.18.4.dist-info/RECORD,,