-
Notifications
You must be signed in to change notification settings - Fork 522
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 function to authorize user to register patient #9000
Add function to authorize user to register patient #9000
Conversation
WalkthroughThe changes introduce the Changes
Assessment against linked issues
Possibly related PRs
Suggested labels
Suggested reviewers
Poem
Warning There were issues while running some tools. Please review the errors and either fix the tool’s configuration or disable the tool if it’s a critical failure. 🔧 eslint
src/components/Facility/FacilityHome.tsxOops! Something went wrong! :( ESLint: 8.57.1 Error: Failed to load parser '@typescript-eslint/parser' declared in '.eslintrc.json': Cannot find module '@typescript-eslint/parser'
Thank you for using CodeRabbit. We offer it for free to the OSS community and would appreciate your support in helping us grow. If you find it useful, would you consider giving us a shout-out on your favorite social media? 🪧 TipsChatThere are 3 ways to chat with CodeRabbit:
Note: Be mindful of the bot's finite context window. It's strongly recommended to break down tasks such as reading entire modules into smaller chunks. For a focused discussion, use review comments to chat about specific files and their changes, instead of using the PR comments. CodeRabbit Commands (Invoked using PR comments)
Other keywords and placeholders
CodeRabbit Configuration File (
|
✅ Deploy Preview for care-ohc ready!
To edit notification comments on pull requests, go to your Netlify site configuration. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 1
🧹 Outside diff range and nitpick comments (1)
src/components/Facility/FacilityHome.tsx (1)
488-500
: Button implementation needs minor improvementsThe conditional rendering successfully prevents unauthorized access, addressing the PR objective. However, there are a few improvements to consider:
- Update the function name once fixed (from previous comment)
- Add an id attribute for testing/accessibility
Apply these improvements:
-{isAuthorizedToRegisterPatientsterAuth() && ( +{isAuthorizedToRegisterPatientsAuth() && ( <ButtonV2 + id="add-patient-details-button" variant="primary" ghost border className="mt-2 flex w-full flex-row justify-center md:w-auto" onClick={() => navigate(`/facility/${facilityId}/patient`)} authorizeFor={NonReadOnlyUsers} > <CareIcon icon="l-plus" className="text-lg" /> <span className="text-sm">{t("add_details_of_patient")}</span> </ButtonV2> )}
📜 Review details
Configuration used: CodeRabbit UI
Review profile: CHILL
📒 Files selected for processing (1)
src/components/Facility/FacilityHome.tsx
(2 hunks)
🔇 Additional comments (1)
src/components/Facility/FacilityHome.tsx (1)
160-182
: Verify the authorization implementation fixes the infinite loop issue
The implementation appears to properly address the infinite loop issue by:
- Preventing unauthorized access through proper authorization checks
- Hiding the "Add Details of Patient" button for unauthorized users
- Properly handling different user types and their permissions
Let's verify there are no other instances of patient registration routes that could bypass this check.
Also applies to: 488-500
✅ Verification successful
Authorization checks are properly implemented across patient registration flow
The verification confirms that the infinite loop issue is properly addressed through consistent authorization checks:
FacilityHome.tsx
has proper authorization checks before showing the registration buttonPatientRegister.tsx
implements identical authorization logic preventing unauthorized accessManagePatients.tsx
enforces the same authorization rules with proper redirects- Router configuration in
PatientRoutes.tsx
shows all patient-related routes are properly structured
The implementation successfully prevents unauthorized access and infinite loops by consistently checking user permissions across all components in the patient registration flow.
🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash
# Search for patient registration routes and verify they're protected
echo "Searching for patient registration routes..."
rg -l "facility/\$\{.*\}/patient" --type ts --type tsx
echo "Searching for navigation to patient registration..."
rg "navigate\(.*facility.*patient" --type ts --type tsx
Length of output: 381
Script:
#!/bin/bash
# Search for patient registration routes and verify they're protected
echo "Searching for patient registration routes..."
rg -l "facility.*patient"
echo "Searching for navigation to patient registration..."
rg "navigate.*facility.*patient" -A 2
Length of output: 5813
Script:
#!/bin/bash
# Check the PatientRegister component for authorization checks
echo "Checking PatientRegister component for auth checks..."
rg "isAuthorized|user_type|authUser" src/components/Patient/PatientRegister.tsx -B 2 -A 2
# Check ManagePatients component for auth checks
echo "Checking ManagePatients component for auth checks..."
rg "isAuthorized|user_type|authUser" src/components/Patient/ManagePatients.tsx -B 2 -A 2
# Check router configuration for patient routes
echo "Checking router protection..."
rg "PatientRegister|patient" src/Routers/routes/PatientRoutes.tsx -B 2 -A 2
Length of output: 4653
@JavidSumra iam seeing changes suggested by ai, look into that as well |
we already have this auth defined in the code base, so use that rather than duplicating it :) |
…f github.com:JavidSumra/care_fe into issues/8988/fix-infinite-rendering-non-home-facility
…ring-non-home-facility
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 2
📜 Review details
Configuration used: CodeRabbit UI
Review profile: CHILL
📒 Files selected for processing (1)
src/components/Patient/PatientRegister.tsx
(4 hunks)
🔇 Additional comments (1)
src/components/Patient/PatientRegister.tsx (1)
1877-1903
: Verify authorization implementation consistency.
Based on the PR comments mentioning existing authorization checks, let's verify:
- If this implementation duplicates existing authorization logic
- If this function is used consistently across all patient registration points
✅ Verification successful
Authorization implementation is consistent and well-integrated
The verification reveals that:
- The
PatientRegisterAuth
function follows existing authorization patterns in the codebase, similar to those inpermissions.ts
andAuthorizedChild.tsx
- It's properly integrated in both
PatientRegister.tsx
andFacilityHome.tsx
components - The implementation aligns with the existing role-based access control system using
user_type
checks - No duplicate authorization logic was found for patient registration
🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash
# Description: Search for existing authorization checks and patient registration points
# Test 1: Look for existing authorization checks
echo "Searching for existing authorization checks..."
rg -l "isAuthorized|canAccess|hasPermission|checkPermission" --type ts --type tsx
# Test 2: Look for patient registration components/routes
echo "Searching for patient registration components..."
rg -l "PatientRegister|addPatient|registerPatient" --type ts --type tsx
# Test 3: Look for facility access checks
echo "Searching for facility access checks..."
rg "facility.*access|access.*facility" --type ts --type tsx
Length of output: 602
Script:
#!/bin/bash
# Description: Search for existing authorization checks and patient registration points
# Test 1: Look for existing authorization checks
echo "Searching for existing authorization checks..."
rg -l "isAuthorized|canAccess|hasPermission|checkPermission"
# Test 2: Look for patient registration components/routes
echo "Searching for patient registration components..."
rg -l "PatientRegister|addPatient|registerPatient"
# Test 3: Look for facility access checks
echo "Searching for facility access checks..."
rg "facility.*access|access.*facility"
# Test 4: Look for similar authorization patterns
echo "Searching for similar authorization patterns..."
rg "user_type.*=.*(\"|').*Admin(\"|')"
# Test 5: Look for usage of PatientRegisterAuth
echo "Searching for PatientRegisterAuth usage..."
rg "PatientRegisterAuth"
Length of output: 4319
Script:
#!/bin/bash
# Let's examine the existing authorization implementations
# Check AuthorizedChild implementation
echo "Checking AuthorizedChild implementation..."
cat src/CAREUI/misc/AuthorizedChild.tsx
# Check permissions.ts implementation
echo "Checking permissions.ts implementation..."
cat src/Utils/permissions.ts
# Check FacilityHome usage context
echo "Checking FacilityHome usage context..."
rg -A 5 -B 5 "PatientRegisterAuth" src/components/Facility/FacilityHome.tsx
Length of output: 2955
Hey, @nihal467 requested changes are done can you please review this PR? |
👋 Hi, @JavidSumra, This message is automatically generated by prince-chrismc/label-merge-conflicts-action so don't hesitate to report issues/improvements there. |
Proposed Changes
isAuthorizedToRegisterPatient
function to handle authorization checks when adding a new patient from the "View Facility" page.@ohcnetwork/care-fe-code-reviewers
Merge Checklist
Summary by CodeRabbit
New Features
Bug Fixes