@levrbet/shared 0.1.101 → 0.1.103
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/dist/cjs/core/types/auth/auth.types.js.map +1 -0
- package/dist/cjs/core/types/auth/index.js +19 -0
- package/dist/cjs/core/types/auth/index.js.map +1 -0
- package/dist/cjs/core/types/auth/request.types.js +15 -0
- package/dist/cjs/core/types/auth/request.types.js.map +1 -0
- package/dist/cjs/core/types/index.js +1 -1
- package/dist/cjs/core/types/index.js.map +1 -1
- package/dist/cjs/react/hooks/auth/useAuthHeaders.js +9 -18
- package/dist/cjs/react/hooks/auth/useAuthHeaders.js.map +1 -1
- package/dist/esm/core/types/{auth.types.d.ts → auth/auth.types.d.ts} +1 -1
- package/dist/esm/core/types/auth/auth.types.d.ts.map +1 -0
- package/dist/esm/core/types/auth/auth.types.js.map +1 -0
- package/dist/esm/core/types/auth/index.d.ts +3 -0
- package/dist/esm/core/types/auth/index.d.ts.map +1 -0
- package/dist/esm/core/types/auth/index.js +3 -0
- package/dist/esm/core/types/auth/index.js.map +1 -0
- package/dist/esm/core/types/auth/request.types.d.ts +20 -0
- package/dist/esm/core/types/auth/request.types.d.ts.map +1 -0
- package/dist/esm/core/types/auth/request.types.js +9 -0
- package/dist/esm/core/types/auth/request.types.js.map +1 -0
- package/dist/esm/core/types/index.d.ts +1 -1
- package/dist/esm/core/types/index.d.ts.map +1 -1
- package/dist/esm/core/types/index.js +1 -1
- package/dist/esm/core/types/index.js.map +1 -1
- package/dist/esm/react/hooks/auth/useAuthHeaders.d.ts +17 -17
- package/dist/esm/react/hooks/auth/useAuthHeaders.d.ts.map +1 -1
- package/dist/esm/react/hooks/auth/useAuthHeaders.js +7 -17
- package/dist/esm/react/hooks/auth/useAuthHeaders.js.map +1 -1
- package/package.json +1 -1
- package/dist/cjs/core/types/auth.types.js.map +0 -1
- package/dist/esm/core/types/auth.types.d.ts.map +0 -1
- package/dist/esm/core/types/auth.types.js.map +0 -1
- /package/dist/cjs/core/types/{auth.types.js → auth/auth.types.js} +0 -0
- /package/dist/esm/core/types/{auth.types.js → auth/auth.types.js} +0 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth.types.js","sourceRoot":"","sources":["../../../../../src/core/types/auth/auth.types.ts"],"names":[],"mappings":";;;AAEA,IAAY,QAMX;AAND,WAAY,QAAQ;IAChB,oCAAwB,CAAA;IACxB,sCAA0B,CAAA;IAC1B,qCAAyB,CAAA;IACzB,yBAAa,CAAA;IACb,wCAA4B,CAAA;AAChC,CAAC,EANW,QAAQ,wBAAR,QAAQ,QAMnB;AAED,4EAA4E;AAC5E,qEAAqE;AACxD,QAAA,gBAAgB,GAAG,kBAAkB,CAAA"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./auth.types"), exports);
|
|
18
|
+
__exportStar(require("./request.types"), exports);
|
|
19
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/core/types/auth/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,+CAA4B;AAC5B,kDAA+B"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.createApiKeySchema = void 0;
|
|
7
|
+
const zod_1 = __importDefault(require("zod"));
|
|
8
|
+
const prisma_1 = require("../../prisma");
|
|
9
|
+
exports.createApiKeySchema = zod_1.default.object({
|
|
10
|
+
name: zod_1.default.string().min(1).max(100),
|
|
11
|
+
scopes: zod_1.default.array(zod_1.default.enum(prisma_1.ApiKeyScope)).min(1, "At least one scope is required."),
|
|
12
|
+
expiresAt: zod_1.default.coerce.date().optional(),
|
|
13
|
+
service: zod_1.default.enum(prisma_1.LevrService).optional(),
|
|
14
|
+
});
|
|
15
|
+
//# sourceMappingURL=request.types.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"request.types.js","sourceRoot":"","sources":["../../../../../src/core/types/auth/request.types.ts"],"names":[],"mappings":";;;;;;AAAA,8CAAmB;AACnB,yCAAuD;AAE1C,QAAA,kBAAkB,GAAG,aAAC,CAAC,MAAM,CAAC;IACvC,IAAI,EAAE,aAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC;IAChC,MAAM,EAAE,aAAC,CAAC,KAAK,CAAC,aAAC,CAAC,IAAI,CAAC,oBAAW,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,iCAAiC,CAAC;IAC9E,SAAS,EAAE,aAAC,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,QAAQ,EAAE;IACrC,OAAO,EAAE,aAAC,CAAC,IAAI,CAAC,oBAAW,CAAC,CAAC,QAAQ,EAAE;CAC1C,CAAC,CAAA"}
|
|
@@ -14,7 +14,7 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
14
14
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
-
__exportStar(require("./auth
|
|
17
|
+
__exportStar(require("./auth"), exports);
|
|
18
18
|
__exportStar(require("./blockchain"), exports);
|
|
19
19
|
__exportStar(require("./indexers.types"), exports);
|
|
20
20
|
__exportStar(require("./misc.types"), exports);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/core/types/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/core/types/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,yCAAsB;AACtB,+CAA4B;AAC5B,mDAAgC;AAChC,+CAA4B;AAC5B,2CAAwB;AACxB,gDAA6B"}
|
|
@@ -3,28 +3,15 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
3
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.useAuthHeaders = void 0;
|
|
6
|
+
exports.useAdminAuthHeaders = exports.useAuthHeaders = void 0;
|
|
7
7
|
const react_auth_1 = require("@privy-io/react-auth");
|
|
8
8
|
const react_query_1 = require("@tanstack/react-query");
|
|
9
9
|
const lodash_1 = __importDefault(require("lodash"));
|
|
10
10
|
const ms_1 = __importDefault(require("ms"));
|
|
11
|
+
const core_1 = require("../../../core");
|
|
11
12
|
const constants_1 = require("../../../core/privy/constants");
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
*
|
|
15
|
-
* This hook automatically manages the retrieval and caching of authentication headers
|
|
16
|
-
* including the user's Ethereum address, Privy access token, and identity token.
|
|
17
|
-
* The headers are refreshed every 10 minutes and cached for optimal performance.
|
|
18
|
-
*
|
|
19
|
-
* @returns A React Query result containing the authentication headers object
|
|
20
|
-
*
|
|
21
|
-
* @example
|
|
22
|
-
* ```typescript
|
|
23
|
-
* // Basic usage in a component
|
|
24
|
-
* const {data: authHeaders = {}} = useAuthHeaders()
|
|
25
|
-
* ```
|
|
26
|
-
*/
|
|
27
|
-
const useAuthHeaders = ({ address } = {}) => {
|
|
13
|
+
function useBaseAuthHeaders(levrAuth, props = {}) {
|
|
14
|
+
const { address } = props;
|
|
28
15
|
const { getAccessToken, user } = (0, react_auth_1.usePrivy)();
|
|
29
16
|
const { identityToken } = (0, react_auth_1.useIdentityToken)();
|
|
30
17
|
const { refreshUser } = (0, react_auth_1.useUser)();
|
|
@@ -35,6 +22,7 @@ const useAuthHeaders = ({ address } = {}) => {
|
|
|
35
22
|
return {};
|
|
36
23
|
await refreshUser();
|
|
37
24
|
return {
|
|
25
|
+
[core_1.LEVR_AUTH_HEADER]: levrAuth,
|
|
38
26
|
[constants_1.ETH_ADDRESS_HEADER]: address,
|
|
39
27
|
[constants_1.PRIVY_ACCESS_TOKEN_HEADER]: await getAccessToken(),
|
|
40
28
|
[constants_1.PRIVY_ID_TOKEN_HEADER]: identityToken,
|
|
@@ -45,6 +33,9 @@ const useAuthHeaders = ({ address } = {}) => {
|
|
|
45
33
|
staleTime: (0, ms_1.default)("10m"),
|
|
46
34
|
gcTime: (0, ms_1.default)("10m"),
|
|
47
35
|
});
|
|
48
|
-
}
|
|
36
|
+
}
|
|
37
|
+
const useAuthHeaders = (props) => useBaseAuthHeaders(core_1.LevrAuth.PRIVY_USER, props);
|
|
49
38
|
exports.useAuthHeaders = useAuthHeaders;
|
|
39
|
+
const useAdminAuthHeaders = (props) => useBaseAuthHeaders(core_1.LevrAuth.PRIVY_ADMIN, props);
|
|
40
|
+
exports.useAdminAuthHeaders = useAdminAuthHeaders;
|
|
50
41
|
//# sourceMappingURL=useAuthHeaders.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useAuthHeaders.js","sourceRoot":"","sources":["../../../../../src/react/hooks/auth/useAuthHeaders.ts"],"names":[],"mappings":";;;;;;AAAA,qDAA0E;AAC1E,uDAAgD;AAChD,oDAAsB;AACtB,4CAAmB;
|
|
1
|
+
{"version":3,"file":"useAuthHeaders.js","sourceRoot":"","sources":["../../../../../src/react/hooks/auth/useAuthHeaders.ts"],"names":[],"mappings":";;;;;;AAAA,qDAA0E;AAC1E,uDAAgD;AAChD,oDAAsB;AACtB,4CAAmB;AAGnB,wCAA0D;AAC1D,6DAAoH;AAMpH,SAAS,kBAAkB,CAAC,QAAkB,EAAE,QAA6B,EAAE;IAC3E,MAAM,EAAE,OAAO,EAAE,GAAG,KAAK,CAAA;IACzB,MAAM,EAAE,cAAc,EAAE,IAAI,EAAE,GAAG,IAAA,qBAAQ,GAAE,CAAA;IAC3C,MAAM,EAAE,aAAa,EAAE,GAAG,IAAA,6BAAgB,GAAE,CAAA;IAC5C,MAAM,EAAE,WAAW,EAAE,GAAG,IAAA,oBAAO,GAAE,CAAA;IAEjC,OAAO,IAAA,sBAAQ,EAAC;QACZ,QAAQ,EAAE,CAAC,aAAa,EAAE,IAAI,EAAE,EAAE,EAAE,OAAO,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,gBAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QACvE,OAAO,EAAE,KAAK,IAAI,EAAE;YAChB,IAAI,CAAC,IAAI;gBAAE,OAAO,EAAE,CAAA;YACpB,MAAM,WAAW,EAAE,CAAA;YAEnB,OAAO;gBACH,CAAC,uBAAgB,CAAC,EAAE,QAAQ;gBAC5B,CAAC,8BAAkB,CAAC,EAAE,OAAO;gBAC7B,CAAC,qCAAyB,CAAC,EAAE,MAAM,cAAc,EAAE;gBACnD,CAAC,iCAAqB,CAAC,EAAE,aAAa;aACzC,CAAA;QACL,CAAC;QACD,OAAO,EAAE,CAAC,gBAAC,CAAC,KAAK,CAAC,IAAI,CAAC;QACvB,eAAe,EAAE,IAAA,YAAE,EAAC,KAAK,CAAC;QAC1B,SAAS,EAAE,IAAA,YAAE,EAAC,KAAK,CAAC;QACpB,MAAM,EAAE,IAAA,YAAE,EAAC,KAAK,CAAC;KACpB,CAAC,CAAA;AACN,CAAC;AAEM,MAAM,cAAc,GAAG,CAAC,KAA2B,EAAE,EAAE,CAAC,kBAAkB,CAAC,eAAQ,CAAC,UAAU,EAAE,KAAK,CAAC,CAAA;AAAhG,QAAA,cAAc,kBAAkF;AAEtG,MAAM,mBAAmB,GAAG,CAAC,KAA2B,EAAE,EAAE,CAAC,kBAAkB,CAAC,eAAQ,CAAC,WAAW,EAAE,KAAK,CAAC,CAAA;AAAtG,QAAA,mBAAmB,uBAAmF"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth.types.d.ts","sourceRoot":"","sources":["../../../../../src/core/types/auth/auth.types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,cAAc,CAAA;AAEvD,oBAAY,QAAQ;IAChB,UAAU,cAAc;IACxB,WAAW,eAAe;IAC1B,UAAU,eAAe;IACzB,IAAI,SAAS;IACb,YAAY,gBAAgB;CAC/B;AAID,eAAO,MAAM,gBAAgB,qBAAqB,CAAA;AAIlD,MAAM,WAAW,gBAAgB;IAC7B;;;OAGG;IACH,OAAO,EAAE,QAAQ,EAAE,CAAA;IAEnB;;;OAGG;IACH,cAAc,CAAC,EAAE,WAAW,EAAE,CAAA;IAE9B;;;OAGG;IACH,eAAe,CAAC,EAAE,WAAW,EAAE,CAAA;IAE/B;;;OAGG;IACH,qBAAqB,CAAC,EAAE,OAAO,CAAA;CAClC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth.types.js","sourceRoot":"","sources":["../../../../../src/core/types/auth/auth.types.ts"],"names":[],"mappings":"AAEA,MAAM,CAAN,IAAY,QAMX;AAND,WAAY,QAAQ;IAChB,oCAAwB,CAAA;IACxB,sCAA0B,CAAA;IAC1B,qCAAyB,CAAA;IACzB,yBAAa,CAAA;IACb,wCAA4B,CAAA;AAChC,CAAC,EANW,QAAQ,KAAR,QAAQ,QAMnB;AAED,4EAA4E;AAC5E,qEAAqE;AACrE,MAAM,CAAC,MAAM,gBAAgB,GAAG,kBAAkB,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/core/types/auth/index.ts"],"names":[],"mappings":"AAAA,cAAc,cAAc,CAAA;AAC5B,cAAc,iBAAiB,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/core/types/auth/index.ts"],"names":[],"mappings":"AAAA,cAAc,cAAc,CAAA;AAC5B,cAAc,iBAAiB,CAAA"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import z from "zod";
|
|
2
|
+
export declare const createApiKeySchema: z.ZodObject<{
|
|
3
|
+
name: z.ZodString;
|
|
4
|
+
scopes: z.ZodArray<z.ZodEnum<{
|
|
5
|
+
Read: "Read";
|
|
6
|
+
Write: "Write";
|
|
7
|
+
}>>;
|
|
8
|
+
expiresAt: z.ZodOptional<z.ZodCoercedDate<unknown>>;
|
|
9
|
+
service: z.ZodOptional<z.ZodEnum<{
|
|
10
|
+
Auth: "Auth";
|
|
11
|
+
Orderbook: "Orderbook";
|
|
12
|
+
OracleCore: "OracleCore";
|
|
13
|
+
OraclePeriphery: "OraclePeriphery";
|
|
14
|
+
OracleProcessor: "OracleProcessor";
|
|
15
|
+
Leaderboard: "Leaderboard";
|
|
16
|
+
Lab: "Lab";
|
|
17
|
+
}>>;
|
|
18
|
+
}, z.core.$strip>;
|
|
19
|
+
export type CreateApiKeyInput = z.infer<typeof createApiKeySchema>;
|
|
20
|
+
//# sourceMappingURL=request.types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"request.types.d.ts","sourceRoot":"","sources":["../../../../../src/core/types/auth/request.types.ts"],"names":[],"mappings":"AAAA,OAAO,CAAC,MAAM,KAAK,CAAA;AAGnB,eAAO,MAAM,kBAAkB;;;;;;;;;;;;;;;;iBAK7B,CAAA;AAEF,MAAM,MAAM,iBAAiB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,kBAAkB,CAAC,CAAA"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import z from "zod";
|
|
2
|
+
import { ApiKeyScope, LevrService } from "../../prisma";
|
|
3
|
+
export const createApiKeySchema = z.object({
|
|
4
|
+
name: z.string().min(1).max(100),
|
|
5
|
+
scopes: z.array(z.enum(ApiKeyScope)).min(1, "At least one scope is required."),
|
|
6
|
+
expiresAt: z.coerce.date().optional(),
|
|
7
|
+
service: z.enum(LevrService).optional(),
|
|
8
|
+
});
|
|
9
|
+
//# sourceMappingURL=request.types.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"request.types.js","sourceRoot":"","sources":["../../../../../src/core/types/auth/request.types.ts"],"names":[],"mappings":"AAAA,OAAO,CAAC,MAAM,KAAK,CAAA;AACnB,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,cAAc,CAAA;AAEvD,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAAC,CAAC,MAAM,CAAC;IACvC,IAAI,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC;IAChC,MAAM,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,iCAAiC,CAAC;IAC9E,SAAS,EAAE,CAAC,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,QAAQ,EAAE;IACrC,OAAO,EAAE,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,QAAQ,EAAE;CAC1C,CAAC,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/core/types/index.ts"],"names":[],"mappings":"AAAA,cAAc,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/core/types/index.ts"],"names":[],"mappings":"AAAA,cAAc,QAAQ,CAAA;AACtB,cAAc,cAAc,CAAA;AAC5B,cAAc,kBAAkB,CAAA;AAChC,cAAc,cAAc,CAAA;AAC5B,cAAc,UAAU,CAAA;AACxB,cAAc,eAAe,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/core/types/index.ts"],"names":[],"mappings":"AAAA,cAAc,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/core/types/index.ts"],"names":[],"mappings":"AAAA,cAAc,QAAQ,CAAA;AACtB,cAAc,cAAc,CAAA;AAC5B,cAAc,kBAAkB,CAAA;AAChC,cAAc,cAAc,CAAA;AAC5B,cAAc,UAAU,CAAA;AACxB,cAAc,eAAe,CAAA"}
|
|
@@ -1,26 +1,26 @@
|
|
|
1
1
|
import { Address } from "viem";
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
*
|
|
5
|
-
* This hook automatically manages the retrieval and caching of authentication headers
|
|
6
|
-
* including the user's Ethereum address, Privy access token, and identity token.
|
|
7
|
-
* The headers are refreshed every 10 minutes and cached for optimal performance.
|
|
8
|
-
*
|
|
9
|
-
* @returns A React Query result containing the authentication headers object
|
|
10
|
-
*
|
|
11
|
-
* @example
|
|
12
|
-
* ```typescript
|
|
13
|
-
* // Basic usage in a component
|
|
14
|
-
* const {data: authHeaders = {}} = useAuthHeaders()
|
|
15
|
-
* ```
|
|
16
|
-
*/
|
|
17
|
-
export declare const useAuthHeaders: ({ address }?: {
|
|
2
|
+
import { LevrAuth } from "../../../core";
|
|
3
|
+
export interface UseAuthHeadersProps {
|
|
18
4
|
address?: Address;
|
|
19
|
-
}
|
|
5
|
+
}
|
|
6
|
+
export declare const useAuthHeaders: (props?: UseAuthHeadersProps) => import("@tanstack/react-query").UseQueryResult<{
|
|
7
|
+
"x-levr-auth-type"?: undefined;
|
|
20
8
|
"x-eth-address"?: undefined;
|
|
21
9
|
"privy-access-token"?: undefined;
|
|
22
10
|
"privy-id-token"?: undefined;
|
|
23
11
|
} | {
|
|
12
|
+
"x-levr-auth-type": LevrAuth;
|
|
13
|
+
"x-eth-address": `0x${string}` | undefined;
|
|
14
|
+
"privy-access-token": string | null;
|
|
15
|
+
"privy-id-token": string | null;
|
|
16
|
+
}, Error>;
|
|
17
|
+
export declare const useAdminAuthHeaders: (props?: UseAuthHeadersProps) => import("@tanstack/react-query").UseQueryResult<{
|
|
18
|
+
"x-levr-auth-type"?: undefined;
|
|
19
|
+
"x-eth-address"?: undefined;
|
|
20
|
+
"privy-access-token"?: undefined;
|
|
21
|
+
"privy-id-token"?: undefined;
|
|
22
|
+
} | {
|
|
23
|
+
"x-levr-auth-type": LevrAuth;
|
|
24
24
|
"x-eth-address": `0x${string}` | undefined;
|
|
25
25
|
"privy-access-token": string | null;
|
|
26
26
|
"privy-id-token": string | null;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useAuthHeaders.d.ts","sourceRoot":"","sources":["../../../../../src/react/hooks/auth/useAuthHeaders.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"useAuthHeaders.d.ts","sourceRoot":"","sources":["../../../../../src/react/hooks/auth/useAuthHeaders.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAA;AAC9B,OAAO,EAAoB,QAAQ,EAAE,MAAM,eAAe,CAAA;AAG1D,MAAM,WAAW,mBAAmB;IAChC,OAAO,CAAC,EAAE,OAAO,CAAA;CACpB;AA4BD,eAAO,MAAM,cAAc,GAAI,QAAQ,mBAAmB;;;;;;;;;;SAAmD,CAAA;AAE7G,eAAO,MAAM,mBAAmB,GAAI,QAAQ,mBAAmB;;;;;;;;;;SAAoD,CAAA"}
|
|
@@ -2,23 +2,10 @@ import { useIdentityToken, usePrivy, useUser } from "@privy-io/react-auth";
|
|
|
2
2
|
import { useQuery } from "@tanstack/react-query";
|
|
3
3
|
import _ from "lodash";
|
|
4
4
|
import ms from "ms";
|
|
5
|
+
import { LEVR_AUTH_HEADER, LevrAuth } from "../../../core";
|
|
5
6
|
import { ETH_ADDRESS_HEADER, PRIVY_ACCESS_TOKEN_HEADER, PRIVY_ID_TOKEN_HEADER } from "../../../core/privy/constants";
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
*
|
|
9
|
-
* This hook automatically manages the retrieval and caching of authentication headers
|
|
10
|
-
* including the user's Ethereum address, Privy access token, and identity token.
|
|
11
|
-
* The headers are refreshed every 10 minutes and cached for optimal performance.
|
|
12
|
-
*
|
|
13
|
-
* @returns A React Query result containing the authentication headers object
|
|
14
|
-
*
|
|
15
|
-
* @example
|
|
16
|
-
* ```typescript
|
|
17
|
-
* // Basic usage in a component
|
|
18
|
-
* const {data: authHeaders = {}} = useAuthHeaders()
|
|
19
|
-
* ```
|
|
20
|
-
*/
|
|
21
|
-
export const useAuthHeaders = ({ address } = {}) => {
|
|
7
|
+
function useBaseAuthHeaders(levrAuth, props = {}) {
|
|
8
|
+
const { address } = props;
|
|
22
9
|
const { getAccessToken, user } = usePrivy();
|
|
23
10
|
const { identityToken } = useIdentityToken();
|
|
24
11
|
const { refreshUser } = useUser();
|
|
@@ -29,6 +16,7 @@ export const useAuthHeaders = ({ address } = {}) => {
|
|
|
29
16
|
return {};
|
|
30
17
|
await refreshUser();
|
|
31
18
|
return {
|
|
19
|
+
[LEVR_AUTH_HEADER]: levrAuth,
|
|
32
20
|
[ETH_ADDRESS_HEADER]: address,
|
|
33
21
|
[PRIVY_ACCESS_TOKEN_HEADER]: await getAccessToken(),
|
|
34
22
|
[PRIVY_ID_TOKEN_HEADER]: identityToken,
|
|
@@ -39,5 +27,7 @@ export const useAuthHeaders = ({ address } = {}) => {
|
|
|
39
27
|
staleTime: ms("10m"),
|
|
40
28
|
gcTime: ms("10m"),
|
|
41
29
|
});
|
|
42
|
-
}
|
|
30
|
+
}
|
|
31
|
+
export const useAuthHeaders = (props) => useBaseAuthHeaders(LevrAuth.PRIVY_USER, props);
|
|
32
|
+
export const useAdminAuthHeaders = (props) => useBaseAuthHeaders(LevrAuth.PRIVY_ADMIN, props);
|
|
43
33
|
//# sourceMappingURL=useAuthHeaders.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useAuthHeaders.js","sourceRoot":"","sources":["../../../../../src/react/hooks/auth/useAuthHeaders.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAA;AAC1E,OAAO,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAA;AAChD,OAAO,CAAC,MAAM,QAAQ,CAAA;AACtB,OAAO,EAAE,MAAM,IAAI,CAAA;
|
|
1
|
+
{"version":3,"file":"useAuthHeaders.js","sourceRoot":"","sources":["../../../../../src/react/hooks/auth/useAuthHeaders.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAA;AAC1E,OAAO,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAA;AAChD,OAAO,CAAC,MAAM,QAAQ,CAAA;AACtB,OAAO,EAAE,MAAM,IAAI,CAAA;AAGnB,OAAO,EAAE,gBAAgB,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAA;AAC1D,OAAO,EAAE,kBAAkB,EAAE,yBAAyB,EAAE,qBAAqB,EAAE,MAAM,+BAA+B,CAAA;AAMpH,SAAS,kBAAkB,CAAC,QAAkB,EAAE,QAA6B,EAAE;IAC3E,MAAM,EAAE,OAAO,EAAE,GAAG,KAAK,CAAA;IACzB,MAAM,EAAE,cAAc,EAAE,IAAI,EAAE,GAAG,QAAQ,EAAE,CAAA;IAC3C,MAAM,EAAE,aAAa,EAAE,GAAG,gBAAgB,EAAE,CAAA;IAC5C,MAAM,EAAE,WAAW,EAAE,GAAG,OAAO,EAAE,CAAA;IAEjC,OAAO,QAAQ,CAAC;QACZ,QAAQ,EAAE,CAAC,aAAa,EAAE,IAAI,EAAE,EAAE,EAAE,OAAO,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QACvE,OAAO,EAAE,KAAK,IAAI,EAAE;YAChB,IAAI,CAAC,IAAI;gBAAE,OAAO,EAAE,CAAA;YACpB,MAAM,WAAW,EAAE,CAAA;YAEnB,OAAO;gBACH,CAAC,gBAAgB,CAAC,EAAE,QAAQ;gBAC5B,CAAC,kBAAkB,CAAC,EAAE,OAAO;gBAC7B,CAAC,yBAAyB,CAAC,EAAE,MAAM,cAAc,EAAE;gBACnD,CAAC,qBAAqB,CAAC,EAAE,aAAa;aACzC,CAAA;QACL,CAAC;QACD,OAAO,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC;QACvB,eAAe,EAAE,EAAE,CAAC,KAAK,CAAC;QAC1B,SAAS,EAAE,EAAE,CAAC,KAAK,CAAC;QACpB,MAAM,EAAE,EAAE,CAAC,KAAK,CAAC;KACpB,CAAC,CAAA;AACN,CAAC;AAED,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,KAA2B,EAAE,EAAE,CAAC,kBAAkB,CAAC,QAAQ,CAAC,UAAU,EAAE,KAAK,CAAC,CAAA;AAE7G,MAAM,CAAC,MAAM,mBAAmB,GAAG,CAAC,KAA2B,EAAE,EAAE,CAAC,kBAAkB,CAAC,QAAQ,CAAC,WAAW,EAAE,KAAK,CAAC,CAAA"}
|
package/package.json
CHANGED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"auth.types.js","sourceRoot":"","sources":["../../../../src/core/types/auth.types.ts"],"names":[],"mappings":";;;AAEA,IAAY,QAMX;AAND,WAAY,QAAQ;IAChB,oCAAwB,CAAA;IACxB,sCAA0B,CAAA;IAC1B,qCAAyB,CAAA;IACzB,yBAAa,CAAA;IACb,wCAA4B,CAAA;AAChC,CAAC,EANW,QAAQ,wBAAR,QAAQ,QAMnB;AAED,4EAA4E;AAC5E,qEAAqE;AACxD,QAAA,gBAAgB,GAAG,kBAAkB,CAAA"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"auth.types.d.ts","sourceRoot":"","sources":["../../../../src/core/types/auth.types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,WAAW,CAAA;AAEpD,oBAAY,QAAQ;IAChB,UAAU,cAAc;IACxB,WAAW,eAAe;IAC1B,UAAU,eAAe;IACzB,IAAI,SAAS;IACb,YAAY,gBAAgB;CAC/B;AAID,eAAO,MAAM,gBAAgB,qBAAqB,CAAA;AAIlD,MAAM,WAAW,gBAAgB;IAC7B;;;OAGG;IACH,OAAO,EAAE,QAAQ,EAAE,CAAA;IAEnB;;;OAGG;IACH,cAAc,CAAC,EAAE,WAAW,EAAE,CAAA;IAE9B;;;OAGG;IACH,eAAe,CAAC,EAAE,WAAW,EAAE,CAAA;IAE/B;;;OAGG;IACH,qBAAqB,CAAC,EAAE,OAAO,CAAA;CAClC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"auth.types.js","sourceRoot":"","sources":["../../../../src/core/types/auth.types.ts"],"names":[],"mappings":"AAEA,MAAM,CAAN,IAAY,QAMX;AAND,WAAY,QAAQ;IAChB,oCAAwB,CAAA;IACxB,sCAA0B,CAAA;IAC1B,qCAAyB,CAAA;IACzB,yBAAa,CAAA;IACb,wCAA4B,CAAA;AAChC,CAAC,EANW,QAAQ,KAAR,QAAQ,QAMnB;AAED,4EAA4E;AAC5E,qEAAqE;AACrE,MAAM,CAAC,MAAM,gBAAgB,GAAG,kBAAkB,CAAA"}
|
|
File without changes
|
|
File without changes
|