|
1 | | -from time_entries._infrastructure import ActivitiesJsonDao |
2 | | -from time_entries._domain import ActivityService, _use_cases, Activity |
3 | | - |
4 | | -import azure.functions as func |
5 | 1 | import json |
6 | 2 | import logging |
7 | 3 | import dataclasses |
| 4 | +import typing |
| 5 | + |
| 6 | +import azure.functions as func |
8 | 7 |
|
| 8 | +from ... import _domain |
| 9 | +from ... import _infrastructure |
9 | 10 |
|
10 | | -JSON_PATH = ( |
| 11 | +_JSON_PATH = ( |
11 | 12 | 'time_entries/_infrastructure/_data_persistence/activities_data.json' |
12 | 13 | ) |
13 | 14 |
|
14 | 15 |
|
15 | | - |
16 | 16 | def create_activity(req: func.HttpRequest) -> func.HttpResponse: |
17 | | - logging.info( |
18 | | - 'Python HTTP trigger function processed a request to create an activity.' |
19 | | - ) |
| 17 | + activity_dao = _infrastructure.ActivitiesJsonDao(_JSON_PATH) |
| 18 | + activity_service = _domain.ActivityService(activity_dao) |
| 19 | + use_case = _domain._use_cases.CreateActivityUseCase(activity_service) |
| 20 | + |
| 21 | + |
20 | 22 | activity_data = req.get_json() |
21 | | - status_code = 200 |
22 | | - if _validate_activity(activity_data): |
23 | | - response = _create_activity(activity_data) |
24 | | - else: |
25 | | - status_code = 404 |
26 | | - response = b'Not possible to create activity, attributes are not correct ' |
27 | 23 |
|
28 | | - return func.HttpResponse( |
29 | | - body=response, status_code=status_code, mimetype="application/json" |
30 | | - ) |
31 | 24 |
|
32 | | -def _create_activity(activity_data: dict) -> str: |
33 | | - activity_use_case = _use_cases.CreateActivityUseCase( |
34 | | - _create_activity_service(JSON_PATH) |
| 25 | + validation_errors = _validate_activity(activity_data) |
| 26 | + if validation_errors: |
| 27 | + return func.HttpResponse( |
| 28 | + body=validation_errors, status_code=400, mimetype="application/json" |
| 29 | + ) |
| 30 | + |
| 31 | + |
| 32 | + activity_to_create = _domain.Activity( |
| 33 | + id= None, |
| 34 | + name=activity_data['name'], |
| 35 | + description=activity_data['description'], |
| 36 | + status=activity_data['status'], |
| 37 | + deleted=activity_data['deleted'], |
| 38 | + tenant_id=activity_data['tenant_id'] |
35 | 39 | ) |
36 | | - activity = activity_use_case.create_activity(activity_data) |
37 | | - return json.dumps(activity.__dict__) if activity else b'Not Found' |
38 | 40 |
|
39 | | -def _validate_activity(activity_data: dict) -> bool: |
40 | | - activity_keys = [field.name for field in dataclasses.fields(Activity)] |
41 | | - new_activity_keys = list(activity_data.keys()) |
42 | | - return all(map(lambda key: key in activity_keys, new_activity_keys)) and len(activity_keys) == len(new_activity_keys) |
43 | 41 |
|
44 | | -def _create_activity_service(path: str): |
45 | | - activity_json = ActivitiesJsonDao(path) |
46 | | - return ActivityService(activity_json) |
| 42 | + created_activity = use_case.create_activity(activity_to_create.__dict__) |
| 43 | + if not create_activity: |
| 44 | + return func.HttpResponse( |
| 45 | + body={'error': 'activity could not be created'}, |
| 46 | + status_code=500, |
| 47 | + mimetype="application/json", |
| 48 | + ) |
| 49 | + return func.HttpResponse( |
| 50 | + body=json.dumps(created_activity.__dict__), |
| 51 | + status_code=201, |
| 52 | + mimetype="application/json" |
| 53 | + ) |
47 | 54 |
|
48 | 55 |
|
| 56 | +def _validate_activity(activity_data: dict) -> typing.List[str]: |
| 57 | + activity_fields = [field.name for field in dataclasses.fields(_domain.Activity)] |
| 58 | + missing_keys = [field for field in activity_fields if field not in activity_data] |
| 59 | + return [ |
| 60 | + f'The {missing_key} key is missing in the input data' |
| 61 | + for missing_key in missing_keys |
| 62 | + ] |
0 commit comments