forked from FormidableLabs/react-native-app-auth
-
Notifications
You must be signed in to change notification settings - Fork 1
/
index.d.ts
121 lines (104 loc) · 3.12 KB
/
index.d.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
export interface ServiceConfiguration {
authorizationEndpoint: string;
tokenEndpoint: string;
revocationEndpoint?: string;
registrationEndpoint?: string;
}
export type BaseConfiguration =
| {
issuer?: string;
serviceConfiguration: ServiceConfiguration;
}
| {
issuer: string;
serviceConfiguration?: ServiceConfiguration;
};
type CustomHeaders = {
authorize?: Record<string, string>;
token?: Record<string, string>;
register?: Record<string, string>;
};
interface BuiltInRegistrationParameters {
client_name?: string;
logo_uri?: string;
client_uri?: string;
policy_uri?: string;
tos_uri?: string;
}
export type RegistrationConfiguration = BaseConfiguration & {
redirectUrls: string[];
responseTypes?: string[];
grantTypes?: string[];
subjectType?: string;
tokenEndpointAuthMethod?: string;
additionalParameters?: BuiltInRegistrationParameters & { [name: string]: string };
dangerouslyAllowInsecureHttpRequests?: boolean;
customHeaders?: CustomHeaders;
};
export interface RegistrationResponse {
clientId: string;
additionalParameters?: { [name: string]: string };
clientIdIssuedAt?: string;
clientSecret?: string;
clientSecretExpiresAt?: string;
registrationAccessToken?: string;
registrationClientUri?: string;
tokenEndpointAuthMethod?: string;
}
interface BuiltInParameters {
display?: 'page' | 'popup' | 'touch' | 'wap';
login_prompt?: string;
prompt?: 'consent' | 'login' | 'none' | 'select_account';
}
export type BaseAuthConfiguration = BaseConfiguration & {
clientId: string;
};
export type AuthConfiguration = BaseAuthConfiguration & {
clientSecret?: string;
scopes: string[];
redirectUrl: string;
additionalParameters?: BuiltInParameters & { [name: string]: string };
clientAuthMethod?: 'basic' | 'post';
dangerouslyAllowInsecureHttpRequests?: boolean;
customHeaders?: CustomHeaders;
useNonce?: boolean;
usePKCE?: boolean;
warmAndPrefetchChrome?: boolean;
};
export interface AuthorizeResult {
accessToken: string;
accessTokenExpirationDate: string;
authorizeAdditionalParameters?: { [name: string]: string };
tokenAdditionalParameters?: { [name: string]: string };
idToken: string;
refreshToken: string;
tokenType: string;
scopes: string[];
}
export interface RefreshResult {
accessToken: string;
accessTokenExpirationDate: string;
additionalParameters?: { [name: string]: string };
idToken: string;
refreshToken: string | null;
tokenType: string;
}
export interface RevokeConfiguration {
tokenToRevoke: string;
sendClientId?: boolean;
includeBasicAuth?: boolean;
}
export interface RefreshConfiguration {
refreshToken: string;
}
export function prefetchConfiguration(config: AuthConfiguration): Promise<void>;
export function register(config: RegistrationConfiguration): Promise<RegistrationResponse>;
export function authorize(config: AuthConfiguration): Promise<AuthorizeResult>;
export function refresh(
config: AuthConfiguration,
refreshConfig: RefreshConfiguration
): Promise<RefreshResult>;
export function revoke(
config: BaseAuthConfiguration,
revokeConfig: RevokeConfiguration
): Promise<void>;