Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Tasking manager fastapi #6649

Open
wants to merge 181 commits into
base: develop
Choose a base branch
from
Open

Tasking manager fastapi #6649

wants to merge 181 commits into from

Conversation

prabinoid
Copy link
Contributor

What type of PR is this? (check all applicable)

  • πŸ• Feature
  • πŸ› Bug Fix
  • πŸ“ Documentation
  • πŸ§‘β€πŸ’» Refactor
  • βœ… Test
  • πŸ€– Build or CI
  • ❓ Other (please specify)

Related Issue

Related discussions:

#6264

https://community.openstreetmap.org/t/migrating-tasking-manager-from-flask-to-fastapi-and-psycopg2-to-asyncpg/116543

Describe this PR

This PR includes the TM fastapi migration and covers the commits from the initial phases of the migration.

This PR is made for the code review of the migration and is NOT be merged currently.

@@ -28,7 +25,7 @@ FROM base as extract-deps
RUN pip install --no-cache-dir --upgrade pip
WORKDIR /opt/python
COPY pyproject.toml pdm.lock README.md /opt/python/
RUN pip install --no-cache-dir pdm==2.18.1
RUN pip install --no-cache-dir pdm==2.8.0
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Small thing, but it might be worth updating pdm to 2.18.1 here to avoid downgrading on merge

router = APIRouter(
prefix="/projects",
tags=["projects"],
dependencies=[Depends(get_db)],
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm not sure this is needed here. Some endpoints may not need a db connection and this would create one anyway. I'm not sure how you would access the database connection variable like this anyway

"""
Get all task annotations for a project
---
tags:
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Entirely optional, but you could always delete this docstrings. Fastapi generates the OpenAPI docs using typing anyway, so it's a bit redundant. It also means you need to remember to update the docstring if you update variables

category_dto = await MappingIssueCategoryService.get_mapping_issue_category_as_dto(
category_id, db
)
return category_dto.model_dump(by_alias=True)
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This will work, but the preferred approach to a manual model dump is probably using response_model on the endpoint decorator. This will handle serialisation and dumping

sort_by = request.query_params.get("sortBy", "date")
sort_direction = request.query_params.get("sortDirection", "desc")
message_type = request.query_params.get("messageType", None)
from_username = request.query_params.get("from")
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is an interesting approach for endpoint query params. It should work, but typically you would define query params as function arguments and they would be parsed as such. If there is confusion, it's possible to explicitly define arguments as fastapi.Query

async with db.transaction():
await CampaignService.create_campaign_organisation(
organisation_id, campaign_id, db
)
message = "campaign with id {} assigned for organisation with id {}".format(
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

F-strings are a bit nicer to read, but not a big deal πŸ‘

return token.model_dump(by_alias=True)


@router.patch("/authentication/applications/{application_key}/")
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Using a PATCH method here seems a bit out of place, but maybe I am missing something

@spwoodcock
Copy link
Member

That's a lot of code changed! Well done on this - lots of great work πŸ™Œ

Just a few minor comments

prabinoid and others added 22 commits January 20, 2025 12:11
* messaging tasks added to background.
* db context added in tasks and removed explicit connection.
* send message on project progress.
* project transfer messaging.
* Auto unlock task refactored.
* Auto unlock task cron job.
* Task geojson export.
* Project partnership filters
* Changeset comment population on project creation and update
* Cleanups
* Email on team actions.
* Campaign create and json responses handled.
* Project info language update for different locales fixed
* Author name in recommended projects.
* Organisation patch fixed.
* Jobs removed from application and separately containerized
* Teams csv download.
* Projects csv download.
* Teams join date.
Copy link

Quality Gate Failed Quality Gate failed

Failed conditions
2 Security Hotspots
C Reliability Rating on New Code (required β‰₯ A)

See analysis details on SonarQube Cloud

Catch issues before they fail your Quality Gate with our IDE extension SonarQube for IDE

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

7 participants