paasta-tools 1.23.0__py3-none-any.whl → 1.23.2__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.
Files changed (66) hide show
  1. paasta_tools/__init__.py +1 -1
  2. paasta_tools/api/api_docs/swagger.json +18 -2
  3. paasta_tools/cli/cmds/remote_run.py +40 -19
  4. paasta_tools/contrib/paasta_update_soa_memcpu.py +82 -19
  5. paasta_tools/kubernetes_tools.py +23 -5
  6. paasta_tools/paastaapi/api/remote_run_api.py +1 -0
  7. paasta_tools/paastaapi/model/inline_response403.py +170 -0
  8. paasta_tools/paastaapi/models/__init__.py +1 -0
  9. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/paasta_update_soa_memcpu.py +82 -19
  10. {paasta_tools-1.23.0.dist-info → paasta_tools-1.23.2.dist-info}/METADATA +1 -1
  11. {paasta_tools-1.23.0.dist-info → paasta_tools-1.23.2.dist-info}/RECORD +66 -65
  12. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/apply_external_resources.py +0 -0
  13. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/bounce_log_latency_parser.py +0 -0
  14. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/check_autoscaler_max_instances.py +0 -0
  15. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/check_cassandracluster_services_replication.py +0 -0
  16. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/check_flink_services_health.py +0 -0
  17. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/check_kubernetes_api.py +0 -0
  18. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/check_kubernetes_services_replication.py +0 -0
  19. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/check_manual_oapi_changes.sh +0 -0
  20. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/check_oom_events.py +0 -0
  21. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/check_orphans.py +0 -0
  22. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/check_spark_jobs.py +0 -0
  23. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/cleanup_kubernetes_cr.py +0 -0
  24. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/cleanup_kubernetes_crd.py +0 -0
  25. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/cleanup_kubernetes_jobs.py +0 -0
  26. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/create_dynamodb_table.py +0 -0
  27. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/create_paasta_playground.py +0 -0
  28. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/delete_kubernetes_deployments.py +0 -0
  29. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/emit_allocated_cpu_metrics.py +0 -0
  30. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/generate_all_deployments +0 -0
  31. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/generate_authenticating_services.py +0 -0
  32. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/generate_deployments_for_service.py +0 -0
  33. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/generate_services_file.py +0 -0
  34. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/generate_services_yaml.py +0 -0
  35. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/get_running_task_allocation.py +0 -0
  36. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/habitat_fixer.py +0 -0
  37. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/ide_helper.py +0 -0
  38. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/is_pod_healthy_in_proxy.py +0 -0
  39. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/is_pod_healthy_in_smartstack.py +0 -0
  40. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/kill_bad_containers.py +0 -0
  41. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/kubernetes_remove_evicted_pods.py +0 -0
  42. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/mass-deploy-tag.sh +0 -0
  43. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/mock_patch_checker.py +0 -0
  44. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/paasta_cleanup_remote_run_resources.py +0 -0
  45. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/paasta_cleanup_stale_nodes.py +0 -0
  46. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/paasta_deploy_tron_jobs +0 -0
  47. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/paasta_execute_docker_command.py +0 -0
  48. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/paasta_secrets_sync.py +0 -0
  49. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/paasta_tabcomplete.sh +0 -0
  50. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/render_template.py +0 -0
  51. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/rightsizer_soaconfigs_update.py +0 -0
  52. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/service_shard_remove.py +0 -0
  53. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/service_shard_update.py +0 -0
  54. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/setup_istio_mesh.py +0 -0
  55. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/setup_kubernetes_cr.py +0 -0
  56. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/setup_kubernetes_crd.py +0 -0
  57. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/setup_kubernetes_internal_crd.py +0 -0
  58. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/setup_kubernetes_job.py +0 -0
  59. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/setup_prometheus_adapter_config.py +0 -0
  60. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/shared_ip_check.py +0 -0
  61. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/synapse_srv_namespaces_fact.py +0 -0
  62. {paasta_tools-1.23.0.data → paasta_tools-1.23.2.data}/scripts/timeouts_metrics_prom.py +0 -0
  63. {paasta_tools-1.23.0.dist-info → paasta_tools-1.23.2.dist-info}/LICENSE +0 -0
  64. {paasta_tools-1.23.0.dist-info → paasta_tools-1.23.2.dist-info}/WHEEL +0 -0
  65. {paasta_tools-1.23.0.dist-info → paasta_tools-1.23.2.dist-info}/entry_points.txt +0 -0
  66. {paasta_tools-1.23.0.dist-info → paasta_tools-1.23.2.dist-info}/top_level.txt +0 -0
paasta_tools/__init__.py CHANGED
@@ -17,4 +17,4 @@
17
17
  # setup phase, the dependencies may not exist on disk yet.
18
18
  #
19
19
  # Don't bump version manually. See `make release` docs in ./Makefile
20
- __version__ = "1.23.0"
20
+ __version__ = "1.23.2"
@@ -930,7 +930,15 @@
930
930
  }
931
931
  },
932
932
  "403": {
933
- "description": "Unauthorized to remote-run this service"
933
+ "description": "Unauthorized to remote-run this service",
934
+ "schema": {
935
+ "type": "object",
936
+ "properties": {
937
+ "reason": {
938
+ "type": "string"
939
+ }
940
+ }
941
+ }
934
942
  },
935
943
  "404": {
936
944
  "description": "Deployment key not found"
@@ -981,7 +989,15 @@
981
989
  }
982
990
  },
983
991
  "403": {
984
- "description": "Unauthorized to remote-run this service"
992
+ "description": "Unauthorized to remote-run this service",
993
+ "schema": {
994
+ "type": "object",
995
+ "properties": {
996
+ "reason": {
997
+ "type": "string"
998
+ }
999
+ }
1000
+ }
985
1001
  },
986
1002
  "404": {
987
1003
  "description": "Service instance not found"
@@ -13,6 +13,7 @@
13
13
  # See the License for the specific language governing permissions and
14
14
  # limitations under the License.
15
15
  import argparse
16
+ import json
16
17
  import shutil
17
18
  import subprocess
18
19
  import sys
@@ -24,6 +25,7 @@ from paasta_tools.cli.utils import get_paasta_oapi_client_with_auth
24
25
  from paasta_tools.cli.utils import lazy_choices_completer
25
26
  from paasta_tools.cli.utils import run_interactive_cli
26
27
  from paasta_tools.kubernetes.remote_run import TOOLBOX_MOCK_SERVICE
28
+ from paasta_tools.paastaapi.exceptions import ApiException
27
29
  from paasta_tools.paastaapi.model.remote_run_start import RemoteRunStart
28
30
  from paasta_tools.paastaapi.model.remote_run_stop import RemoteRunStop
29
31
  from paasta_tools.utils import get_username
@@ -57,6 +59,18 @@ def _list_services_and_toolboxes() -> List[str]:
57
59
  )
58
60
 
59
61
 
62
+ def parse_error(body: str) -> str:
63
+ try:
64
+ body_object = json.loads(body)
65
+ except json.decoder.JSONDecodeError:
66
+ return body
67
+ return (
68
+ body_object.get("reason")
69
+ or body_object.get("message")
70
+ or json.dumps(body_object, indent=4)
71
+ )
72
+
73
+
60
74
  def paasta_remote_run_start(
61
75
  args: argparse.Namespace,
62
76
  system_paasta_config: SystemPaastaConfig,
@@ -72,19 +86,21 @@ def paasta_remote_run_start(
72
86
  return 1
73
87
 
74
88
  user = get_username()
75
- start_response = client.remote_run.remote_run_start(
76
- args.service,
77
- args.instance,
78
- RemoteRunStart(
79
- user=user,
80
- interactive=args.interactive,
81
- recreate=args.recreate,
82
- max_duration=args.max_duration,
83
- toolbox=args.toolbox,
84
- ),
85
- )
86
- if start_response.status >= 300:
87
- print(f"Error from PaaSTA APIs while starting job: {start_response.message}")
89
+ try:
90
+ start_response = client.remote_run.remote_run_start(
91
+ args.service,
92
+ args.instance,
93
+ RemoteRunStart(
94
+ user=user,
95
+ interactive=args.interactive,
96
+ recreate=args.recreate,
97
+ max_duration=args.max_duration,
98
+ toolbox=args.toolbox,
99
+ ),
100
+ )
101
+ except ApiException as e:
102
+ error_msg = parse_error(e.body)
103
+ print(f"Error from PaaSTA APIs while starting job: {error_msg}")
88
104
  return 1
89
105
 
90
106
  print(
@@ -172,13 +188,18 @@ def paasta_remote_run_stop(
172
188
  if not client:
173
189
  print("Cannot get a paasta-api client")
174
190
  return 1
175
- response = client.remote_run.remote_run_stop(
176
- args.service,
177
- args.instance,
178
- RemoteRunStop(user=get_username(), toolbox=args.toolbox),
179
- )
191
+ try:
192
+ response = client.remote_run.remote_run_stop(
193
+ args.service,
194
+ args.instance,
195
+ RemoteRunStop(user=get_username(), toolbox=args.toolbox),
196
+ )
197
+ except ApiException as e:
198
+ error_msg = parse_error(e.body)
199
+ print(f"Error from PaaSTA APIs while stopping job: {error_msg}")
200
+ return 1
180
201
  print(response.message)
181
- return 0 if response.status < 300 else 1
202
+ return 0
182
203
 
183
204
 
184
205
  def add_common_args_to_parser(parser: argparse.ArgumentParser):
@@ -135,6 +135,11 @@ def cwd(path):
135
135
  os.chdir(pwd)
136
136
 
137
137
 
138
+ def _force_str_to_int(value: str) -> int:
139
+ """Force convert strings into ints - even if they're technically floats."""
140
+ return int(float(value))
141
+
142
+
138
143
  def get_report_from_splunk(creds, app, filename, criteria_filter):
139
144
  """Expect a table containing at least the following fields:
140
145
  criteria (<service> kubernetes-<cluster_name> <instance>)
@@ -165,29 +170,87 @@ def get_report_from_splunk(creds, app, filename, criteria_filter):
165
170
  resp_text = [x for x in resp_text if x]
166
171
  resp_text = [json.loads(x) for x in resp_text]
167
172
  services_to_update = {}
173
+
168
174
  for d in resp_text:
169
175
  if "result" not in d:
170
176
  raise ValueError(f"Splunk request didn't return any results: {resp_text}")
171
177
  criteria = d["result"]["criteria"]
172
- serv = {}
173
- serv["service"] = criteria.split(" ")[0]
174
- serv["cluster"] = criteria.split(" ")[1]
175
- serv["instance"] = criteria.split(" ")[2]
176
- serv["owner"] = d["result"].get("service_owner", "Unavailable")
177
- serv["date"] = d["result"]["_time"].split(" ")[0]
178
- serv["money"] = d["result"].get("estimated_monthly_savings", 0)
179
- serv["project"] = d["result"].get("project", "Unavailable")
180
- serv["cpus"] = d["result"].get("suggested_cpus")
181
- serv["old_cpus"] = d["result"].get("current_cpus")
182
- serv["mem"] = d["result"].get("suggested_mem")
183
- serv["old_mem"] = d["result"].get("current_mem")
184
- serv["disk"] = d["result"].get("suggested_disk")
185
- serv["old_disk"] = d["result"].get("current_disk")
186
- serv["min_instances"] = d["result"].get("suggested_min_instances")
187
- serv["max_instances"] = d["result"].get("suggested_max_instances")
188
- serv["hacheck_cpus"] = d["result"].get("suggested_hacheck_cpus")
189
- serv["cpu_burst_add"] = d["result"].get("suggested_cpu_burst_add")
190
- services_to_update[criteria] = serv
178
+
179
+ serv = {
180
+ "cluster": criteria.split(" ")[1],
181
+ "date": d["result"]["_time"].split(" ")[0],
182
+ "instance": criteria.split(" ")[2],
183
+ "money": d["result"].get("estimated_monthly_savings", 0),
184
+ "owner": d["result"].get("service_owner", "Unavailable"),
185
+ "project": d["result"].get("project", "Unavailable"),
186
+ "service": criteria.split(" ")[0],
187
+ # only mergeable fields below
188
+ "cpu_burst_add": d["result"].get("suggested_cpu_burst_add"),
189
+ "cpus": d["result"].get("suggested_cpus"),
190
+ "disk": d["result"].get("suggested_disk"),
191
+ "hacheck_cpus": d["result"].get("suggested_hacheck_cpus"),
192
+ "max_instances": d["result"].get("suggested_max_instances"),
193
+ "mem": d["result"].get("suggested_mem"),
194
+ "min_instances": d["result"].get("suggested_min_instances"),
195
+ "old_cpus": d["result"].get("current_cpus"),
196
+ "old_disk": d["result"].get("current_disk"),
197
+ "old_mem": d["result"].get("current_mem"),
198
+ }
199
+
200
+ # the report we get is all strings, so we need to convert them to the right types
201
+ field_conversions = {
202
+ "current_cpus": float,
203
+ "suggested_cpu_burst_add": float,
204
+ "suggested_cpus": float,
205
+ "suggested_disk": int,
206
+ "suggested_hacheck_cpus": float,
207
+ "suggested_max_instances": int,
208
+ "suggested_mem": int,
209
+ "suggested_min_instances": int,
210
+ # not quite sure why these are floats...they're ints in soaconfigs
211
+ "current_disk": _force_str_to_int,
212
+ "current_mem": _force_str_to_int,
213
+ }
214
+
215
+ # merge results if we've already seen rows for this service
216
+ # NOTE: this is necessary since the Splunk search can return multiple rows
217
+ # for the same (service, cluster, instance) tuple as the autotune query
218
+ # treats certain cpu allocation changes as if the tuple was entirely different.
219
+ # this is ostensibly due to a theory that if you update resource allocation, existing
220
+ # autotune data is potentially invalidated - but in practice this ends up hampering
221
+ # autotune for services with highly variable resource allocation - e.g., we have some services
222
+ # that have their cpu allocation tweaked by +/-.1 cpu pretty frequently, but then min/max autotune
223
+ # is never updated.
224
+ if criteria in services_to_update:
225
+ for key in serv:
226
+ # we probably don't want to merge any other fields since they're going to be strings :p
227
+ if key not in field_conversions:
228
+ continue
229
+
230
+ last_proposed_suggestion = services_to_update[criteria][key]
231
+ proposed_suggestion = serv[key]
232
+
233
+ # if both are non-null, take the max of the two
234
+ if (
235
+ last_proposed_suggestion is not None
236
+ and proposed_suggestion is not None
237
+ ):
238
+ services_to_update[criteria][key] = max(
239
+ last_proposed_suggestion,
240
+ proposed_suggestion,
241
+ key=field_conversions[key],
242
+ )
243
+ # otherwise, if only one of these is non-null, use that one
244
+ elif last_proposed_suggestion is not None:
245
+ services_to_update[criteria][key] = last_proposed_suggestion
246
+ elif proposed_suggestion is not None:
247
+ services_to_update[criteria][key] = proposed_suggestion
248
+ # otherwise, if we didn't enter any of the above branches, we're essentially leaving in place the
249
+ # existing None
250
+
251
+ # otherwise, simply add the service to the final report
252
+ else:
253
+ services_to_update[criteria] = serv
191
254
 
192
255
  return {
193
256
  "search": search,
@@ -4334,21 +4334,39 @@ def ensure_service_account(
4334
4334
  kube_client: KubeClient,
4335
4335
  k8s_role: Optional[str] = None,
4336
4336
  ) -> None:
4337
+ role_annotation = "eks.amazonaws.com/role-arn"
4337
4338
  sa_name = get_service_account_name(iam_role, k8s_role)
4338
4339
 
4339
- if not any(
4340
- sa.metadata and sa.metadata.name == sa_name
4341
- for sa in get_all_service_accounts(kube_client, namespace)
4342
- ):
4340
+ existing_sa = None
4341
+ for sa in get_all_service_accounts(kube_client, namespace):
4342
+ if sa.metadata and sa.metadata.name == sa_name:
4343
+ existing_sa = sa
4344
+ break
4345
+ else:
4343
4346
  sa = V1ServiceAccount(
4344
4347
  kind="ServiceAccount",
4345
4348
  metadata=V1ObjectMeta(
4346
4349
  name=sa_name,
4347
4350
  namespace=namespace,
4348
- annotations={"eks.amazonaws.com/role-arn": iam_role},
4351
+ annotations={role_annotation: iam_role},
4349
4352
  ),
4350
4353
  )
4351
4354
  kube_client.core.create_namespaced_service_account(namespace=namespace, body=sa)
4355
+ if existing_sa:
4356
+ if (
4357
+ not sa.metadata.annotations
4358
+ or sa.metadata.annotations.get(role_annotation, None) != iam_role
4359
+ ):
4360
+ # NOTE: we don't annotate SAs apart with anything other
4361
+ # than the pod identity role ARN, so this will remove
4362
+ # any annotations that folks may have manually added
4363
+ sa.metadata.annotations = {role_annotation: iam_role}
4364
+ kube_client.core.patch_namespaced_service_account(
4365
+ namespace=namespace, body=sa, name=sa.metadata.name
4366
+ )
4367
+ log.info(
4368
+ f"Updated ServiceAccount {sa.metadata.name} iam_role to {iam_role}"
4369
+ )
4352
4370
 
4353
4371
  # we're expecting that any Role dynamically associated with a Service Account already exists.
4354
4372
  # at Yelp, this means that we have a version-controlled resource for the Role in Puppet.
@@ -23,6 +23,7 @@ from paasta_tools.paastaapi.model_utils import ( # noqa: F401
23
23
  none_type,
24
24
  validate_and_convert_types
25
25
  )
26
+ from paasta_tools.paastaapi.model.inline_response403 import InlineResponse403
26
27
  from paasta_tools.paastaapi.model.remote_run_outcome import RemoteRunOutcome
27
28
  from paasta_tools.paastaapi.model.remote_run_start import RemoteRunStart
28
29
  from paasta_tools.paastaapi.model.remote_run_stop import RemoteRunStop
@@ -0,0 +1,170 @@
1
+ # coding: utf-8
2
+
3
+ """
4
+ Paasta API
5
+
6
+ No description provided (generated by Openapi Generator https://github.com/openapitools/openapi-generator) # noqa: E501
7
+
8
+ The version of the OpenAPI document: 1.2.0
9
+ Generated by: https://openapi-generator.tech
10
+ """
11
+
12
+
13
+ import re # noqa: F401
14
+ import sys # noqa: F401
15
+
16
+ import nulltype # noqa: F401
17
+
18
+ from paasta_tools.paastaapi.model_utils import ( # noqa: F401
19
+ ApiTypeError,
20
+ ModelComposed,
21
+ ModelNormal,
22
+ ModelSimple,
23
+ cached_property,
24
+ change_keys_js_to_python,
25
+ convert_js_args_to_python_args,
26
+ date,
27
+ datetime,
28
+ file_type,
29
+ none_type,
30
+ validate_get_composed_info,
31
+ )
32
+
33
+
34
+ class InlineResponse403(ModelNormal):
35
+ """NOTE: This class is auto generated by OpenAPI Generator.
36
+ Ref: https://openapi-generator.tech
37
+
38
+ Do not edit the class manually.
39
+
40
+ Attributes:
41
+ allowed_values (dict): The key is the tuple path to the attribute
42
+ and the for var_name this is (var_name,). The value is a dict
43
+ with a capitalized key describing the allowed value and an allowed
44
+ value. These dicts store the allowed enum values.
45
+ attribute_map (dict): The key is attribute name
46
+ and the value is json key in definition.
47
+ discriminator_value_class_map (dict): A dict to go from the discriminator
48
+ variable value to the discriminator class name.
49
+ validations (dict): The key is the tuple path to the attribute
50
+ and the for var_name this is (var_name,). The value is a dict
51
+ that stores validations for max_length, min_length, max_items,
52
+ min_items, exclusive_maximum, inclusive_maximum, exclusive_minimum,
53
+ inclusive_minimum, and regex.
54
+ additional_properties_type (tuple): A tuple of classes accepted
55
+ as additional properties values.
56
+ """
57
+
58
+ allowed_values = {
59
+ }
60
+
61
+ validations = {
62
+ }
63
+
64
+ additional_properties_type = None
65
+
66
+ _nullable = False
67
+
68
+ @cached_property
69
+ def openapi_types():
70
+ """
71
+ This must be a method because a model may have properties that are
72
+ of type self, this must run after the class is loaded
73
+
74
+ Returns
75
+ openapi_types (dict): The key is attribute name
76
+ and the value is attribute type.
77
+ """
78
+ return {
79
+ 'reason': (str,), # noqa: E501
80
+ }
81
+
82
+ @cached_property
83
+ def discriminator():
84
+ return None
85
+
86
+
87
+ attribute_map = {
88
+ 'reason': 'reason', # noqa: E501
89
+ }
90
+
91
+ _composed_schemas = {}
92
+
93
+ required_properties = set([
94
+ '_data_store',
95
+ '_check_type',
96
+ '_spec_property_naming',
97
+ '_path_to_item',
98
+ '_configuration',
99
+ '_visited_composed_classes',
100
+ ])
101
+
102
+ @convert_js_args_to_python_args
103
+ def __init__(self, *args, **kwargs): # noqa: E501
104
+ """InlineResponse403 - a model defined in OpenAPI
105
+
106
+ Keyword Args:
107
+ _check_type (bool): if True, values for parameters in openapi_types
108
+ will be type checked and a TypeError will be
109
+ raised if the wrong type is input.
110
+ Defaults to True
111
+ _path_to_item (tuple/list): This is a list of keys or values to
112
+ drill down to the model in received_data
113
+ when deserializing a response
114
+ _spec_property_naming (bool): True if the variable names in the input data
115
+ are serialized names, as specified in the OpenAPI document.
116
+ False if the variable names in the input data
117
+ are pythonic names, e.g. snake case (default)
118
+ _configuration (Configuration): the instance to use when
119
+ deserializing a file_type parameter.
120
+ If passed, type conversion is attempted
121
+ If omitted no type conversion is done.
122
+ _visited_composed_classes (tuple): This stores a tuple of
123
+ classes that we have traveled through so that
124
+ if we see that class again we will not use its
125
+ discriminator again.
126
+ When traveling through a discriminator, the
127
+ composed schema that is
128
+ is traveled through is added to this set.
129
+ For example if Animal has a discriminator
130
+ petType and we pass in "Dog", and the class Dog
131
+ allOf includes Animal, we move through Animal
132
+ once using the discriminator, and pick Dog.
133
+ Then in Dog, we will make an instance of the
134
+ Animal class but this time we won't travel
135
+ through its discriminator because we passed in
136
+ _visited_composed_classes = (Animal,)
137
+ reason (str): [optional] # noqa: E501
138
+ """
139
+
140
+ _check_type = kwargs.pop('_check_type', True)
141
+ _spec_property_naming = kwargs.pop('_spec_property_naming', False)
142
+ _path_to_item = kwargs.pop('_path_to_item', ())
143
+ _configuration = kwargs.pop('_configuration', None)
144
+ _visited_composed_classes = kwargs.pop('_visited_composed_classes', ())
145
+
146
+ if args:
147
+ raise ApiTypeError(
148
+ "Invalid positional arguments=%s passed to %s. Remove those invalid positional arguments." % (
149
+ args,
150
+ self.__class__.__name__,
151
+ ),
152
+ path_to_item=_path_to_item,
153
+ valid_classes=(self.__class__,),
154
+ )
155
+
156
+ self._data_store = {}
157
+ self._check_type = _check_type
158
+ self._spec_property_naming = _spec_property_naming
159
+ self._path_to_item = _path_to_item
160
+ self._configuration = _configuration
161
+ self._visited_composed_classes = _visited_composed_classes + (self.__class__,)
162
+
163
+ for var_name, var_value in kwargs.items():
164
+ if var_name not in self.attribute_map and \
165
+ self._configuration is not None and \
166
+ self._configuration.discard_unknown_keys and \
167
+ self.additional_properties_type is None:
168
+ # discard variable.
169
+ continue
170
+ setattr(self, var_name, var_value)
@@ -30,6 +30,7 @@ from paasta_tools.paastaapi.model.inline_object import InlineObject
30
30
  from paasta_tools.paastaapi.model.inline_response200 import InlineResponse200
31
31
  from paasta_tools.paastaapi.model.inline_response2001 import InlineResponse2001
32
32
  from paasta_tools.paastaapi.model.inline_response202 import InlineResponse202
33
+ from paasta_tools.paastaapi.model.inline_response403 import InlineResponse403
33
34
  from paasta_tools.paastaapi.model.instance_bounce_status import InstanceBounceStatus
34
35
  from paasta_tools.paastaapi.model.instance_mesh_status import InstanceMeshStatus
35
36
  from paasta_tools.paastaapi.model.instance_status import InstanceStatus
@@ -135,6 +135,11 @@ def cwd(path):
135
135
  os.chdir(pwd)
136
136
 
137
137
 
138
+ def _force_str_to_int(value: str) -> int:
139
+ """Force convert strings into ints - even if they're technically floats."""
140
+ return int(float(value))
141
+
142
+
138
143
  def get_report_from_splunk(creds, app, filename, criteria_filter):
139
144
  """Expect a table containing at least the following fields:
140
145
  criteria (<service> kubernetes-<cluster_name> <instance>)
@@ -165,29 +170,87 @@ def get_report_from_splunk(creds, app, filename, criteria_filter):
165
170
  resp_text = [x for x in resp_text if x]
166
171
  resp_text = [json.loads(x) for x in resp_text]
167
172
  services_to_update = {}
173
+
168
174
  for d in resp_text:
169
175
  if "result" not in d:
170
176
  raise ValueError(f"Splunk request didn't return any results: {resp_text}")
171
177
  criteria = d["result"]["criteria"]
172
- serv = {}
173
- serv["service"] = criteria.split(" ")[0]
174
- serv["cluster"] = criteria.split(" ")[1]
175
- serv["instance"] = criteria.split(" ")[2]
176
- serv["owner"] = d["result"].get("service_owner", "Unavailable")
177
- serv["date"] = d["result"]["_time"].split(" ")[0]
178
- serv["money"] = d["result"].get("estimated_monthly_savings", 0)
179
- serv["project"] = d["result"].get("project", "Unavailable")
180
- serv["cpus"] = d["result"].get("suggested_cpus")
181
- serv["old_cpus"] = d["result"].get("current_cpus")
182
- serv["mem"] = d["result"].get("suggested_mem")
183
- serv["old_mem"] = d["result"].get("current_mem")
184
- serv["disk"] = d["result"].get("suggested_disk")
185
- serv["old_disk"] = d["result"].get("current_disk")
186
- serv["min_instances"] = d["result"].get("suggested_min_instances")
187
- serv["max_instances"] = d["result"].get("suggested_max_instances")
188
- serv["hacheck_cpus"] = d["result"].get("suggested_hacheck_cpus")
189
- serv["cpu_burst_add"] = d["result"].get("suggested_cpu_burst_add")
190
- services_to_update[criteria] = serv
178
+
179
+ serv = {
180
+ "cluster": criteria.split(" ")[1],
181
+ "date": d["result"]["_time"].split(" ")[0],
182
+ "instance": criteria.split(" ")[2],
183
+ "money": d["result"].get("estimated_monthly_savings", 0),
184
+ "owner": d["result"].get("service_owner", "Unavailable"),
185
+ "project": d["result"].get("project", "Unavailable"),
186
+ "service": criteria.split(" ")[0],
187
+ # only mergeable fields below
188
+ "cpu_burst_add": d["result"].get("suggested_cpu_burst_add"),
189
+ "cpus": d["result"].get("suggested_cpus"),
190
+ "disk": d["result"].get("suggested_disk"),
191
+ "hacheck_cpus": d["result"].get("suggested_hacheck_cpus"),
192
+ "max_instances": d["result"].get("suggested_max_instances"),
193
+ "mem": d["result"].get("suggested_mem"),
194
+ "min_instances": d["result"].get("suggested_min_instances"),
195
+ "old_cpus": d["result"].get("current_cpus"),
196
+ "old_disk": d["result"].get("current_disk"),
197
+ "old_mem": d["result"].get("current_mem"),
198
+ }
199
+
200
+ # the report we get is all strings, so we need to convert them to the right types
201
+ field_conversions = {
202
+ "current_cpus": float,
203
+ "suggested_cpu_burst_add": float,
204
+ "suggested_cpus": float,
205
+ "suggested_disk": int,
206
+ "suggested_hacheck_cpus": float,
207
+ "suggested_max_instances": int,
208
+ "suggested_mem": int,
209
+ "suggested_min_instances": int,
210
+ # not quite sure why these are floats...they're ints in soaconfigs
211
+ "current_disk": _force_str_to_int,
212
+ "current_mem": _force_str_to_int,
213
+ }
214
+
215
+ # merge results if we've already seen rows for this service
216
+ # NOTE: this is necessary since the Splunk search can return multiple rows
217
+ # for the same (service, cluster, instance) tuple as the autotune query
218
+ # treats certain cpu allocation changes as if the tuple was entirely different.
219
+ # this is ostensibly due to a theory that if you update resource allocation, existing
220
+ # autotune data is potentially invalidated - but in practice this ends up hampering
221
+ # autotune for services with highly variable resource allocation - e.g., we have some services
222
+ # that have their cpu allocation tweaked by +/-.1 cpu pretty frequently, but then min/max autotune
223
+ # is never updated.
224
+ if criteria in services_to_update:
225
+ for key in serv:
226
+ # we probably don't want to merge any other fields since they're going to be strings :p
227
+ if key not in field_conversions:
228
+ continue
229
+
230
+ last_proposed_suggestion = services_to_update[criteria][key]
231
+ proposed_suggestion = serv[key]
232
+
233
+ # if both are non-null, take the max of the two
234
+ if (
235
+ last_proposed_suggestion is not None
236
+ and proposed_suggestion is not None
237
+ ):
238
+ services_to_update[criteria][key] = max(
239
+ last_proposed_suggestion,
240
+ proposed_suggestion,
241
+ key=field_conversions[key],
242
+ )
243
+ # otherwise, if only one of these is non-null, use that one
244
+ elif last_proposed_suggestion is not None:
245
+ services_to_update[criteria][key] = last_proposed_suggestion
246
+ elif proposed_suggestion is not None:
247
+ services_to_update[criteria][key] = proposed_suggestion
248
+ # otherwise, if we didn't enter any of the above branches, we're essentially leaving in place the
249
+ # existing None
250
+
251
+ # otherwise, simply add the service to the final report
252
+ else:
253
+ services_to_update[criteria] = serv
191
254
 
192
255
  return {
193
256
  "search": search,
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: paasta-tools
3
- Version: 1.23.0
3
+ Version: 1.23.2
4
4
  Summary: Tools for Yelps SOA infrastructure
5
5
  Author: Compute Infrastructure @ Yelp
6
6
  Author-email: compute-infra@yelp.com
@@ -1,7 +1,7 @@
1
1
  k8s_itests/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
2
2
  k8s_itests/test_autoscaling.py,sha256=gX30L1wG1sDBaM0wE2aYR4OqHPSLvQBZ6LV0mLTrXZA,536
3
3
  k8s_itests/utils.py,sha256=PNibpYR0-g8Jcts9CjpkNb3oVzmdk9tZQrrNRuATCCM,966
4
- paasta_tools/__init__.py,sha256=KG4WCssbPvOuppkO5M6ybpBwC1U5jcsazBfNJBZ9pDc,865
4
+ paasta_tools/__init__.py,sha256=FNzecKTrL2alMs3c9piWPOBfwAl3bxachfSL1WRnUKQ,865
5
5
  paasta_tools/adhoc_tools.py,sha256=OfhyZwilB93kNX8r4Nq_KyZCvsZ4rNX-FBcQAi41KCM,4751
6
6
  paasta_tools/apply_external_resources.py,sha256=DHZJ8zkGQKTBR6Ku2lNxnrdHo8rD7PD0rZEN2yloOn8,3375
7
7
  paasta_tools/async_utils.py,sha256=ELB2qHP-F2IlMes-kxgy5q9PRUSUTZ-AKw5hQ2K0l_E,3514
@@ -43,7 +43,7 @@ paasta_tools/generate_services_yaml.py,sha256=BM760XGEOmLeJcEm0ez5nBZ2NmFJWsNXbZ
43
43
  paasta_tools/hacheck.py,sha256=GtQd32G4JoB2bOWqzH9h9NPrkg8a50i-iXAblfYz2p4,2748
44
44
  paasta_tools/iptables.py,sha256=SQ7hutHarfCd13oAknKv_h9rUuln4rf11W6C2HHUy9g,7518
45
45
  paasta_tools/kafkacluster_tools.py,sha256=NMfowdpYhFpXW55MKx_eX6rrQj5Fn-5M_9ryZKd749A,4992
46
- paasta_tools/kubernetes_tools.py,sha256=nHc1CdVMrGg3DJTdu49viog6cXdhQrgvFbqrZ-QZquA,180306
46
+ paasta_tools/kubernetes_tools.py,sha256=zR29IQMhBUei1B8W5Oo-XskN91kfbReMzW6JxL4I_0U,181094
47
47
  paasta_tools/list_kubernetes_service_instances.py,sha256=UEPiTqNxUAqUgSyPzJlNcrI2W4HBwpngzDM1QD6AAVQ,3910
48
48
  paasta_tools/list_tron_namespaces.py,sha256=wfSkPY9_C-RkORmnon3DWL2lVZ4GNSSDG9VkFrDfY1E,1679
49
49
  paasta_tools/long_running_service_tools.py,sha256=PE4K9opcx16tEc3XxWgQBKCpV4cJYS2JfN-dyTFhmB4,26137
@@ -85,7 +85,7 @@ paasta_tools/api/__init__.py,sha256=H0VmJeHyCSXD9GbiEjjQwcB_sKOcoBiyK-IEJMmtCyQ,
85
85
  paasta_tools/api/api.py,sha256=SwlBbwH9e8ihnBSSkLU65CHrnzyQeDHPfRg_ik5LWZU,9859
86
86
  paasta_tools/api/client.py,sha256=RwEeM0fiwdcEpJQQEocuhdEZVnMdh8QwRHTwbx3wFP8,3614
87
87
  paasta_tools/api/settings.py,sha256=UbRnHL2GKeRfzfQ4qdlDy2KapGR-GoGpXK0SzNXUeM4,1303
88
- paasta_tools/api/api_docs/swagger.json,sha256=iNQm2m0vtbZulS3JozcodUC7gvU9Mfqy16YLZ5P_s_g,89538
88
+ paasta_tools/api/api_docs/swagger.json,sha256=7VPnPUV4pnx9LdEXar6MYDx46xPvLzSxwlHRngybiiU,90166
89
89
  paasta_tools/api/tweens/__init__.py,sha256=nN1myeu8LuQKCDxz4XF9f55IDi13DSQgQ5e7OLP7DK8,144
90
90
  paasta_tools/api/tweens/auth.py,sha256=dran1Duk0tInhN_dutg-QgRcPfc5DADk5h7D2WVBPek,4197
91
91
  paasta_tools/api/tweens/profiling.py,sha256=prvrusCyDzP2j-64UCI-XGYxqDyyx8CDLKXl64oi-6M,3756
@@ -131,7 +131,7 @@ paasta_tools/cli/cmds/mark_for_deployment.py,sha256=mlb2BJECJnvbzAY7nTVly_kA5pNh
131
131
  paasta_tools/cli/cmds/mesh_status.py,sha256=PRhUVeDqURVm1RtiCH5Hcj7OUOqvkOTfa_JsCyCmyDg,6125
132
132
  paasta_tools/cli/cmds/pause_service_autoscaler.py,sha256=3Ie0wTkpRkl-Uja33WzWkPmBa5EJcPxMNAcZ8_P1LSo,3494
133
133
  paasta_tools/cli/cmds/push_to_registry.py,sha256=F7hWPY7MFtqznUfmJoQ0QPc5zAF5BS30_FWdQOrIqME,9736
134
- paasta_tools/cli/cmds/remote_run.py,sha256=ObyUzWtv3uipiU7344-7QASzsWov7r5qSfugkz-ePLo,10490
134
+ paasta_tools/cli/cmds/remote_run.py,sha256=q_yRO9hpacdrUdt98FRcKwxK62ROBxpcrUqesKBBo1A,11073
135
135
  paasta_tools/cli/cmds/rollback.py,sha256=_42IwJaCXzo8e_GRbjImeG-7_o4ZGUMqX6meLRXD10Y,13841
136
136
  paasta_tools/cli/cmds/secret.py,sha256=onVUKyh4uuxBHLcBQcMYH_1uBbRjJrnPa5nMwHGzDSk,19709
137
137
  paasta_tools/cli/cmds/security_check.py,sha256=IEtcM0Hv2BWcavCjWcnPbyfrLcCRYC8jHLiHDj020z4,2377
@@ -174,7 +174,7 @@ paasta_tools/contrib/is_pod_healthy_in_smartstack.py,sha256=CWNIiwm-1FpXT5hpmZFA
174
174
  paasta_tools/contrib/kill_bad_containers.py,sha256=DVpemHWcH_gxlXK_9KS5pGOLbgbpwqN04lx1qyC0_Yk,3861
175
175
  paasta_tools/contrib/mass-deploy-tag.sh,sha256=cfPgDDvAOhy3ijTUocklogzoIY8hfoE6T5QI-0aqcfM,1578
176
176
  paasta_tools/contrib/mock_patch_checker.py,sha256=Y_kpCYrfxhkdMTf8KTvObtwD9hk1Cre9xhYMS5JxxEg,2575
177
- paasta_tools/contrib/paasta_update_soa_memcpu.py,sha256=nCVY7q6oiplRwxHXHXGo2qPbp0y2jKHdH9mK-bEefj0,17885
177
+ paasta_tools/contrib/paasta_update_soa_memcpu.py,sha256=RTFlg1VNJqj0etKLcQPuhlNfuZjbQuXiF2slKOvCXFw,20827
178
178
  paasta_tools/contrib/render_template.py,sha256=NWMFcWJ4ddV6rQsTVsINYhyVUh9kheR2Rtam-LJ5IsY,3991
179
179
  paasta_tools/contrib/rightsizer_soaconfigs_update.py,sha256=0UPVtDyX6wXXurv7l5fiKuzXH8VEszKx_V7UqDm6Ck0,10493
180
180
  paasta_tools/contrib/service_shard_remove.py,sha256=WCvCxu3GTYEa3cYnWybTOiuHN14axj0x5_-snVd-mqE,4927
@@ -227,7 +227,7 @@ paasta_tools/paastaapi/rest.py,sha256=jSS2J2DRpNLtkK98EDgQcMO1MkTocTP244_rzeuXvQ
227
227
  paasta_tools/paastaapi/api/__init__.py,sha256=HkTSCN0zRGu6mtrPDQmdoPrrVzam8A-ljnGL6Ys3GOE,229
228
228
  paasta_tools/paastaapi/api/autoscaler_api.py,sha256=0lTQ6JBTmt_HJ7x2EM03r1NESxlZJ5sJSRBNgGQ1toQ,15912
229
229
  paasta_tools/paastaapi/api/default_api.py,sha256=Kl6pqZNzydLVC-MVZYGjXzXcHI69RTSHvcX9FqnWQoU,20369
230
- paasta_tools/paastaapi/api/remote_run_api.py,sha256=MdnmIFSsvj501_vgaNIkVKidLpmTBtpyc9Op-3tJwFk,21409
230
+ paasta_tools/paastaapi/api/remote_run_api.py,sha256=9TOzmPAlxt-19s1qGJ3PcLDWU4OJvxJKO_R6h3foYRs,21487
231
231
  paasta_tools/paastaapi/api/resources_api.py,sha256=jctcU5rMlUTza0f3zHnfl1B469amc1t6ahB5xI__fbc,5468
232
232
  paasta_tools/paastaapi/api/service_api.py,sha256=83HBVYbwzbbkh4AF4-wIgPEYMm_5jt9iOfOF_jYUhUs,63600
233
233
  paasta_tools/paastaapi/apis/__init__.py,sha256=1Q2S7uGtbgDu6a4-c3xx5Ei9JM1YIzctM5dZ5k0tGeA,760
@@ -251,6 +251,7 @@ paasta_tools/paastaapi/model/inline_object.py,sha256=KZyF22Vv0oDJJkeZwozhjbgFgoQ
251
251
  paasta_tools/paastaapi/model/inline_response200.py,sha256=5t4-jtpWG0zWSSrqZTpckgS1jqdBYHRGJqelpDwcolY,6691
252
252
  paasta_tools/paastaapi/model/inline_response2001.py,sha256=B83DDjFDB-fK8T9xK58mJFvsE4_QKiL6WgZjXZiROqA,6579
253
253
  paasta_tools/paastaapi/model/inline_response202.py,sha256=ZngMZ_GHBmgx6gVuPlr1WZmn3ymCRSEG7_iePMmvmA0,7327
254
+ paasta_tools/paastaapi/model/inline_response403.py,sha256=hSSH9PK14JotxIAuQqeY_lxAZkP-KLGNRvv0mhQpyOs,6561
254
255
  paasta_tools/paastaapi/model/instance_bounce_status.py,sha256=pWoHZtKd_bx0crlL6IgFqE6w22Ke5MYPvOmD8C0MDRU,8444
255
256
  paasta_tools/paastaapi/model/instance_mesh_status.py,sha256=2DHz4ToNM2b12e0U1oHzySPHAv1GeWrqRnuA-djAoWo,7357
256
257
  paasta_tools/paastaapi/model/instance_status.py,sha256=iO2RCfNd93muqRyEk8porhch97ykKZDMy3zMhIn6MEA,9761
@@ -283,68 +284,68 @@ paasta_tools/paastaapi/model/smartstack_backend.py,sha256=jC12hYMur2Iw8hyKVOWlxS
283
284
  paasta_tools/paastaapi/model/smartstack_location.py,sha256=a39BeS49HyGup_15EgKiyuCxSepocPwi5IElGF2vlt8,7241
284
285
  paasta_tools/paastaapi/model/smartstack_status.py,sha256=3CJKc3IfNYhg0mPJQ4mqIMo2KgTYuzLfvHcQ53iCT8Y,7325
285
286
  paasta_tools/paastaapi/model/task_tail_lines.py,sha256=ogrAad-WAEhf3Eq23crg_KzB-yanpxzE9hK23tOTLY8,7025
286
- paasta_tools/paastaapi/models/__init__.py,sha256=FtiAxdFp7ivblYQcumIayzGJD5gTIjktkUemNG9IBVk,4390
287
+ paasta_tools/paastaapi/models/__init__.py,sha256=3C_qYCHZTvHDm_EbE7LChAsbNHJelnopju_jZZf_tCo,4468
287
288
  paasta_tools/secret_providers/__init__.py,sha256=N6kEw3uvY3fxQZgAtR58-lWGQOKfrsHOrc9SYzXd2uQ,1975
288
289
  paasta_tools/secret_providers/vault.py,sha256=3vQGKMAgBPKawU6hNw4wPtYxYrNe7iN3tx66TSxAXEA,7517
289
290
  paasta_tools/tron/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
290
291
  paasta_tools/tron/client.py,sha256=ypWjM4bZCzQWLn-qe1driqAxvF0ux8dROuFUv63dryA,5562
291
292
  paasta_tools/tron/tron_command_context.py,sha256=c6mph_DAt7pjcE3Uo271haJ0DfxJzfvcRhR2o-UmOeY,5379
292
293
  paasta_tools/tron/tron_timeutils.py,sha256=vDn04K7A3Xbs3lM04EgLuViC8AavOc5qyo8J5MC5nLk,3054
293
- paasta_tools-1.23.0.data/scripts/apply_external_resources.py,sha256=BOIdCQ5Md9RI3enzqbIWQge3clkXhPybAmLE3hqfDwQ,3347
294
- paasta_tools-1.23.0.data/scripts/bounce_log_latency_parser.py,sha256=dC06a0a5LdtPJ8xo88QWe5DMH_vwVB1BNbkFH7kJ3j0,2225
295
- paasta_tools-1.23.0.data/scripts/check_autoscaler_max_instances.py,sha256=2z6ifSU26-ULOK-FXp75b45mCdjSJnuvU8TxvapB8Wk,9423
296
- paasta_tools-1.23.0.data/scripts/check_cassandracluster_services_replication.py,sha256=mKlCK9pRNzxnOt41wA6CtDQIHhcky438i044kA6pbEc,1127
297
- paasta_tools-1.23.0.data/scripts/check_flink_services_health.py,sha256=ElYa1hr6KUcXuu0B8Nf-dt2Vfyo5FrwF5gVV4QBX7Lg,7162
298
- paasta_tools-1.23.0.data/scripts/check_kubernetes_api.py,sha256=BhOqJkkKNJPfonfIPonW5dlIubd1ji-3ppjXHomNwzM,1522
299
- paasta_tools-1.23.0.data/scripts/check_kubernetes_services_replication.py,sha256=LCLlumReRdy9Cw_sPpqanjPcBlbcrJDiECaYYru5Cwk,5751
300
- paasta_tools-1.23.0.data/scripts/check_manual_oapi_changes.sh,sha256=1IdphwXP7xnMNS7huZ3FeEHy67-nY4n3ydHmbojQvJg,879
301
- paasta_tools-1.23.0.data/scripts/check_oom_events.py,sha256=tUr14T2LYEgqwpAq4vkZ_Z0VTPOfQg7yrSSkwGQ86Hg,7801
302
- paasta_tools-1.23.0.data/scripts/check_orphans.py,sha256=zVC5ShFY7LUnPDUytRNsMgvqXkECHvyZlc3qZMpxLko,9985
303
- paasta_tools-1.23.0.data/scripts/check_spark_jobs.py,sha256=pVUdWmZSBuh4CbpW7cZ1Loq8FX0QFS0LQk2b24TGRyE,7317
304
- paasta_tools-1.23.0.data/scripts/cleanup_kubernetes_cr.py,sha256=m-w_wuTuVG9FlwQQkxXYgri5DTGac9Nc2pbK4k1FNDE,4659
305
- paasta_tools-1.23.0.data/scripts/cleanup_kubernetes_crd.py,sha256=p9eLk-0-pU-hcVg-GAM92h1ZdQqlvmYhBzUFCiMPYR8,4478
306
- paasta_tools-1.23.0.data/scripts/cleanup_kubernetes_jobs.py,sha256=7LHB4tsz1kt-zygssIfQbBY6c3LSqXYDUILvHkSfBog,12433
307
- paasta_tools-1.23.0.data/scripts/create_dynamodb_table.py,sha256=9wJftWGgNtvLnpXeUqpoMXBIIep1hNySf0YiQmzpl5c,1167
308
- paasta_tools-1.23.0.data/scripts/create_paasta_playground.py,sha256=jzoE5e1pxWeVXwCEkD9O0jefOhEnIlSa3QMP9PC2f0M,3239
309
- paasta_tools-1.23.0.data/scripts/delete_kubernetes_deployments.py,sha256=de4C-5yqEuCeJXp6zhbc0v-c0LOElr4qabLnOTRcX4o,3124
310
- paasta_tools-1.23.0.data/scripts/emit_allocated_cpu_metrics.py,sha256=Cjd3xoOJoYSP3ciSAlZ7fh6_z678KpYt43Xh-WVCY1M,1859
311
- paasta_tools-1.23.0.data/scripts/generate_all_deployments,sha256=Qr5B0zogTOr8Lcn_7dpORixpGIJcXZ_pWz_ZlWnmsik,248
312
- paasta_tools-1.23.0.data/scripts/generate_authenticating_services.py,sha256=r5AQyquVm8_rbAhBETUU2ZHZvolpqZZTakW3lKFiOqw,2982
313
- paasta_tools-1.23.0.data/scripts/generate_deployments_for_service.py,sha256=FAFzIAtKY7GsA13s-ssCMH7T-_p9B1pBtyyYFzsCZ6k,9822
314
- paasta_tools-1.23.0.data/scripts/generate_services_file.py,sha256=w3Wyyn9ZkjfrvkT0SnTbh5mrTZJnjhTC2JIqLBpb6-g,3583
315
- paasta_tools-1.23.0.data/scripts/generate_services_yaml.py,sha256=XyIUsHa1BPLqeklayaFewX69-6GT_luaSLS_TMDLkQ0,991
316
- paasta_tools-1.23.0.data/scripts/get_running_task_allocation.py,sha256=rV2IFGWU2sEYAVDCwKZgeseOAewFzfDiFeCnsPXdGXY,10890
317
- paasta_tools-1.23.0.data/scripts/habitat_fixer.py,sha256=hCC7fEnxrBOmiCJj4rPwhGlae9JsYg_gltk10l-FwaE,2625
318
- paasta_tools-1.23.0.data/scripts/ide_helper.py,sha256=YxHHqbnrJ88XI9Pmlup2QSvp15qVN5ugLuPYkEsmBCw,12334
319
- paasta_tools-1.23.0.data/scripts/is_pod_healthy_in_proxy.py,sha256=MiY85MJDXcN9oS8d840WG1iYDIzzO9lmk_NC0i_CrQg,4321
320
- paasta_tools-1.23.0.data/scripts/is_pod_healthy_in_smartstack.py,sha256=z3uP9sgwLwg94BubFgBKare2t1L5qhcY48MWsJxjxPY,1697
321
- paasta_tools-1.23.0.data/scripts/kill_bad_containers.py,sha256=oNY5x0Zg0eu34cXhFy60I7WRlqg4PKD_6xWi0eoRTCA,3832
322
- paasta_tools-1.23.0.data/scripts/kubernetes_remove_evicted_pods.py,sha256=D9Ovdc9Xer_Qf3vM5CtPVcKvnMwLiC0H-WQmQGXrBKM,5274
323
- paasta_tools-1.23.0.data/scripts/mass-deploy-tag.sh,sha256=cfPgDDvAOhy3ijTUocklogzoIY8hfoE6T5QI-0aqcfM,1578
324
- paasta_tools-1.23.0.data/scripts/mock_patch_checker.py,sha256=Q6Je8QjmfLzdnv_6JR6ehh2kA5SUxmeZGeLI2WC3BSY,2559
325
- paasta_tools-1.23.0.data/scripts/paasta_cleanup_remote_run_resources.py,sha256=4oN9UwnR7q6aEEyFUhVrT41VSeQJ2YS3upFpbZQXNUI,4558
326
- paasta_tools-1.23.0.data/scripts/paasta_cleanup_stale_nodes.py,sha256=C-DmEVgtienoMgJnIeESvFqWcJOW2SOGoS1l8RXA8NE,6304
327
- paasta_tools-1.23.0.data/scripts/paasta_deploy_tron_jobs,sha256=fFN2aP5FNSm5WfDV3yvLpihXaKkAF65MRXFcN2iD7S4,106
328
- paasta_tools-1.23.0.data/scripts/paasta_execute_docker_command.py,sha256=6kh7h2bleQbNULc37MiRsfnk9MDHqVv30UQdg3rF3kQ,4086
329
- paasta_tools-1.23.0.data/scripts/paasta_secrets_sync.py,sha256=sMdyWMt9BU5CmWHIRwzhpFKve7zxFHkygt_SNTJutWM,28766
330
- paasta_tools-1.23.0.data/scripts/paasta_tabcomplete.sh,sha256=qbQKSriz_L4MogA12L_8i-tg0Lplpshbk_FUMjK6uG0,929
331
- paasta_tools-1.23.0.data/scripts/paasta_update_soa_memcpu.py,sha256=1LOHMb4Gp3DcfkOzdCr9rcLa4mZXIv1p93sFvt7h96s,17871
332
- paasta_tools-1.23.0.data/scripts/render_template.py,sha256=KcKfeSP2a9f6fMDRhnjX7OJaHmFIBtCJcHhUI_B7p9Y,3975
333
- paasta_tools-1.23.0.data/scripts/rightsizer_soaconfigs_update.py,sha256=0UPVtDyX6wXXurv7l5fiKuzXH8VEszKx_V7UqDm6Ck0,10493
334
- paasta_tools-1.23.0.data/scripts/service_shard_remove.py,sha256=WCvCxu3GTYEa3cYnWybTOiuHN14axj0x5_-snVd-mqE,4927
335
- paasta_tools-1.23.0.data/scripts/service_shard_update.py,sha256=AajuRS4s-HXhEcIIYK2dsyBSdCjZbh4x6Po48ipl7M4,13346
336
- paasta_tools-1.23.0.data/scripts/setup_istio_mesh.py,sha256=LbLxeI_DnhNXkyCgG-GxutlNu9_vcIitorYr4I9x4CY,11575
337
- paasta_tools-1.23.0.data/scripts/setup_kubernetes_cr.py,sha256=8Jj362SLgoR6k0ZwzZ4bkJc3RJrxk-f2dpHD5zJXCuo,14625
338
- paasta_tools-1.23.0.data/scripts/setup_kubernetes_crd.py,sha256=QCiFOcSmE0nMEheIb7IUnYMUn0heh1kHyMFBCm7XIRU,4020
339
- paasta_tools-1.23.0.data/scripts/setup_kubernetes_internal_crd.py,sha256=dDyAOKFow7yeHWGa197angYwGTDWNyR7vZ6Cx5JlS6k,4629
340
- paasta_tools-1.23.0.data/scripts/setup_kubernetes_job.py,sha256=iGuGjDoevjpmdV3SXnAg65AwljkqC_c5yzTVvEsJ1xc,16929
341
- paasta_tools-1.23.0.data/scripts/setup_prometheus_adapter_config.py,sha256=51iFbtMu7MZzv9PVuQftJ59BUVBKdeC7G_zkt9-IXdc,40728
342
- paasta_tools-1.23.0.data/scripts/shared_ip_check.py,sha256=dbMwCwDLy9hCIbVWV1rk0FKuBkZNuQtM59hGVKxV2B4,2464
343
- paasta_tools-1.23.0.data/scripts/synapse_srv_namespaces_fact.py,sha256=HFX0zIXkXIjtAw8zrA7mUiy6NOKR11eBzE39R3aZv_E,1408
344
- paasta_tools-1.23.0.data/scripts/timeouts_metrics_prom.py,sha256=icK1j72-e-hvbUGs3LtcaMn9KBMopD9cGv5UUVo-OSc,2607
345
- paasta_tools-1.23.0.dist-info/LICENSE,sha256=Tcxn8PpeSjHDwUTemLW_thUNxcOOm612dK_no2ebEpo,10837
346
- paasta_tools-1.23.0.dist-info/METADATA,sha256=jZNNw1kpj4efbBRI8LMsnccK_WkaGsH6AEsLguueLpw,2169
347
- paasta_tools-1.23.0.dist-info/WHEEL,sha256=iAkIy5fosb7FzIOwONchHf19Qu7_1wCWyFNR5gu9nU0,91
348
- paasta_tools-1.23.0.dist-info/entry_points.txt,sha256=5osYZ62iLdhb63d3P8e9ujafe97kisiB3K-geR5IdH8,1076
349
- paasta_tools-1.23.0.dist-info/top_level.txt,sha256=6vZZAZ7bbaDxuXZjNYixDwzkrezpNgDQHpS0ikvFOk4,24
350
- paasta_tools-1.23.0.dist-info/RECORD,,
294
+ paasta_tools-1.23.2.data/scripts/apply_external_resources.py,sha256=BOIdCQ5Md9RI3enzqbIWQge3clkXhPybAmLE3hqfDwQ,3347
295
+ paasta_tools-1.23.2.data/scripts/bounce_log_latency_parser.py,sha256=dC06a0a5LdtPJ8xo88QWe5DMH_vwVB1BNbkFH7kJ3j0,2225
296
+ paasta_tools-1.23.2.data/scripts/check_autoscaler_max_instances.py,sha256=2z6ifSU26-ULOK-FXp75b45mCdjSJnuvU8TxvapB8Wk,9423
297
+ paasta_tools-1.23.2.data/scripts/check_cassandracluster_services_replication.py,sha256=mKlCK9pRNzxnOt41wA6CtDQIHhcky438i044kA6pbEc,1127
298
+ paasta_tools-1.23.2.data/scripts/check_flink_services_health.py,sha256=ElYa1hr6KUcXuu0B8Nf-dt2Vfyo5FrwF5gVV4QBX7Lg,7162
299
+ paasta_tools-1.23.2.data/scripts/check_kubernetes_api.py,sha256=BhOqJkkKNJPfonfIPonW5dlIubd1ji-3ppjXHomNwzM,1522
300
+ paasta_tools-1.23.2.data/scripts/check_kubernetes_services_replication.py,sha256=LCLlumReRdy9Cw_sPpqanjPcBlbcrJDiECaYYru5Cwk,5751
301
+ paasta_tools-1.23.2.data/scripts/check_manual_oapi_changes.sh,sha256=1IdphwXP7xnMNS7huZ3FeEHy67-nY4n3ydHmbojQvJg,879
302
+ paasta_tools-1.23.2.data/scripts/check_oom_events.py,sha256=tUr14T2LYEgqwpAq4vkZ_Z0VTPOfQg7yrSSkwGQ86Hg,7801
303
+ paasta_tools-1.23.2.data/scripts/check_orphans.py,sha256=zVC5ShFY7LUnPDUytRNsMgvqXkECHvyZlc3qZMpxLko,9985
304
+ paasta_tools-1.23.2.data/scripts/check_spark_jobs.py,sha256=pVUdWmZSBuh4CbpW7cZ1Loq8FX0QFS0LQk2b24TGRyE,7317
305
+ paasta_tools-1.23.2.data/scripts/cleanup_kubernetes_cr.py,sha256=m-w_wuTuVG9FlwQQkxXYgri5DTGac9Nc2pbK4k1FNDE,4659
306
+ paasta_tools-1.23.2.data/scripts/cleanup_kubernetes_crd.py,sha256=p9eLk-0-pU-hcVg-GAM92h1ZdQqlvmYhBzUFCiMPYR8,4478
307
+ paasta_tools-1.23.2.data/scripts/cleanup_kubernetes_jobs.py,sha256=7LHB4tsz1kt-zygssIfQbBY6c3LSqXYDUILvHkSfBog,12433
308
+ paasta_tools-1.23.2.data/scripts/create_dynamodb_table.py,sha256=9wJftWGgNtvLnpXeUqpoMXBIIep1hNySf0YiQmzpl5c,1167
309
+ paasta_tools-1.23.2.data/scripts/create_paasta_playground.py,sha256=jzoE5e1pxWeVXwCEkD9O0jefOhEnIlSa3QMP9PC2f0M,3239
310
+ paasta_tools-1.23.2.data/scripts/delete_kubernetes_deployments.py,sha256=de4C-5yqEuCeJXp6zhbc0v-c0LOElr4qabLnOTRcX4o,3124
311
+ paasta_tools-1.23.2.data/scripts/emit_allocated_cpu_metrics.py,sha256=Cjd3xoOJoYSP3ciSAlZ7fh6_z678KpYt43Xh-WVCY1M,1859
312
+ paasta_tools-1.23.2.data/scripts/generate_all_deployments,sha256=Qr5B0zogTOr8Lcn_7dpORixpGIJcXZ_pWz_ZlWnmsik,248
313
+ paasta_tools-1.23.2.data/scripts/generate_authenticating_services.py,sha256=r5AQyquVm8_rbAhBETUU2ZHZvolpqZZTakW3lKFiOqw,2982
314
+ paasta_tools-1.23.2.data/scripts/generate_deployments_for_service.py,sha256=FAFzIAtKY7GsA13s-ssCMH7T-_p9B1pBtyyYFzsCZ6k,9822
315
+ paasta_tools-1.23.2.data/scripts/generate_services_file.py,sha256=w3Wyyn9ZkjfrvkT0SnTbh5mrTZJnjhTC2JIqLBpb6-g,3583
316
+ paasta_tools-1.23.2.data/scripts/generate_services_yaml.py,sha256=XyIUsHa1BPLqeklayaFewX69-6GT_luaSLS_TMDLkQ0,991
317
+ paasta_tools-1.23.2.data/scripts/get_running_task_allocation.py,sha256=rV2IFGWU2sEYAVDCwKZgeseOAewFzfDiFeCnsPXdGXY,10890
318
+ paasta_tools-1.23.2.data/scripts/habitat_fixer.py,sha256=hCC7fEnxrBOmiCJj4rPwhGlae9JsYg_gltk10l-FwaE,2625
319
+ paasta_tools-1.23.2.data/scripts/ide_helper.py,sha256=YxHHqbnrJ88XI9Pmlup2QSvp15qVN5ugLuPYkEsmBCw,12334
320
+ paasta_tools-1.23.2.data/scripts/is_pod_healthy_in_proxy.py,sha256=MiY85MJDXcN9oS8d840WG1iYDIzzO9lmk_NC0i_CrQg,4321
321
+ paasta_tools-1.23.2.data/scripts/is_pod_healthy_in_smartstack.py,sha256=z3uP9sgwLwg94BubFgBKare2t1L5qhcY48MWsJxjxPY,1697
322
+ paasta_tools-1.23.2.data/scripts/kill_bad_containers.py,sha256=oNY5x0Zg0eu34cXhFy60I7WRlqg4PKD_6xWi0eoRTCA,3832
323
+ paasta_tools-1.23.2.data/scripts/kubernetes_remove_evicted_pods.py,sha256=D9Ovdc9Xer_Qf3vM5CtPVcKvnMwLiC0H-WQmQGXrBKM,5274
324
+ paasta_tools-1.23.2.data/scripts/mass-deploy-tag.sh,sha256=cfPgDDvAOhy3ijTUocklogzoIY8hfoE6T5QI-0aqcfM,1578
325
+ paasta_tools-1.23.2.data/scripts/mock_patch_checker.py,sha256=Q6Je8QjmfLzdnv_6JR6ehh2kA5SUxmeZGeLI2WC3BSY,2559
326
+ paasta_tools-1.23.2.data/scripts/paasta_cleanup_remote_run_resources.py,sha256=4oN9UwnR7q6aEEyFUhVrT41VSeQJ2YS3upFpbZQXNUI,4558
327
+ paasta_tools-1.23.2.data/scripts/paasta_cleanup_stale_nodes.py,sha256=C-DmEVgtienoMgJnIeESvFqWcJOW2SOGoS1l8RXA8NE,6304
328
+ paasta_tools-1.23.2.data/scripts/paasta_deploy_tron_jobs,sha256=fFN2aP5FNSm5WfDV3yvLpihXaKkAF65MRXFcN2iD7S4,106
329
+ paasta_tools-1.23.2.data/scripts/paasta_execute_docker_command.py,sha256=6kh7h2bleQbNULc37MiRsfnk9MDHqVv30UQdg3rF3kQ,4086
330
+ paasta_tools-1.23.2.data/scripts/paasta_secrets_sync.py,sha256=sMdyWMt9BU5CmWHIRwzhpFKve7zxFHkygt_SNTJutWM,28766
331
+ paasta_tools-1.23.2.data/scripts/paasta_tabcomplete.sh,sha256=qbQKSriz_L4MogA12L_8i-tg0Lplpshbk_FUMjK6uG0,929
332
+ paasta_tools-1.23.2.data/scripts/paasta_update_soa_memcpu.py,sha256=5fShpZYpb7EeoC70cWdICnNHjHAaNU5mTHaAc3mloIs,20813
333
+ paasta_tools-1.23.2.data/scripts/render_template.py,sha256=KcKfeSP2a9f6fMDRhnjX7OJaHmFIBtCJcHhUI_B7p9Y,3975
334
+ paasta_tools-1.23.2.data/scripts/rightsizer_soaconfigs_update.py,sha256=0UPVtDyX6wXXurv7l5fiKuzXH8VEszKx_V7UqDm6Ck0,10493
335
+ paasta_tools-1.23.2.data/scripts/service_shard_remove.py,sha256=WCvCxu3GTYEa3cYnWybTOiuHN14axj0x5_-snVd-mqE,4927
336
+ paasta_tools-1.23.2.data/scripts/service_shard_update.py,sha256=AajuRS4s-HXhEcIIYK2dsyBSdCjZbh4x6Po48ipl7M4,13346
337
+ paasta_tools-1.23.2.data/scripts/setup_istio_mesh.py,sha256=LbLxeI_DnhNXkyCgG-GxutlNu9_vcIitorYr4I9x4CY,11575
338
+ paasta_tools-1.23.2.data/scripts/setup_kubernetes_cr.py,sha256=8Jj362SLgoR6k0ZwzZ4bkJc3RJrxk-f2dpHD5zJXCuo,14625
339
+ paasta_tools-1.23.2.data/scripts/setup_kubernetes_crd.py,sha256=QCiFOcSmE0nMEheIb7IUnYMUn0heh1kHyMFBCm7XIRU,4020
340
+ paasta_tools-1.23.2.data/scripts/setup_kubernetes_internal_crd.py,sha256=dDyAOKFow7yeHWGa197angYwGTDWNyR7vZ6Cx5JlS6k,4629
341
+ paasta_tools-1.23.2.data/scripts/setup_kubernetes_job.py,sha256=iGuGjDoevjpmdV3SXnAg65AwljkqC_c5yzTVvEsJ1xc,16929
342
+ paasta_tools-1.23.2.data/scripts/setup_prometheus_adapter_config.py,sha256=51iFbtMu7MZzv9PVuQftJ59BUVBKdeC7G_zkt9-IXdc,40728
343
+ paasta_tools-1.23.2.data/scripts/shared_ip_check.py,sha256=dbMwCwDLy9hCIbVWV1rk0FKuBkZNuQtM59hGVKxV2B4,2464
344
+ paasta_tools-1.23.2.data/scripts/synapse_srv_namespaces_fact.py,sha256=HFX0zIXkXIjtAw8zrA7mUiy6NOKR11eBzE39R3aZv_E,1408
345
+ paasta_tools-1.23.2.data/scripts/timeouts_metrics_prom.py,sha256=icK1j72-e-hvbUGs3LtcaMn9KBMopD9cGv5UUVo-OSc,2607
346
+ paasta_tools-1.23.2.dist-info/LICENSE,sha256=Tcxn8PpeSjHDwUTemLW_thUNxcOOm612dK_no2ebEpo,10837
347
+ paasta_tools-1.23.2.dist-info/METADATA,sha256=8ssTMi7oQLfMckK0YE5GeGER2naRsQK_n5FtSqk1b4M,2169
348
+ paasta_tools-1.23.2.dist-info/WHEEL,sha256=iAkIy5fosb7FzIOwONchHf19Qu7_1wCWyFNR5gu9nU0,91
349
+ paasta_tools-1.23.2.dist-info/entry_points.txt,sha256=5osYZ62iLdhb63d3P8e9ujafe97kisiB3K-geR5IdH8,1076
350
+ paasta_tools-1.23.2.dist-info/top_level.txt,sha256=6vZZAZ7bbaDxuXZjNYixDwzkrezpNgDQHpS0ikvFOk4,24
351
+ paasta_tools-1.23.2.dist-info/RECORD,,