assemblyline-core 4.5.1.dev409__tar.gz → 4.5.1.dev413__tar.gz

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 (88) hide show
  1. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/PKG-INFO +1 -1
  2. assemblyline_core-4.5.1.dev413/assemblyline_core/VERSION +1 -0
  3. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/dispatching/dispatcher.py +1 -1
  4. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/metrics/helper.py +10 -2
  5. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/scaler/controllers/kubernetes_ctl.py +2 -2
  6. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core.egg-info/PKG-INFO +1 -1
  7. assemblyline_core-4.5.1.dev409/assemblyline_core/VERSION +0 -1
  8. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/LICENCE.md +0 -0
  9. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/README.md +0 -0
  10. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/__init__.py +0 -0
  11. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/alerter/__init__.py +0 -0
  12. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/alerter/processing.py +0 -0
  13. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/alerter/run_alerter.py +0 -0
  14. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/archiver/__init__.py +0 -0
  15. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/archiver/run_archiver.py +0 -0
  16. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/badlist_client.py +0 -0
  17. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/dispatching/__init__.py +0 -0
  18. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/dispatching/__main__.py +0 -0
  19. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/dispatching/client.py +0 -0
  20. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/dispatching/schedules.py +0 -0
  21. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/dispatching/timeout.py +0 -0
  22. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/expiry/__init__.py +0 -0
  23. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/expiry/run_expiry.py +0 -0
  24. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/ingester/__init__.py +0 -0
  25. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/ingester/__main__.py +0 -0
  26. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/ingester/constants.py +0 -0
  27. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/ingester/ingester.py +0 -0
  28. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/metrics/__init__.py +0 -0
  29. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/metrics/es_metrics.py +0 -0
  30. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/metrics/heartbeat_formatter.py +0 -0
  31. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/metrics/metrics_server.py +0 -0
  32. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/metrics/run_heartbeat_manager.py +0 -0
  33. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/metrics/run_metrics_aggregator.py +0 -0
  34. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/metrics/run_statistics_aggregator.py +0 -0
  35. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/plumber/__init__.py +0 -0
  36. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/plumber/run_plumber.py +0 -0
  37. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/replay/__init__.py +0 -0
  38. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/replay/client.py +0 -0
  39. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/replay/creator/__init__.py +0 -0
  40. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/replay/creator/run.py +0 -0
  41. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/replay/creator/run_worker.py +0 -0
  42. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/replay/loader/__init__.py +0 -0
  43. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/replay/loader/run.py +0 -0
  44. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/replay/loader/run_worker.py +0 -0
  45. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/replay/replay.py +0 -0
  46. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/safelist_client.py +0 -0
  47. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/scaler/__init__.py +0 -0
  48. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/scaler/collection.py +0 -0
  49. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/scaler/controllers/__init__.py +0 -0
  50. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/scaler/controllers/docker_ctl.py +0 -0
  51. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/scaler/controllers/interface.py +0 -0
  52. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/scaler/run_scaler.py +0 -0
  53. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/scaler/scaler_server.py +0 -0
  54. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/server_base.py +0 -0
  55. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/signature_client.py +0 -0
  56. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/submission_client.py +0 -0
  57. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/tasking_client.py +0 -0
  58. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/updater/__init__.py +0 -0
  59. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/updater/helper.py +0 -0
  60. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/updater/run_updater.py +0 -0
  61. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/vacuum/__init__.py +0 -0
  62. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/vacuum/crawler.py +0 -0
  63. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/vacuum/department_map.py +0 -0
  64. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/vacuum/safelist.py +0 -0
  65. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/vacuum/stream_map.py +0 -0
  66. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/vacuum/worker.py +0 -0
  67. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/workflow/__init__.py +0 -0
  68. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core/workflow/run_workflow.py +0 -0
  69. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core.egg-info/SOURCES.txt +0 -0
  70. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core.egg-info/dependency_links.txt +0 -0
  71. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core.egg-info/requires.txt +0 -0
  72. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/assemblyline_core.egg-info/top_level.txt +0 -0
  73. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/setup.cfg +0 -0
  74. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/setup.py +0 -0
  75. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/test/test_alerter.py +0 -0
  76. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/test/test_badlist_client.py +0 -0
  77. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/test/test_dispatcher.py +0 -0
  78. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/test/test_expiry.py +0 -0
  79. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/test/test_plumber.py +0 -0
  80. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/test/test_replay.py +0 -0
  81. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/test/test_safelist_client.py +0 -0
  82. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/test/test_scaler.py +0 -0
  83. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/test/test_scheduler.py +0 -0
  84. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/test/test_signature_client.py +0 -0
  85. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/test/test_simulation.py +0 -0
  86. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/test/test_vacuum.py +0 -0
  87. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/test/test_worker_ingest.py +0 -0
  88. {assemblyline_core-4.5.1.dev409 → assemblyline_core-4.5.1.dev413}/test/test_worker_submit.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.2
2
2
  Name: assemblyline-core
3
- Version: 4.5.1.dev409
3
+ Version: 4.5.1.dev413
4
4
  Summary: Assemblyline 4 - Core components
5
5
  Home-page: https://github.com/CybercentreCanada/assemblyline-core/
6
6
  Author: CCCS Assemblyline development team
@@ -0,0 +1 @@
1
+ 4.5.1.dev413
@@ -182,7 +182,7 @@ class TemporaryFileData:
182
182
  self.shared_values[key] = []
183
183
 
184
184
  # make sure the input is the right type
185
- if not isinstance(values, list | tuple):
185
+ if not isinstance(values, (list, tuple)):
186
186
  return False
187
187
 
188
188
  # Add each value one at a time testing for new values
@@ -1,7 +1,8 @@
1
1
  import time
2
-
3
2
  import elasticsearch
4
3
 
4
+ from os import environ
5
+
5
6
  from assemblyline.datastore.exceptions import ILMException
6
7
 
7
8
  MAX_RETRY_BACKOFF = 10
@@ -64,6 +65,11 @@ def create_ilm_policy(es, name, archive_config):
64
65
  def ensure_indexes(log, es, config, indexes, datastream_enabled=False):
65
66
  for index_type in indexes:
66
67
  try:
68
+ # Get the shard/replica configuration for metric-based indices from the environment
69
+ # Otherwise default to values for a single-node Elastic cluster
70
+ replicas = environ.get(f"ELASTIC_{index_type.upper()}_METRICS_REPLICAS", environ.get('ELASTIC_DEFAULT_METRICS_REPLICAS', 0))
71
+ shards = environ.get(f"ELASTIC_{index_type.upper()}_METRICS_SHARDS", environ.get('ELASTIC_DEFAULT_METRICS_SHARDS', 1))
72
+
67
73
  index = f"al_metrics_{index_type}_ds" if datastream_enabled else f"al_metrics_{index_type}"
68
74
  policy = f"{index}_policy"
69
75
  while True:
@@ -83,7 +89,9 @@ def ensure_indexes(log, es, config, indexes, datastream_enabled=False):
83
89
  template_body = {
84
90
  "settings": {
85
91
  "index.lifecycle.name": policy,
86
- "index.codec": "best_compression"
92
+ "index.codec": "best_compression",
93
+ "index.number_of_replicas": replicas,
94
+ "index.number_of_shards": shards
87
95
  }
88
96
  }
89
97
  put_template_func = None
@@ -1194,7 +1194,7 @@ class KubernetesController(ControllerInterface):
1194
1194
  service = self.api.read_namespaced_service(deployment_name, self.namespace)
1195
1195
  service.metadata.labels = labels
1196
1196
  service.spec.selector = labels
1197
- service.spec.ports = [V1ServicePort(port=int(_p)) for _p in spec.container.ports]
1197
+ service.spec.ports = [V1ServicePort(port=int(_p), name=f"port-{_p}") for _p in spec.container.ports]
1198
1198
  self.api.patch_namespaced_service(deployment_name, self.namespace, service)
1199
1199
  except ApiException as error:
1200
1200
  if error.status != 404:
@@ -1204,7 +1204,7 @@ class KubernetesController(ControllerInterface):
1204
1204
  spec=V1ServiceSpec(
1205
1205
  cluster_ip='None',
1206
1206
  selector=labels,
1207
- ports=[V1ServicePort(port=int(_p)) for _p in spec.container.ports]
1207
+ ports=[V1ServicePort(port=int(_p), name=f"port-{_p}") for _p in spec.container.ports]
1208
1208
  )
1209
1209
  )
1210
1210
  self.api.create_namespaced_service(self.namespace, service)
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.2
2
2
  Name: assemblyline-core
3
- Version: 4.5.1.dev409
3
+ Version: 4.5.1.dev413
4
4
  Summary: Assemblyline 4 - Core components
5
5
  Home-page: https://github.com/CybercentreCanada/assemblyline-core/
6
6
  Author: CCCS Assemblyline development team
@@ -1 +0,0 @@
1
- 4.5.1.dev409