@depup/supabase__auth-js 2.99.2-depup.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +25 -0
- package/changes.json +5 -0
- package/dist/main/AuthAdminApi.d.ts +4 -0
- package/dist/main/AuthAdminApi.d.ts.map +1 -0
- package/dist/main/AuthAdminApi.js +7 -0
- package/dist/main/AuthAdminApi.js.map +1 -0
- package/dist/main/AuthClient.d.ts +4 -0
- package/dist/main/AuthClient.d.ts.map +1 -0
- package/dist/main/AuthClient.js +7 -0
- package/dist/main/AuthClient.js.map +1 -0
- package/dist/main/GoTrueAdminApi.d.ts +227 -0
- package/dist/main/GoTrueAdminApi.d.ts.map +1 -0
- package/dist/main/GoTrueAdminApi.js +596 -0
- package/dist/main/GoTrueAdminApi.js.map +1 -0
- package/dist/main/GoTrueClient.d.ts +783 -0
- package/dist/main/GoTrueClient.d.ts.map +1 -0
- package/dist/main/GoTrueClient.js +3029 -0
- package/dist/main/GoTrueClient.js.map +1 -0
- package/dist/main/index.d.ts +9 -0
- package/dist/main/index.d.ts.map +1 -0
- package/dist/main/index.js +20 -0
- package/dist/main/index.js.map +1 -0
- package/dist/main/lib/base64url.d.ts +76 -0
- package/dist/main/lib/base64url.d.ts.map +1 -0
- package/dist/main/lib/base64url.js +269 -0
- package/dist/main/lib/base64url.js.map +1 -0
- package/dist/main/lib/constants.d.ts +26 -0
- package/dist/main/lib/constants.d.ts.map +1 -0
- package/dist/main/lib/constants.js +31 -0
- package/dist/main/lib/constants.js.map +1 -0
- package/dist/main/lib/error-codes.d.ts +7 -0
- package/dist/main/lib/error-codes.d.ts.map +1 -0
- package/dist/main/lib/error-codes.js +3 -0
- package/dist/main/lib/error-codes.js.map +1 -0
- package/dist/main/lib/errors.d.ts +243 -0
- package/dist/main/lib/errors.d.ts.map +1 -0
- package/dist/main/lib/errors.js +289 -0
- package/dist/main/lib/errors.js.map +1 -0
- package/dist/main/lib/fetch.d.ts +34 -0
- package/dist/main/lib/fetch.d.ts.map +1 -0
- package/dist/main/lib/fetch.js +184 -0
- package/dist/main/lib/fetch.js.map +1 -0
- package/dist/main/lib/helpers.d.ts +91 -0
- package/dist/main/lib/helpers.d.ts.map +1 -0
- package/dist/main/lib/helpers.js +395 -0
- package/dist/main/lib/helpers.js.map +1 -0
- package/dist/main/lib/local-storage.d.ts +9 -0
- package/dist/main/lib/local-storage.d.ts.map +1 -0
- package/dist/main/lib/local-storage.js +21 -0
- package/dist/main/lib/local-storage.js.map +1 -0
- package/dist/main/lib/locks.d.ts +107 -0
- package/dist/main/lib/locks.d.ts.map +1 -0
- package/dist/main/lib/locks.js +314 -0
- package/dist/main/lib/locks.js.map +1 -0
- package/dist/main/lib/polyfills.d.ts +5 -0
- package/dist/main/lib/polyfills.d.ts.map +1 -0
- package/dist/main/lib/polyfills.js +29 -0
- package/dist/main/lib/polyfills.js.map +1 -0
- package/dist/main/lib/types.d.ts +1861 -0
- package/dist/main/lib/types.d.ts.map +1 -0
- package/dist/main/lib/types.js +23 -0
- package/dist/main/lib/types.js.map +1 -0
- package/dist/main/lib/version.d.ts +2 -0
- package/dist/main/lib/version.d.ts.map +1 -0
- package/dist/main/lib/version.js +11 -0
- package/dist/main/lib/version.js.map +1 -0
- package/dist/main/lib/web3/ethereum.d.ts +96 -0
- package/dist/main/lib/web3/ethereum.d.ts.map +1 -0
- package/dist/main/lib/web3/ethereum.js +66 -0
- package/dist/main/lib/web3/ethereum.js.map +1 -0
- package/dist/main/lib/web3/solana.d.ts +160 -0
- package/dist/main/lib/web3/solana.d.ts.map +1 -0
- package/dist/main/lib/web3/solana.js +4 -0
- package/dist/main/lib/web3/solana.js.map +1 -0
- package/dist/main/lib/webauthn.d.ts +276 -0
- package/dist/main/lib/webauthn.d.ts.map +1 -0
- package/dist/main/lib/webauthn.dom.d.ts +583 -0
- package/dist/main/lib/webauthn.dom.d.ts.map +1 -0
- package/dist/main/lib/webauthn.dom.js +4 -0
- package/dist/main/lib/webauthn.dom.js.map +1 -0
- package/dist/main/lib/webauthn.errors.d.ts +80 -0
- package/dist/main/lib/webauthn.errors.d.ts.map +1 -0
- package/dist/main/lib/webauthn.errors.js +265 -0
- package/dist/main/lib/webauthn.errors.js.map +1 -0
- package/dist/main/lib/webauthn.js +706 -0
- package/dist/main/lib/webauthn.js.map +1 -0
- package/dist/module/AuthAdminApi.d.ts +4 -0
- package/dist/module/AuthAdminApi.d.ts.map +1 -0
- package/dist/module/AuthAdminApi.js +4 -0
- package/dist/module/AuthAdminApi.js.map +1 -0
- package/dist/module/AuthClient.d.ts +4 -0
- package/dist/module/AuthClient.d.ts.map +1 -0
- package/dist/module/AuthClient.js +4 -0
- package/dist/module/AuthClient.js.map +1 -0
- package/dist/module/GoTrueAdminApi.d.ts +227 -0
- package/dist/module/GoTrueAdminApi.d.ts.map +1 -0
- package/dist/module/GoTrueAdminApi.js +593 -0
- package/dist/module/GoTrueAdminApi.js.map +1 -0
- package/dist/module/GoTrueClient.d.ts +783 -0
- package/dist/module/GoTrueClient.d.ts.map +1 -0
- package/dist/module/GoTrueClient.js +3026 -0
- package/dist/module/GoTrueClient.js.map +1 -0
- package/dist/module/index.d.ts +9 -0
- package/dist/module/index.d.ts.map +1 -0
- package/dist/module/index.js +9 -0
- package/dist/module/index.js.map +1 -0
- package/dist/module/lib/base64url.d.ts +76 -0
- package/dist/module/lib/base64url.d.ts.map +1 -0
- package/dist/module/lib/base64url.js +257 -0
- package/dist/module/lib/base64url.js.map +1 -0
- package/dist/module/lib/constants.d.ts +26 -0
- package/dist/module/lib/constants.d.ts.map +1 -0
- package/dist/module/lib/constants.js +28 -0
- package/dist/module/lib/constants.js.map +1 -0
- package/dist/module/lib/error-codes.d.ts +7 -0
- package/dist/module/lib/error-codes.d.ts.map +1 -0
- package/dist/module/lib/error-codes.js +2 -0
- package/dist/module/lib/error-codes.js.map +1 -0
- package/dist/module/lib/errors.d.ts +243 -0
- package/dist/module/lib/errors.d.ts.map +1 -0
- package/dist/module/lib/errors.js +266 -0
- package/dist/module/lib/errors.js.map +1 -0
- package/dist/module/lib/fetch.d.ts +34 -0
- package/dist/module/lib/fetch.d.ts.map +1 -0
- package/dist/module/lib/fetch.js +174 -0
- package/dist/module/lib/fetch.js.map +1 -0
- package/dist/module/lib/helpers.d.ts +91 -0
- package/dist/module/lib/helpers.d.ts.map +1 -0
- package/dist/module/lib/helpers.js +368 -0
- package/dist/module/lib/helpers.js.map +1 -0
- package/dist/module/lib/local-storage.d.ts +9 -0
- package/dist/module/lib/local-storage.d.ts.map +1 -0
- package/dist/module/lib/local-storage.js +18 -0
- package/dist/module/lib/local-storage.js.map +1 -0
- package/dist/module/lib/locks.d.ts +107 -0
- package/dist/module/lib/locks.d.ts.map +1 -0
- package/dist/module/lib/locks.js +306 -0
- package/dist/module/lib/locks.js.map +1 -0
- package/dist/module/lib/polyfills.d.ts +5 -0
- package/dist/module/lib/polyfills.d.ts.map +1 -0
- package/dist/module/lib/polyfills.js +26 -0
- package/dist/module/lib/polyfills.js.map +1 -0
- package/dist/module/lib/types.d.ts +1861 -0
- package/dist/module/lib/types.d.ts.map +1 -0
- package/dist/module/lib/types.js +20 -0
- package/dist/module/lib/types.js.map +1 -0
- package/dist/module/lib/version.d.ts +2 -0
- package/dist/module/lib/version.d.ts.map +1 -0
- package/dist/module/lib/version.js +8 -0
- package/dist/module/lib/version.js.map +1 -0
- package/dist/module/lib/web3/ethereum.d.ts +96 -0
- package/dist/module/lib/web3/ethereum.d.ts.map +1 -0
- package/dist/module/lib/web3/ethereum.js +60 -0
- package/dist/module/lib/web3/ethereum.js.map +1 -0
- package/dist/module/lib/web3/solana.d.ts +160 -0
- package/dist/module/lib/web3/solana.d.ts.map +1 -0
- package/dist/module/lib/web3/solana.js +3 -0
- package/dist/module/lib/web3/solana.js.map +1 -0
- package/dist/module/lib/webauthn.d.ts +276 -0
- package/dist/module/lib/webauthn.d.ts.map +1 -0
- package/dist/module/lib/webauthn.dom.d.ts +583 -0
- package/dist/module/lib/webauthn.dom.d.ts.map +1 -0
- package/dist/module/lib/webauthn.dom.js +3 -0
- package/dist/module/lib/webauthn.dom.js.map +1 -0
- package/dist/module/lib/webauthn.errors.d.ts +80 -0
- package/dist/module/lib/webauthn.errors.d.ts.map +1 -0
- package/dist/module/lib/webauthn.errors.js +257 -0
- package/dist/module/lib/webauthn.errors.js.map +1 -0
- package/dist/module/lib/webauthn.js +689 -0
- package/dist/module/lib/webauthn.js.map +1 -0
- package/dist/tsconfig.module.tsbuildinfo +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/package.json +56 -0
- package/src/AuthAdminApi.ts +5 -0
- package/src/AuthClient.ts +5 -0
- package/src/GoTrueAdminApi.ts +723 -0
- package/src/GoTrueClient.ts +4078 -0
- package/src/index.ts +13 -0
- package/src/lib/base64url.ts +308 -0
- package/src/lib/constants.ts +34 -0
- package/src/lib/error-codes.ts +90 -0
- package/src/lib/errors.ts +324 -0
- package/src/lib/fetch.ts +283 -0
- package/src/lib/helpers.ts +463 -0
- package/src/lib/local-storage.ts +21 -0
- package/src/lib/locks.ts +375 -0
- package/src/lib/polyfills.ts +23 -0
- package/src/lib/types.ts +2229 -0
- package/src/lib/version.ts +7 -0
- package/src/lib/web3/ethereum.ts +184 -0
- package/src/lib/web3/solana.ts +186 -0
- package/src/lib/webauthn.dom.ts +636 -0
- package/src/lib/webauthn.errors.ts +317 -0
- package/src/lib/webauthn.ts +946 -0
|
@@ -0,0 +1,593 @@
|
|
|
1
|
+
import { __rest } from "tslib";
|
|
2
|
+
import { _generateLinkResponse, _noResolveJsonResponse, _request, _userResponse, } from './lib/fetch';
|
|
3
|
+
import { resolveFetch, validateUUID } from './lib/helpers';
|
|
4
|
+
import { SIGN_OUT_SCOPES, } from './lib/types';
|
|
5
|
+
import { isAuthError } from './lib/errors';
|
|
6
|
+
export default class GoTrueAdminApi {
|
|
7
|
+
/**
|
|
8
|
+
* Creates an admin API client that can be used to manage users and OAuth clients.
|
|
9
|
+
*
|
|
10
|
+
* @example
|
|
11
|
+
* ```ts
|
|
12
|
+
* import { GoTrueAdminApi } from '@supabase/auth-js'
|
|
13
|
+
*
|
|
14
|
+
* const admin = new GoTrueAdminApi({
|
|
15
|
+
* url: 'https://xyzcompany.supabase.co/auth/v1',
|
|
16
|
+
* headers: { Authorization: `Bearer ${process.env.SUPABASE_SERVICE_ROLE_KEY}` },
|
|
17
|
+
* })
|
|
18
|
+
* ```
|
|
19
|
+
*/
|
|
20
|
+
constructor({ url = '', headers = {}, fetch, }) {
|
|
21
|
+
this.url = url;
|
|
22
|
+
this.headers = headers;
|
|
23
|
+
this.fetch = resolveFetch(fetch);
|
|
24
|
+
this.mfa = {
|
|
25
|
+
listFactors: this._listFactors.bind(this),
|
|
26
|
+
deleteFactor: this._deleteFactor.bind(this),
|
|
27
|
+
};
|
|
28
|
+
this.oauth = {
|
|
29
|
+
listClients: this._listOAuthClients.bind(this),
|
|
30
|
+
createClient: this._createOAuthClient.bind(this),
|
|
31
|
+
getClient: this._getOAuthClient.bind(this),
|
|
32
|
+
updateClient: this._updateOAuthClient.bind(this),
|
|
33
|
+
deleteClient: this._deleteOAuthClient.bind(this),
|
|
34
|
+
regenerateClientSecret: this._regenerateOAuthClientSecret.bind(this),
|
|
35
|
+
};
|
|
36
|
+
this.customProviders = {
|
|
37
|
+
listProviders: this._listCustomProviders.bind(this),
|
|
38
|
+
createProvider: this._createCustomProvider.bind(this),
|
|
39
|
+
getProvider: this._getCustomProvider.bind(this),
|
|
40
|
+
updateProvider: this._updateCustomProvider.bind(this),
|
|
41
|
+
deleteProvider: this._deleteCustomProvider.bind(this),
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* Removes a logged-in session.
|
|
46
|
+
* @param jwt A valid, logged-in JWT.
|
|
47
|
+
* @param scope The logout sope.
|
|
48
|
+
*/
|
|
49
|
+
async signOut(jwt, scope = SIGN_OUT_SCOPES[0]) {
|
|
50
|
+
if (SIGN_OUT_SCOPES.indexOf(scope) < 0) {
|
|
51
|
+
throw new Error(`@supabase/auth-js: Parameter scope must be one of ${SIGN_OUT_SCOPES.join(', ')}`);
|
|
52
|
+
}
|
|
53
|
+
try {
|
|
54
|
+
await _request(this.fetch, 'POST', `${this.url}/logout?scope=${scope}`, {
|
|
55
|
+
headers: this.headers,
|
|
56
|
+
jwt,
|
|
57
|
+
noResolveJson: true,
|
|
58
|
+
});
|
|
59
|
+
return { data: null, error: null };
|
|
60
|
+
}
|
|
61
|
+
catch (error) {
|
|
62
|
+
if (isAuthError(error)) {
|
|
63
|
+
return { data: null, error };
|
|
64
|
+
}
|
|
65
|
+
throw error;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
/**
|
|
69
|
+
* Sends an invite link to an email address.
|
|
70
|
+
* @param email The email address of the user.
|
|
71
|
+
* @param options Additional options to be included when inviting.
|
|
72
|
+
*/
|
|
73
|
+
async inviteUserByEmail(email, options = {}) {
|
|
74
|
+
try {
|
|
75
|
+
return await _request(this.fetch, 'POST', `${this.url}/invite`, {
|
|
76
|
+
body: { email, data: options.data },
|
|
77
|
+
headers: this.headers,
|
|
78
|
+
redirectTo: options.redirectTo,
|
|
79
|
+
xform: _userResponse,
|
|
80
|
+
});
|
|
81
|
+
}
|
|
82
|
+
catch (error) {
|
|
83
|
+
if (isAuthError(error)) {
|
|
84
|
+
return { data: { user: null }, error };
|
|
85
|
+
}
|
|
86
|
+
throw error;
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
/**
|
|
90
|
+
* Generates email links and OTPs to be sent via a custom email provider.
|
|
91
|
+
* @param email The user's email.
|
|
92
|
+
* @param options.password User password. For signup only.
|
|
93
|
+
* @param options.data Optional user metadata. For signup only.
|
|
94
|
+
* @param options.redirectTo The redirect url which should be appended to the generated link
|
|
95
|
+
*/
|
|
96
|
+
async generateLink(params) {
|
|
97
|
+
try {
|
|
98
|
+
const { options } = params, rest = __rest(params, ["options"]);
|
|
99
|
+
const body = Object.assign(Object.assign({}, rest), options);
|
|
100
|
+
if ('newEmail' in rest) {
|
|
101
|
+
// replace newEmail with new_email in request body
|
|
102
|
+
body.new_email = rest === null || rest === void 0 ? void 0 : rest.newEmail;
|
|
103
|
+
delete body['newEmail'];
|
|
104
|
+
}
|
|
105
|
+
return await _request(this.fetch, 'POST', `${this.url}/admin/generate_link`, {
|
|
106
|
+
body: body,
|
|
107
|
+
headers: this.headers,
|
|
108
|
+
xform: _generateLinkResponse,
|
|
109
|
+
redirectTo: options === null || options === void 0 ? void 0 : options.redirectTo,
|
|
110
|
+
});
|
|
111
|
+
}
|
|
112
|
+
catch (error) {
|
|
113
|
+
if (isAuthError(error)) {
|
|
114
|
+
return {
|
|
115
|
+
data: {
|
|
116
|
+
properties: null,
|
|
117
|
+
user: null,
|
|
118
|
+
},
|
|
119
|
+
error,
|
|
120
|
+
};
|
|
121
|
+
}
|
|
122
|
+
throw error;
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
// User Admin API
|
|
126
|
+
/**
|
|
127
|
+
* Creates a new user.
|
|
128
|
+
* This function should only be called on a server. Never expose your `service_role` key in the browser.
|
|
129
|
+
*/
|
|
130
|
+
async createUser(attributes) {
|
|
131
|
+
try {
|
|
132
|
+
return await _request(this.fetch, 'POST', `${this.url}/admin/users`, {
|
|
133
|
+
body: attributes,
|
|
134
|
+
headers: this.headers,
|
|
135
|
+
xform: _userResponse,
|
|
136
|
+
});
|
|
137
|
+
}
|
|
138
|
+
catch (error) {
|
|
139
|
+
if (isAuthError(error)) {
|
|
140
|
+
return { data: { user: null }, error };
|
|
141
|
+
}
|
|
142
|
+
throw error;
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
/**
|
|
146
|
+
* Get a list of users.
|
|
147
|
+
*
|
|
148
|
+
* This function should only be called on a server. Never expose your `service_role` key in the browser.
|
|
149
|
+
* @param params An object which supports `page` and `perPage` as numbers, to alter the paginated results.
|
|
150
|
+
*/
|
|
151
|
+
async listUsers(params) {
|
|
152
|
+
var _a, _b, _c, _d, _e, _f, _g;
|
|
153
|
+
try {
|
|
154
|
+
const pagination = { nextPage: null, lastPage: 0, total: 0 };
|
|
155
|
+
const response = await _request(this.fetch, 'GET', `${this.url}/admin/users`, {
|
|
156
|
+
headers: this.headers,
|
|
157
|
+
noResolveJson: true,
|
|
158
|
+
query: {
|
|
159
|
+
page: (_b = (_a = params === null || params === void 0 ? void 0 : params.page) === null || _a === void 0 ? void 0 : _a.toString()) !== null && _b !== void 0 ? _b : '',
|
|
160
|
+
per_page: (_d = (_c = params === null || params === void 0 ? void 0 : params.perPage) === null || _c === void 0 ? void 0 : _c.toString()) !== null && _d !== void 0 ? _d : '',
|
|
161
|
+
},
|
|
162
|
+
xform: _noResolveJsonResponse,
|
|
163
|
+
});
|
|
164
|
+
if (response.error)
|
|
165
|
+
throw response.error;
|
|
166
|
+
const users = await response.json();
|
|
167
|
+
const total = (_e = response.headers.get('x-total-count')) !== null && _e !== void 0 ? _e : 0;
|
|
168
|
+
const links = (_g = (_f = response.headers.get('link')) === null || _f === void 0 ? void 0 : _f.split(',')) !== null && _g !== void 0 ? _g : [];
|
|
169
|
+
if (links.length > 0) {
|
|
170
|
+
links.forEach((link) => {
|
|
171
|
+
const page = parseInt(link.split(';')[0].split('=')[1].substring(0, 1));
|
|
172
|
+
const rel = JSON.parse(link.split(';')[1].split('=')[1]);
|
|
173
|
+
pagination[`${rel}Page`] = page;
|
|
174
|
+
});
|
|
175
|
+
pagination.total = parseInt(total);
|
|
176
|
+
}
|
|
177
|
+
return { data: Object.assign(Object.assign({}, users), pagination), error: null };
|
|
178
|
+
}
|
|
179
|
+
catch (error) {
|
|
180
|
+
if (isAuthError(error)) {
|
|
181
|
+
return { data: { users: [] }, error };
|
|
182
|
+
}
|
|
183
|
+
throw error;
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
/**
|
|
187
|
+
* Get user by id.
|
|
188
|
+
*
|
|
189
|
+
* @param uid The user's unique identifier
|
|
190
|
+
*
|
|
191
|
+
* This function should only be called on a server. Never expose your `service_role` key in the browser.
|
|
192
|
+
*/
|
|
193
|
+
async getUserById(uid) {
|
|
194
|
+
validateUUID(uid);
|
|
195
|
+
try {
|
|
196
|
+
return await _request(this.fetch, 'GET', `${this.url}/admin/users/${uid}`, {
|
|
197
|
+
headers: this.headers,
|
|
198
|
+
xform: _userResponse,
|
|
199
|
+
});
|
|
200
|
+
}
|
|
201
|
+
catch (error) {
|
|
202
|
+
if (isAuthError(error)) {
|
|
203
|
+
return { data: { user: null }, error };
|
|
204
|
+
}
|
|
205
|
+
throw error;
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
/**
|
|
209
|
+
* Updates the user data. Changes are applied directly without confirmation flows.
|
|
210
|
+
*
|
|
211
|
+
* @param uid The user's unique identifier
|
|
212
|
+
* @param attributes The data you want to update.
|
|
213
|
+
*
|
|
214
|
+
* This function should only be called on a server. Never expose your `service_role` key in the browser.
|
|
215
|
+
*
|
|
216
|
+
* @remarks
|
|
217
|
+
* **Important:** This is a server-side operation and does **not** trigger client-side
|
|
218
|
+
* `onAuthStateChange` listeners. The admin API has no connection to client state.
|
|
219
|
+
*
|
|
220
|
+
* To sync changes to the client after calling this method:
|
|
221
|
+
* 1. On the client, call `supabase.auth.refreshSession()` to fetch the updated user data
|
|
222
|
+
* 2. This will trigger the `TOKEN_REFRESHED` event and notify all listeners
|
|
223
|
+
*
|
|
224
|
+
* @example
|
|
225
|
+
* ```typescript
|
|
226
|
+
* // Server-side (Edge Function)
|
|
227
|
+
* const { data, error } = await supabase.auth.admin.updateUserById(
|
|
228
|
+
* userId,
|
|
229
|
+
* { user_metadata: { preferences: { theme: 'dark' } } }
|
|
230
|
+
* )
|
|
231
|
+
*
|
|
232
|
+
* // Client-side (to sync the changes)
|
|
233
|
+
* const { data, error } = await supabase.auth.refreshSession()
|
|
234
|
+
* // onAuthStateChange listeners will now be notified with updated user
|
|
235
|
+
* ```
|
|
236
|
+
*
|
|
237
|
+
* @see {@link GoTrueClient.refreshSession} for syncing admin changes to the client
|
|
238
|
+
* @see {@link GoTrueClient.updateUser} for client-side user updates (triggers listeners automatically)
|
|
239
|
+
*/
|
|
240
|
+
async updateUserById(uid, attributes) {
|
|
241
|
+
validateUUID(uid);
|
|
242
|
+
try {
|
|
243
|
+
return await _request(this.fetch, 'PUT', `${this.url}/admin/users/${uid}`, {
|
|
244
|
+
body: attributes,
|
|
245
|
+
headers: this.headers,
|
|
246
|
+
xform: _userResponse,
|
|
247
|
+
});
|
|
248
|
+
}
|
|
249
|
+
catch (error) {
|
|
250
|
+
if (isAuthError(error)) {
|
|
251
|
+
return { data: { user: null }, error };
|
|
252
|
+
}
|
|
253
|
+
throw error;
|
|
254
|
+
}
|
|
255
|
+
}
|
|
256
|
+
/**
|
|
257
|
+
* Delete a user. Requires a `service_role` key.
|
|
258
|
+
*
|
|
259
|
+
* @param id The user id you want to remove.
|
|
260
|
+
* @param shouldSoftDelete If true, then the user will be soft-deleted from the auth schema. Soft deletion allows user identification from the hashed user ID but is not reversible.
|
|
261
|
+
* Defaults to false for backward compatibility.
|
|
262
|
+
*
|
|
263
|
+
* This function should only be called on a server. Never expose your `service_role` key in the browser.
|
|
264
|
+
*/
|
|
265
|
+
async deleteUser(id, shouldSoftDelete = false) {
|
|
266
|
+
validateUUID(id);
|
|
267
|
+
try {
|
|
268
|
+
return await _request(this.fetch, 'DELETE', `${this.url}/admin/users/${id}`, {
|
|
269
|
+
headers: this.headers,
|
|
270
|
+
body: {
|
|
271
|
+
should_soft_delete: shouldSoftDelete,
|
|
272
|
+
},
|
|
273
|
+
xform: _userResponse,
|
|
274
|
+
});
|
|
275
|
+
}
|
|
276
|
+
catch (error) {
|
|
277
|
+
if (isAuthError(error)) {
|
|
278
|
+
return { data: { user: null }, error };
|
|
279
|
+
}
|
|
280
|
+
throw error;
|
|
281
|
+
}
|
|
282
|
+
}
|
|
283
|
+
async _listFactors(params) {
|
|
284
|
+
validateUUID(params.userId);
|
|
285
|
+
try {
|
|
286
|
+
const { data, error } = await _request(this.fetch, 'GET', `${this.url}/admin/users/${params.userId}/factors`, {
|
|
287
|
+
headers: this.headers,
|
|
288
|
+
xform: (factors) => {
|
|
289
|
+
return { data: { factors }, error: null };
|
|
290
|
+
},
|
|
291
|
+
});
|
|
292
|
+
return { data, error };
|
|
293
|
+
}
|
|
294
|
+
catch (error) {
|
|
295
|
+
if (isAuthError(error)) {
|
|
296
|
+
return { data: null, error };
|
|
297
|
+
}
|
|
298
|
+
throw error;
|
|
299
|
+
}
|
|
300
|
+
}
|
|
301
|
+
async _deleteFactor(params) {
|
|
302
|
+
validateUUID(params.userId);
|
|
303
|
+
validateUUID(params.id);
|
|
304
|
+
try {
|
|
305
|
+
const data = await _request(this.fetch, 'DELETE', `${this.url}/admin/users/${params.userId}/factors/${params.id}`, {
|
|
306
|
+
headers: this.headers,
|
|
307
|
+
});
|
|
308
|
+
return { data, error: null };
|
|
309
|
+
}
|
|
310
|
+
catch (error) {
|
|
311
|
+
if (isAuthError(error)) {
|
|
312
|
+
return { data: null, error };
|
|
313
|
+
}
|
|
314
|
+
throw error;
|
|
315
|
+
}
|
|
316
|
+
}
|
|
317
|
+
/**
|
|
318
|
+
* Lists all OAuth clients with optional pagination.
|
|
319
|
+
* Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.
|
|
320
|
+
*
|
|
321
|
+
* This function should only be called on a server. Never expose your `service_role` key in the browser.
|
|
322
|
+
*/
|
|
323
|
+
async _listOAuthClients(params) {
|
|
324
|
+
var _a, _b, _c, _d, _e, _f, _g;
|
|
325
|
+
try {
|
|
326
|
+
const pagination = { nextPage: null, lastPage: 0, total: 0 };
|
|
327
|
+
const response = await _request(this.fetch, 'GET', `${this.url}/admin/oauth/clients`, {
|
|
328
|
+
headers: this.headers,
|
|
329
|
+
noResolveJson: true,
|
|
330
|
+
query: {
|
|
331
|
+
page: (_b = (_a = params === null || params === void 0 ? void 0 : params.page) === null || _a === void 0 ? void 0 : _a.toString()) !== null && _b !== void 0 ? _b : '',
|
|
332
|
+
per_page: (_d = (_c = params === null || params === void 0 ? void 0 : params.perPage) === null || _c === void 0 ? void 0 : _c.toString()) !== null && _d !== void 0 ? _d : '',
|
|
333
|
+
},
|
|
334
|
+
xform: _noResolveJsonResponse,
|
|
335
|
+
});
|
|
336
|
+
if (response.error)
|
|
337
|
+
throw response.error;
|
|
338
|
+
const clients = await response.json();
|
|
339
|
+
const total = (_e = response.headers.get('x-total-count')) !== null && _e !== void 0 ? _e : 0;
|
|
340
|
+
const links = (_g = (_f = response.headers.get('link')) === null || _f === void 0 ? void 0 : _f.split(',')) !== null && _g !== void 0 ? _g : [];
|
|
341
|
+
if (links.length > 0) {
|
|
342
|
+
links.forEach((link) => {
|
|
343
|
+
const page = parseInt(link.split(';')[0].split('=')[1].substring(0, 1));
|
|
344
|
+
const rel = JSON.parse(link.split(';')[1].split('=')[1]);
|
|
345
|
+
pagination[`${rel}Page`] = page;
|
|
346
|
+
});
|
|
347
|
+
pagination.total = parseInt(total);
|
|
348
|
+
}
|
|
349
|
+
return { data: Object.assign(Object.assign({}, clients), pagination), error: null };
|
|
350
|
+
}
|
|
351
|
+
catch (error) {
|
|
352
|
+
if (isAuthError(error)) {
|
|
353
|
+
return { data: { clients: [] }, error };
|
|
354
|
+
}
|
|
355
|
+
throw error;
|
|
356
|
+
}
|
|
357
|
+
}
|
|
358
|
+
/**
|
|
359
|
+
* Creates a new OAuth client.
|
|
360
|
+
* Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.
|
|
361
|
+
*
|
|
362
|
+
* This function should only be called on a server. Never expose your `service_role` key in the browser.
|
|
363
|
+
*/
|
|
364
|
+
async _createOAuthClient(params) {
|
|
365
|
+
try {
|
|
366
|
+
return await _request(this.fetch, 'POST', `${this.url}/admin/oauth/clients`, {
|
|
367
|
+
body: params,
|
|
368
|
+
headers: this.headers,
|
|
369
|
+
xform: (client) => {
|
|
370
|
+
return { data: client, error: null };
|
|
371
|
+
},
|
|
372
|
+
});
|
|
373
|
+
}
|
|
374
|
+
catch (error) {
|
|
375
|
+
if (isAuthError(error)) {
|
|
376
|
+
return { data: null, error };
|
|
377
|
+
}
|
|
378
|
+
throw error;
|
|
379
|
+
}
|
|
380
|
+
}
|
|
381
|
+
/**
|
|
382
|
+
* Gets details of a specific OAuth client.
|
|
383
|
+
* Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.
|
|
384
|
+
*
|
|
385
|
+
* This function should only be called on a server. Never expose your `service_role` key in the browser.
|
|
386
|
+
*/
|
|
387
|
+
async _getOAuthClient(clientId) {
|
|
388
|
+
try {
|
|
389
|
+
return await _request(this.fetch, 'GET', `${this.url}/admin/oauth/clients/${clientId}`, {
|
|
390
|
+
headers: this.headers,
|
|
391
|
+
xform: (client) => {
|
|
392
|
+
return { data: client, error: null };
|
|
393
|
+
},
|
|
394
|
+
});
|
|
395
|
+
}
|
|
396
|
+
catch (error) {
|
|
397
|
+
if (isAuthError(error)) {
|
|
398
|
+
return { data: null, error };
|
|
399
|
+
}
|
|
400
|
+
throw error;
|
|
401
|
+
}
|
|
402
|
+
}
|
|
403
|
+
/**
|
|
404
|
+
* Updates an existing OAuth client.
|
|
405
|
+
* Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.
|
|
406
|
+
*
|
|
407
|
+
* This function should only be called on a server. Never expose your `service_role` key in the browser.
|
|
408
|
+
*/
|
|
409
|
+
async _updateOAuthClient(clientId, params) {
|
|
410
|
+
try {
|
|
411
|
+
return await _request(this.fetch, 'PUT', `${this.url}/admin/oauth/clients/${clientId}`, {
|
|
412
|
+
body: params,
|
|
413
|
+
headers: this.headers,
|
|
414
|
+
xform: (client) => {
|
|
415
|
+
return { data: client, error: null };
|
|
416
|
+
},
|
|
417
|
+
});
|
|
418
|
+
}
|
|
419
|
+
catch (error) {
|
|
420
|
+
if (isAuthError(error)) {
|
|
421
|
+
return { data: null, error };
|
|
422
|
+
}
|
|
423
|
+
throw error;
|
|
424
|
+
}
|
|
425
|
+
}
|
|
426
|
+
/**
|
|
427
|
+
* Deletes an OAuth client.
|
|
428
|
+
* Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.
|
|
429
|
+
*
|
|
430
|
+
* This function should only be called on a server. Never expose your `service_role` key in the browser.
|
|
431
|
+
*/
|
|
432
|
+
async _deleteOAuthClient(clientId) {
|
|
433
|
+
try {
|
|
434
|
+
await _request(this.fetch, 'DELETE', `${this.url}/admin/oauth/clients/${clientId}`, {
|
|
435
|
+
headers: this.headers,
|
|
436
|
+
noResolveJson: true,
|
|
437
|
+
});
|
|
438
|
+
return { data: null, error: null };
|
|
439
|
+
}
|
|
440
|
+
catch (error) {
|
|
441
|
+
if (isAuthError(error)) {
|
|
442
|
+
return { data: null, error };
|
|
443
|
+
}
|
|
444
|
+
throw error;
|
|
445
|
+
}
|
|
446
|
+
}
|
|
447
|
+
/**
|
|
448
|
+
* Regenerates the secret for an OAuth client.
|
|
449
|
+
* Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.
|
|
450
|
+
*
|
|
451
|
+
* This function should only be called on a server. Never expose your `service_role` key in the browser.
|
|
452
|
+
*/
|
|
453
|
+
async _regenerateOAuthClientSecret(clientId) {
|
|
454
|
+
try {
|
|
455
|
+
return await _request(this.fetch, 'POST', `${this.url}/admin/oauth/clients/${clientId}/regenerate_secret`, {
|
|
456
|
+
headers: this.headers,
|
|
457
|
+
xform: (client) => {
|
|
458
|
+
return { data: client, error: null };
|
|
459
|
+
},
|
|
460
|
+
});
|
|
461
|
+
}
|
|
462
|
+
catch (error) {
|
|
463
|
+
if (isAuthError(error)) {
|
|
464
|
+
return { data: null, error };
|
|
465
|
+
}
|
|
466
|
+
throw error;
|
|
467
|
+
}
|
|
468
|
+
}
|
|
469
|
+
/**
|
|
470
|
+
* Lists all custom providers with optional type filter.
|
|
471
|
+
*
|
|
472
|
+
* This function should only be called on a server. Never expose your `service_role` key in the browser.
|
|
473
|
+
*/
|
|
474
|
+
async _listCustomProviders(params) {
|
|
475
|
+
try {
|
|
476
|
+
const query = {};
|
|
477
|
+
if (params === null || params === void 0 ? void 0 : params.type) {
|
|
478
|
+
query.type = params.type;
|
|
479
|
+
}
|
|
480
|
+
return await _request(this.fetch, 'GET', `${this.url}/admin/custom-providers`, {
|
|
481
|
+
headers: this.headers,
|
|
482
|
+
query,
|
|
483
|
+
xform: (data) => {
|
|
484
|
+
var _a;
|
|
485
|
+
return { data: { providers: (_a = data === null || data === void 0 ? void 0 : data.providers) !== null && _a !== void 0 ? _a : [] }, error: null };
|
|
486
|
+
},
|
|
487
|
+
});
|
|
488
|
+
}
|
|
489
|
+
catch (error) {
|
|
490
|
+
if (isAuthError(error)) {
|
|
491
|
+
return { data: { providers: [] }, error };
|
|
492
|
+
}
|
|
493
|
+
throw error;
|
|
494
|
+
}
|
|
495
|
+
}
|
|
496
|
+
/**
|
|
497
|
+
* Creates a new custom OIDC/OAuth provider.
|
|
498
|
+
*
|
|
499
|
+
* For OIDC providers, the server fetches and validates the OpenID Connect discovery document
|
|
500
|
+
* from the issuer's well-known endpoint (or the provided `discovery_url`) at creation time.
|
|
501
|
+
* This may return a validation error (`error_code: "validation_failed"`) if the discovery
|
|
502
|
+
* document is unreachable, not valid JSON, missing required fields, or if the issuer
|
|
503
|
+
* in the document does not match the expected issuer.
|
|
504
|
+
*
|
|
505
|
+
* This function should only be called on a server. Never expose your `service_role` key in the browser.
|
|
506
|
+
*/
|
|
507
|
+
async _createCustomProvider(params) {
|
|
508
|
+
try {
|
|
509
|
+
return await _request(this.fetch, 'POST', `${this.url}/admin/custom-providers`, {
|
|
510
|
+
body: params,
|
|
511
|
+
headers: this.headers,
|
|
512
|
+
xform: (provider) => {
|
|
513
|
+
return { data: provider, error: null };
|
|
514
|
+
},
|
|
515
|
+
});
|
|
516
|
+
}
|
|
517
|
+
catch (error) {
|
|
518
|
+
if (isAuthError(error)) {
|
|
519
|
+
return { data: null, error };
|
|
520
|
+
}
|
|
521
|
+
throw error;
|
|
522
|
+
}
|
|
523
|
+
}
|
|
524
|
+
/**
|
|
525
|
+
* Gets details of a specific custom provider by identifier.
|
|
526
|
+
*
|
|
527
|
+
* This function should only be called on a server. Never expose your `service_role` key in the browser.
|
|
528
|
+
*/
|
|
529
|
+
async _getCustomProvider(identifier) {
|
|
530
|
+
try {
|
|
531
|
+
return await _request(this.fetch, 'GET', `${this.url}/admin/custom-providers/${identifier}`, {
|
|
532
|
+
headers: this.headers,
|
|
533
|
+
xform: (provider) => {
|
|
534
|
+
return { data: provider, error: null };
|
|
535
|
+
},
|
|
536
|
+
});
|
|
537
|
+
}
|
|
538
|
+
catch (error) {
|
|
539
|
+
if (isAuthError(error)) {
|
|
540
|
+
return { data: null, error };
|
|
541
|
+
}
|
|
542
|
+
throw error;
|
|
543
|
+
}
|
|
544
|
+
}
|
|
545
|
+
/**
|
|
546
|
+
* Updates an existing custom provider.
|
|
547
|
+
*
|
|
548
|
+
* When `issuer` or `discovery_url` is changed on an OIDC provider, the server re-fetches and
|
|
549
|
+
* validates the discovery document before persisting. This may return a validation error
|
|
550
|
+
* (`error_code: "validation_failed"`) if the discovery document is unreachable, invalid, or
|
|
551
|
+
* the issuer does not match.
|
|
552
|
+
*
|
|
553
|
+
* This function should only be called on a server. Never expose your `service_role` key in the browser.
|
|
554
|
+
*/
|
|
555
|
+
async _updateCustomProvider(identifier, params) {
|
|
556
|
+
try {
|
|
557
|
+
return await _request(this.fetch, 'PUT', `${this.url}/admin/custom-providers/${identifier}`, {
|
|
558
|
+
body: params,
|
|
559
|
+
headers: this.headers,
|
|
560
|
+
xform: (provider) => {
|
|
561
|
+
return { data: provider, error: null };
|
|
562
|
+
},
|
|
563
|
+
});
|
|
564
|
+
}
|
|
565
|
+
catch (error) {
|
|
566
|
+
if (isAuthError(error)) {
|
|
567
|
+
return { data: null, error };
|
|
568
|
+
}
|
|
569
|
+
throw error;
|
|
570
|
+
}
|
|
571
|
+
}
|
|
572
|
+
/**
|
|
573
|
+
* Deletes a custom provider.
|
|
574
|
+
*
|
|
575
|
+
* This function should only be called on a server. Never expose your `service_role` key in the browser.
|
|
576
|
+
*/
|
|
577
|
+
async _deleteCustomProvider(identifier) {
|
|
578
|
+
try {
|
|
579
|
+
await _request(this.fetch, 'DELETE', `${this.url}/admin/custom-providers/${identifier}`, {
|
|
580
|
+
headers: this.headers,
|
|
581
|
+
noResolveJson: true,
|
|
582
|
+
});
|
|
583
|
+
return { data: null, error: null };
|
|
584
|
+
}
|
|
585
|
+
catch (error) {
|
|
586
|
+
if (isAuthError(error)) {
|
|
587
|
+
return { data: null, error };
|
|
588
|
+
}
|
|
589
|
+
throw error;
|
|
590
|
+
}
|
|
591
|
+
}
|
|
592
|
+
}
|
|
593
|
+
//# sourceMappingURL=GoTrueAdminApi.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"GoTrueAdminApi.js","sourceRoot":"","sources":["../../src/GoTrueAdminApi.ts"],"names":[],"mappings":"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"}
|