2016-02-12 19:39:20 +00:00
|
|
|
import json
|
|
|
|
|
2017-09-13 19:00:39 +00:00
|
|
|
try:
|
|
|
|
from urllib import unquote
|
2017-12-08 21:02:34 +00:00
|
|
|
except ImportError:
|
2017-11-26 21:28:28 +00:00
|
|
|
from urllib.parse import unquote
|
2017-09-13 19:00:39 +00:00
|
|
|
|
2018-09-06 22:15:27 +00:00
|
|
|
from moto.core.utils import amz_crc32, amzn_request_id, path_url
|
2016-02-12 19:39:20 +00:00
|
|
|
from moto.core.responses import BaseResponse
|
2017-11-26 21:28:28 +00:00
|
|
|
from .models import lambda_backends
|
2016-02-12 19:39:20 +00:00
|
|
|
|
|
|
|
|
|
|
|
class LambdaResponse(BaseResponse):
|
2017-11-26 21:28:28 +00:00
|
|
|
@property
|
|
|
|
def json_body(self):
|
|
|
|
"""
|
|
|
|
:return: JSON
|
|
|
|
:rtype: dict
|
|
|
|
"""
|
|
|
|
return json.loads(self.body)
|
|
|
|
|
|
|
|
@property
|
|
|
|
def lambda_backend(self):
|
|
|
|
"""
|
|
|
|
Get backend
|
|
|
|
:return: Lambda Backend
|
|
|
|
:rtype: moto.awslambda.models.LambdaBackend
|
|
|
|
"""
|
|
|
|
return lambda_backends[self.region]
|
2017-02-16 03:35:45 +00:00
|
|
|
|
2017-02-24 00:43:48 +00:00
|
|
|
def root(self, request, full_url, headers):
|
|
|
|
self.setup_class(request, full_url, headers)
|
2019-10-31 15:44:26 +00:00
|
|
|
if request.method == "GET":
|
2017-02-24 00:43:48 +00:00
|
|
|
return self._list_functions(request, full_url, headers)
|
2019-10-31 15:44:26 +00:00
|
|
|
elif request.method == "POST":
|
2017-02-24 00:43:48 +00:00
|
|
|
return self._create_function(request, full_url, headers)
|
2016-02-12 19:39:20 +00:00
|
|
|
else:
|
|
|
|
raise ValueError("Cannot handle request")
|
|
|
|
|
2019-08-21 01:54:57 +00:00
|
|
|
def event_source_mappings(self, request, full_url, headers):
|
|
|
|
self.setup_class(request, full_url, headers)
|
2019-10-31 15:44:26 +00:00
|
|
|
if request.method == "GET":
|
2019-08-21 01:54:57 +00:00
|
|
|
querystring = self.querystring
|
2019-10-31 15:44:26 +00:00
|
|
|
event_source_arn = querystring.get("EventSourceArn", [None])[0]
|
|
|
|
function_name = querystring.get("FunctionName", [None])[0]
|
2019-08-21 01:54:57 +00:00
|
|
|
return self._list_event_source_mappings(event_source_arn, function_name)
|
2019-10-31 15:44:26 +00:00
|
|
|
elif request.method == "POST":
|
2019-08-21 01:54:57 +00:00
|
|
|
return self._create_event_source_mapping(request, full_url, headers)
|
|
|
|
else:
|
|
|
|
raise ValueError("Cannot handle request")
|
|
|
|
|
|
|
|
def event_source_mapping(self, request, full_url, headers):
|
|
|
|
self.setup_class(request, full_url, headers)
|
2019-10-31 15:44:26 +00:00
|
|
|
path = request.path if hasattr(request, "path") else path_url(request.url)
|
|
|
|
uuid = path.split("/")[-1]
|
|
|
|
if request.method == "GET":
|
2019-08-21 01:54:57 +00:00
|
|
|
return self._get_event_source_mapping(uuid)
|
2019-10-31 15:44:26 +00:00
|
|
|
elif request.method == "PUT":
|
2019-08-21 01:54:57 +00:00
|
|
|
return self._update_event_source_mapping(uuid)
|
2019-10-31 15:44:26 +00:00
|
|
|
elif request.method == "DELETE":
|
2019-08-21 01:54:57 +00:00
|
|
|
return self._delete_event_source_mapping(uuid)
|
|
|
|
else:
|
|
|
|
raise ValueError("Cannot handle request")
|
|
|
|
|
2021-01-17 15:28:49 +00:00
|
|
|
def list_layers(self, request, full_url, headers):
|
|
|
|
self.setup_class(request, full_url, headers)
|
|
|
|
if request.method == "GET":
|
|
|
|
return self._list_layers(request, headers)
|
|
|
|
|
|
|
|
def layers_versions(self, request, full_url, headers):
|
|
|
|
self.setup_class(request, full_url, headers)
|
|
|
|
if request.method == "GET":
|
|
|
|
return self._get_layer_versions(request, full_url, headers)
|
|
|
|
if request.method == "POST":
|
|
|
|
return self._publish_layer_version(request, full_url, headers)
|
|
|
|
|
2017-02-24 00:43:48 +00:00
|
|
|
def function(self, request, full_url, headers):
|
|
|
|
self.setup_class(request, full_url, headers)
|
2019-10-31 15:44:26 +00:00
|
|
|
if request.method == "GET":
|
2017-02-24 00:43:48 +00:00
|
|
|
return self._get_function(request, full_url, headers)
|
2019-10-31 15:44:26 +00:00
|
|
|
elif request.method == "DELETE":
|
2017-02-24 00:43:48 +00:00
|
|
|
return self._delete_function(request, full_url, headers)
|
2016-02-12 19:39:20 +00:00
|
|
|
else:
|
|
|
|
raise ValueError("Cannot handle request")
|
|
|
|
|
2017-11-26 21:28:28 +00:00
|
|
|
def versions(self, request, full_url, headers):
|
|
|
|
self.setup_class(request, full_url, headers)
|
2019-10-31 15:44:26 +00:00
|
|
|
if request.method == "GET":
|
2017-11-26 21:28:28 +00:00
|
|
|
# This is ListVersionByFunction
|
2019-02-16 15:27:23 +00:00
|
|
|
|
2019-10-31 15:44:26 +00:00
|
|
|
path = request.path if hasattr(request, "path") else path_url(request.url)
|
|
|
|
function_name = path.split("/")[-2]
|
2019-02-16 15:27:23 +00:00
|
|
|
return self._list_versions_by_function(function_name)
|
|
|
|
|
2019-10-31 15:44:26 +00:00
|
|
|
elif request.method == "POST":
|
2017-11-26 21:28:28 +00:00
|
|
|
return self._publish_function(request, full_url, headers)
|
|
|
|
else:
|
|
|
|
raise ValueError("Cannot handle request")
|
|
|
|
|
2017-10-17 00:06:22 +00:00
|
|
|
@amz_crc32
|
|
|
|
@amzn_request_id
|
2017-02-24 00:43:48 +00:00
|
|
|
def invoke(self, request, full_url, headers):
|
|
|
|
self.setup_class(request, full_url, headers)
|
2019-10-31 15:44:26 +00:00
|
|
|
if request.method == "POST":
|
2017-02-24 00:43:48 +00:00
|
|
|
return self._invoke(request, full_url)
|
2016-06-22 19:24:46 +00:00
|
|
|
else:
|
|
|
|
raise ValueError("Cannot handle request")
|
|
|
|
|
2017-10-17 00:06:22 +00:00
|
|
|
@amz_crc32
|
|
|
|
@amzn_request_id
|
2017-09-13 04:44:22 +00:00
|
|
|
def invoke_async(self, request, full_url, headers):
|
|
|
|
self.setup_class(request, full_url, headers)
|
2019-10-31 15:44:26 +00:00
|
|
|
if request.method == "POST":
|
2017-09-13 04:44:22 +00:00
|
|
|
return self._invoke_async(request, full_url)
|
|
|
|
else:
|
|
|
|
raise ValueError("Cannot handle request")
|
|
|
|
|
2017-09-13 19:00:39 +00:00
|
|
|
def tag(self, request, full_url, headers):
|
|
|
|
self.setup_class(request, full_url, headers)
|
2019-10-31 15:44:26 +00:00
|
|
|
if request.method == "GET":
|
2017-09-13 19:00:39 +00:00
|
|
|
return self._list_tags(request, full_url)
|
2019-10-31 15:44:26 +00:00
|
|
|
elif request.method == "POST":
|
2017-09-13 19:00:39 +00:00
|
|
|
return self._tag_resource(request, full_url)
|
2019-10-31 15:44:26 +00:00
|
|
|
elif request.method == "DELETE":
|
2017-09-13 19:00:39 +00:00
|
|
|
return self._untag_resource(request, full_url)
|
|
|
|
else:
|
|
|
|
raise ValueError("Cannot handle {0} request".format(request.method))
|
|
|
|
|
2017-10-03 00:33:50 +00:00
|
|
|
def policy(self, request, full_url, headers):
|
2019-10-22 21:09:44 +00:00
|
|
|
self.setup_class(request, full_url, headers)
|
2019-10-31 15:44:26 +00:00
|
|
|
if request.method == "GET":
|
2017-10-03 00:33:50 +00:00
|
|
|
return self._get_policy(request, full_url, headers)
|
2020-01-23 18:46:24 +00:00
|
|
|
elif request.method == "POST":
|
2017-10-03 02:23:00 +00:00
|
|
|
return self._add_policy(request, full_url, headers)
|
2020-01-23 18:46:24 +00:00
|
|
|
elif request.method == "DELETE":
|
|
|
|
return self._del_policy(request, full_url, headers, self.querystring)
|
|
|
|
else:
|
|
|
|
raise ValueError("Cannot handle {0} request".format(request.method))
|
2017-10-03 02:23:00 +00:00
|
|
|
|
2019-10-08 20:59:03 +00:00
|
|
|
def configuration(self, request, full_url, headers):
|
2019-10-09 20:15:10 +00:00
|
|
|
self.setup_class(request, full_url, headers)
|
2019-10-31 15:44:26 +00:00
|
|
|
if request.method == "PUT":
|
2019-10-09 20:15:10 +00:00
|
|
|
return self._put_configuration(request)
|
2021-01-10 15:24:04 +00:00
|
|
|
if request.method == "GET":
|
|
|
|
return self._get_function_configuration(request, full_url, headers)
|
2019-10-08 20:59:03 +00:00
|
|
|
else:
|
|
|
|
raise ValueError("Cannot handle request")
|
|
|
|
|
|
|
|
def code(self, request, full_url, headers):
|
2019-10-09 20:15:10 +00:00
|
|
|
self.setup_class(request, full_url, headers)
|
2019-10-31 15:44:26 +00:00
|
|
|
if request.method == "PUT":
|
2019-10-09 20:15:10 +00:00
|
|
|
return self._put_code()
|
2019-10-08 20:59:03 +00:00
|
|
|
else:
|
|
|
|
raise ValueError("Cannot handle request")
|
|
|
|
|
2020-08-26 10:06:53 +00:00
|
|
|
def function_concurrency(self, request, full_url, headers):
|
|
|
|
http_method = request.method
|
|
|
|
self.setup_class(request, full_url, headers)
|
|
|
|
|
|
|
|
if http_method == "GET":
|
|
|
|
return self._get_function_concurrency(request)
|
|
|
|
elif http_method == "DELETE":
|
|
|
|
return self._delete_function_concurrency(request)
|
|
|
|
elif http_method == "PUT":
|
|
|
|
return self._put_function_concurrency(request)
|
|
|
|
else:
|
|
|
|
raise ValueError("Cannot handle request")
|
|
|
|
|
2017-10-03 02:23:00 +00:00
|
|
|
def _add_policy(self, request, full_url, headers):
|
2019-10-31 15:44:26 +00:00
|
|
|
path = request.path if hasattr(request, "path") else path_url(request.url)
|
2021-08-28 06:23:44 +00:00
|
|
|
function_name = unquote(path.split("/")[-2])
|
2018-04-07 18:07:17 +00:00
|
|
|
if self.lambda_backend.get_function(function_name):
|
2020-01-23 18:46:24 +00:00
|
|
|
statement = self.body
|
2020-04-03 09:30:05 +00:00
|
|
|
self.lambda_backend.add_permission(function_name, statement)
|
2020-01-23 18:46:24 +00:00
|
|
|
return 200, {}, json.dumps({"Statement": statement})
|
2017-10-03 02:23:00 +00:00
|
|
|
else:
|
|
|
|
return 404, {}, "{}"
|
2017-10-03 00:33:50 +00:00
|
|
|
|
|
|
|
def _get_policy(self, request, full_url, headers):
|
2019-10-31 15:44:26 +00:00
|
|
|
path = request.path if hasattr(request, "path") else path_url(request.url)
|
2021-08-28 06:23:44 +00:00
|
|
|
function_name = unquote(path.split("/")[-2])
|
2018-04-07 18:07:17 +00:00
|
|
|
if self.lambda_backend.get_function(function_name):
|
2020-01-23 18:46:24 +00:00
|
|
|
out = self.lambda_backend.get_policy_wire_format(function_name)
|
|
|
|
return 200, {}, out
|
|
|
|
else:
|
|
|
|
return 404, {}, "{}"
|
|
|
|
|
|
|
|
def _del_policy(self, request, full_url, headers, querystring):
|
|
|
|
path = request.path if hasattr(request, "path") else path_url(request.url)
|
2021-08-28 06:23:44 +00:00
|
|
|
function_name = unquote(path.split("/")[-3])
|
2020-01-23 18:46:24 +00:00
|
|
|
statement_id = path.split("/")[-1].split("?")[0]
|
|
|
|
revision = querystring.get("RevisionId", "")
|
|
|
|
if self.lambda_backend.get_function(function_name):
|
2020-04-03 09:30:05 +00:00
|
|
|
self.lambda_backend.remove_permission(function_name, statement_id, revision)
|
2020-01-23 18:46:24 +00:00
|
|
|
return 204, {}, "{}"
|
2017-10-03 00:33:50 +00:00
|
|
|
else:
|
|
|
|
return 404, {}, "{}"
|
|
|
|
|
2017-02-24 00:43:48 +00:00
|
|
|
def _invoke(self, request, full_url):
|
2017-02-17 03:51:04 +00:00
|
|
|
response_headers = {}
|
2016-06-22 19:24:46 +00:00
|
|
|
|
2020-02-05 01:06:55 +00:00
|
|
|
# URL Decode in case it's a ARN:
|
|
|
|
function_name = unquote(self.path.rsplit("/", 2)[-2])
|
2019-10-31 15:44:26 +00:00
|
|
|
qualifier = self._get_param("qualifier")
|
2016-06-22 19:24:46 +00:00
|
|
|
|
2020-05-07 09:55:15 +00:00
|
|
|
payload = self.lambda_backend.invoke(
|
2019-11-15 16:34:14 +00:00
|
|
|
function_name, qualifier, self.body, self.headers, response_headers
|
|
|
|
)
|
|
|
|
if payload:
|
2021-06-30 10:02:38 +00:00
|
|
|
response_headers["content-type"] = "application/json"
|
2020-04-17 04:28:27 +00:00
|
|
|
if request.headers.get("X-Amz-Invocation-Type") == "Event":
|
2018-08-14 23:00:03 +00:00
|
|
|
status_code = 202
|
2020-04-17 04:28:27 +00:00
|
|
|
elif request.headers.get("X-Amz-Invocation-Type") == "DryRun":
|
2018-08-14 23:00:03 +00:00
|
|
|
status_code = 204
|
|
|
|
else:
|
2020-05-07 09:55:15 +00:00
|
|
|
if request.headers.get("X-Amz-Log-Type") != "Tail":
|
|
|
|
del response_headers["x-amz-log-result"]
|
2018-08-14 23:00:03 +00:00
|
|
|
status_code = 200
|
|
|
|
return status_code, response_headers, payload
|
2016-06-22 19:24:46 +00:00
|
|
|
else:
|
2017-02-17 03:51:04 +00:00
|
|
|
return 404, response_headers, "{}"
|
2016-06-22 19:24:46 +00:00
|
|
|
|
2017-09-13 04:44:22 +00:00
|
|
|
def _invoke_async(self, request, full_url):
|
|
|
|
response_headers = {}
|
|
|
|
|
2021-08-28 06:23:44 +00:00
|
|
|
function_name = unquote(self.path.rsplit("/", 3)[-3])
|
2017-11-26 21:28:28 +00:00
|
|
|
|
|
|
|
fn = self.lambda_backend.get_function(function_name, None)
|
|
|
|
if fn:
|
|
|
|
payload = fn.invoke(self.body, self.headers, response_headers)
|
2019-10-31 15:44:26 +00:00
|
|
|
response_headers["Content-Length"] = str(len(payload))
|
2017-11-26 21:28:28 +00:00
|
|
|
return 202, response_headers, payload
|
2017-09-14 02:06:05 +00:00
|
|
|
else:
|
2017-09-13 04:44:22 +00:00
|
|
|
return 404, response_headers, "{}"
|
|
|
|
|
2016-02-12 19:39:20 +00:00
|
|
|
def _list_functions(self, request, full_url, headers):
|
2021-08-28 14:26:44 +00:00
|
|
|
querystring = self.querystring
|
|
|
|
func_version = querystring.get("FunctionVersion", [None])[0]
|
2019-10-31 15:44:26 +00:00
|
|
|
result = {"Functions": []}
|
2017-11-26 21:28:28 +00:00
|
|
|
|
2021-08-28 14:26:44 +00:00
|
|
|
for fn in self.lambda_backend.list_functions(func_version):
|
2017-11-26 21:28:28 +00:00
|
|
|
json_data = fn.get_configuration()
|
2019-10-31 15:44:26 +00:00
|
|
|
result["Functions"].append(json_data)
|
2017-11-26 21:28:28 +00:00
|
|
|
|
|
|
|
return 200, {}, json.dumps(result)
|
2016-02-12 19:39:20 +00:00
|
|
|
|
2019-02-16 15:27:23 +00:00
|
|
|
def _list_versions_by_function(self, function_name):
|
2019-10-31 15:44:26 +00:00
|
|
|
result = {"Versions": []}
|
2019-02-16 15:27:23 +00:00
|
|
|
|
2019-02-16 18:37:46 +00:00
|
|
|
functions = self.lambda_backend.list_versions_by_function(function_name)
|
|
|
|
if functions:
|
|
|
|
for fn in functions:
|
|
|
|
json_data = fn.get_configuration()
|
2019-10-31 15:44:26 +00:00
|
|
|
result["Versions"].append(json_data)
|
2019-02-16 15:27:23 +00:00
|
|
|
|
|
|
|
return 200, {}, json.dumps(result)
|
|
|
|
|
2016-02-12 19:39:20 +00:00
|
|
|
def _create_function(self, request, full_url, headers):
|
2019-11-17 10:59:20 +00:00
|
|
|
fn = self.lambda_backend.create_function(self.json_body)
|
|
|
|
config = fn.get_configuration()
|
|
|
|
return 201, {}, json.dumps(config)
|
2016-02-12 19:39:20 +00:00
|
|
|
|
2019-08-21 01:54:57 +00:00
|
|
|
def _create_event_source_mapping(self, request, full_url, headers):
|
2019-11-17 10:59:20 +00:00
|
|
|
fn = self.lambda_backend.create_event_source_mapping(self.json_body)
|
|
|
|
config = fn.get_configuration()
|
|
|
|
return 201, {}, json.dumps(config)
|
2019-08-21 01:54:57 +00:00
|
|
|
|
|
|
|
def _list_event_source_mappings(self, event_source_arn, function_name):
|
2019-10-31 15:44:26 +00:00
|
|
|
esms = self.lambda_backend.list_event_source_mappings(
|
|
|
|
event_source_arn, function_name
|
|
|
|
)
|
|
|
|
result = {"EventSourceMappings": [esm.get_configuration() for esm in esms]}
|
2019-08-21 01:54:57 +00:00
|
|
|
return 200, {}, json.dumps(result)
|
|
|
|
|
|
|
|
def _get_event_source_mapping(self, uuid):
|
|
|
|
result = self.lambda_backend.get_event_source_mapping(uuid)
|
|
|
|
if result:
|
|
|
|
return 200, {}, json.dumps(result.get_configuration())
|
|
|
|
else:
|
|
|
|
return 404, {}, "{}"
|
|
|
|
|
|
|
|
def _update_event_source_mapping(self, uuid):
|
|
|
|
result = self.lambda_backend.update_event_source_mapping(uuid, self.json_body)
|
|
|
|
if result:
|
|
|
|
return 202, {}, json.dumps(result.get_configuration())
|
|
|
|
else:
|
|
|
|
return 404, {}, "{}"
|
|
|
|
|
|
|
|
def _delete_event_source_mapping(self, uuid):
|
|
|
|
esm = self.lambda_backend.delete_event_source_mapping(uuid)
|
|
|
|
if esm:
|
|
|
|
json_result = esm.get_configuration()
|
2019-10-31 15:44:26 +00:00
|
|
|
json_result.update({"State": "Deleting"})
|
2019-08-21 01:54:57 +00:00
|
|
|
return 202, {}, json.dumps(json_result)
|
|
|
|
else:
|
|
|
|
return 404, {}, "{}"
|
|
|
|
|
2017-11-26 21:28:28 +00:00
|
|
|
def _publish_function(self, request, full_url, headers):
|
2019-10-31 15:44:26 +00:00
|
|
|
function_name = self.path.rsplit("/", 2)[-2]
|
2021-08-28 14:26:44 +00:00
|
|
|
description = self._get_param("Description")
|
2016-02-12 19:39:20 +00:00
|
|
|
|
2021-08-28 14:26:44 +00:00
|
|
|
fn = self.lambda_backend.publish_function(function_name, description)
|
2017-11-26 21:28:28 +00:00
|
|
|
if fn:
|
|
|
|
config = fn.get_configuration()
|
2019-03-17 08:54:34 +00:00
|
|
|
return 201, {}, json.dumps(config)
|
2017-11-26 21:28:28 +00:00
|
|
|
else:
|
|
|
|
return 404, {}, "{}"
|
2016-02-12 19:39:20 +00:00
|
|
|
|
2017-11-26 21:28:28 +00:00
|
|
|
def _delete_function(self, request, full_url, headers):
|
2019-10-31 15:44:26 +00:00
|
|
|
function_name = unquote(self.path.rsplit("/", 1)[-1])
|
|
|
|
qualifier = self._get_param("Qualifier", None)
|
2017-11-26 21:28:28 +00:00
|
|
|
|
|
|
|
if self.lambda_backend.delete_function(function_name, qualifier):
|
2017-02-17 03:51:04 +00:00
|
|
|
return 204, {}, ""
|
2016-02-12 19:39:20 +00:00
|
|
|
else:
|
2017-02-17 03:51:04 +00:00
|
|
|
return 404, {}, "{}"
|
2016-02-12 19:39:20 +00:00
|
|
|
|
2021-01-10 15:24:04 +00:00
|
|
|
@staticmethod
|
|
|
|
def _set_configuration_qualifier(configuration, qualifier):
|
|
|
|
if qualifier is None or qualifier == "$LATEST":
|
|
|
|
configuration["Version"] = "$LATEST"
|
|
|
|
if qualifier == "$LATEST":
|
|
|
|
configuration["FunctionArn"] += ":$LATEST"
|
|
|
|
return configuration
|
|
|
|
|
2016-02-12 19:39:20 +00:00
|
|
|
def _get_function(self, request, full_url, headers):
|
2019-11-04 15:14:43 +00:00
|
|
|
function_name = unquote(self.path.rsplit("/", 1)[-1])
|
2019-10-31 15:44:26 +00:00
|
|
|
qualifier = self._get_param("Qualifier", None)
|
2016-02-12 19:39:20 +00:00
|
|
|
|
2017-11-26 21:28:28 +00:00
|
|
|
fn = self.lambda_backend.get_function(function_name, qualifier)
|
2016-02-12 19:39:20 +00:00
|
|
|
|
2017-11-26 21:28:28 +00:00
|
|
|
if fn:
|
2016-02-12 19:39:20 +00:00
|
|
|
code = fn.get_code()
|
2021-01-10 15:24:04 +00:00
|
|
|
code["Configuration"] = self._set_configuration_qualifier(
|
|
|
|
code["Configuration"], qualifier
|
|
|
|
)
|
2017-02-17 03:51:04 +00:00
|
|
|
return 200, {}, json.dumps(code)
|
2016-02-12 19:39:20 +00:00
|
|
|
else:
|
2020-02-06 23:26:20 +00:00
|
|
|
return 404, {"x-amzn-ErrorType": "ResourceNotFoundException"}, "{}"
|
2017-02-16 03:35:45 +00:00
|
|
|
|
2021-01-10 15:24:04 +00:00
|
|
|
def _get_function_configuration(self, request, full_url, headers):
|
|
|
|
function_name = unquote(self.path.rsplit("/", 2)[-2])
|
|
|
|
qualifier = self._get_param("Qualifier", None)
|
|
|
|
|
|
|
|
fn = self.lambda_backend.get_function(function_name, qualifier)
|
|
|
|
|
|
|
|
if fn:
|
|
|
|
configuration = self._set_configuration_qualifier(
|
|
|
|
fn.get_configuration(), qualifier
|
|
|
|
)
|
|
|
|
return 200, {}, json.dumps(configuration)
|
|
|
|
else:
|
|
|
|
return 404, {"x-amzn-ErrorType": "ResourceNotFoundException"}, "{}"
|
|
|
|
|
2016-02-12 19:39:20 +00:00
|
|
|
def _get_aws_region(self, full_url):
|
2017-12-01 20:37:27 +00:00
|
|
|
region = self.region_regex.search(full_url)
|
2016-02-12 19:39:20 +00:00
|
|
|
if region:
|
|
|
|
return region.group(1)
|
|
|
|
else:
|
|
|
|
return self.default_region
|
2017-09-13 19:00:39 +00:00
|
|
|
|
|
|
|
def _list_tags(self, request, full_url):
|
2019-10-31 15:44:26 +00:00
|
|
|
function_arn = unquote(self.path.rsplit("/", 1)[-1])
|
2017-09-13 19:00:39 +00:00
|
|
|
|
2017-11-26 21:28:28 +00:00
|
|
|
fn = self.lambda_backend.get_function_by_arn(function_arn)
|
|
|
|
if fn:
|
2019-10-31 15:44:26 +00:00
|
|
|
return 200, {}, json.dumps({"Tags": fn.tags})
|
2017-09-13 19:00:39 +00:00
|
|
|
else:
|
|
|
|
return 404, {}, "{}"
|
|
|
|
|
|
|
|
def _tag_resource(self, request, full_url):
|
2019-10-31 15:44:26 +00:00
|
|
|
function_arn = unquote(self.path.rsplit("/", 1)[-1])
|
2017-09-13 19:00:39 +00:00
|
|
|
|
2019-10-31 15:44:26 +00:00
|
|
|
if self.lambda_backend.tag_resource(function_arn, self.json_body["Tags"]):
|
2017-09-13 19:00:39 +00:00
|
|
|
return 200, {}, "{}"
|
|
|
|
else:
|
|
|
|
return 404, {}, "{}"
|
|
|
|
|
|
|
|
def _untag_resource(self, request, full_url):
|
2019-10-31 15:44:26 +00:00
|
|
|
function_arn = unquote(self.path.rsplit("/", 1)[-1])
|
|
|
|
tag_keys = self.querystring["tagKeys"]
|
2017-09-13 19:00:39 +00:00
|
|
|
|
2017-11-26 21:28:28 +00:00
|
|
|
if self.lambda_backend.untag_resource(function_arn, tag_keys):
|
2017-09-13 19:00:39 +00:00
|
|
|
return 204, {}, "{}"
|
|
|
|
else:
|
|
|
|
return 404, {}, "{}"
|
2019-10-08 20:59:03 +00:00
|
|
|
|
2019-10-09 20:15:10 +00:00
|
|
|
def _put_configuration(self, request):
|
2021-08-28 06:23:44 +00:00
|
|
|
function_name = unquote(self.path.rsplit("/", 2)[-2])
|
2019-10-31 15:44:26 +00:00
|
|
|
qualifier = self._get_param("Qualifier", None)
|
2019-11-15 16:34:14 +00:00
|
|
|
resp = self.lambda_backend.update_function_configuration(
|
|
|
|
function_name, qualifier, body=self.json_body
|
|
|
|
)
|
2019-10-08 20:59:03 +00:00
|
|
|
|
2019-11-15 16:34:14 +00:00
|
|
|
if resp:
|
|
|
|
return 200, {}, json.dumps(resp)
|
2019-10-08 20:59:03 +00:00
|
|
|
else:
|
|
|
|
return 404, {}, "{}"
|
|
|
|
|
2019-10-09 20:15:10 +00:00
|
|
|
def _put_code(self):
|
2021-08-28 06:23:44 +00:00
|
|
|
function_name = unquote(self.path.rsplit("/", 2)[-2])
|
2019-10-31 15:44:26 +00:00
|
|
|
qualifier = self._get_param("Qualifier", None)
|
2019-11-15 16:34:14 +00:00
|
|
|
resp = self.lambda_backend.update_function_code(
|
|
|
|
function_name, qualifier, body=self.json_body
|
|
|
|
)
|
2019-10-08 20:59:03 +00:00
|
|
|
|
2019-11-15 16:34:14 +00:00
|
|
|
if resp:
|
|
|
|
return 200, {}, json.dumps(resp)
|
2019-10-08 20:59:03 +00:00
|
|
|
else:
|
|
|
|
return 404, {}, "{}"
|
2020-08-26 10:06:53 +00:00
|
|
|
|
|
|
|
def _get_function_concurrency(self, request):
|
2021-08-28 06:23:44 +00:00
|
|
|
path_function_name = unquote(self.path.rsplit("/", 2)[-2])
|
2020-08-26 10:06:53 +00:00
|
|
|
function_name = self.lambda_backend.get_function(path_function_name)
|
|
|
|
|
|
|
|
if function_name is None:
|
|
|
|
return 404, {}, "{}"
|
|
|
|
|
|
|
|
resp = self.lambda_backend.get_function_concurrency(path_function_name)
|
|
|
|
return 200, {}, json.dumps({"ReservedConcurrentExecutions": resp})
|
|
|
|
|
|
|
|
def _delete_function_concurrency(self, request):
|
2021-08-28 06:23:44 +00:00
|
|
|
path_function_name = unquote(self.path.rsplit("/", 2)[-2])
|
2020-08-26 10:06:53 +00:00
|
|
|
function_name = self.lambda_backend.get_function(path_function_name)
|
|
|
|
|
|
|
|
if function_name is None:
|
|
|
|
return 404, {}, "{}"
|
|
|
|
|
|
|
|
self.lambda_backend.delete_function_concurrency(path_function_name)
|
|
|
|
|
|
|
|
return 204, {}, "{}"
|
|
|
|
|
|
|
|
def _put_function_concurrency(self, request):
|
2021-08-28 06:23:44 +00:00
|
|
|
path_function_name = unquote(self.path.rsplit("/", 2)[-2])
|
2020-08-26 10:06:53 +00:00
|
|
|
function = self.lambda_backend.get_function(path_function_name)
|
|
|
|
|
|
|
|
if function is None:
|
|
|
|
return 404, {}, "{}"
|
|
|
|
|
|
|
|
concurrency = self._get_param("ReservedConcurrentExecutions", None)
|
|
|
|
resp = self.lambda_backend.put_function_concurrency(
|
|
|
|
path_function_name, concurrency
|
|
|
|
)
|
|
|
|
|
|
|
|
return 200, {}, json.dumps({"ReservedConcurrentExecutions": resp})
|
2021-01-17 15:28:49 +00:00
|
|
|
|
|
|
|
def _list_layers(self, request, headers):
|
|
|
|
layers = self.lambda_backend.list_layers()
|
|
|
|
return (200, {}, json.dumps({"Layers": layers}))
|
|
|
|
|
|
|
|
def _get_layer_versions(self, request, full_url, headers):
|
|
|
|
layer_name = self.path.rsplit("/", 2)[-2]
|
|
|
|
layer_versions = self.lambda_backend.get_layer_versions(layer_name)
|
|
|
|
return (
|
|
|
|
200,
|
|
|
|
{},
|
|
|
|
json.dumps(
|
|
|
|
{"LayerVersions": [lv.get_layer_version() for lv in layer_versions]}
|
|
|
|
),
|
|
|
|
)
|
|
|
|
|
|
|
|
def _publish_layer_version(self, request, full_url, headers):
|
|
|
|
spec = self.json_body
|
|
|
|
if "LayerName" not in spec:
|
|
|
|
spec["LayerName"] = self.path.rsplit("/", 2)[-2]
|
|
|
|
layer_version = self.lambda_backend.publish_layer_version(spec)
|
|
|
|
config = layer_version.get_layer_version()
|
|
|
|
return 201, {}, json.dumps(config)
|