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

Add API endpoints for departments #1138

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

Add API endpoints for departments #1138

wants to merge 72 commits into from

Conversation

michplunkett
Copy link
Collaborator

@michplunkett michplunkett commented Dec 18, 2024

Fixes issue

#385

Description of Changes

Add the baseline features for a data-focused API.

Tests and Linting

  • This branch is up-to-date with the develop branch.
  • pytest passes on my local development environment.
  • pre-commit passes on my local development environment.

@michplunkett michplunkett self-assigned this Dec 18, 2024
@michplunkett michplunkett linked an issue Dec 18, 2024 that may be closed by this pull request
Comment on lines 18 to 19
@v1.route("/departments/<int:department_id>/officers", methods=[HTTPMethod.GET])
def download_dept_officers(department_id: int):
Copy link
Collaborator Author

Choose a reason for hiding this comment

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

Using one of the formats here: #385 (comment)

Thoughts, @sea-kelp @abandoned-prototype @b-meson @AetherUnbound?

@michplunkett michplunkett changed the title Add data API Add v1 data API Dec 19, 2024
@michplunkett michplunkett changed the title Add v1 data API WIP: Add v1 data API Dec 21, 2024
michplunkett added a commit that referenced this pull request Jan 2, 2025
## Description of Changes
Addressed inconsistencies with the model `__repr__` functions.

Mostly making this because this PR got a bit out of control:
#1138

## Tests and Linting
- [x] This branch is up-to-date with the `develop` branch.
- [x] `pytest` passes on my local development environment.
- [x] `pre-commit` passes on my local development environment.
michplunkett added a commit that referenced this pull request Jan 6, 2025
## Fixes issue
Sets the groundwork for this issue:
#385

## Description of Changes
Simplifying the import logic for the `auth` and `main` routes of the
application. This also sets up the work for this PR:
#1138

## Tests and Linting
- [x] This branch is up-to-date with the `develop` branch.
- [x] `pytest` passes on my local development environment.
- [x] `pre-commit` passes on my local development environment.
@michplunkett michplunkett changed the title WIP: Add v1 data API Add API endpoints for departments Jan 17, 2025
@michplunkett michplunkett removed a link to an issue Jan 17, 2025
@michplunkett michplunkett marked this pull request as ready for review January 17, 2025 19:13
Comment on lines +134 to +145
cache_params = (Department(id=department_id), KEY_DEPT_ALL_NOTES)
notes = get_database_cache_entry(*cache_params)

if notes is None:
notes = (
db.session.query(Description)
.join(Description.officer)
.filter(Officer.department_id == department_id)
.options(contains_eager(Description.officer))
.all()
)
put_database_cache_entry(*cache_params, notes)
Copy link
Collaborator Author

Choose a reason for hiding this comment

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

It might be worth moving these to static functions on each of the objects since they are used both here and in views.

@michplunkett
Copy link
Collaborator Author

Things that might be needed, are documentation for these endpoints. I'm not sure what a good protocol is for that rn, though I'm welcome to suggestions.

Comment on lines +38 to +41
resp_assignments = client.get(
url_for("v1.get_dept_assignments", department_id=department_id),
follow_redirects=True,
)
Copy link
Collaborator Author

Choose a reason for hiding this comment

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

I could probably get rid of follow_redirects, but I think it might be worth keeping in case we modify the endpoint at some point.

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

Successfully merging this pull request may close these issues.

1 participant