diff --git a/.github/workflows/build-images-from-branch.yml b/.github/workflows/build-images-from-branch.yml
index f9051506d0a..b5d03c5f191 100644
--- a/.github/workflows/build-images-from-branch.yml
+++ b/.github/workflows/build-images-from-branch.yml
@@ -49,11 +49,11 @@ jobs:
echo "Pushing version $VERSION"
echo "version=$VERSION" >> $GITHUB_OUTPUT
if [ "${{ github.event_name }}" == 'push' ]; then
- BRANCH=${GITHUB_HEAD_REF:-${GITHUB_REF#refs/heads/}}
+ BRANCH=${GITHUB_HEAD_REF:-${GITHUB_REF#refs/heads/}}
elif [ "${{ github.event_name }}" == 'pull_request' ]; then
- BRANCH=${{ github.event.pull_request.head.ref }}
+ BRANCH=${{ github.event.pull_request.head.ref }}
else
- BRANCH=${{ inputs.branch_name }}
+ BRANCH=${{ inputs.branch_name }}
fi
ESCAPED_BRANCH=$(echo $BRANCH | sed 's/[^a-zA-Z0-9_.-]/-/g')
echo "from branch $BRANCH"
diff --git a/CHANGELOG.md b/CHANGELOG.md
index 1de1ed2c9f1..e0e5a8e4b6a 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -61,6 +61,7 @@
- Fix hardcoded placeholder copy of input when saving a query in advanced search
- Handle label params used in form inputs when rendering in action details modal
- **Staged files getting reset on precommit hook failure** We were running lint-staged separately on each package using lerna which potentially created a race condition causing staged changes to get lost on failure. Now we are running lint-staged directly without depending on lerna. **_This is purely a DX improvement without affecting any functionality of the system_**
+- Fix `informantType` missing in template object which prevented rendering informant relationship data in the certificates [#5952](https://github.com/opencrvs/opencrvs-core/issues/5952)
### Breaking changes
diff --git a/packages/client/graphql.schema.json b/packages/client/graphql.schema.json
index ea0e0a08061..4abbfabc0dc 100644
--- a/packages/client/graphql.schema.json
+++ b/packages/client/graphql.schema.json
@@ -9860,6 +9860,39 @@
"isDeprecated": false,
"deprecationReason": null
},
+ {
+ "name": "confirmRegistration",
+ "description": null,
+ "args": [
+ {
+ "name": "id",
+ "description": null,
+ "type": {
+ "kind": "NON_NULL",
+ "name": null,
+ "ofType": {
+ "kind": "SCALAR",
+ "name": "ID",
+ "ofType": null
+ }
+ },
+ "defaultValue": null,
+ "isDeprecated": false,
+ "deprecationReason": null
+ }
+ ],
+ "type": {
+ "kind": "NON_NULL",
+ "name": null,
+ "ofType": {
+ "kind": "SCALAR",
+ "name": "ID",
+ "ofType": null
+ }
+ },
+ "isDeprecated": false,
+ "deprecationReason": null
+ },
{
"name": "createBirthRegistration",
"description": null,
@@ -11605,356 +11638,6 @@
],
"possibleTypes": null
},
- {
- "kind": "OBJECT",
- "name": "OIDPUserAddress",
- "description": null,
- "fields": [
- {
- "name": "city",
- "description": null,
- "args": [],
- "type": {
- "kind": "SCALAR",
- "name": "String",
- "ofType": null
- },
- "isDeprecated": false,
- "deprecationReason": null
- },
- {
- "name": "country",
- "description": null,
- "args": [],
- "type": {
- "kind": "SCALAR",
- "name": "String",
- "ofType": null
- },
- "isDeprecated": false,
- "deprecationReason": null
- },
- {
- "name": "formatted",
- "description": null,
- "args": [],
- "type": {
- "kind": "SCALAR",
- "name": "String",
- "ofType": null
- },
- "isDeprecated": false,
- "deprecationReason": null
- },
- {
- "name": "locality",
- "description": null,
- "args": [],
- "type": {
- "kind": "SCALAR",
- "name": "String",
- "ofType": null
- },
- "isDeprecated": false,
- "deprecationReason": null
- },
- {
- "name": "postal_code",
- "description": null,
- "args": [],
- "type": {
- "kind": "SCALAR",
- "name": "String",
- "ofType": null
- },
- "isDeprecated": false,
- "deprecationReason": null
- },
- {
- "name": "region",
- "description": null,
- "args": [],
- "type": {
- "kind": "SCALAR",
- "name": "String",
- "ofType": null
- },
- "isDeprecated": false,
- "deprecationReason": null
- },
- {
- "name": "street_address",
- "description": null,
- "args": [],
- "type": {
- "kind": "SCALAR",
- "name": "String",
- "ofType": null
- },
- "isDeprecated": false,
- "deprecationReason": null
- }
- ],
- "inputFields": null,
- "interfaces": [],
- "enumValues": null,
- "possibleTypes": null
- },
- {
- "kind": "OBJECT",
- "name": "OIDPUserInfo",
- "description": null,
- "fields": [
- {
- "name": "address",
- "description": null,
- "args": [],
- "type": {
- "kind": "OBJECT",
- "name": "OIDPUserAddress",
- "ofType": null
- },
- "isDeprecated": false,
- "deprecationReason": null
- },
- {
- "name": "birthdate",
- "description": null,
- "args": [],
- "type": {
- "kind": "SCALAR",
- "name": "String",
- "ofType": null
- },
- "isDeprecated": false,
- "deprecationReason": null
- },
- {
- "name": "email",
- "description": null,
- "args": [],
- "type": {
- "kind": "SCALAR",
- "name": "String",
- "ofType": null
- },
- "isDeprecated": false,
- "deprecationReason": null
- },
- {
- "name": "email_verified",
- "description": null,
- "args": [],
- "type": {
- "kind": "SCALAR",
- "name": "Boolean",
- "ofType": null
- },
- "isDeprecated": false,
- "deprecationReason": null
- },
- {
- "name": "family_name",
- "description": null,
- "args": [],
- "type": {
- "kind": "SCALAR",
- "name": "String",
- "ofType": null
- },
- "isDeprecated": false,
- "deprecationReason": null
- },
- {
- "name": "gender",
- "description": null,
- "args": [],
- "type": {
- "kind": "SCALAR",
- "name": "String",
- "ofType": null
- },
- "isDeprecated": false,
- "deprecationReason": null
- },
- {
- "name": "given_name",
- "description": null,
- "args": [],
- "type": {
- "kind": "SCALAR",
- "name": "String",
- "ofType": null
- },
- "isDeprecated": false,
- "deprecationReason": null
- },
- {
- "name": "locale",
- "description": null,
- "args": [],
- "type": {
- "kind": "SCALAR",
- "name": "String",
- "ofType": null
- },
- "isDeprecated": false,
- "deprecationReason": null
- },
- {
- "name": "middle_name",
- "description": null,
- "args": [],
- "type": {
- "kind": "SCALAR",
- "name": "String",
- "ofType": null
- },
- "isDeprecated": false,
- "deprecationReason": null
- },
- {
- "name": "name",
- "description": null,
- "args": [],
- "type": {
- "kind": "SCALAR",
- "name": "String",
- "ofType": null
- },
- "isDeprecated": false,
- "deprecationReason": null
- },
- {
- "name": "nickname",
- "description": null,
- "args": [],
- "type": {
- "kind": "SCALAR",
- "name": "String",
- "ofType": null
- },
- "isDeprecated": false,
- "deprecationReason": null
- },
- {
- "name": "phone_number",
- "description": null,
- "args": [],
- "type": {
- "kind": "SCALAR",
- "name": "String",
- "ofType": null
- },
- "isDeprecated": false,
- "deprecationReason": null
- },
- {
- "name": "phone_number_verified",
- "description": null,
- "args": [],
- "type": {
- "kind": "SCALAR",
- "name": "Boolean",
- "ofType": null
- },
- "isDeprecated": false,
- "deprecationReason": null
- },
- {
- "name": "picture",
- "description": null,
- "args": [],
- "type": {
- "kind": "SCALAR",
- "name": "String",
- "ofType": null
- },
- "isDeprecated": false,
- "deprecationReason": null
- },
- {
- "name": "preferred_username",
- "description": null,
- "args": [],
- "type": {
- "kind": "SCALAR",
- "name": "String",
- "ofType": null
- },
- "isDeprecated": false,
- "deprecationReason": null
- },
- {
- "name": "profile",
- "description": null,
- "args": [],
- "type": {
- "kind": "SCALAR",
- "name": "String",
- "ofType": null
- },
- "isDeprecated": false,
- "deprecationReason": null
- },
- {
- "name": "sub",
- "description": null,
- "args": [],
- "type": {
- "kind": "NON_NULL",
- "name": null,
- "ofType": {
- "kind": "SCALAR",
- "name": "String",
- "ofType": null
- }
- },
- "isDeprecated": false,
- "deprecationReason": null
- },
- {
- "name": "updated_at",
- "description": null,
- "args": [],
- "type": {
- "kind": "SCALAR",
- "name": "Int",
- "ofType": null
- },
- "isDeprecated": false,
- "deprecationReason": null
- },
- {
- "name": "website",
- "description": null,
- "args": [],
- "type": {
- "kind": "SCALAR",
- "name": "String",
- "ofType": null
- },
- "isDeprecated": false,
- "deprecationReason": null
- },
- {
- "name": "zoneinfo",
- "description": null,
- "args": [],
- "type": {
- "kind": "SCALAR",
- "name": "String",
- "ofType": null
- },
- "isDeprecated": false,
- "deprecationReason": null
- }
- ],
- "inputFields": null,
- "interfaces": [],
- "enumValues": null,
- "possibleTypes": null
- },
{
"kind": "INPUT_OBJECT",
"name": "ObservationFHIRIDS",
@@ -13767,79 +13450,6 @@
"isDeprecated": false,
"deprecationReason": null
},
- {
- "name": "getOIDPUserInfo",
- "description": null,
- "args": [
- {
- "name": "clientId",
- "description": null,
- "type": {
- "kind": "NON_NULL",
- "name": null,
- "ofType": {
- "kind": "SCALAR",
- "name": "String",
- "ofType": null
- }
- },
- "defaultValue": null,
- "isDeprecated": false,
- "deprecationReason": null
- },
- {
- "name": "code",
- "description": null,
- "type": {
- "kind": "NON_NULL",
- "name": null,
- "ofType": {
- "kind": "SCALAR",
- "name": "String",
- "ofType": null
- }
- },
- "defaultValue": null,
- "isDeprecated": false,
- "deprecationReason": null
- },
- {
- "name": "grantType",
- "description": null,
- "type": {
- "kind": "SCALAR",
- "name": "String",
- "ofType": null
- },
- "defaultValue": null,
- "isDeprecated": false,
- "deprecationReason": null
- },
- {
- "name": "redirectUri",
- "description": null,
- "type": {
- "kind": "NON_NULL",
- "name": null,
- "ofType": {
- "kind": "SCALAR",
- "name": "String",
- "ofType": null
- }
- },
- "defaultValue": null,
- "isDeprecated": false,
- "deprecationReason": null
- }
- ],
- "type": {
- "kind": "OBJECT",
- "name": "UserInfo",
- "ofType": null
- },
- "isDeprecated": false,
- "deprecationReason": null
- },
{
"name": "getRegistrationsListByFilter",
"description": null,
@@ -19816,65 +19426,6 @@
"enumValues": null,
"possibleTypes": null
},
- {
- "kind": "OBJECT",
- "name": "UserInfo",
- "description": null,
- "fields": [
- {
- "name": "districtFhirId",
- "description": null,
- "args": [],
- "type": {
- "kind": "SCALAR",
- "name": "String",
- "ofType": null
- },
- "isDeprecated": false,
- "deprecationReason": null
- },
- {
- "name": "locationLevel3FhirId",
- "description": null,
- "args": [],
- "type": {
- "kind": "SCALAR",
- "name": "String",
- "ofType": null
- },
- "isDeprecated": false,
- "deprecationReason": null
- },
- {
- "name": "oidpUserInfo",
- "description": null,
- "args": [],
- "type": {
- "kind": "OBJECT",
- "name": "OIDPUserInfo",
- "ofType": null
- },
- "isDeprecated": false,
- "deprecationReason": null
- },
- {
- "name": "stateFhirId",
- "description": null,
- "args": [],
- "type": {
- "kind": "SCALAR",
- "name": "String",
- "ofType": null
- },
- "isDeprecated": false,
- "deprecationReason": null
- }
- ],
- "inputFields": null,
- "interfaces": [],
- "enumValues": null,
- "possibleTypes": null
- },
{
"kind": "INPUT_OBJECT",
"name": "UserInput",
diff --git a/packages/client/src/App.tsx b/packages/client/src/App.tsx
index d6b32c54739..78e43a12276 100644
--- a/packages/client/src/App.tsx
+++ b/packages/client/src/App.tsx
@@ -63,7 +63,6 @@ import { AdministrativeLevels } from '@client/views/Organisation/AdministrativeL
import { VerifyCertificatePage } from '@client/views/VerifyCertificate/VerifyCertificatePage'
import { IssueCertificate } from '@client/views/IssueCertificate/IssueCertificate'
import { IssuePayment } from '@client/views/IssueCertificate/IssueCollectorForm/IssuePayment'
-import { OIDPVerificationCallback } from './views/OIDPVerificationCallback/OIDPVerificationCallback'
import { ApolloProvider } from '@client/utils/ApolloProvider'
import { Home } from '@client/views/OfficeHome/Home'
import { PrintRecord } from './views/PrintRecord/PrintRecord'
@@ -533,15 +532,6 @@ export function App(props: IAppProps) {
}
component={IssuePayment}
/>
-
(
(val: string) => setFieldValue(fieldDefinition.name, val),
[fieldDefinition.name, setFieldValue]
)
- const isOnline = useOnlineStatus()
const inputProps = {
id: fieldDefinition.name,
@@ -615,21 +609,6 @@ const GeneratedInputField = React.memo(
)
}
- if (fieldDefinition.type === NID_VERIFICATION_BUTTON) {
- return (
-
-
-
- )
- }
-
if (fieldDefinition.type === REDIRECT) {
return (
void
}
interface IDispatchProps {
@@ -1120,18 +1098,12 @@ class FormSectionComponent extends React.Component {
field.searchableType as LocationType[]
)
}
- : field.type === NID_VERIFICATION_BUTTON
- ? ({
- ...field,
- onClick: this.props.onNidAuthenticationClick
- } as INidVerificationButton)
: field
if (
field.type === FETCH_BUTTON ||
field.type === FIELD_WITH_DYNAMIC_DEFINITIONS ||
field.type === SELECT_WITH_DYNAMIC_OPTIONS ||
- field.type === NID_VERIFICATION_BUTTON ||
field.type === BUTTON
) {
return (
@@ -1311,7 +1283,6 @@ export const FormFieldGenerator: React.FC = (props) => {
const userDetails = useSelector(getUserDetails)
const intl = useIntl()
const dispatch = useDispatch()
- const { onClick: onNidAuthenticationClick } = useNidAuthentication()
return (
@@ -1345,7 +1316,6 @@ export const FormFieldGenerator: React.FC = (props) => {
offlineCountryConfig={offlineCountryConfig}
userDetails={userDetails}
dynamicDispatch={(...args) => dispatch(dynamicDispatch(...args))}
- onNidAuthenticationClick={onNidAuthenticationClick}
/>
)}
diff --git a/packages/client/src/forms/index.ts b/packages/client/src/forms/index.ts
index e13538d0534..8ef12d4503b 100644
--- a/packages/client/src/forms/index.ts
+++ b/packages/client/src/forms/index.ts
@@ -69,7 +69,6 @@ export const DYNAMIC_LIST = 'DYNAMIC_LIST'
export const FETCH_BUTTON = 'FETCH_BUTTON'
export const LOCATION_SEARCH_INPUT = 'LOCATION_SEARCH_INPUT'
export const TIME = 'TIME'
-export const NID_VERIFICATION_BUTTON = 'NID_VERIFICATION_BUTTON'
export const DIVIDER = 'DIVIDER'
export const HEADING3 = 'HEADING3'
export const SIGNATURE = 'SIGNATURE'
@@ -716,12 +715,6 @@ export interface ITimeFormFIeld extends IFormFieldBase {
type: typeof TIME
ignorePlaceHolder?: boolean
}
-export interface INidVerificationButton extends IFormFieldBase {
- type: typeof NID_VERIFICATION_BUTTON
- labelForVerified: MessageDescriptor
- labelForUnverified: MessageDescriptor
- labelForOffline: MessageDescriptor
-}
export interface ISignatureFormField extends IFormFieldBase {
type: typeof SIGNATURE
@@ -790,7 +783,6 @@ export type IFormField =
| ILocationSearchInputFormField
| IDateRangePickerFormField
| ITimeFormFIeld
- | INidVerificationButton
| IDividerFormField
| ISignatureFormField
| IHttpFormField
@@ -1231,13 +1223,6 @@ export interface Ii18nLoaderButtonField extends Ii18nFormFieldBase {
errorText: string
networkErrorText: string
}
-export interface Ii18nNidVerificationButtonField extends Ii18nFormFieldBase {
- type: typeof NID_VERIFICATION_BUTTON
- onClick: () => void
- labelForVerified: string
- labelForUnverified: string
- labelForOffline: string
-}
export interface I18nDividerField extends Ii18nFormFieldBase {
type: typeof DIVIDER
@@ -1317,7 +1302,6 @@ export type Ii18nFormField =
| Ii18nLocationSearchInputFormField
| Ii18nDateRangePickerFormField
| Ii18nTimeFormField
- | Ii18nNidVerificationButtonField
| I18nDividerField
| I18nHeading3Field
| Ii18nSignatureField
diff --git a/packages/client/src/forms/register/mappings/query/field-mappings.ts b/packages/client/src/forms/register/mappings/query/field-mappings.ts
index 98b898271e0..1628ff15b41 100644
--- a/packages/client/src/forms/register/mappings/query/field-mappings.ts
+++ b/packages/client/src/forms/register/mappings/query/field-mappings.ts
@@ -109,6 +109,9 @@ export const fieldValueTransformer =
sectionId: SectionId,
field: IFormField
) => {
+ if (!(sectionId in transformedData)) {
+ transformedData[sectionId] = {}
+ }
if (queryData[sectionId] && queryData[sectionId][transformedFieldName]) {
transformedData[sectionId][field.name] =
queryData[sectionId][transformedFieldName]
diff --git a/packages/client/src/forms/utils.ts b/packages/client/src/forms/utils.ts
index c732a35549c..9c7e35dd56f 100644
--- a/packages/client/src/forms/utils.ts
+++ b/packages/client/src/forms/utils.ts
@@ -41,8 +41,6 @@ import {
FIELD_WITH_DYNAMIC_DEFINITIONS,
IRadioGroupWithNestedFieldsFormField,
ISelectFormFieldWithOptions,
- NID_VERIFICATION_BUTTON,
- INidVerificationButton,
BULLET_LIST,
HIDDEN,
Ii18nHiddenFormField,
@@ -190,18 +188,6 @@ export const internationaliseFieldObject = (
)
}
- if (base.type === NID_VERIFICATION_BUTTON) {
- ;(base as any).labelForVerified = intl.formatMessage(
- (field as INidVerificationButton).labelForVerified
- )
- ;(base as any).labelForUnverified = intl.formatMessage(
- (field as INidVerificationButton).labelForUnverified
- )
- ;(base as any).labelForOffline = intl.formatMessage(
- (field as INidVerificationButton).labelForOffline
- )
- }
-
if (isFieldButton(field)) {
;(base as Ii18nButtonFormField).buttonLabel = intl.formatMessage(
field.buttonLabel
diff --git a/packages/client/src/i18n/messages/views/nidVerificationCallback.ts b/packages/client/src/i18n/messages/views/nidVerificationCallback.ts
deleted file mode 100644
index ffda7b5abc6..00000000000
--- a/packages/client/src/i18n/messages/views/nidVerificationCallback.ts
+++ /dev/null
@@ -1,33 +0,0 @@
-/*
- * This Source Code Form is subject to the terms of the Mozilla Public
- * License, v. 2.0. If a copy of the MPL was not distributed with this
- * file, You can obtain one at https://mozilla.org/MPL/2.0/.
- *
- * OpenCRVS is also distributed under the terms of the Civil Registration
- * & Healthcare Disclaimer located at http://opencrvs.org/license.
- *
- * Copyright (C) The OpenCRVS Authors located at https://github.com/opencrvs/opencrvs-core/blob/master/AUTHORS.
- */
-import { defineMessages, MessageDescriptor } from 'react-intl'
-
-interface INidVerfificationCallBackMessages
- extends Record {
- authenticatingNid: MessageDescriptor
- failedToAuthenticateNid: MessageDescriptor
-}
-
-const messagesToDefine: INidVerfificationCallBackMessages = {
- authenticatingNid: {
- defaultMessage: 'Authenticating National ID',
- id: 'misc.nidCallback.authenticatingNid',
- description: 'Label for nid authention ongoing phase'
- },
- failedToAuthenticateNid: {
- defaultMessage: 'Failed to authenticate National ID',
- id: 'misc.nidCallback.failedToAuthenticateNid',
- description: 'Label for nid authention failed phase'
- }
-}
-
-export const messages: INidVerfificationCallBackMessages =
- defineMessages(messagesToDefine)
diff --git a/packages/client/src/navigation/routes.ts b/packages/client/src/navigation/routes.ts
index 15fae4c9741..35395667abe 100644
--- a/packages/client/src/navigation/routes.ts
+++ b/packages/client/src/navigation/routes.ts
@@ -99,6 +99,4 @@ export const VIEW_RECORD = '/:declarationId/viewRecord'
export const VIEW_VERIFY_CERTIFICATE = '/verify-certificate/:declarationId'
export const ORGANISATIONS_INDEX = '/organisation/:locationId?'
-export const OIDP_VERIFICATION_CALLBACK = '/mosip-callback'
-
export const PRINT_RECORD = '/print-record/:declarationId'
diff --git a/packages/client/src/setupTests.ts b/packages/client/src/setupTests.ts
index 087036e3fa9..8d844ab9a87 100644
--- a/packages/client/src/setupTests.ts
+++ b/packages/client/src/setupTests.ts
@@ -278,11 +278,3 @@ vi.mock('react-router', async () => ({
section: 'child'
}))
}))
-
-vi.mock('@client/views/OIDPVerificationCallback/utils', async () => ({
- ...((await vi.importActual(
- '@client/views/OIDPVerificationCallback/utils'
- )) as any),
- useExtractCallBackState: vi.fn(),
- useQueryParams: vi.fn()
-}))
diff --git a/packages/client/src/tests/schema.graphql b/packages/client/src/tests/schema.graphql
index 5ec139d5272..f3cd1807ecc 100644
--- a/packages/client/src/tests/schema.graphql
+++ b/packages/client/src/tests/schema.graphql
@@ -1114,39 +1114,6 @@ input ObservationFHIRIDS {
lastPreviousLiveBirth: String
}
-type OIDPUserAddress {
- formatted: String
- street_address: String
- locality: String
- region: String
- postal_code: String
- city: String
- country: String
-}
-
-type OIDPUserInfo {
- sub: String!
- name: String
- given_name: String
- family_name: String
- middle_name: String
- nickname: String
- preferred_username: String
- profile: String
- picture: String
- website: String
- email: String
- email_verified: Boolean
- gender: String
- birthdate: String
- zoneinfo: String
- locale: String
- phone_number: String
- phone_number_verified: Boolean
- address: OIDPUserAddress
- updated_at: Int
-}
-
type OperationHistorySearchSet {
operationType: String
operatedOn: Date
@@ -1388,12 +1355,6 @@ type Query {
): [SystemRole!]
fetchSystem(clientId: ID!): System
informantSMSNotifications: [SMSNotification!]
- getOIDPUserInfo(
- code: String!
- clientId: String!
- redirectUri: String!
- grantType: String
- ): UserInfo
}
type QuestionnaireQuestion {
@@ -1877,13 +1838,6 @@ input UserIdentifierInput {
value: String
}
-type UserInfo {
- oidpUserInfo: OIDPUserInfo
- districtFhirId: String
- stateFhirId: String
- locationLevel3FhirId: String
-}
-
input UserInput {
id: ID
name: [HumanNameInput!]!
diff --git a/packages/client/src/utils/gateway.ts b/packages/client/src/utils/gateway.ts
index f9b238b2419..3fc5f1fd1a2 100644
--- a/packages/client/src/utils/gateway.ts
+++ b/packages/client/src/utils/gateway.ts
@@ -946,6 +946,7 @@ export type Mutation = {
changeEmail?: Maybe
changePassword?: Maybe
changePhone?: Maybe
+ confirmRegistration: Scalars['ID']
createBirthRegistration: CreatedIds
createBirthRegistrationCorrection: Scalars['ID']
createDeathRegistration: CreatedIds
@@ -1046,6 +1047,10 @@ export type MutationChangePhoneArgs = {
verifyCode: Scalars['String']
}
+export type MutationConfirmRegistrationArgs = {
+ id: Scalars['ID']
+}
+
export type MutationCreateBirthRegistrationArgs = {
details: BirthRegistrationInput
}
@@ -1248,41 +1253,6 @@ export enum NotificationType {
Sms = 'SMS'
}
-export type OidpUserAddress = {
- __typename?: 'OIDPUserAddress'
- city?: Maybe
- country?: Maybe
- formatted?: Maybe
- locality?: Maybe
- postal_code?: Maybe
- region?: Maybe
- street_address?: Maybe
-}
-
-export type OidpUserInfo = {
- __typename?: 'OIDPUserInfo'
- address?: Maybe
- birthdate?: Maybe
- email?: Maybe
- email_verified?: Maybe
- family_name?: Maybe
- gender?: Maybe
- given_name?: Maybe
- locale?: Maybe
- middle_name?: Maybe
- name?: Maybe
- nickname?: Maybe
- phone_number?: Maybe
- phone_number_verified?: Maybe
- picture?: Maybe
- preferred_username?: Maybe
- profile?: Maybe
- sub: Scalars['String']
- updated_at?: Maybe
- website?: Maybe
- zoneinfo?: Maybe
-}
-
export type ObservationFhirids = {
attendantAtBirth?: InputMaybe
birthType?: InputMaybe
@@ -1412,7 +1382,6 @@ export type Query = {
getDeclarationsStartedMetrics?: Maybe
getEventsWithProgress?: Maybe
getLocationStatistics?: Maybe
- getOIDPUserInfo?: Maybe
getRegistrationsListByFilter?: Maybe
getSystemRoles?: Maybe>
getTotalCertifications?: Maybe>
@@ -1510,13 +1479,6 @@ export type QueryGetLocationStatisticsArgs = {
populationYear: Scalars['Int']
}
-export type QueryGetOidpUserInfoArgs = {
- clientId: Scalars['String']
- code: Scalars['String']
- grantType?: InputMaybe
- redirectUri: Scalars['String']
-}
-
export type QueryGetRegistrationsListByFilterArgs = {
event: Scalars['String']
filterBy: Scalars['String']
@@ -2167,14 +2129,6 @@ export type UserIdentifierInput = {
value?: InputMaybe
}
-export type UserInfo = {
- __typename?: 'UserInfo'
- districtFhirId?: Maybe
- locationLevel3FhirId?: Maybe
- oidpUserInfo?: Maybe
- stateFhirId?: Maybe
-}
-
export type UserInput = {
device?: InputMaybe
email?: InputMaybe
@@ -5365,55 +5319,6 @@ export type MarkEventAsNotDuplicateMutation = {
markEventAsNotDuplicate: string
}
-export type GetOidpUserInfoQueryVariables = Exact<{
- code: Scalars['String']
- clientId: Scalars['String']
- redirectUri: Scalars['String']
- grantType?: InputMaybe
-}>
-
-export type GetOidpUserInfoQuery = {
- __typename?: 'Query'
- getOIDPUserInfo?: {
- __typename?: 'UserInfo'
- districtFhirId?: string | null
- stateFhirId?: string | null
- locationLevel3FhirId?: string | null
- oidpUserInfo?: {
- __typename?: 'OIDPUserInfo'
- sub: string
- name?: string | null
- given_name?: string | null
- family_name?: string | null
- middle_name?: string | null
- nickname?: string | null
- preferred_username?: string | null
- profile?: string | null
- picture?: string | null
- website?: string | null
- email?: string | null
- email_verified?: boolean | null
- gender?: string | null
- birthdate?: string | null
- zoneinfo?: string | null
- locale?: string | null
- phone_number?: string | null
- phone_number_verified?: boolean | null
- updated_at?: number | null
- address?: {
- __typename?: 'OIDPUserAddress'
- formatted?: string | null
- street_address?: string | null
- locality?: string | null
- region?: string | null
- postal_code?: string | null
- city?: string | null
- country?: string | null
- } | null
- } | null
- } | null
-}
-
type EventSearchFields_BirthEventSearchSet_Fragment = {
__typename?: 'BirthEventSearchSet'
dateOfBirth?: PlainDate | null
diff --git a/packages/client/src/views/OIDPVerificationCallback/OIDPVerificationCallback.test.tsx b/packages/client/src/views/OIDPVerificationCallback/OIDPVerificationCallback.test.tsx
deleted file mode 100644
index 4b8d9e005b1..00000000000
--- a/packages/client/src/views/OIDPVerificationCallback/OIDPVerificationCallback.test.tsx
+++ /dev/null
@@ -1,164 +0,0 @@
-/*
- * This Source Code Form is subject to the terms of the Mozilla Public
- * License, v. 2.0. If a copy of the MPL was not distributed with this
- * file, You can obtain one at https://mozilla.org/MPL/2.0/.
- *
- * OpenCRVS is also distributed under the terms of the Civil Registration
- * & Healthcare Disclaimer located at http://opencrvs.org/license.
- *
- * Copyright (C) The OpenCRVS Authors located at https://github.com/opencrvs/opencrvs-core/blob/master/AUTHORS.
- */
-import { checkAuth } from '@client/profile/profileActions'
-import { queries } from '@client/profile/queries'
-import { storage } from '@client/storage'
-import { createStore } from '@client/store'
-import { createTestComponent, mockUserResponse } from '@client/tests/util'
-import { merge } from 'lodash'
-import * as React from 'react'
-import { waitFor, waitForElement } from '@client/tests/wait-for-element'
-import { vi, Mock } from 'vitest'
-import { OIDPVerificationCallback } from './OIDPVerificationCallback'
-import { URLSearchParams } from 'url'
-import { useQueryParams, useExtractCallBackState } from './utils'
-import { GET_OIDP_USER_INFO } from './queries'
-import { createDeclaration, storeDeclaration } from '@client/declarations'
-import { Event } from '@client/utils/gateway'
-
-const draft = createDeclaration(Event.Birth)
-draft.data.mother = {}
-
-const mockFetchUserDetails = vi.fn()
-
-const registerScopeToken =
- 'eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCJ9.eyJzY29wZSI6WyJyZWdpc3RlciIsImNlcnRpZnkiLCJkZW1vIl0sImlhdCI6MTU0MjY4ODc3MCwiZXhwIjoxNTQzMjkzNTcwLCJhdWQiOlsib3BlbmNydnM6YXV0aC11c2VyIiwib3BlbmNydnM6dXNlci1tZ250LXVzZXIiLCJvcGVuY3J2czpoZWFydGgtdXNlciIsIm9wZW5jcnZzOmdhdGV3YXktdXNlciIsIm9wZW5jcnZzOm5vdGlmaWNhdGlvbi11c2VyIiwib3BlbmNydnM6d29ya2Zsb3ctdXNlciJdLCJpc3MiOiJvcGVuY3J2czphdXRoLXNlcnZpY2UiLCJzdWIiOiI1YmVhYWY2MDg0ZmRjNDc5MTA3ZjI5OGMifQ.ElQd99Lu7WFX3L_0RecU_Q7-WZClztdNpepo7deNHqzro-Cog4WLN7RW3ZS5PuQtMaiOq1tCb-Fm3h7t4l4KDJgvC11OyT7jD6R2s2OleoRVm3Mcw5LPYuUVHt64lR_moex0x_bCqS72iZmjrjS-fNlnWK5zHfYAjF2PWKceMTGk6wnI9N49f6VwwkinJcwJi6ylsjVkylNbutQZO0qTc7HRP-cBfAzNcKD37FqTRNpVSvHdzQSNcs7oiv3kInDN5aNa2536XSd3H-RiKR9hm9eID9bSIJgFIGzkWRd5jnoYxT70G0t03_mTVnDnqPXDtyI-lmerx24Ost0rQLUNIg'
-const getItem = window.localStorage.getItem as Mock
-const nameObj = {
- data: {
- getUser: {
- name: [
- {
- use: 'en',
- firstNames: 'Mohammad',
- familyName: 'Ashraful',
- __typename: 'HumanName'
- },
- { use: 'bn', firstNames: '', familyName: '', __typename: 'HumanName' }
- ],
- role: {
- _id: '778464c0-08f8-4fb7-8a37-b86d1efc462a',
- labels: [
- {
- lang: 'en',
- label: 'DISTRICT_REGISTRAR'
- }
- ]
- }
- }
- }
-}
-
-merge(mockUserResponse, nameObj)
-mockFetchUserDetails.mockReturnValue(mockUserResponse)
-queries.fetchUserDetails = mockFetchUserDetails
-storage.getItem = vi.fn()
-storage.setItem = vi.fn()
-
-// Define the mock query
-
-const graphqlMocks = [
- {
- request: {
- query: GET_OIDP_USER_INFO,
- variables: {
- code: '1234',
- clientId: '7b621732-6c1d-4808-81b2-fd67f05f3af3',
- redirectUri: 'http://localhost:3000/mosip-callback'
- }
- },
- result: {
- data: {
- getOIDPUserInfo: {
- oidpUserInfo: {
- sub: '123',
- name: 'John Doe',
- given_name: 'John',
- family_name: 'Doe',
- middle_name: null,
- nickname: null,
- preferred_username: 'jdoe',
- profile: 'https://example.com/profile',
- picture: 'https://example.com/picture.jpg',
- website: 'https://example.com',
- email: 'jdoe@example.com',
- email_verified: true,
- gender: 'male',
- birthdate: '1980-01-01',
- zoneinfo: 'America/Los_Angeles',
- locale: 'en-US',
- phone_number: '+1-123-456-7890',
- phone_number_verified: true,
- address: {
- formatted: '123 Main St\nSan Francisco, CA 94105\nUSA',
- street_address: '123 Main St',
- locality: 'San Francisco',
- region: 'CA',
- postal_code: '94105',
- country: 'USA'
- },
- updated_at: '2023-03-30T10:00:00Z'
- },
- districtFhirId: '12345',
- stateFhirId: '67890'
- }
- }
- }
- }
-]
-
-let { store, history } = createStore()
-
-beforeEach(async () => {
- ;({ store, history } = createStore())
-
- getItem.mockReturnValue(registerScopeToken)
- getItem.mockReturnValue('ea02388')
- ;(useExtractCallBackState as Mock).mockImplementation(() => ({
- pathname: 'http://localhost:3000/mosip-callback',
- section: 'mother',
- declarationId: draft.id
- }))
- ;(useQueryParams as Mock).mockImplementation(
- () => new URLSearchParams({ code: '1234' })
- )
-
- await store.dispatch(checkAuth())
- await store.dispatch(storeDeclaration(draft))
-})
-
-describe('Nid Verfication Callback page', () => {
- it('When nid user is successfully fetched', async () => {
- const testComponent = await createTestComponent(
- ,
- { store, history, graphqlMocks: graphqlMocks }
- )
- await waitFor(() => testComponent.find('#authenticating-label').length > 0)
-
- await new Promise((resolve) => {
- setTimeout(resolve, 100)
- })
-
- const declaration = store
- .getState()
- .declarationsState.declarations.find((d) => d.id === draft.id)
- expect(declaration?.data.mother.firstNamesEng).toBe('John')
- })
-
- it('When nid user info fetch has failed', async () => {
- const testComponent = await createTestComponent(
- ,
- { store, history }
- )
-
- await waitForElement(testComponent, '#authentication-failed-label')
- })
-})
diff --git a/packages/client/src/views/OIDPVerificationCallback/OIDPVerificationCallback.tsx b/packages/client/src/views/OIDPVerificationCallback/OIDPVerificationCallback.tsx
deleted file mode 100644
index a0686eedbda..00000000000
--- a/packages/client/src/views/OIDPVerificationCallback/OIDPVerificationCallback.tsx
+++ /dev/null
@@ -1,151 +0,0 @@
-/*
- * This Source Code Form is subject to the terms of the Mozilla Public
- * License, v. 2.0. If a copy of the MPL was not distributed with this
- * file, You can obtain one at https://mozilla.org/MPL/2.0/.
- *
- * OpenCRVS is also distributed under the terms of the Civil Registration
- * & Healthcare Disclaimer located at http://opencrvs.org/license.
- *
- * Copyright (C) The OpenCRVS Authors located at https://github.com/opencrvs/opencrvs-core/blob/master/AUTHORS.
- */
-import {
- IDeclaration,
- modifyDeclaration,
- writeDeclaration
-} from '@client/declarations'
-import { selectCountryLogo, getOfflineData } from '@client/offline/selectors'
-import React from 'react'
-import { useIntl } from 'react-intl'
-import { useDispatch, useSelector } from 'react-redux'
-import {
- addNidUserInfoToDeclaration,
- useExtractCallBackState,
- useQueryParams
-} from '@client/views/OIDPVerificationCallback/utils'
-import styled from 'styled-components'
-import { Link, Stack, Text, Spinner, Button, Icon } from '@opencrvs/components'
-import { CountryLogo } from '@opencrvs/components/lib/icons'
-import { LogoContainer } from '@client/views/UserSetup/UserSetupPage'
-import { buttonMessages } from '@client/i18n/messages'
-import { messages as nidCallbackMessages } from '@client/i18n/messages/views/nidVerificationCallback'
-import { useQuery } from '@apollo/client'
-import { useDeclaration } from '@client/declarations/selectors'
-import { GET_OIDP_USER_INFO } from '@client/views/OIDPVerificationCallback/queries'
-import { useHistory } from 'react-router'
-import { OIDP_VERIFICATION_CALLBACK } from '@client/navigation/routes'
-
-// OIDP Verification Callback
-// --
-// Checks the ?state= query parameter for a JSON string like: { pathname: "/path/somewhere" }
-// Redirects to the pathname in state
-
-const Page = styled.div`
- color: ${({ theme }) => theme.colors.copy};
- background: ${({ theme }) => theme.colors.background};
- min-height: 100vh;
- display: flex;
- flex-direction: column;
- text-align: center;
-`
-const Container = styled.div`
- width: 288px;
- margin: auto;
- margin-top: 10vh;
-`
-
-const UserActionsContainer = styled.div`
- background: ${({ theme }) => theme.colors.white};
- padding: 24px 40px;
- border: 1px solid ${({ theme }) => theme.colors.grey300};
- border-radius: 10px;
-`
-
-export const OIDPVerificationCallback = () => {
- const params = useQueryParams()
- const { pathname, declarationId, section } = useExtractCallBackState()
- const code = params.get('code')
- const offlineData = useSelector(getOfflineData)
- const clientId = offlineData.systems.find((s) => s.type === 'NATIONAL_ID')
- ?.settings?.openIdProviderClientId
- const intl = useIntl()
- const logo = useSelector(selectCountryLogo)
- const declaration = useDeclaration(declarationId)
- const dispatch = useDispatch()
- const history = useHistory()
- const oidpUserInfoQueryVariables = {
- code,
- clientId,
- redirectUri: `${window.location.origin}${OIDP_VERIFICATION_CALLBACK}`
- }
- const { loading, error, refetch } = useQuery(GET_OIDP_USER_INFO, {
- variables: oidpUserInfoQueryVariables,
- notifyOnNetworkStatusChange: true,
- onCompleted: (data) => {
- addNidUserInfoToDeclaration(declaration, section, data.getOIDPUserInfo)
- dispatch(modifyDeclaration(declaration))
- dispatch(writeDeclaration(declaration))
- goToVerificationOrigin()
- }
- })
-
- if (!pathname) {
- // Do not redirect and let the hooks throw
- return null
- }
-
- const goToVerificationOrigin = () => {
- pathname && history.push(pathname)
- }
-
- const handleRetry = () => refetch(oidpUserInfoQueryVariables)
-
- return (
-
-
-
-
-
-
-
-
- {loading && (
- <>
-
-
- {intl.formatMessage(nidCallbackMessages.authenticatingNid)}
-
- >
- )}
- {error && (
- <>
-
-
- {intl.formatMessage(
- nidCallbackMessages.failedToAuthenticateNid
- )}
-
-
- >
- )}
-
- {intl.formatMessage(buttonMessages.cancel)}
-
-
-
-
-
-
- )
-}
diff --git a/packages/client/src/views/OIDPVerificationCallback/queries.ts b/packages/client/src/views/OIDPVerificationCallback/queries.ts
deleted file mode 100644
index 6d3cbb6ab15..00000000000
--- a/packages/client/src/views/OIDPVerificationCallback/queries.ts
+++ /dev/null
@@ -1,61 +0,0 @@
-/*
- * This Source Code Form is subject to the terms of the Mozilla Public
- * License, v. 2.0. If a copy of the MPL was not distributed with this
- * file, You can obtain one at https://mozilla.org/MPL/2.0/.
- *
- * OpenCRVS is also distributed under the terms of the Civil Registration
- * & Healthcare Disclaimer located at http://opencrvs.org/license.
- *
- * Copyright (C) The OpenCRVS Authors located at https://github.com/opencrvs/opencrvs-core/blob/master/AUTHORS.
- */
-import { gql } from '@apollo/client'
-
-export const GET_OIDP_USER_INFO = gql`
- query getOIDPUserInfo(
- $code: String!
- $clientId: String!
- $redirectUri: String!
- $grantType: String
- ) {
- getOIDPUserInfo(
- code: $code
- clientId: $clientId
- redirectUri: $redirectUri
- grantType: $grantType
- ) {
- oidpUserInfo {
- sub
- name
- given_name
- family_name
- middle_name
- nickname
- preferred_username
- profile
- picture
- website
- email
- email_verified
- gender
- birthdate
- zoneinfo
- locale
- phone_number
- phone_number_verified
- address {
- formatted
- street_address
- locality
- region
- postal_code
- city
- country
- }
- updated_at
- }
- districtFhirId
- stateFhirId
- locationLevel3FhirId
- }
- }
-`
diff --git a/packages/client/src/views/OIDPVerificationCallback/utils.ts b/packages/client/src/views/OIDPVerificationCallback/utils.ts
deleted file mode 100644
index 36661fc1ea2..00000000000
--- a/packages/client/src/views/OIDPVerificationCallback/utils.ts
+++ /dev/null
@@ -1,271 +0,0 @@
-/*
- * This Source Code Form is subject to the terms of the Mozilla Public
- * License, v. 2.0. If a copy of the MPL was not distributed with this
- * file, You can obtain one at https://mozilla.org/MPL/2.0/.
- *
- * OpenCRVS is also distributed under the terms of the Civil Registration
- * & Healthcare Disclaimer located at http://opencrvs.org/license.
- *
- * Copyright (C) The OpenCRVS Authors located at https://github.com/opencrvs/opencrvs-core/blob/master/AUTHORS.
- */
-
-import { IDeclaration, writeDeclaration } from '@client/declarations'
-import { useDeclaration } from '@client/declarations/selectors'
-import { isDefaultCountry } from '@client/forms/utils'
-import { OIDP_VERIFICATION_CALLBACK } from '@client/navigation/routes'
-import { IOfflineData } from '@client/offline/reducer'
-import { getOfflineData } from '@client/offline/selectors'
-import formatDate from '@client/utils/date-formatting'
-import { camelCase } from 'lodash'
-import { useEffect, useMemo } from 'react'
-import { useDispatch, useSelector } from 'react-redux'
-import { useLocation, useRouteMatch } from 'react-router'
-
-interface OIDPUserAddress {
- formatted?: string | null
- street_address?: string | null
- locality?: string | null
- region?: string | null
- postal_code?: string | null
- city?: string | null
- country?: string | null
-}
-
-interface oidpUserInfo {
- sub: string
- name?: string | null
- given_name?: string | null
- family_name?: string | null
- middle_name?: string | null
- nickname?: string | null
- preferred_username?: string | null
- profile?: string | null
- picture?: string | null
- website?: string | null
- email?: string | null
- email_verified?: boolean | null
- gender?: string | null
- birthdate?: string | null
- zoneinfo?: string | null
- locale?: string | null
- phone_number?: string | null
- phone_number_verified?: boolean | null
- address?: OIDPUserAddress | null
- updated_at?: number | null
-}
-
-interface UserInfo {
- oidpUserInfo: oidpUserInfo
- districtFhirId?: string | null
- stateFhirId?: string | null
- locationLevel3FhirId?: string | null
-}
-
-interface INidCallbackState {
- pathname: string | undefined
- declarationId: string
- section: string
-}
-
-export function useQueryParams() {
- const { search } = useLocation()
-
- return useMemo(() => new URLSearchParams(search), [search])
-}
-
-export function addNidUserInfoToDeclaration(
- declaration: IDeclaration,
- section: string,
- nidUserInfo: UserInfo
-) {
- const oidpUserInfo = nidUserInfo.oidpUserInfo
-
- // initialise the section (mother/father/informant) if it doesn't exist
- if (!declaration.data[section]) {
- declaration.data[section] = {}
- }
-
- const declarationDataSection = declaration.data[section]
- const fieldsModifiedByNidUserInfo = []
- const splitFullName = splitName(oidpUserInfo.name)
-
- if (oidpUserInfo.birthdate) {
- // Deceased don't have "deceased" -prefix
- const dataSection = section === 'deceased' ? '' : section
- declarationDataSection[camelCase(`${dataSection}BirthDate`)] = formatDate(
- new Date(oidpUserInfo.birthdate),
- 'yyyy-MM-dd'
- )
- fieldsModifiedByNidUserInfo.push(camelCase(`${dataSection}BirthDate`))
- }
-
- if (splitFullName.firstName) {
- declarationDataSection['firstNamesEng'] = splitFullName.firstName
- fieldsModifiedByNidUserInfo.push('firstNamesEng')
- }
- if (splitFullName.lastName) {
- declarationDataSection['familyNameEng'] = splitFullName.lastName
- fieldsModifiedByNidUserInfo.push('familyNameEng')
- }
-
- if (oidpUserInfo.address?.country) {
- declarationDataSection['countryPrimary'] = oidpUserInfo.address.country
- fieldsModifiedByNidUserInfo.push('countryPrimary')
-
- if (isDefaultCountry(oidpUserInfo.address.country)) {
- //populate default country specific address fields
- if (nidUserInfo.stateFhirId) {
- declarationDataSection['statePrimary'] = nidUserInfo.stateFhirId
- fieldsModifiedByNidUserInfo.push('statePrimary')
- }
- if (nidUserInfo.districtFhirId) {
- declarationDataSection['districtPrimary'] = nidUserInfo.districtFhirId
- fieldsModifiedByNidUserInfo.push('districtPrimary')
- }
- if (nidUserInfo.locationLevel3FhirId) {
- declarationDataSection['locationLevel3Primary'] =
- nidUserInfo.locationLevel3FhirId
- fieldsModifiedByNidUserInfo.push('locationLevel3Primary')
- }
- if (oidpUserInfo.address.street_address) {
- declarationDataSection['addressLine2UrbanOptionPrimary'] =
- oidpUserInfo.address.street_address
- fieldsModifiedByNidUserInfo.push('addressLine2UrbanOptionPrimary')
- }
- if (oidpUserInfo.address.postal_code) {
- declarationDataSection['postCodePrimary'] =
- oidpUserInfo.address.postal_code
- fieldsModifiedByNidUserInfo.push('postCodePrimary')
- }
- } else {
- //populate international address fields
- if (oidpUserInfo.address.region) {
- declarationDataSection['internationalStatePrimary'] =
- oidpUserInfo.address.region
- fieldsModifiedByNidUserInfo.push('internationalStatePrimary')
- }
- if (oidpUserInfo.address.locality) {
- declarationDataSection['internationalDistrictPrimary'] =
- oidpUserInfo.address.locality
- fieldsModifiedByNidUserInfo.push('internationalDistrictPrimary')
- }
- if (oidpUserInfo.address.city) {
- declarationDataSection['locationLevel3Primary'] =
- oidpUserInfo.address.city
- fieldsModifiedByNidUserInfo.push('locationLevel3Primary')
- }
- if (oidpUserInfo.address.street_address) {
- declarationDataSection['internationalAddressLine1Primary'] =
- oidpUserInfo.address.street_address
- fieldsModifiedByNidUserInfo.push('internationalAddressLine1Primary')
- }
- if (oidpUserInfo.address.postal_code) {
- declarationDataSection['internationalPostcodePrimary'] =
- oidpUserInfo.address.postal_code
- fieldsModifiedByNidUserInfo.push('internationalPostcodePrimary')
- }
- }
-
- if (section === 'father') {
- declarationDataSection['primaryAddressSameAsOtherPrimary'] = false
- }
-
- if (section === 'spouse') {
- declarationDataSection['primaryAddressSameAsOtherPrimary'] = false
- }
- }
-
- declarationDataSection['fieldsModifiedByNidUserInfo'] =
- fieldsModifiedByNidUserInfo
- declarationDataSection[`${section}NidVerification`] = oidpUserInfo.sub
-}
-
-function splitName(name: string | undefined | null = '') {
- if (!name) {
- return { firstName: '', lastName: '' }
- }
-
- const [firstName, ...lastName] = name.split(' ').filter(Boolean)
- return {
- firstName: firstName,
- lastName: lastName.join(' ')
- }
-}
-
-export const useNidAuthentication = () => {
- const dispatch = useDispatch()
- const match = useRouteMatch()
- const matchParams = match.params as {
- declarationId: string
- groupId: string
- pageId: string
- }
- const offlineCountryConfig = useSelector(getOfflineData)
- const declaration = useDeclaration(matchParams.declarationId)
-
- const onClick = () =>
- dispatch(
- writeDeclaration(declaration, () => {
- redirectToNidIntegration(
- offlineCountryConfig,
- matchParams.declarationId,
- matchParams.pageId,
- match.url
- )
- })
- )
-
- return { onClick }
-}
-
-export function redirectToNidIntegration(
- offlineCountryConfig: IOfflineData,
- declarationId: string,
- currentSection: string,
- currentPathname: string
-) {
- const nidSystemSetting = offlineCountryConfig.systems.find(
- (s) => s.type === 'NATIONAL_ID'
- )?.settings
-
- if (!nidSystemSetting) {
- return
- }
- const url = new URL(`${nidSystemSetting?.openIdProviderBaseUrl}authorize`)
-
- url.searchParams.append(
- 'client_id',
- nidSystemSetting?.openIdProviderClientId || ''
- )
- url.searchParams.append(
- 'redirect_uri',
- `${window.location.origin}${OIDP_VERIFICATION_CALLBACK}`
- )
- url.searchParams.append('response_type', 'code')
- url.searchParams.append('scope', 'openid profile')
- url.searchParams.append('acr_values', 'mosip:idp:acr:static-code')
- const stateToBeSent: INidCallbackState = {
- pathname: currentPathname,
- declarationId: declarationId,
- section: currentSection
- }
- url.searchParams.append('state', JSON.stringify(stateToBeSent))
- url.searchParams.append('claims', nidSystemSetting.openIdProviderClaims || '')
- window.location.href = url.toString()
-}
-
-export const useExtractCallBackState = () => {
- const params = useQueryParams()
-
- useEffect(() => {
- if (!params.get('state')) {
- throw new Error('No state provided from OIDP callback.')
- }
- }, [params])
-
- const { pathname, declarationId, section } = JSON.parse(
- params.get('state') ?? '{}'
- ) as INidCallbackState
-
- return { pathname, declarationId, section }
-}
diff --git a/packages/client/src/views/RegisterForm/review/ReviewSection.tsx b/packages/client/src/views/RegisterForm/review/ReviewSection.tsx
index 7cfc1bc0721..c2406b6b80d 100644
--- a/packages/client/src/views/RegisterForm/review/ReviewSection.tsx
+++ b/packages/client/src/views/RegisterForm/review/ReviewSection.tsx
@@ -68,7 +68,6 @@ import {
SELECT_WITH_DYNAMIC_OPTIONS,
SELECT_WITH_OPTIONS,
SubmissionAction,
- NID_VERIFICATION_BUTTON,
WARNING,
DIVIDER,
HIDDEN
@@ -132,7 +131,6 @@ import {
} from '@client/views/CorrectionForm/utils'
import { ListReview } from '@opencrvs/components/lib/ListReview'
import { DuplicateWarning } from '@client/views/Duplicates/DuplicateWarning'
-import { VerificationButton } from '@opencrvs/components/lib/VerificationButton'
import { DuplicateForm } from '@client/views/RegisterForm/duplicate/DuplicateForm'
import { Button } from '@opencrvs/components/lib/Button'
import { UserDetails } from '@client/utils/userUtils'
@@ -542,25 +540,6 @@ const renderValue = (
)
return (selectedLocation && selectedLocation.displayLabel) || ''
}
- if (field.type === NID_VERIFICATION_BUTTON) {
- return (
- {}}
- labelForVerified={intl.formatMessage(
- formMessageDescriptors.nidVerified
- )}
- labelForUnverified={intl.formatMessage(
- formMessageDescriptors.nidNotVerified
- )}
- labelForOffline={intl.formatMessage(formMessageDescriptors.nidOffline)}
- reviewLabelForUnverified={intl.formatMessage(
- formMessageDescriptors.nidNotVerifiedReviewSection
- )}
- status={value ? 'verified' : 'unverified'}
- useAsReviewLabel={true}
- />
- )
- }
if (typeof value === 'boolean') {
return value
diff --git a/packages/components/src/VerificationButton/VerificationButton.stories.tsx b/packages/components/src/VerificationButton/VerificationButton.stories.tsx
deleted file mode 100644
index 86c315a0e0a..00000000000
--- a/packages/components/src/VerificationButton/VerificationButton.stories.tsx
+++ /dev/null
@@ -1,60 +0,0 @@
-/*
- * This Source Code Form is subject to the terms of the Mozilla Public
- * License, v. 2.0. If a copy of the MPL was not distributed with this
- * file, You can obtain one at https://mozilla.org/MPL/2.0/.
- *
- * OpenCRVS is also distributed under the terms of the Civil Registration
- * & Healthcare Disclaimer located at http://opencrvs.org/license.
- *
- * Copyright (C) The OpenCRVS Authors located at https://github.com/opencrvs/opencrvs-core/blob/master/AUTHORS.
- */
-import * as React from 'react'
-import { ComponentMeta, ComponentStory } from '@storybook/react'
-import { VerificationButton } from './VerificationButton'
-
-export default {
- title: 'Controls/Verification button',
- component: VerificationButton,
- parameters: {
- docs: {
- description: {
- component: `
-\`\` is used for authentication flow. It can show an action button, a verified icon or a disabled button with an offline message.`
- }
- }
- }
-} as ComponentMeta
-
-const Template: ComponentStory = (args) => {
- return
-}
-
-export const Unverified = Template.bind({})
-Unverified.args = {
- status: 'unverified',
- onClick: () => {},
- labelForVerified: 'Authenticated',
- labelForUnverified: 'Authenticate',
- labelForOffline:
- 'National ID authentication is currently not available offline.'
-}
-
-export const Verified = Template.bind({})
-Verified.args = {
- status: 'verified',
- onClick: () => {},
- labelForVerified: 'Authenticated',
- labelForUnverified: 'Authenticate',
- labelForOffline:
- 'National ID authentication is currently not available offline.'
-}
-
-export const Offline = Template.bind({})
-Offline.args = {
- status: 'offline',
- onClick: () => {},
- labelForVerified: 'Authenticated',
- labelForUnverified: 'Authenticate',
- labelForOffline:
- 'National ID authentication is currently not available offline.'
-}
diff --git a/packages/components/src/VerificationButton/VerificationButton.tsx b/packages/components/src/VerificationButton/VerificationButton.tsx
deleted file mode 100644
index 5910a4c0501..00000000000
--- a/packages/components/src/VerificationButton/VerificationButton.tsx
+++ /dev/null
@@ -1,99 +0,0 @@
-/*
- * This Source Code Form is subject to the terms of the Mozilla Public
- * License, v. 2.0. If a copy of the MPL was not distributed with this
- * file, You can obtain one at https://mozilla.org/MPL/2.0/.
- *
- * OpenCRVS is also distributed under the terms of the Civil Registration
- * & Healthcare Disclaimer located at http://opencrvs.org/license.
- *
- * Copyright (C) The OpenCRVS Authors located at https://github.com/opencrvs/opencrvs-core/blob/master/AUTHORS.
- */
-import * as React from 'react'
-import { Icon } from '../Icon'
-import { Button } from '../Button'
-import styled from 'styled-components'
-import { Text } from '../Text'
-import { Stack } from '../Stack'
-
-export interface VerificationButtonProps {
- status?: 'unverified' | 'verified' | 'offline'
- id?: string
- onClick: () => void
- labelForVerified: string
- labelForUnverified: string
- labelForOffline: string
- reviewLabelForUnverified?: string
- useAsReviewLabel?: boolean
-}
-
-const VerificationBadge = styled.div`
- display: inline-flex;
- justify-content: center;
- align-items: center;
- height: 40px;
- color: ${({ theme }) => theme.colors.primary};
- svg {
- height: 24px;
- width: 24px;
- vertical-align: top;
- margin-left: -2px;
- margin-right: 8px;
- pointer-events: none;
- }
-`
-
-export const VerificationButton = ({
- status = 'unverified',
- onClick,
- labelForUnverified,
- labelForVerified,
- labelForOffline,
- reviewLabelForUnverified,
- useAsReviewLabel
-}: VerificationButtonProps) => {
- return (
- <>
- {status === 'unverified' && !useAsReviewLabel && (
-
- )}
-
- {status === 'unverified' && useAsReviewLabel && (
-
-
-
- {reviewLabelForUnverified}
-
-
- )}
-
- {status === 'offline' && (
-
-
-
- {labelForOffline}
-
-
- )}
-
- {status === 'verified' && (
-
-
-
- {labelForVerified}
-
-
- )}
- >
- )
-}
diff --git a/packages/components/src/VerificationButton/index.ts b/packages/components/src/VerificationButton/index.ts
deleted file mode 100644
index cae4ae99661..00000000000
--- a/packages/components/src/VerificationButton/index.ts
+++ /dev/null
@@ -1,11 +0,0 @@
-/*
- * This Source Code Form is subject to the terms of the Mozilla Public
- * License, v. 2.0. If a copy of the MPL was not distributed with this
- * file, You can obtain one at https://mozilla.org/MPL/2.0/.
- *
- * OpenCRVS is also distributed under the terms of the Civil Registration
- * & Healthcare Disclaimer located at http://opencrvs.org/license.
- *
- * Copyright (C) The OpenCRVS Authors located at https://github.com/opencrvs/opencrvs-core/blob/master/AUTHORS.
- */
-export * from './VerificationButton'
diff --git a/packages/components/src/index.ts b/packages/components/src/index.ts
index e8be3cd7af5..72f96d9a488 100644
--- a/packages/components/src/index.ts
+++ b/packages/components/src/index.ts
@@ -76,7 +76,6 @@ export * from './Toggle'
export * from './ToggleIcon'
export * from './ToggleMenu'
export * from './Tooltip'
-export * from './VerificationButton'
export * from './VerticalBar'
export * from './ViewData'
export * from './WarningMessage'
diff --git a/packages/config/src/handlers/forms/field.ts b/packages/config/src/handlers/forms/field.ts
index 0330876d34d..8ddcfc0ebc3 100644
--- a/packages/config/src/handlers/forms/field.ts
+++ b/packages/config/src/handlers/forms/field.ts
@@ -106,9 +106,6 @@ const LocationSearchInputField = base.extend({
type: z.literal('LOCATION_SEARCH_INPUT')
})
const TimeField = base.extend({ type: z.literal('TIME') })
-const NidVerificationButtonField = base.extend({
- type: z.literal('NID_VERIFICATION_BUTTON')
-})
const DividerField = base.extend({ type: z.literal('DIVIDER') })
const Heading3Field = base.extend({ type: z.literal('HEADING3') })
const SignatureField = base.extend({ type: z.literal('SIGNATURE') })
@@ -165,7 +162,6 @@ export const field = z.discriminatedUnion('type', [
FetchButtonField,
LocationSearchInputField,
TimeField,
- NidVerificationButtonField,
DividerField,
Heading3Field,
SignatureField,
diff --git a/packages/gateway/src/constants.ts b/packages/gateway/src/constants.ts
index 740cc44ad63..039a9f42809 100644
--- a/packages/gateway/src/constants.ts
+++ b/packages/gateway/src/constants.ts
@@ -50,8 +50,3 @@ export const CONFIG_SMS_CODE_EXPIRY_SECONDS = env.CONFIG_SMS_CODE_EXPIRY_SECONDS
export const CONFIG_SYSTEM_TOKEN_EXPIRY_SECONDS =
env.CONFIG_SYSTEM_TOKEN_EXPIRY_SECONDS
export const MINIO_BUCKET = env.MINIO_BUCKET
-export const OIDP_BASE_URL = env.NATIONAL_ID_OIDP_BASE_URL
-export const OIDP_TOKEN_URL = env.NATIONAL_ID_OIDP_TOKEN_URL
-export const OIDP_USERINFO_URL = env.NATIONAL_ID_OIDP_USERINFO_URL
-export const OIDP_CLIENT_PRIVATE_KEY = env.NATIONAL_ID_OIDP_CLIENT_PRIVATE_KEY
-export const OIDP_JWT_AUD_CLAIM = env.NATIONAL_ID_OIDP_JWT_AUD_CLAIM
diff --git a/packages/gateway/src/environment.ts b/packages/gateway/src/environment.ts
index 04f8d7cc5ad..7fdc7179d83 100644
--- a/packages/gateway/src/environment.ts
+++ b/packages/gateway/src/environment.ts
@@ -46,17 +46,5 @@ export const env = cleanEnv(process.env, {
CONFIG_TOKEN_EXPIRY_SECONDS: num({ default: 604800 }), // 1 week
CONFIG_SMS_CODE_EXPIRY_SECONDS: num({ default: 600 }), // 10 minutes
CONFIG_SYSTEM_TOKEN_EXPIRY_SECONDS: num({ default: 600 }), // 10 minutes
- MINIO_BUCKET: str({ devDefault: 'ocrvs' }),
-
- NATIONAL_ID_OIDP_BASE_URL: str({ default: undefined }),
- NATIONAL_ID_OIDP_TOKEN_URL: str({ default: undefined }),
- NATIONAL_ID_OIDP_USERINFO_URL: str({ default: undefined }),
- NATIONAL_ID_OIDP_CLIENT_PRIVATE_KEY: str({
- default: undefined,
- desc: 'Base64 encoded RS256 JSON Web Key'
- }),
- NATIONAL_ID_OIDP_JWT_AUD_CLAIM: str({
- default: undefined,
- desc: 'Value for "aud" claim when getting access token for fetching Open ID provider user info'
- })
+ MINIO_BUCKET: str({ devDefault: 'ocrvs' })
})
diff --git a/packages/gateway/src/features/OIDPUserInfo/oidp-types.ts b/packages/gateway/src/features/OIDPUserInfo/oidp-types.ts
deleted file mode 100644
index 68fed026edf..00000000000
--- a/packages/gateway/src/features/OIDPUserInfo/oidp-types.ts
+++ /dev/null
@@ -1,41 +0,0 @@
-/*
- * This Source Code Form is subject to the terms of the Mozilla Public
- * License, v. 2.0. If a copy of the MPL was not distributed with this
- * file, You can obtain one at https://mozilla.org/MPL/2.0/.
- *
- * OpenCRVS is also distributed under the terms of the Civil Registration
- * & Healthcare Disclaimer located at http://opencrvs.org/license.
- *
- * Copyright (C) The OpenCRVS Authors located at https://github.com/opencrvs/opencrvs-core/blob/master/AUTHORS.
- */
-type OIDPUserAddress = {
- formatted: string
- street_address: string
- locality: string
- region: string
- postal_code: string
- city: string
- country: string
-}
-export type OIDPUserInfo = {
- sub: string
- name?: string
- given_name?: string
- family_name?: string
- middle_name?: string
- nickname?: string
- preferred_username?: string
- profile?: string
- picture?: string
- website?: string
- email?: string
- email_verified?: boolean
- gender?: 'female' | 'male'
- birthdate?: string
- zoneinfo?: string
- locale?: string
- phone_number?: string
- phone_number_verified?: boolean
- address?: Partial
- updated_at?: number
-}
diff --git a/packages/gateway/src/features/OIDPUserInfo/root-resolvers.test.ts b/packages/gateway/src/features/OIDPUserInfo/root-resolvers.test.ts
deleted file mode 100644
index 56b1a3a6534..00000000000
--- a/packages/gateway/src/features/OIDPUserInfo/root-resolvers.test.ts
+++ /dev/null
@@ -1,267 +0,0 @@
-/*
- * This Source Code Form is subject to the terms of the Mozilla Public
- * License, v. 2.0. If a copy of the MPL was not distributed with this
- * file, You can obtain one at https://mozilla.org/MPL/2.0/.
- *
- * OpenCRVS is also distributed under the terms of the Civil Registration
- * & Healthcare Disclaimer located at http://opencrvs.org/license.
- *
- * Copyright (C) The OpenCRVS Authors located at https://github.com/opencrvs/opencrvs-core/blob/master/AUTHORS.
- */
-import { resolvers as typeResolvers } from '@gateway/features/OIDPUserInfo/root-resolvers'
-import { OIDP_CLIENT_PRIVATE_KEY } from '@gateway/constants'
-import * as fetchAny from 'jest-fetch-mock'
-import * as jose from 'jose'
-import { TestResolvers } from '@gateway/utils/testUtils'
-const resolvers = typeResolvers as unknown as TestResolvers
-const fetch = fetchAny as fetchAny.FetchMock
-
-beforeEach(() => {
- fetch.resetMocks()
-})
-
-describe('get user info from OIDP national id integration', () => {
- it('returns user info and decrypts JWT properly', async () => {
- const jwtPayload = {
- sub: '1234567890',
- name: 'Pyry Rouvila',
- given_name: 'Pyry',
- family_name: 'Rouvila',
- middle_name: 'Test',
- birthdate: '1980-04-01',
- address: {
- formatted: 'Testingston 1\n12345 Ibombo, Central\nFarajaland',
- street_address: 'Tammelankatu 1',
- locality: 'Ibombo',
- region: 'Central',
- postal_code: '12345',
- country: 'Farajaland'
- }
- }
-
- const decodeKey = Buffer.from(
- OIDP_CLIENT_PRIVATE_KEY!,
- 'base64'
- )?.toString()
- const jwkObject = JSON.parse(decodeKey)
- const privateKey = await jose.importJWK(jwkObject, 'RS256')
- const encoded = await new jose.SignJWT(jwtPayload)
- .setProtectedHeader({ alg: 'RS256' })
- .sign(privateKey)
-
- fetch
- .mockResponseOnce(
- JSON.stringify({
- access_token: 'some-access-token'
- })
- )
- .mockResponseOnce(encoded)
- .mockResponseOnce(
- JSON.stringify({
- resourceType: 'Bundle',
- id: '34abc0a0-912d-4b8b-97fd-def9a2321b0f',
- meta: { lastUpdated: '2023-05-19T15:39:21.599+00:00' },
- type: 'searchset',
- total: 0,
- link: [
- {
- relation: 'self',
- url: 'http://localhost:7070/location?name=Farajaland'
- }
- ],
- entry: []
- })
- )
- .mockResponseOnce(
- JSON.stringify({
- resourceType: 'Bundle',
- id: 'c819db15-fc28-4606-9db4-095378a06125',
- meta: {
- lastUpdated: '2023-03-10T13:46:59.923+00:00'
- },
- type: 'searchset',
- total: 1,
- link: [
- {
- relation: 'self',
- url: 'http://localhost:7070/location?name=Central'
- }
- ],
- entry: [
- {
- fullUrl:
- 'http://localhost:7070/location/5dd96001-7c94-4eeb-b96e-8a987957f7a2/_history/b3f14d83-eb74-4cfa-b17e-039d57d222f0',
- resource: {
- resourceType: 'Location',
- identifier: [
- {
- system: 'http://opencrvs.org/specs/id/statistical-code',
- value: 'ADMIN_STRUCTURE_AWn3s2RqgAN'
- },
- {
- system: 'http://opencrvs.org/specs/id/jurisdiction-type',
- value: 'STATE'
- }
- ],
- name: 'Central',
- alias: ['Central'],
- description: 'AWn3s2RqgAN',
- status: 'active',
- mode: 'instance',
- partOf: {
- reference: 'Location/0'
- },
- type: {
- coding: [
- {
- system: 'http://opencrvs.org/specs/location-type',
- code: 'ADMIN_STRUCTURE'
- }
- ]
- },
- physicalType: {
- coding: [
- {
- code: 'jdn',
- display: 'Jurisdiction'
- }
- ]
- },
- extension: [],
- meta: {
- lastUpdated: '2023-01-18T12:54:05.278+00:00',
- versionId: 'b3f14d83-eb74-4cfa-b17e-039d57d222f0'
- },
- id: '5dd96001-7c94-4eeb-b96e-8a987957f7a2'
- },
- request: {
- method: 'PUT',
- url: 'Location/5dd96001-7c94-4eeb-b96e-8a987957f7a2'
- }
- }
- ]
- })
- )
- .mockResponseOnce(
- JSON.stringify({
- resourceType: 'Bundle',
- id: 'c6f0f99f-ad27-4e6e-9705-a320c1eb3423',
- meta: {
- lastUpdated: '2023-03-10T11:55:07.461+00:00'
- },
- type: 'searchset',
- total: 1,
- link: [
- {
- relation: 'self',
- url: 'http://localhost:7070/location?name=Ibombo&type=ADMIN_STRUCTURE'
- }
- ],
- entry: [
- {
- fullUrl:
- 'http://localhost:7070/location/ab93d5a5-c078-4dfa-b4ca-d54d1e57bca0/_history/5127621b-de2a-4bd2-b530-6413924f2ed2',
- resource: {
- resourceType: 'Location',
- identifier: [
- {
- system: 'http://opencrvs.org/specs/id/statistical-code',
- value: 'ADMIN_STRUCTURE_oEBf29y8JP8'
- },
- {
- system: 'http://opencrvs.org/specs/id/jurisdiction-type',
- value: 'DISTRICT'
- }
- ],
- name: 'Ibombo',
- alias: ['Ibombo'],
- description: 'oEBf29y8JP8',
- status: 'active',
- mode: 'instance',
- partOf: {
- reference: 'Location/5dd96001-7c94-4eeb-b96e-8a987957f7a2'
- },
- type: {
- coding: [
- {
- system: 'http://opencrvs.org/specs/location-type',
- code: 'ADMIN_STRUCTURE'
- }
- ]
- },
- physicalType: {
- coding: [
- {
- code: 'jdn',
- display: 'Jurisdiction'
- }
- ]
- },
- extension: [],
- meta: {
- lastUpdated: '2023-01-18T12:54:05.324+00:00',
- versionId: '5127621b-de2a-4bd2-b530-6413924f2ed2'
- },
- id: 'ab93d5a5-c078-4dfa-b4ca-d54d1e57bca0'
- },
- request: {
- method: 'PUT',
- url: 'Location/ab93d5a5-c078-4dfa-b4ca-d54d1e57bca0'
- }
- }
- ]
- })
- )
-
- const data = await resolvers.Query!.getOIDPUserInfo(
- {},
- {
- code: 'some-code',
- clientId: 'some-client-id',
- redirectUri: 'http://localhost:3000/mosip-callback'
- }
- )
- expect(fetch.mock.calls[0][0]).toMatch(/oauth\/v2\/token$/)
- expect(fetch.mock.calls[1][0]).toMatch(/oidc\/v2\/userinfo$/)
- expect(fetch.mock.calls[2][0]).toMatch(
- /Location\?name=Farajaland&type=ADMIN_STRUCTURE$/
- )
- expect(fetch.mock.calls[3][0]).toMatch(
- /Location\?name=Central&type=ADMIN_STRUCTURE$/
- )
- expect(fetch.mock.calls[4][0]).toMatch(
- /Location\?name=Ibombo&type=ADMIN_STRUCTURE$/
- )
- expect(data).toEqual({
- oidpUserInfo: jwtPayload,
- districtFhirId: '5dd96001-7c94-4eeb-b96e-8a987957f7a2',
- locationLevel3FhirId: 'ab93d5a5-c078-4dfa-b4ca-d54d1e57bca0',
- stateFhirId: null
- })
- })
-
- it('throws an error if no access token is returned', async () => {
- fetch.mockResponseOnce(
- JSON.stringify({
- error: 'invalid_assertion',
- error_description: 'invalid_assertion'
- }),
- { status: 400 }
- )
-
- try {
- await resolvers.Query!.getOIDPUserInfo(
- {},
- {
- code: 'some-code',
- clientId: 'some-client-id',
- redirectUri: 'http://localhost:3000/mosip-callback'
- }
- )
- } catch (e) {
- expect(e.message).toMatch('No access token was returned')
- }
-
- expect.assertions(1)
- })
-})
diff --git a/packages/gateway/src/features/OIDPUserInfo/root-resolvers.ts b/packages/gateway/src/features/OIDPUserInfo/root-resolvers.ts
deleted file mode 100644
index 1180e016cd7..00000000000
--- a/packages/gateway/src/features/OIDPUserInfo/root-resolvers.ts
+++ /dev/null
@@ -1,34 +0,0 @@
-/*
- * This Source Code Form is subject to the terms of the Mozilla Public
- * License, v. 2.0. If a copy of the MPL was not distributed with this
- * file, You can obtain one at https://mozilla.org/MPL/2.0/.
- *
- * OpenCRVS is also distributed under the terms of the Civil Registration
- * & Healthcare Disclaimer located at http://opencrvs.org/license.
- *
- * Copyright (C) The OpenCRVS Authors located at https://github.com/opencrvs/opencrvs-core/blob/master/AUTHORS.
- */
-import { GQLResolver } from '@gateway/graphql/schema'
-import { fetchToken, fetchUserInfo } from './utils'
-
-export const resolvers: GQLResolver = {
- Query: {
- getOIDPUserInfo: async (_, { code, clientId, redirectUri, grantType }) => {
- const tokenResponse = await fetchToken({
- code,
- clientId,
- redirectUri,
- grantType
- })
-
- if (!tokenResponse.access_token) {
- throw new Error(
- 'Something went wrong with the OIDP token request. No access token was returned. Response from OIDP: ' +
- JSON.stringify(tokenResponse)
- )
- }
-
- return fetchUserInfo(tokenResponse.access_token)
- }
- }
-}
diff --git a/packages/gateway/src/features/OIDPUserInfo/schema.graphql b/packages/gateway/src/features/OIDPUserInfo/schema.graphql
deleted file mode 100644
index a3d41fedbcd..00000000000
--- a/packages/gateway/src/features/OIDPUserInfo/schema.graphql
+++ /dev/null
@@ -1,57 +0,0 @@
-# This Source Code Form is subject to the terms of the Mozilla Public
-# License, v. 2.0. If a copy of the MPL was not distributed with this
-# file, You can obtain one at https://mozilla.org/MPL/2.0/.
-#
-# OpenCRVS is also distributed under the terms of the Civil Registration
-# & Healthcare Disclaimer located at http://opencrvs.org/license.
-#
-# Copyright (C) The OpenCRVS Authors located at https://github.com/opencrvs/opencrvs-core/blob/master/AUTHORS.
-
-type OIDPUserAddress {
- formatted: String
- street_address: String
- locality: String
- region: String
- postal_code: String
- city: String
- country: String
-}
-
-type OIDPUserInfo {
- sub: String!
- name: String
- given_name: String
- family_name: String
- middle_name: String
- nickname: String
- preferred_username: String
- profile: String
- picture: String
- website: String
- email: String
- email_verified: Boolean
- gender: String
- birthdate: String
- zoneinfo: String
- locale: String
- phone_number: String
- phone_number_verified: Boolean
- address: OIDPUserAddress
- updated_at: Int
-}
-
-type UserInfo {
- oidpUserInfo: OIDPUserInfo
- districtFhirId: String
- stateFhirId: String
- locationLevel3FhirId: String
-}
-
-type Query {
- getOIDPUserInfo(
- code: String!
- clientId: String!
- redirectUri: String!
- grantType: String
- ): UserInfo
-}
diff --git a/packages/gateway/src/features/OIDPUserInfo/utils.ts b/packages/gateway/src/features/OIDPUserInfo/utils.ts
deleted file mode 100644
index aa42fd4dae2..00000000000
--- a/packages/gateway/src/features/OIDPUserInfo/utils.ts
+++ /dev/null
@@ -1,146 +0,0 @@
-/*
- * This Source Code Form is subject to the terms of the Mozilla Public
- * License, v. 2.0. If a copy of the MPL was not distributed with this
- * file, You can obtain one at https://mozilla.org/MPL/2.0/.
- *
- * OpenCRVS is also distributed under the terms of the Civil Registration
- * & Healthcare Disclaimer located at http://opencrvs.org/license.
- *
- * Copyright (C) The OpenCRVS Authors located at https://github.com/opencrvs/opencrvs-core/blob/master/AUTHORS.
- */
-import * as jwt from 'jsonwebtoken'
-import * as jose from 'jose'
-import fetch from '@gateway/fetch'
-import {
- OIDP_CLIENT_PRIVATE_KEY,
- OIDP_JWT_AUD_CLAIM,
- OIDP_TOKEN_URL,
- OIDP_USERINFO_URL
-} from '@gateway/constants'
-
-import { logger } from '@opencrvs/commons'
-import { OIDPUserInfo } from './oidp-types'
-import { Bundle, Location } from '@opencrvs/commons/types'
-import { fetchFromHearth } from '@gateway/features/fhir/service'
-
-const TOKEN_GRANT_TYPE = 'authorization_code'
-const CLIENT_ASSERTION_TYPE =
- 'urn:ietf:params:oauth:client-assertion-type:jwt-bearer'
-
-const JWT_ALG = 'RS256'
-const JWT_EXPIRATION_TIME = '1h'
-
-export type FetchTokenProps = {
- code: string
- clientId: string
- redirectUri: string
- grantType?: string
-}
-
-const searchLocationFromHearth = (name: string) =>
- fetchFromHearth>(
- `/Location?${new URLSearchParams({ name, type: 'ADMIN_STRUCTURE' })}`
- )
-
-const findAdminStructureLocationWithName = async (name: string) => {
- const fhirBundleLocations = await searchLocationFromHearth(name)
-
- if ((fhirBundleLocations.entry?.length ?? 0) > 1) {
- throw new Error(
- 'Multiple admin structure locations found with the same name'
- )
- }
-
- if ((fhirBundleLocations.entry?.length ?? 0) === 0) {
- logger.warn('No admin structure location found with the name: ' + name)
- return null
- }
-
- return fhirBundleLocations.entry?.[0].resource?.id
-}
-
-const pickUserInfo = async (userInfo: OIDPUserInfo) => {
- const stateFhirId =
- userInfo.address?.country &&
- (await findAdminStructureLocationWithName(userInfo.address.country))
-
- return {
- oidpUserInfo: userInfo,
- stateFhirId,
- districtFhirId:
- userInfo.address?.region &&
- (await findAdminStructureLocationWithName(userInfo.address.region)),
- locationLevel3FhirId:
- userInfo.address?.locality &&
- (await findAdminStructureLocationWithName(userInfo.address.locality))
- }
-}
-
-export const fetchToken = async ({
- code,
- clientId,
- redirectUri,
- grantType = TOKEN_GRANT_TYPE
-}: FetchTokenProps) => {
- const body = new URLSearchParams({
- code: code,
- client_id: clientId,
- redirect_uri: redirectUri,
- grant_type: grantType,
- client_assertion_type: CLIENT_ASSERTION_TYPE,
- client_assertion: await generateSignedJwt(clientId)
- })
-
- const request = await fetch(OIDP_TOKEN_URL!, {
- method: 'POST',
- headers: {
- 'Content-Type': 'application/x-www-form-urlencoded'
- },
- body
- })
-
- const response = await request.json()
- return response as { access_token?: string }
-}
-
-export const fetchUserInfo = async (accessToken: string) => {
- const request = await fetch(OIDP_USERINFO_URL!, {
- headers: {
- Authorization: 'Bearer ' + accessToken
- }
- })
-
- const response = await request.text()
- const decodedResponse = decodeUserInfoResponse(response)
-
- logger.info(`OIDP user info response succeeded`)
-
- return pickUserInfo(decodedResponse)
-}
-
-const generateSignedJwt = async (clientId: string) => {
- const header = {
- alg: JWT_ALG,
- typ: 'JWT'
- }
-
- const payload = {
- iss: clientId,
- sub: clientId,
- aud: OIDP_JWT_AUD_CLAIM
- }
-
- const decodeKey = Buffer.from(OIDP_CLIENT_PRIVATE_KEY!, 'base64')?.toString()
- const jwkObject = JSON.parse(decodeKey)
- const privateKey = await jose.importJWK(jwkObject, JWT_ALG)
-
- return new jose.SignJWT(payload)
- .setProtectedHeader(header)
- .setIssuedAt()
- .setExpirationTime(JWT_EXPIRATION_TIME)
- .sign(privateKey)
-}
-
-const decodeUserInfoResponse = (response: string) => {
- return jwt.decode(response) as OIDPUserInfo
-}
diff --git a/packages/gateway/src/graphql/config.ts b/packages/gateway/src/graphql/config.ts
index fa554e2e352..c0d94db2c87 100644
--- a/packages/gateway/src/graphql/config.ts
+++ b/packages/gateway/src/graphql/config.ts
@@ -31,7 +31,6 @@ import { searchTypeResolvers } from '@gateway/features/search/type-resolvers'
import { resolvers as userRootResolvers } from '@gateway/features/user/root-resolvers'
import { resolvers as correctionRootResolvers } from '@gateway/features/correction/root-resolvers'
import { resolvers as bookmarkAdvancedSearchResolvers } from '@gateway/features/bookmarkAdvancedSearch/root-resolvers'
-import { resolvers as OIDPUserInfoResolvers } from '@gateway/features/OIDPUserInfo/root-resolvers'
import {
ISystemModelData,
IUserModelData,
@@ -84,7 +83,6 @@ export const resolvers: StringIndexed = merge(
correctionRootResolvers as IResolvers,
integrationResolver as IResolvers,
bookmarkAdvancedSearchResolvers as IResolvers,
- OIDPUserInfoResolvers as IResolvers,
{
FieldValue: new GraphQLScalarType({
name: 'FieldValue',
diff --git a/packages/gateway/src/graphql/index.graphql b/packages/gateway/src/graphql/index.graphql
index ab8ca23a042..f9f8634bfd4 100644
--- a/packages/gateway/src/graphql/index.graphql
+++ b/packages/gateway/src/graphql/index.graphql
@@ -19,7 +19,6 @@
# import Mutation.* from '../features/systems/schema.graphql'
# import Query.* from '../features/systems/schema.graphql'
# import Mutation from '../features/bookmarkAdvancedSearch/schema.graphql'
-# import Query.* from '../features/OIDPUserInfo/schema.graphql'
# import * from 'common.graphql'
# TODO
diff --git a/packages/gateway/src/graphql/schema.d.ts b/packages/gateway/src/graphql/schema.d.ts
index e1e1352ee24..81b819f07b9 100644
--- a/packages/gateway/src/graphql/schema.d.ts
+++ b/packages/gateway/src/graphql/schema.d.ts
@@ -50,7 +50,6 @@ export interface GQLQuery {
getEventsWithProgress?: GQLEventProgressResultSet
getSystemRoles?: Array
fetchSystem?: GQLSystem
- getOIDPUserInfo?: GQLUserInfo
}
export interface GQLMutation {
@@ -509,13 +508,6 @@ export interface GQLSystem {
settings?: GQLSystemSettings
}
-export interface GQLUserInfo {
- oidpUserInfo?: GQLOIDPUserInfo
- districtFhirId?: string
- stateFhirId?: string
- locationLevel3FhirId?: string
-}
-
export interface GQLCorrectionInput {
requester: string
requesterOther?: string
@@ -1020,29 +1012,6 @@ export interface GQLSystemSettings {
openIdProviderClaims?: string
}
-export interface GQLOIDPUserInfo {
- sub: string
- name?: string
- given_name?: string
- family_name?: string
- middle_name?: string
- nickname?: string
- preferred_username?: string
- profile?: string
- picture?: string
- website?: string
- email?: string
- email_verified?: boolean
- gender?: string
- birthdate?: string
- zoneinfo?: string
- locale?: string
- phone_number?: string
- phone_number_verified?: boolean
- address?: GQLOIDPUserAddress
- updated_at?: number
-}
-
export interface GQLAttachmentInput {
_fhirID?: string
contentType?: string
@@ -1517,16 +1486,6 @@ export interface GQLWebhookPermission {
permissions: Array
}
-export interface GQLOIDPUserAddress {
- formatted?: string
- street_address?: string
- locality?: string
- region?: string
- postal_code?: string
- city?: string
- country?: string
-}
-
export const enum GQLAttachmentInputStatus {
approved = 'approved',
validated = 'validated',
@@ -1749,7 +1708,6 @@ export interface GQLResolver {
EventProgressResultSet?: GQLEventProgressResultSetTypeResolver
SystemRole?: GQLSystemRoleTypeResolver
System?: GQLSystemTypeResolver
- UserInfo?: GQLUserInfoTypeResolver
CreatedIds?: GQLCreatedIdsTypeResolver
Reinstated?: GQLReinstatedTypeResolver
Avatar?: GQLAvatarTypeResolver
@@ -1792,7 +1750,6 @@ export interface GQLResolver {
EventProgressSet?: GQLEventProgressSetTypeResolver
SystemSettings?: GQLSystemSettingsTypeResolver
- OIDPUserInfo?: GQLOIDPUserInfoTypeResolver
AssignmentData?: GQLAssignmentDataTypeResolver
RegWorkflow?: GQLRegWorkflowTypeResolver
Certificate?: GQLCertificateTypeResolver
@@ -1816,7 +1773,6 @@ export interface GQLResolver {
MarriageEventSearchSet?: GQLMarriageEventSearchSetTypeResolver
EventProgressData?: GQLEventProgressDataTypeResolver
WebhookPermission?: GQLWebhookPermissionTypeResolver
- OIDPUserAddress?: GQLOIDPUserAddressTypeResolver
FieldValue?: GraphQLScalarType
AuditLogItemBase?: {
__resolveType: GQLAuditLogItemBaseTypeResolver
@@ -1862,7 +1818,6 @@ export interface GQLQueryTypeResolver {
getEventsWithProgress?: QueryToGetEventsWithProgressResolver
getSystemRoles?: QueryToGetSystemRolesResolver
fetchSystem?: QueryToFetchSystemResolver
- getOIDPUserInfo?: QueryToGetOIDPUserInfoResolver
}
export interface QueryToSendNotificationToAllUsersArgs {
@@ -2461,21 +2416,6 @@ export interface QueryToFetchSystemResolver {
): TResult
}
-export interface QueryToGetOIDPUserInfoArgs {
- code: string
- clientId: string
- redirectUri: string
- grantType?: string
-}
-export interface QueryToGetOIDPUserInfoResolver {
- (
- parent: TParent,
- args: QueryToGetOIDPUserInfoArgs,
- context: Context,
- info: GraphQLResolveInfo
- ): TResult
-}
-
export interface GQLMutationTypeResolver {
requestRegistrationCorrection?: MutationToRequestRegistrationCorrectionResolver
rejectRegistrationCorrection?: MutationToRejectRegistrationCorrectionResolver
@@ -5471,55 +5411,6 @@ export interface SystemToSettingsResolver {
): TResult
}
-export interface GQLUserInfoTypeResolver {
- oidpUserInfo?: UserInfoToOidpUserInfoResolver
- districtFhirId?: UserInfoToDistrictFhirIdResolver
- stateFhirId?: UserInfoToStateFhirIdResolver
- locationLevel3FhirId?: UserInfoToLocationLevel3FhirIdResolver
-}
-
-export interface UserInfoToOidpUserInfoResolver {
- (
- parent: TParent,
- args: {},
- context: Context,
- info: GraphQLResolveInfo
- ): TResult
-}
-
-export interface UserInfoToDistrictFhirIdResolver<
- TParent = any,
- TResult = any
-> {
- (
- parent: TParent,
- args: {},
- context: Context,
- info: GraphQLResolveInfo
- ): TResult
-}
-
-export interface UserInfoToStateFhirIdResolver {
- (
- parent: TParent,
- args: {},
- context: Context,
- info: GraphQLResolveInfo
- ): TResult
-}
-
-export interface UserInfoToLocationLevel3FhirIdResolver<
- TParent = any,
- TResult = any
-> {
- (
- parent: TParent,
- args: {},
- context: Context,
- info: GraphQLResolveInfo
- ): TResult
-}
-
export interface GQLCreatedIdsTypeResolver {
compositionId?: CreatedIdsToCompositionIdResolver
trackingId?: CreatedIdsToTrackingIdResolver
@@ -7880,233 +7771,6 @@ export interface SystemSettingsToOpenIdProviderClaimsResolver<
): TResult
}
-export interface GQLOIDPUserInfoTypeResolver {
- sub?: OIDPUserInfoToSubResolver
- name?: OIDPUserInfoToNameResolver
- given_name?: OIDPUserInfoToGiven_nameResolver
- family_name?: OIDPUserInfoToFamily_nameResolver
- middle_name?: OIDPUserInfoToMiddle_nameResolver
- nickname?: OIDPUserInfoToNicknameResolver
- preferred_username?: OIDPUserInfoToPreferred_usernameResolver
- profile?: OIDPUserInfoToProfileResolver
- picture?: OIDPUserInfoToPictureResolver
- website?: OIDPUserInfoToWebsiteResolver
- email?: OIDPUserInfoToEmailResolver
- email_verified?: OIDPUserInfoToEmail_verifiedResolver
- gender?: OIDPUserInfoToGenderResolver
- birthdate?: OIDPUserInfoToBirthdateResolver
- zoneinfo?: OIDPUserInfoToZoneinfoResolver
- locale?: OIDPUserInfoToLocaleResolver
- phone_number?: OIDPUserInfoToPhone_numberResolver
- phone_number_verified?: OIDPUserInfoToPhone_number_verifiedResolver
- address?: OIDPUserInfoToAddressResolver
- updated_at?: OIDPUserInfoToUpdated_atResolver
-}
-
-export interface OIDPUserInfoToSubResolver {
- (
- parent: TParent,
- args: {},
- context: Context,
- info: GraphQLResolveInfo
- ): TResult
-}
-
-export interface OIDPUserInfoToNameResolver {
- (
- parent: TParent,
- args: {},
- context: Context,
- info: GraphQLResolveInfo
- ): TResult
-}
-
-export interface OIDPUserInfoToGiven_nameResolver<
- TParent = any,
- TResult = any
-> {
- (
- parent: TParent,
- args: {},
- context: Context,
- info: GraphQLResolveInfo
- ): TResult
-}
-
-export interface OIDPUserInfoToFamily_nameResolver<
- TParent = any,
- TResult = any
-> {
- (
- parent: TParent,
- args: {},
- context: Context,
- info: GraphQLResolveInfo
- ): TResult
-}
-
-export interface OIDPUserInfoToMiddle_nameResolver<
- TParent = any,
- TResult = any
-> {
- (
- parent: TParent,
- args: {},
- context: Context,
- info: GraphQLResolveInfo
- ): TResult
-}
-
-export interface OIDPUserInfoToNicknameResolver {
- (
- parent: TParent,
- args: {},
- context: Context,
- info: GraphQLResolveInfo
- ): TResult
-}
-
-export interface OIDPUserInfoToPreferred_usernameResolver<
- TParent = any,
- TResult = any
-> {
- (
- parent: TParent,
- args: {},
- context: Context,
- info: GraphQLResolveInfo
- ): TResult
-}
-
-export interface OIDPUserInfoToProfileResolver {
- (
- parent: TParent,
- args: {},
- context: Context,
- info: GraphQLResolveInfo
- ): TResult
-}
-
-export interface OIDPUserInfoToPictureResolver {
- (
- parent: TParent,
- args: {},
- context: Context,
- info: GraphQLResolveInfo
- ): TResult
-}
-
-export interface OIDPUserInfoToWebsiteResolver {
- (
- parent: TParent,
- args: {},
- context: Context,
- info: GraphQLResolveInfo
- ): TResult
-}
-
-export interface OIDPUserInfoToEmailResolver {
- (
- parent: TParent,
- args: {},
- context: Context,
- info: GraphQLResolveInfo
- ): TResult
-}
-
-export interface OIDPUserInfoToEmail_verifiedResolver<
- TParent = any,
- TResult = any
-> {
- (
- parent: TParent,
- args: {},
- context: Context,
- info: GraphQLResolveInfo
- ): TResult
-}
-
-export interface OIDPUserInfoToGenderResolver {
- (
- parent: TParent,
- args: {},
- context: Context,
- info: GraphQLResolveInfo
- ): TResult
-}
-
-export interface OIDPUserInfoToBirthdateResolver {
- (
- parent: TParent,
- args: {},
- context: Context,
- info: GraphQLResolveInfo
- ): TResult
-}
-
-export interface OIDPUserInfoToZoneinfoResolver {
- (
- parent: TParent,
- args: {},
- context: Context,
- info: GraphQLResolveInfo
- ): TResult
-}
-
-export interface OIDPUserInfoToLocaleResolver {
- (
- parent: TParent,
- args: {},
- context: Context,
- info: GraphQLResolveInfo
- ): TResult
-}
-
-export interface OIDPUserInfoToPhone_numberResolver<
- TParent = any,
- TResult = any
-> {
- (
- parent: TParent,
- args: {},
- context: Context,
- info: GraphQLResolveInfo
- ): TResult
-}
-
-export interface OIDPUserInfoToPhone_number_verifiedResolver<
- TParent = any,
- TResult = any
-> {
- (
- parent: TParent,
- args: {},
- context: Context,
- info: GraphQLResolveInfo
- ): TResult
-}
-
-export interface OIDPUserInfoToAddressResolver {
- (
- parent: TParent,
- args: {},
- context: Context,
- info: GraphQLResolveInfo
- ): TResult
-}
-
-export interface OIDPUserInfoToUpdated_atResolver<
- TParent = any,
- TResult = any
-> {
- (
- parent: TParent,
- args: {},
- context: Context,
- info: GraphQLResolveInfo
- ): TResult
-}
-
export interface GQLAssignmentDataTypeResolver {
practitionerId?: AssignmentDataToPractitionerIdResolver
firstName?: AssignmentDataToFirstNameResolver
@@ -10550,94 +10214,6 @@ export interface WebhookPermissionToPermissionsResolver<
): TResult
}
-export interface GQLOIDPUserAddressTypeResolver {
- formatted?: OIDPUserAddressToFormattedResolver
- street_address?: OIDPUserAddressToStreet_addressResolver
- locality?: OIDPUserAddressToLocalityResolver
- region?: OIDPUserAddressToRegionResolver
- postal_code?: OIDPUserAddressToPostal_codeResolver
- city?: OIDPUserAddressToCityResolver
- country?: OIDPUserAddressToCountryResolver
-}
-
-export interface OIDPUserAddressToFormattedResolver<
- TParent = any,
- TResult = any
-> {
- (
- parent: TParent,
- args: {},
- context: Context,
- info: GraphQLResolveInfo
- ): TResult
-}
-
-export interface OIDPUserAddressToStreet_addressResolver<
- TParent = any,
- TResult = any
-> {
- (
- parent: TParent,
- args: {},
- context: Context,
- info: GraphQLResolveInfo
- ): TResult
-}
-
-export interface OIDPUserAddressToLocalityResolver<
- TParent = any,
- TResult = any
-> {
- (
- parent: TParent,
- args: {},
- context: Context,
- info: GraphQLResolveInfo
- ): TResult
-}
-
-export interface OIDPUserAddressToRegionResolver {
- (
- parent: TParent,
- args: {},
- context: Context,
- info: GraphQLResolveInfo
- ): TResult
-}
-
-export interface OIDPUserAddressToPostal_codeResolver<
- TParent = any,
- TResult = any
-> {
- (
- parent: TParent,
- args: {},
- context: Context,
- info: GraphQLResolveInfo
- ): TResult
-}
-
-export interface OIDPUserAddressToCityResolver {
- (
- parent: TParent,
- args: {},
- context: Context,
- info: GraphQLResolveInfo
- ): TResult
-}
-
-export interface OIDPUserAddressToCountryResolver<
- TParent = any,
- TResult = any
-> {
- (
- parent: TParent,
- args: {},
- context: Context,
- info: GraphQLResolveInfo
- ): TResult
-}
-
export interface GQLAuditLogItemBaseTypeResolver {
(parent: TParent, context: Context, info: GraphQLResolveInfo):
| 'UserAuditLogItemWithComposition'
diff --git a/packages/gateway/src/graphql/schema.graphql b/packages/gateway/src/graphql/schema.graphql
index 4cf1069b494..6ff47e98326 100644
--- a/packages/gateway/src/graphql/schema.graphql
+++ b/packages/gateway/src/graphql/schema.graphql
@@ -147,12 +147,6 @@ type Query {
sortOrder: String
): [SystemRole!]
fetchSystem(clientId: ID!): System
- getOIDPUserInfo(
- code: String!
- clientId: String!
- redirectUri: String!
- grantType: String
- ): UserInfo
}
type Mutation {
@@ -635,13 +629,6 @@ type System {
settings: SystemSettings
}
-type UserInfo {
- oidpUserInfo: OIDPUserInfo
- districtFhirId: String
- stateFhirId: String
- locationLevel3FhirId: String
-}
-
input CorrectionInput {
requester: String!
requesterOther: String
@@ -1122,29 +1109,6 @@ type SystemSettings {
openIdProviderClaims: String
}
-type OIDPUserInfo {
- sub: String!
- name: String
- given_name: String
- family_name: String
- middle_name: String
- nickname: String
- preferred_username: String
- profile: String
- picture: String
- website: String
- email: String
- email_verified: Boolean
- gender: String
- birthdate: String
- zoneinfo: String
- locale: String
- phone_number: String
- phone_number_verified: Boolean
- address: OIDPUserAddress
- updated_at: Int
-}
-
input AttachmentInput {
_fhirID: ID
contentType: String
@@ -1618,16 +1582,6 @@ type WebhookPermission {
permissions: [String!]!
}
-type OIDPUserAddress {
- formatted: String
- street_address: String
- locality: String
- region: String
- postal_code: String
- city: String
- country: String
-}
-
enum AttachmentInputStatus {
approved
validated
diff --git a/packages/gateway/test/setupJest.ts b/packages/gateway/test/setupJest.ts
index 12052b031da..001598ad33e 100644
--- a/packages/gateway/test/setupJest.ts
+++ b/packages/gateway/test/setupJest.ts
@@ -17,12 +17,3 @@ jest.setMock('node-fetch', { default: fetch, Headers: f.Headers })
jest.setMock('@opencrvs/commons/monitoring')
process.env.CERT_PUBLIC_KEY_PATH = join(__dirname, './cert.key.pub')
-process.env.NATIONAL_ID_OIDP_CLIENT_PRIVATE_KEY =
- 'ewogICAgInAiOiAiMVRMMlRPOWxNZnZOWThzeWVReFFrd3F1RThfdll5bV85ZS1yUkxRaV9reWJvLUMwUXJYVklQRFNfN2laV3I4WFB0MGlMWnJkemtjSzU0dGtKWGRkYWk3bEhxM3VyNndLU09uUHVPMURNS0stLXlNR3lCd0RfazdTbUdLUDlsTml3Q0pDT1Q2dDdjWEM1SnBEaVBNc05HQWNEUDZyRGFQQ2tlMzZUcjV5LW5NIiwKICAgICJrdHkiOiAiUlNBIiwKICAgICJxIjogIng4U1FwSHc2UlFnWmxHUC1EdWpiS1pRcUZxczAxU0ZsczFQa1lya25yM01rV1FrUFVGVDlubW5CbTlHWlVwbUV0TU9WZDc4SWVfdHV1UGZFVFo1SWYwTmt0bTNJdS1Pcm9jQzJBU3IzQnF0dUZyUnhUWTRJbnVBVnhHd0VuV0Frd1ZWR1dJQklEVkhSeHhGblAwZUo0YWNmVGVDcWs4QTE1cFRhOUo2MmY4ayIsCiAgICAiZCI6ICJubms3Q2RtT2hucVdyMTU1cW5hc25PY2pPamYyVEJLNlVpYUJOcWw1S1FBMmlJSnJGa0F1ZXFYcmwzM1J0eVgtZFFtOU1NTnhNLUYwMUpac3REME50eW1ZdXlzOVFMbGhKbld2RHlGLXlmMHJHOFJPVHROQkNuZjgxNUE2STQ1UzhqVUlXMGI1dl9lQlAxY1lKdWRLSW5QNlY0NVRZUEFlSjhKQ2hPeFJ2RlJHX2loOFVRaTdDZFZWNXFvVUVpX1lOWXNleTc1cTZpTFRiRVFFOExsNE9lMnRFNDMxTnltMTBaa185R2FNVEp0SU1YMm1iMW01blFfMTZmRC1ZNDZvWDlucW9zUUtUZ19uYmRoUFU3QWQwNW5MSjZFRER0X0JIbDNfc0d1blhrN3BhMjFTN1hfRjBQT0JrdG42dlNUV0FEZjQtM2pXaFNHa21yX3pyR3hLc1EiLAogICAgImUiOiAiQVFBQiIsCiAgICAicWkiOiAiRlpCaE55Uk5nMVhJVW44d1VFVGRCSEh4Qmx0Wk9tbDJhUzNXYlVZb3VuQlN1NDhoVk9BOGpWdFJFaWFBc25xUkxtaGNIN3V0aWVCTHBKazZsZ2pyM3RINnh3WklOSDRCb1NBYnRyUW5DMXd1ZE1fa1FCX1hpRk4tSFhPX0oyU2thV05nb19JSFFING1udXZnRUkxUEdpZGdwZzJ2NnJ6V3R3ZW5rbXhHblJnIiwKICAgICJkcCI6ICJNYkhMVDJ1TnZ2VGVqeUJTQjMwald1TG1hSl9UUU4zLWJLa00xdHJXUFVoR0R4RFZjNmRHb29MXzY3TnZxNE5YTzhQM3I0R2xxZXROVTJOZVdJMVdMT1g1YWdsSTFaSFlZOTU4R0xMVk1vVDgxelQyNDdZRUNFYl9ONTNoeUp6dks3SFFsZDlTVTFZQmM1LXhsajU0VTAwRHZOT3ZzMkkwZkNkb2JPcGZpcGsiLAogICAgImFsZyI6ICJSUzI1NiIsCiAgICAiZHEiOiAiYlJkRjJkMVJRTk5zaktHU1l2ZjhmeGNfYU1PMEJWUElvd2FFS1BsdDE1MHNVMGJrU3YwdXh1eF80eVN4OHU2TkR0M2o2TkcwdzJnS0RnNlg3NzhwWGY0aXFKRUpWcm04eDRkaW5QNm1pY2ppUkpuamFmUFBkMXR0NTZjSldodmYxb2hIOHhxU3ZsdFpFTG5MUlQ0LTZMQ0lJdEkydEpyNWxHTGpzMFJjNnlrIiwKICAgICJuIjogInBsNVE4QWVsT1ozWERyc093ems5T0ExNzR1WEF3ZnpxOW1NVXB2cVEwMC1sMFlKWGljZUlfWU13ZVJnS0tGTnpEMklEajhGNnJqaDh1THEwdjhiTE5oLWQzUEFwRHBTMTVOc3ZhN2U4VFZNR1paLVZJVDVKVGZqMzZsNWR2Q1oxa21MRUJ2ZjJhbzFHOVowMXU0NDNMZDRueEgzNHpkLTlUZU5VRXp4ejAweXUtOFBrRkJ5OGNySGVCR2JmcUlTLV9nbVJ6ZEIwclFQM29GT3hiNWJfa01WYUR6Wm5YSFVVemFIdDRNOEcxcHF2QjJOZzQzUDQ0d2NJME1YMVNHVkRQbGMtZVBfNjFjNW5qTzhoVnhnbUZzOUt0WVR5a0t3OXhsYUh6U1dCbG9ObVZFeG1Yd1ItckVzSTdJczdxOUpWTjdEVzNaNmYzRnk3NVpnN21rZXhTdyIKfQ=='
-process.env.NATIONAL_ID_OIDP_BASE_URL = 'http://localhost:27501/v1/oid/'
-process.env.NATIONAL_ID_OIDP_TOKEN_URL =
- 'http://localhost:27502/v1/esignet/oauth/v2/token'
-process.env.NATIONAL_ID_OIDP_USERINFO_URL =
- 'http://localhost:27502/v1/esignet/oidc/v2/userinfo'
-process.env.NATIONAL_ID_OIDP_JWT_AUD_CLAIM =
- 'http://localhost:27501/v1/idp/oauth/token'
diff --git a/packages/user-mgnt/src/constants.ts b/packages/user-mgnt/src/constants.ts
index 2136746db35..89e256a7345 100644
--- a/packages/user-mgnt/src/constants.ts
+++ b/packages/user-mgnt/src/constants.ts
@@ -26,10 +26,3 @@ export const RECORD_SEARCH_QUOTA = env.RECORD_SEARCH_QUOTA
export const FHIR_URL = env.FHIR_URL
export const METRICS_URL = env.METRICS_URL
-
-export const NATIONAL_ID_OIDP_BASE_URL = env.NATIONAL_ID_OIDP_BASE_URL
-export const NATIONAL_ID_OIDP_CLIENT_ID = env.NATIONAL_ID_OIDP_CLIENT_ID
-export const NATIONAL_ID_OIDP_ESSENTIAL_CLAIMS =
- env.NATIONAL_ID_OIDP_ESSENTIAL_CLAIMS
-export const NATIONAL_ID_OIDP_VOLUNTARY_CLAIMS =
- env.NATIONAL_ID_OIDP_VOLUNTARY_CLAIMS
diff --git a/packages/user-mgnt/src/environment.ts b/packages/user-mgnt/src/environment.ts
index 8c9b5c22db2..1d6026efda3 100644
--- a/packages/user-mgnt/src/environment.ts
+++ b/packages/user-mgnt/src/environment.ts
@@ -24,10 +24,5 @@ export const env = cleanEnv(process.env, {
RECORD_SEARCH_QUOTA: num({ default: 2000 }),
FHIR_URL: url({ devDefault: 'http://localhost:3447/fhir' }),
- METRICS_URL: url({ devDefault: 'http://localhost:1050' }),
-
- NATIONAL_ID_OIDP_BASE_URL: str({ default: undefined }),
- NATIONAL_ID_OIDP_CLIENT_ID: str({ default: undefined }),
- NATIONAL_ID_OIDP_ESSENTIAL_CLAIMS: str({ default: undefined }),
- NATIONAL_ID_OIDP_VOLUNTARY_CLAIMS: str({ default: undefined })
+ METRICS_URL: url({ devDefault: 'http://localhost:1050' })
})
diff --git a/packages/user-mgnt/src/utils/system.ts b/packages/user-mgnt/src/utils/system.ts
index 00620af2387..ef3a21084c4 100644
--- a/packages/user-mgnt/src/utils/system.ts
+++ b/packages/user-mgnt/src/utils/system.ts
@@ -8,12 +8,6 @@
*
* Copyright (C) The OpenCRVS Authors located at https://github.com/opencrvs/opencrvs-core/blob/master/AUTHORS.
*/
-import {
- NATIONAL_ID_OIDP_CLIENT_ID,
- NATIONAL_ID_OIDP_BASE_URL,
- NATIONAL_ID_OIDP_ESSENTIAL_CLAIMS,
- NATIONAL_ID_OIDP_VOLUNTARY_CLAIMS
-} from '@user-mgnt/constants'
import { ISystemModel } from '@user-mgnt/model/system'
import { pick } from 'lodash'
import { Types } from 'mongoose'
@@ -33,30 +27,12 @@ export const integratingSystemTypes = {
type MongooseQueriedSystem = ISystemModel & { _id: Types.ObjectId }
const pickSettings = (system: MongooseQueriedSystem) => {
- const openIdProviderClaims = convertClaimsToUserInfoClaims({
- openIdProviderEssentialClaims: NATIONAL_ID_OIDP_ESSENTIAL_CLAIMS,
- openIdProviderVoluntaryClaims: NATIONAL_ID_OIDP_VOLUNTARY_CLAIMS
- })
-
- const openIdConnectUrl =
- system.type === 'NATIONAL_ID' &&
- NATIONAL_ID_OIDP_CLIENT_ID &&
- NATIONAL_ID_OIDP_BASE_URL &&
- (NATIONAL_ID_OIDP_ESSENTIAL_CLAIMS || NATIONAL_ID_OIDP_VOLUNTARY_CLAIMS)
- ? {
- openIdProviderBaseUrl: NATIONAL_ID_OIDP_BASE_URL,
- openIdProviderClientId: NATIONAL_ID_OIDP_CLIENT_ID,
- openIdProviderClaims
- }
- : {}
-
const webhook = system.settings.webhook.map((ite) => ({
event: ite.event,
permissions: ite.permissions
}))
return {
- ...openIdConnectUrl,
webhook,
dailyQuota: system.settings.dailyQuota
}
@@ -80,26 +56,3 @@ export const pickSystem = (system: MongooseQueriedSystem) => {
settings: pickSettings(system)
}
}
-
-const convertClaimsToUserInfoClaims = ({
- openIdProviderEssentialClaims,
- openIdProviderVoluntaryClaims
-}: {
- openIdProviderEssentialClaims?: string
- openIdProviderVoluntaryClaims?: string
-}) => {
- const userinfo: Record = {}
-
- for (const claim of (openIdProviderVoluntaryClaims ?? '').split(',')) {
- userinfo[claim] = { essential: false }
- }
-
- for (const claim of (openIdProviderEssentialClaims ?? '').split(',')) {
- userinfo[claim] = { essential: true }
- }
-
- return JSON.stringify({
- userinfo,
- id_token: {}
- })
-}