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