Commit c5c78bd
authored
Agh gsr booking (#365)
* Implement AGH GSR booking (still need accurate gsr_data and database migration)
* feat: update gsr_data with AGH gid, lid, rename LibCal credentials to GENERAL_LIBCAL_* for clarity
* fix(gsr): fix AGH booking security vulnerabilities and improve reliability
- Fix critical room authorization bypass in PennGroupsBookingWrapper
- Replace insecure substring matching with precise room number extraction
- Add HTTP status validation and consistent error messaging
- Extract helper methods to eliminate code duplication
- Map LibCal room names to PennGroups extensions correctly
* Fix flake8 linting errors in gsr_booking
Fixes whitespace, import ordering, line lengths, and other
style issues to ensure code passes pre-commit hooks.
* Fix remaining linting issues in gsr_booking
- Add missing newline, fix import ordering, clean whitespace
* Format gsr_booking with black and ruff
- Split long lines and apply consistent formatting
* feat: add SEAS booking support for Amy Gutmann Hall
Add migration 0013 to support SEAS user bookings:
- Add GroupMembership.is_seas field for SEAS affiliation tracking
- Add PENNGRP to GSR.kind choices for SEAS locations
- Update test expectations for AGH at position 2 in GSR data
* Fix PennGroups API error handling in get_authorized_rooms
Raise APIError on connection/API failures instead of returning None.
Only return {} for SUBJECT_NOT_FOUND (not SEAS). Distinguishes API
errors from user eligibility.
* feat: adding gsr booking api credentials to base.py, modify add_pennlabs_users to include seas in zip
* feat: Add SEAS status checking and improve API error handling
- Integrate PennGroups API for SEAS membership verification
- Add is_seas field and AGH room authorization checks
- Standardize error handling: both is_wharton() and is_seas() now raise APIError
- Add graceful fallbacks in model layer (check_wharton/check_seas)
- Update tests with proper mocking for all API calls
* feat: Implement GSR filtering by membership and fix test mocking
- Add dynamic GSR filtering in Locations view based on Wharton/SEAS status
- Penn Labs members see all GSRs (administrative override)
- Fix test mock decorator conflicts by moving to method-level
- Add comprehensive test coverage for location filtering (7 new tests)
- Add mock JSON files for PennGroups API responses
- Add graceful error handling for API failures
All 67 GSR booking tests pass. Backward compatible.
* fix: Use response data directly in location filtering tests
Fix CI test failures by reading field from response data
instead of looking up GSRs by ID. This makes tests more robust
and environment-independent.
All tests now use directly from the response
instead of , avoiding DoesNotExist
errors when GSR IDs differ between local and CI environments.
* fix test_get_location_penn_labs_member and test github actions gsr loading
* include gsr count in assert message to debug gsr counts in github actions
* feat(gsr): improve PennGroups/AGH GSR booking tests
- Fix deprecated assertEquals -> assertEqual
- Add 7 new comprehensive tests for PennGroups/AGH functionality
- Fix test_unauthorized_room_booking_fails mock
- Add missing ConnectTimeout import
* add clear cache to locations tests to hopefully fix ci/cd testing?
* fix(gsr): implement per-permission-level caching for locations endpoint
* fix: add back accidentally deleted task, slightly improve test documentation
* Fix PennGroups API to use pennid and add local dev support
- Update get_authorized_rooms to use pennid instead of username for PennGroups API calls
- Add get_user_pennid helper to extract pennid from Platform API
- Add bearer token fallback in get_user_info for local development when IPC fails
- Update tests to mock get_user_pennid method
- Add .env file with local development credentials
* fix(gsr): handle LibCal space/item API returning list
* fix: resolve merge conflicts with main in gsr_booking.
* fix(gsr): correctly match both numeric and alphanumeric room identifiers.
* refactor(gsr): simplify permission check error handling and add logging
- Add logging to is_wharton() and is_seas() to track API failures
- Return False instead of raising errors for failed permission checks
- Remove need for try/except boilerplate from views, models, and commands1 parent a4e6fa7 commit c5c78bd
23 files changed
Lines changed: 1864 additions & 86 deletions
File tree
- backend
- gsr_booking
- data
- management/commands
- migrations
- pennmobile/settings
- portal
- tests/gsr_booking
Large diffs are not rendered by default.
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | 1 | | |
2 | 2 | | |
| 3 | + | |
3 | 4 | | |
4 | 5 | | |
5 | 6 | | |
| |||
Lines changed: 17 additions & 4 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | 1 | | |
2 | 2 | | |
3 | 3 | | |
4 | | - | |
| 4 | + | |
5 | 5 | | |
6 | 6 | | |
7 | 7 | | |
| |||
21 | 21 | | |
22 | 22 | | |
23 | 23 | | |
| 24 | + | |
24 | 25 | | |
25 | 26 | | |
26 | 27 | | |
| |||
34 | 35 | | |
35 | 36 | | |
36 | 37 | | |
| 38 | + | |
37 | 39 | | |
38 | 40 | | |
39 | 41 | | |
| 42 | + | |
| 43 | + | |
40 | 44 | | |
41 | 45 | | |
42 | 46 | | |
43 | | - | |
44 | | - | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
45 | 56 | | |
46 | 57 | | |
47 | 58 | | |
48 | 59 | | |
49 | 60 | | |
50 | | - | |
| 61 | + | |
51 | 62 | | |
52 | 63 | | |
53 | 64 | | |
| |||
56 | 67 | | |
57 | 68 | | |
58 | 69 | | |
| 70 | + | |
59 | 71 | | |
60 | 72 | | |
61 | 73 | | |
| |||
64 | 76 | | |
65 | 77 | | |
66 | 78 | | |
| 79 | + | |
67 | 80 | | |
68 | 81 | | |
69 | 82 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
2 | 2 | | |
3 | 3 | | |
4 | 4 | | |
5 | | - | |
| 5 | + | |
6 | 6 | | |
7 | 7 | | |
8 | 8 | | |
| |||
17 | 17 | | |
18 | 18 | | |
19 | 19 | | |
20 | | - | |
21 | | - | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
22 | 32 | | |
23 | | - | |
| 33 | + | |
Lines changed: 29 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
Lines changed: 8 additions & 3 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
6 | 6 | | |
7 | 7 | | |
8 | 8 | | |
9 | | - | |
| 9 | + | |
10 | 10 | | |
11 | 11 | | |
12 | 12 | | |
13 | 13 | | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
14 | 17 | | |
15 | 18 | | |
16 | | - | |
| 19 | + | |
17 | 20 | | |
18 | 21 | | |
19 | 22 | | |
20 | 23 | | |
21 | 24 | | |
22 | 25 | | |
23 | 26 | | |
24 | | - | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
Lines changed: 27 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
Lines changed: 13 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | 1 | | |
2 | 2 | | |
3 | 3 | | |
| 4 | + | |
4 | 5 | | |
| 6 | + | |
| 7 | + | |
5 | 8 | | |
6 | 9 | | |
7 | 10 | | |
| |||
30 | 33 | | |
31 | 34 | | |
32 | 35 | | |
| 36 | + | |
| 37 | + | |
33 | 38 | | |
34 | 39 | | |
35 | 40 | | |
| |||
38 | 43 | | |
39 | 44 | | |
40 | 45 | | |
41 | | - | |
| 46 | + | |
42 | 47 | | |
43 | 48 | | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
44 | 52 | | |
45 | 53 | | |
46 | 54 | | |
47 | 55 | | |
48 | 56 | | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
49 | 60 | | |
50 | 61 | | |
51 | 62 | | |
| |||
95 | 106 | | |
96 | 107 | | |
97 | 108 | | |
98 | | - | |
| 109 | + | |
| 110 | + | |
| 111 | + | |
| 112 | + | |
| 113 | + | |
| 114 | + | |
99 | 115 | | |
100 | 116 | | |
101 | 117 | | |
| |||
163 | 179 | | |
164 | 180 | | |
165 | 181 | | |
166 | | - | |
| 182 | + | |
| 183 | + | |
| 184 | + | |
| 185 | + | |
| 186 | + | |
| 187 | + | |
| 188 | + | |
| 189 | + | |
| 190 | + | |
| 191 | + | |
| 192 | + | |
| 193 | + | |
| 194 | + | |
| 195 | + | |
| 196 | + | |
| 197 | + | |
| 198 | + | |
| 199 | + | |
| 200 | + | |
| 201 | + | |
| 202 | + | |
| 203 | + | |
| 204 | + | |
| 205 | + | |
| 206 | + | |
| 207 | + | |
| 208 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | 1 | | |
2 | | - | |
3 | 2 | | |
4 | 3 | | |
5 | 4 | | |
6 | 5 | | |
7 | 6 | | |
8 | 7 | | |
| 8 | + | |
9 | 9 | | |
10 | 10 | | |
11 | 11 | | |
| |||
15 | 15 | | |
16 | 16 | | |
17 | 17 | | |
18 | | - | |
19 | 18 | | |
20 | 19 | | |
21 | 20 | | |
| |||
27 | 26 | | |
28 | 27 | | |
29 | 28 | | |
30 | | - | |
| 29 | + | |
31 | 30 | | |
32 | 31 | | |
| 32 | + | |
33 | 33 | | |
34 | 34 | | |
35 | 35 | | |
| |||
0 commit comments