mirror of
https://github.com/mosip/inji-wallet.git
synced 2026-01-07 20:53:54 -05:00
Signed-off-by: KiruthikaJeyashankar <81218987+KiruthikaJeyashankar@users.noreply.github.com>
340 lines
9.3 KiB
TypeScript
340 lines
9.3 KiB
TypeScript
import {request} from './request';
|
|
import {
|
|
API_CACHED_STORAGE_KEYS,
|
|
changeCrendetialRegistry,
|
|
COMMON_PROPS_KEY,
|
|
} from './constants';
|
|
import {INITIAL_CONFIG} from './InitialConfig';
|
|
import {getItem, setItem} from '../machines/store';
|
|
import {faceMatchConfig} from './commonUtil';
|
|
import {configure} from '@iriscan/biometric-sdk-react-native';
|
|
import {
|
|
getErrorEventData,
|
|
getImpressionEventData,
|
|
sendErrorEvent,
|
|
sendImpressionEvent,
|
|
} from './telemetry/TelemetryUtils';
|
|
import {TelemetryConstants} from './telemetry/TelemetryConstants';
|
|
|
|
export const API_URLS: ApiUrls = {
|
|
issuersList: {
|
|
method: 'GET',
|
|
buildURL: (): `/${string}` => '/v1/mimoto/issuers',
|
|
},
|
|
issuerConfig: {
|
|
method: 'GET',
|
|
buildURL: (issuerId: string): `/${string}` =>
|
|
`/v1/mimoto/issuers/${issuerId}`,
|
|
},
|
|
issuerWellknownConfig: {
|
|
method: 'GET',
|
|
buildURL: (issuerId: string): `/${string}` =>
|
|
`/v1/mimoto/issuers/${issuerId}/.well-known`,
|
|
},
|
|
allProperties: {
|
|
method: 'GET',
|
|
buildURL: (): `/${string}` => '/v1/mimoto/allProperties',
|
|
},
|
|
getIndividualId: {
|
|
method: 'POST',
|
|
buildURL: (): `/${string}` => '/v1/mimoto/aid/get-individual-id',
|
|
},
|
|
reqIndividualOTP: {
|
|
method: 'POST',
|
|
buildURL: (): `/${string}` => '/v1/mimoto/req/individualId/otp',
|
|
},
|
|
walletBinding: {
|
|
method: 'POST',
|
|
buildURL: (): `/${string}` => '/v1/mimoto/wallet-binding',
|
|
},
|
|
bindingOtp: {
|
|
method: 'POST',
|
|
buildURL: (): `/${string}` => '/v1/mimoto/binding-otp',
|
|
},
|
|
requestOtp: {
|
|
method: 'POST',
|
|
buildURL: (): `/${string}` => '/v1/mimoto/req/otp',
|
|
},
|
|
credentialRequest: {
|
|
method: 'POST',
|
|
buildURL: (): `/${string}` => '/v1/mimoto/credentialshare/request',
|
|
},
|
|
credentialStatus: {
|
|
method: 'GET',
|
|
buildURL: (id: string): `/${string}` =>
|
|
`/v1/mimoto/credentialshare/request/status/${id}`,
|
|
},
|
|
credentialDownload: {
|
|
method: 'POST',
|
|
buildURL: (): `/${string}` => '/v1/mimoto/credentialshare/download',
|
|
},
|
|
linkTransaction: {
|
|
method: 'POST',
|
|
buildURL: (): `/${string}` =>
|
|
'/v1/esignet/linked-authorization/v2/link-transaction',
|
|
},
|
|
authenticate: {
|
|
method: 'POST',
|
|
buildURL: (): `/${string}` =>
|
|
'/v1/esignet/linked-authorization/v2/authenticate',
|
|
},
|
|
sendConsent: {
|
|
method: 'POST',
|
|
buildURL: (): `/${string}` => '/v1/esignet/linked-authorization/v2/consent',
|
|
},
|
|
googleAccountProfileInfo: {
|
|
method: 'GET',
|
|
buildURL: (accessToken: string): `${string}` =>
|
|
`https://www.googleapis.com/oauth2/v1/userinfo?alt=json&access_token=${accessToken}`,
|
|
},
|
|
};
|
|
|
|
export const API = {
|
|
fetchIssuers: async () => {
|
|
const response = await request(
|
|
API_URLS.issuersList.method,
|
|
API_URLS.issuersList.buildURL(),
|
|
);
|
|
return response.response.issuers || [];
|
|
},
|
|
|
|
fetchIssuerConfig: async (issuerId: string) => {
|
|
const response = await request(
|
|
API_URLS.issuerConfig.method,
|
|
API_URLS.issuerConfig.buildURL(issuerId),
|
|
);
|
|
return response.response;
|
|
},
|
|
fetchIssuerWellknownConfig: async (issuerId: string) => {
|
|
const response = await request(
|
|
API_URLS.issuerWellknownConfig.method,
|
|
API_URLS.issuerWellknownConfig.buildURL(issuerId),
|
|
);
|
|
return response;
|
|
},
|
|
fetchAllProperties: async () => {
|
|
const response = await request(
|
|
API_URLS.allProperties.method,
|
|
API_URLS.allProperties.buildURL(),
|
|
);
|
|
return response.response;
|
|
},
|
|
getGoogleAccountProfileInfo: async accessToken =>
|
|
await request(
|
|
API_URLS.googleAccountProfileInfo.method,
|
|
API_URLS.googleAccountProfileInfo.buildURL(accessToken),
|
|
undefined,
|
|
'',
|
|
),
|
|
};
|
|
|
|
export const CACHED_API = {
|
|
fetchIssuers: () =>
|
|
generateCacheAPIFunction({
|
|
cacheKey: API_CACHED_STORAGE_KEYS.fetchIssuers,
|
|
fetchCall: API.fetchIssuers,
|
|
}),
|
|
|
|
fetchIssuerConfig: (issuerId: string) =>
|
|
generateCacheAPIFunction({
|
|
cacheKey: API_CACHED_STORAGE_KEYS.fetchIssuerConfig(issuerId),
|
|
fetchCall: API.fetchIssuerConfig.bind(null, issuerId),
|
|
}),
|
|
fetchIssuerWellknownConfig: (
|
|
issuerId: string,
|
|
isCachePreferred: boolean = false,
|
|
) =>
|
|
generateCacheAPIFunction({
|
|
isCachePreferred,
|
|
cacheKey: API_CACHED_STORAGE_KEYS.fetchIssuerWellknownConfig(issuerId),
|
|
fetchCall: API.fetchIssuerWellknownConfig.bind(null, issuerId),
|
|
}),
|
|
|
|
getAllProperties: (isCachePreferred: boolean) =>
|
|
generateCacheAPIFunction({
|
|
isCachePreferred,
|
|
cacheKey: COMMON_PROPS_KEY,
|
|
fetchCall: API.fetchAllProperties,
|
|
onErrorHardCodedValue: INITIAL_CONFIG.allProperties,
|
|
}),
|
|
};
|
|
|
|
interface GenerateCacheAPIFunctionProps {
|
|
isCachePreferred?: boolean;
|
|
cacheKey: string;
|
|
fetchCall: (...props: any) => Promise<any>;
|
|
onErrorHardCodedValue?: any;
|
|
}
|
|
|
|
async function generateCacheAPIFunction({
|
|
isCachePreferred = false,
|
|
cacheKey = '',
|
|
fetchCall = () => Promise.resolve(),
|
|
onErrorHardCodedValue = undefined,
|
|
}: GenerateCacheAPIFunctionProps) {
|
|
if (isCachePreferred) {
|
|
return await generateCacheAPIFunctionWithCachePreference(
|
|
cacheKey,
|
|
fetchCall,
|
|
onErrorHardCodedValue,
|
|
);
|
|
} else {
|
|
return await generateCacheAPIFunctionWithAPIPreference(
|
|
cacheKey,
|
|
fetchCall,
|
|
onErrorHardCodedValue,
|
|
);
|
|
}
|
|
}
|
|
|
|
async function generateCacheAPIFunctionWithCachePreference(
|
|
cacheKey: string,
|
|
fetchCall: (...props: any[]) => any,
|
|
onErrorHardCodedValue?: any,
|
|
) {
|
|
try {
|
|
const response = await getItem(cacheKey, null, '');
|
|
|
|
if (response) {
|
|
return response;
|
|
} else {
|
|
const response = await fetchCall();
|
|
setItem(cacheKey, response, '').then(() =>
|
|
console.log('Cached response for ' + cacheKey),
|
|
);
|
|
|
|
return response;
|
|
}
|
|
} catch (error) {
|
|
console.warn(`Failed to load due to network issue in cache preferred api call.
|
|
cache key:${cacheKey} and has onErrorHardCodedValue:${
|
|
onErrorHardCodedValue != undefined
|
|
}`);
|
|
console.log(error);
|
|
|
|
if (onErrorHardCodedValue != undefined) {
|
|
return onErrorHardCodedValue;
|
|
} else {
|
|
throw error;
|
|
}
|
|
}
|
|
}
|
|
|
|
async function generateCacheAPIFunctionWithAPIPreference(
|
|
cacheKey: string,
|
|
fetchCall: (...props: any[]) => any,
|
|
onErrorHardCodedValue?: any,
|
|
) {
|
|
try {
|
|
const response = await fetchCall();
|
|
setItem(cacheKey, response, '').then(() =>
|
|
console.log('Cached response for ' + cacheKey),
|
|
);
|
|
return response;
|
|
} catch (error) {
|
|
console.warn(`Failed to load due to network issue in API preferred api call.
|
|
cache key:${cacheKey} and has onErrorHardCodedValue:${
|
|
onErrorHardCodedValue != undefined
|
|
}`);
|
|
|
|
console.log(error);
|
|
|
|
const response = await getItem(cacheKey, null, '');
|
|
|
|
if (response) {
|
|
return response;
|
|
} else {
|
|
if (response == null) {
|
|
throw error;
|
|
} else if (onErrorHardCodedValue != undefined) {
|
|
return onErrorHardCodedValue;
|
|
} else {
|
|
throw error;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
export default async function getAllConfigurations(
|
|
host = undefined,
|
|
isCachePreferred = true,
|
|
) {
|
|
host && changeCrendetialRegistry(host);
|
|
return await CACHED_API.getAllProperties(isCachePreferred);
|
|
}
|
|
|
|
export async function downloadModel() {
|
|
try {
|
|
console.log('restart Face model init');
|
|
const injiProp = await getAllConfigurations();
|
|
const maxRetryStr = injiProp.modelDownloadMaxRetry;
|
|
const maxRetry = parseInt(maxRetryStr);
|
|
const resp: string = injiProp != null ? injiProp.faceSdkModelUrl : null;
|
|
|
|
if (resp != null) {
|
|
for (let counter = 0; counter < maxRetry; counter++) {
|
|
const config = faceMatchConfig(resp);
|
|
const result = await configure(config);
|
|
console.log('model download result is = ' + result);
|
|
if (result) {
|
|
sendImpressionEvent(
|
|
getImpressionEventData(
|
|
TelemetryConstants.FlowType.faceModelInit,
|
|
TelemetryConstants.Screens.home,
|
|
{status: TelemetryConstants.EndEventStatus.success},
|
|
),
|
|
);
|
|
break;
|
|
} else if (!result && counter === maxRetry - 1) {
|
|
sendErrorEvent(
|
|
getErrorEventData(
|
|
TelemetryConstants.FlowType.faceModelInit,
|
|
TelemetryConstants.ErrorId.failure,
|
|
TelemetryConstants.ErrorMessage.faceModelInitFailed,
|
|
),
|
|
);
|
|
}
|
|
}
|
|
}
|
|
} catch (error) {
|
|
sendErrorEvent(
|
|
getErrorEventData(
|
|
TelemetryConstants.FlowType.faceModelInit,
|
|
TelemetryConstants.ErrorId.failure,
|
|
TelemetryConstants.ErrorMessage.faceModelInitFailed,
|
|
error,
|
|
),
|
|
);
|
|
console.error('Error while downloading face model - ', error);
|
|
}
|
|
}
|
|
|
|
type Api_Params = {
|
|
method: 'GET' | 'POST' | 'PATCH'; // Define the HTTP methods
|
|
buildURL: (param?: string) => `/${string}`; // Define the buildURL function signature
|
|
};
|
|
|
|
type ApiUrls = {
|
|
issuersList: Api_Params;
|
|
issuerConfig: Api_Params;
|
|
issuerWellknownConfig: Api_Params;
|
|
allProperties: Api_Params;
|
|
getIndividualId: Api_Params;
|
|
reqIndividualOTP: Api_Params;
|
|
walletBinding: Api_Params;
|
|
bindingOtp: Api_Params;
|
|
requestOtp: Api_Params;
|
|
credentialRequest: Api_Params;
|
|
credentialStatus: Api_Params;
|
|
credentialDownload: Api_Params;
|
|
linkTransaction: Api_Params;
|
|
authenticate: Api_Params;
|
|
sendConsent: Api_Params;
|
|
googleAccountProfileInfo: Api_Params;
|
|
};
|
|
|
|
export interface DownloadProps {
|
|
maxDownloadLimit: number;
|
|
downloadInterval: number;
|
|
}
|