moto/moto/emrcontainers/responses.py
2021-11-01 09:36:38 -01:00

136 lines
5.0 KiB
Python

"""Handles incoming emrcontainers requests, invokes methods, returns responses."""
import json
from moto.core.responses import BaseResponse
from .models import emrcontainers_backends
DEFAULT_MAX_RESULTS = 100
DEFAULT_NEXT_TOKEN = ""
DEFAULT_CONTAINER_PROVIDER_TYPE = "EKS"
class EMRContainersResponse(BaseResponse):
"""Handler for EMRContainers requests and responses."""
SERVICE_NAME = "emr-containers"
@property
def emrcontainers_backend(self):
"""Return backend instance specific for this region."""
return emrcontainers_backends[self.region]
def create_virtual_cluster(self):
name = self._get_param("name")
container_provider = self._get_param("containerProvider")
client_token = self._get_param("clientToken")
tags = self._get_param("tags")
virtual_cluster = self.emrcontainers_backend.create_virtual_cluster(
name=name,
container_provider=container_provider,
client_token=client_token,
tags=tags,
)
return 200, {}, json.dumps(dict(virtual_cluster))
def delete_virtual_cluster(self):
id = self._get_param("virtualClusterId")
virtual_cluster = self.emrcontainers_backend.delete_virtual_cluster(id=id)
return 200, {}, json.dumps(dict(virtual_cluster))
def describe_virtual_cluster(self):
id = self._get_param("virtualClusterId")
virtual_cluster = self.emrcontainers_backend.describe_virtual_cluster(id=id)
response = {"virtualCluster": virtual_cluster}
return 200, {}, json.dumps(response)
def list_virtual_clusters(self):
container_provider_id = self._get_param("containerProviderId")
container_provider_type = self._get_param(
"containerProviderType", DEFAULT_CONTAINER_PROVIDER_TYPE
)
created_after = self._get_param("createdAfter")
created_before = self._get_param("createdBefore")
states = self.querystring.get("states", [])
max_results = self._get_int_param("maxResults", DEFAULT_MAX_RESULTS)
next_token = self._get_param("nextToken", DEFAULT_NEXT_TOKEN)
virtual_clusters, next_token = self.emrcontainers_backend.list_virtual_clusters(
container_provider_id=container_provider_id,
container_provider_type=container_provider_type,
created_after=created_after,
created_before=created_before,
states=states,
max_results=max_results,
next_token=next_token,
)
response = {"virtualClusters": virtual_clusters, "nextToken": next_token}
return 200, {}, json.dumps(response)
def start_job_run(self):
name = self._get_param("name")
virtual_cluster_id = self._get_param("virtualClusterId")
client_token = self._get_param("clientToken")
execution_role_arn = self._get_param("executionRoleArn")
release_label = self._get_param("releaseLabel")
job_driver = self._get_param("jobDriver")
configuration_overrides = self._get_param("configurationOverrides")
tags = self._get_param("tags")
job = self.emrcontainers_backend.start_job_run(
name=name,
virtual_cluster_id=virtual_cluster_id,
client_token=client_token,
execution_role_arn=execution_role_arn,
release_label=release_label,
job_driver=job_driver,
configuration_overrides=configuration_overrides,
tags=tags,
)
return 200, {}, json.dumps(dict(job))
def cancel_job_run(self):
id = self._get_param("jobRunId")
virtual_cluster_id = self._get_param("virtualClusterId")
job = self.emrcontainers_backend.cancel_job_run(
id=id, virtual_cluster_id=virtual_cluster_id,
)
return 200, {}, json.dumps(dict(job))
def list_job_runs(self):
virtual_cluster_id = self._get_param("virtualClusterId")
created_before = self._get_param("createdBefore")
created_after = self._get_param("createdAfter")
name = self._get_param("name")
states = self.querystring.get("states", [])
max_results = self._get_int_param("maxResults", DEFAULT_MAX_RESULTS)
next_token = self._get_param("nextToken", DEFAULT_NEXT_TOKEN)
job_runs, next_token = self.emrcontainers_backend.list_job_runs(
virtual_cluster_id=virtual_cluster_id,
created_before=created_before,
created_after=created_after,
name=name,
states=states,
max_results=max_results,
next_token=next_token,
)
response = {"jobRuns": job_runs, "nextToken": next_token}
return 200, {}, json.dumps(response)
def describe_job_run(self):
id = self._get_param("jobRunId")
virtual_cluster_id = self._get_param("virtualClusterId")
job_run = self.emrcontainers_backend.describe_job_run(
id=id, virtual_cluster_id=virtual_cluster_id,
)
response = {"jobRun": job_run}
return 200, {}, json.dumps(response)