@levrbet/shared 0.2.43 → 0.2.45
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/core/contracts/addresses.d.ts +20 -0
- package/dist/core/contracts/addresses.js +33 -13
- package/dist/core/contracts/addresses.js.map +1 -1
- package/dist/core/contracts/instances.d.ts +7 -2
- package/dist/core/contracts/instances.js +20 -1
- package/dist/core/contracts/instances.js.map +1 -1
- package/dist/core/index.d.ts +1 -0
- package/dist/core/index.js +1 -0
- package/dist/core/index.js.map +1 -1
- package/dist/core/indexers/envio.test.query.d.ts +5 -2
- package/dist/core/indexers/envio.test.query.js +8 -3
- package/dist/core/indexers/envio.test.query.js.map +1 -1
- package/dist/core/indexers/indexers.service.js +32 -12
- package/dist/core/indexers/indexers.service.js.map +1 -1
- package/dist/core/indexers/subsquid.test.query.d.ts +4 -1
- package/dist/core/indexers/subsquid.test.query.js +22 -2
- package/dist/core/indexers/subsquid.test.query.js.map +1 -1
- package/dist/core/socket.io/events.d.ts +20 -0
- package/dist/core/socket.io/events.js +20 -0
- package/dist/core/socket.io/events.js.map +1 -0
- package/dist/core/socket.io/index.d.ts +2 -0
- package/dist/core/socket.io/index.js +19 -0
- package/dist/core/socket.io/index.js.map +1 -0
- package/dist/core/socket.io/rooms.d.ts +6 -0
- package/dist/core/socket.io/rooms.js +10 -0
- package/dist/core/socket.io/rooms.js.map +1 -0
- package/dist/core/types/oracle/market/markets.types.d.ts +4 -4
- package/dist/core/types/oracle/market/positions.types.d.ts +17 -1
- package/dist/core/types/oracle/requests/game.request.types.d.ts +7 -5
- package/dist/core/types/oracle/requests/game.request.types.js +6 -4
- package/dist/core/types/oracle/requests/game.request.types.js.map +1 -1
- package/dist/core/types/oracle/requests/index.d.ts +2 -0
- package/dist/core/types/oracle/requests/index.js +2 -0
- package/dist/core/types/oracle/requests/index.js.map +1 -1
- package/dist/core/types/oracle/requests/odds.response.types.d.ts +2 -0
- package/dist/core/types/oracle/requests/odds.response.types.js +3 -0
- package/dist/core/types/oracle/requests/odds.response.types.js.map +1 -0
- package/dist/core/types/oracle/requests/user.request.type.d.ts +4 -0
- package/dist/core/types/oracle/requests/user.request.type.js +3 -0
- package/dist/core/types/oracle/requests/user.request.type.js.map +1 -0
- package/dist/core/utils/misc.utils.d.ts +6 -0
- package/dist/core/utils/misc.utils.js +17 -1
- package/dist/core/utils/misc.utils.js.map +1 -1
- package/dist/core/validators/bytes.validators.d.ts +4 -3
- package/dist/core/validators/bytes.validators.js +4 -4
- package/dist/core/validators/bytes.validators.js.map +1 -1
- package/dist/react/hooks/auth/useAuthHeaders.js +2 -1
- package/dist/react/hooks/auth/useAuthHeaders.js.map +1 -1
- package/dist/react/hooks/contracts/erc20/index.d.ts +6 -0
- package/dist/react/hooks/contracts/erc20/index.js +23 -0
- package/dist/react/hooks/contracts/erc20/index.js.map +1 -0
- package/dist/react/hooks/contracts/erc20/useApproveErc20.d.ts +13 -0
- package/dist/react/hooks/contracts/erc20/useApproveErc20.js +28 -0
- package/dist/react/hooks/contracts/erc20/useApproveErc20.js.map +1 -0
- package/dist/react/hooks/contracts/erc20/useErc20Allowance.d.ts +10 -0
- package/dist/react/hooks/contracts/erc20/useErc20Allowance.js +34 -0
- package/dist/react/hooks/contracts/erc20/useErc20Allowance.js.map +1 -0
- package/dist/react/hooks/contracts/erc20/useErc20Balance.d.ts +22 -0
- package/dist/react/hooks/contracts/erc20/useErc20Balance.js +95 -0
- package/dist/react/hooks/contracts/erc20/useErc20Balance.js.map +1 -0
- package/dist/react/hooks/contracts/erc20/useErc20Decimals.d.ts +8 -0
- package/dist/react/hooks/contracts/erc20/useErc20Decimals.js +28 -0
- package/dist/react/hooks/contracts/erc20/useErc20Decimals.js.map +1 -0
- package/dist/react/hooks/contracts/erc20/useErc20Symbol.d.ts +8 -0
- package/dist/react/hooks/contracts/erc20/useErc20Symbol.js +28 -0
- package/dist/react/hooks/contracts/erc20/useErc20Symbol.js.map +1 -0
- package/dist/react/hooks/contracts/erc20/useTransferErc20.d.ts +13 -0
- package/dist/react/hooks/contracts/erc20/useTransferErc20.js +31 -0
- package/dist/react/hooks/contracts/erc20/useTransferErc20.js.map +1 -0
- package/dist/react/hooks/contracts/index.d.ts +1 -0
- package/dist/react/hooks/contracts/index.js +1 -0
- package/dist/react/hooks/contracts/index.js.map +1 -1
- package/dist/react/hooks/contracts/useContracts.d.ts +7 -1
- package/dist/react/hooks/contracts/useContracts.js +24 -2
- package/dist/react/hooks/contracts/useContracts.js.map +1 -1
- package/dist/react/index.d.ts +1 -0
- package/dist/react/index.js +1 -0
- package/dist/react/index.js.map +1 -1
- package/dist/react/injectedDependencies.d.ts +4 -3
- package/dist/react/injectedDependencies.js +2 -1
- package/dist/react/injectedDependencies.js.map +1 -1
- package/dist/react/queryKeys.d.ts +17 -0
- package/dist/react/queryKeys.js +23 -0
- package/dist/react/queryKeys.js.map +1 -0
- package/dist/server/config/redis.d.ts +1 -1
- package/dist/server/config/redis.js +9 -3
- package/dist/server/config/redis.js.map +1 -1
- package/dist/server/oracle/redis-cache-manager/channels.d.ts +1 -5
- package/dist/server/oracle/redis-cache-manager/channels.js +5 -14
- package/dist/server/oracle/redis-cache-manager/channels.js.map +1 -1
- package/dist/server/services/index.d.ts +1 -0
- package/dist/server/services/index.js +1 -0
- package/dist/server/services/index.js.map +1 -1
- package/dist/server/services/presigned.urls.d.ts +11 -0
- package/dist/server/services/presigned.urls.js +41 -0
- package/dist/server/services/presigned.urls.js.map +1 -0
- package/package.json +9 -6
- package/dist/core/prisma/generated/client.d.ts +0 -1
- package/dist/core/prisma/generated/client.js +0 -4
- package/dist/core/prisma/generated/default.d.ts +0 -1
- package/dist/core/prisma/generated/default.js +0 -4
- package/dist/core/prisma/generated/edge.d.ts +0 -1
- package/dist/core/prisma/generated/edge.js +0 -536
- package/dist/core/prisma/generated/index-browser.js +0 -523
- package/dist/core/prisma/generated/index.d.ts +0 -31059
- package/dist/core/prisma/generated/index.js +0 -557
- package/dist/core/prisma/generated/libquery_engine-linux-musl-openssl-3.0.x.so.node +0 -0
- package/dist/core/prisma/generated/package.json +0 -183
- package/dist/core/prisma/generated/runtime/edge-esm.js +0 -34
- package/dist/core/prisma/generated/runtime/edge.js +0 -34
- package/dist/core/prisma/generated/runtime/index-browser.d.ts +0 -370
- package/dist/core/prisma/generated/runtime/index-browser.js +0 -16
- package/dist/core/prisma/generated/runtime/library.d.ts +0 -3982
- package/dist/core/prisma/generated/runtime/library.js +0 -146
- package/dist/core/prisma/generated/runtime/react-native.js +0 -83
- package/dist/core/prisma/generated/runtime/wasm-compiler-edge.js +0 -84
- package/dist/core/prisma/generated/runtime/wasm-engine-edge.js +0 -36
- package/dist/core/prisma/generated/schema.prisma +0 -460
- package/dist/core/prisma/generated/wasm-edge-light-loader.mjs +0 -4
- package/dist/core/prisma/generated/wasm-worker-loader.mjs +0 -4
- package/dist/core/prisma/generated/wasm.d.ts +0 -1
- package/dist/core/prisma/generated/wasm.js +0 -543
|
@@ -0,0 +1,28 @@
|
|
|
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.useErc20Symbol = void 0;
|
|
7
|
+
const lodash_1 = __importDefault(require("lodash"));
|
|
8
|
+
const core_1 = require("../../../../core");
|
|
9
|
+
const injectedDependencies_1 = require("../../../injectedDependencies");
|
|
10
|
+
const queryKeys_1 = require("../../../queryKeys");
|
|
11
|
+
const useErc20Symbol = ({ erc20Address, chainId: _chainId }) => {
|
|
12
|
+
const { useQuery, useChainId } = (0, injectedDependencies_1.getDependencies)();
|
|
13
|
+
const chainId = useChainId?.() ?? _chainId;
|
|
14
|
+
return useQuery({
|
|
15
|
+
queryKey: queryKeys_1.queryKeys.erc20.symbol(erc20Address, chainId),
|
|
16
|
+
queryFn: async () => {
|
|
17
|
+
if (!erc20Address || !chainId)
|
|
18
|
+
throw new Error("Missing erc20Address or chainId");
|
|
19
|
+
const contract = (0, core_1.getErc20Contract)(erc20Address, chainId);
|
|
20
|
+
return await contract.read.symbol();
|
|
21
|
+
},
|
|
22
|
+
enabled: !lodash_1.default.isNil(erc20Address) && !lodash_1.default.isNil(chainId),
|
|
23
|
+
staleTime: Infinity,
|
|
24
|
+
gcTime: Infinity,
|
|
25
|
+
});
|
|
26
|
+
};
|
|
27
|
+
exports.useErc20Symbol = useErc20Symbol;
|
|
28
|
+
//# sourceMappingURL=useErc20Symbol.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useErc20Symbol.js","sourceRoot":"","sources":["../../../../../src/react/hooks/contracts/erc20/useErc20Symbol.ts"],"names":[],"mappings":";;;;;;AAAA,oDAAsB;AAEtB,2CAA8D;AAC9D,wEAA+D;AAC/D,kDAA8C;AAOvC,MAAM,cAAc,GAAG,CAAC,EAAE,YAAY,EAAE,OAAO,EAAE,QAAQ,EAAwB,EAAE,EAAE;IACxF,MAAM,EAAE,QAAQ,EAAE,UAAU,EAAE,GAAG,IAAA,sCAAe,GAAE,CAAA;IAClD,MAAM,OAAO,GAAG,UAAU,EAAE,EAAE,IAAI,QAAQ,CAAA;IAE1C,OAAO,QAAQ,CAAC;QACZ,QAAQ,EAAE,qBAAS,CAAC,KAAK,CAAC,MAAM,CAAC,YAAY,EAAE,OAAO,CAAC;QACvD,OAAO,EAAE,KAAK,IAAI,EAAE;YAChB,IAAI,CAAC,YAAY,IAAI,CAAC,OAAO;gBAAE,MAAM,IAAI,KAAK,CAAC,iCAAiC,CAAC,CAAA;YAEjF,MAAM,QAAQ,GAAG,IAAA,uBAAgB,EAAC,YAAY,EAAE,OAAO,CAAC,CAAA;YAExD,OAAO,MAAM,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,CAAA;QACvC,CAAC;QACD,OAAO,EAAE,CAAC,gBAAC,CAAC,KAAK,CAAC,YAAY,CAAC,IAAI,CAAC,gBAAC,CAAC,KAAK,CAAC,OAAO,CAAC;QACpD,SAAS,EAAE,QAAQ;QACnB,MAAM,EAAE,QAAQ;KACnB,CAAC,CAAA;AACN,CAAC,CAAA;AAjBY,QAAA,cAAc,kBAiB1B"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { Address } from "viem";
|
|
2
|
+
import { LevrChain } from "../../../../core";
|
|
3
|
+
interface UseTransferErc20Params {
|
|
4
|
+
erc20Address?: Address;
|
|
5
|
+
chainId?: LevrChain;
|
|
6
|
+
toAddress?: Address;
|
|
7
|
+
}
|
|
8
|
+
export declare const useTransferErc20: ({ erc20Address, chainId: _chainId, toAddress }?: UseTransferErc20Params) => import("@tanstack/react-query").UseMutationResult<{
|
|
9
|
+
hash: `0x${string}`;
|
|
10
|
+
}, Error, {
|
|
11
|
+
amount: bigint;
|
|
12
|
+
}, unknown>;
|
|
13
|
+
export {};
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.useTransferErc20 = void 0;
|
|
4
|
+
const core_1 = require("../../../../core");
|
|
5
|
+
const injectedDependencies_1 = require("../../../injectedDependencies");
|
|
6
|
+
const queryKeys_1 = require("../../../queryKeys");
|
|
7
|
+
const useTransferErc20 = ({ erc20Address, chainId: _chainId, toAddress } = {}) => {
|
|
8
|
+
const { useMutation, useChainId, useConnectorClient, useAccount } = (0, injectedDependencies_1.getDependencies)();
|
|
9
|
+
const chainId = useChainId?.() ?? _chainId;
|
|
10
|
+
const { data: walletClient } = useConnectorClient?.() ?? {};
|
|
11
|
+
const { address: userAddress } = useAccount?.() ?? {};
|
|
12
|
+
return useMutation({
|
|
13
|
+
mutationFn: async ({ amount }) => {
|
|
14
|
+
if (!erc20Address || !chainId || !toAddress)
|
|
15
|
+
throw new Error("Missing erc20Address, chainId, or toAddress");
|
|
16
|
+
if (!walletClient)
|
|
17
|
+
throw new Error("Wallet client not available");
|
|
18
|
+
const contract = (0, core_1.getErc20Contract)(erc20Address, chainId, { walletClient });
|
|
19
|
+
const hash = await contract.write.transfer([toAddress, amount]);
|
|
20
|
+
return { hash };
|
|
21
|
+
},
|
|
22
|
+
meta: {
|
|
23
|
+
invalidatesQueries: [
|
|
24
|
+
queryKeys_1.queryKeys.erc20.balance(erc20Address, userAddress, chainId),
|
|
25
|
+
queryKeys_1.queryKeys.erc20.balance(erc20Address, toAddress, chainId),
|
|
26
|
+
],
|
|
27
|
+
},
|
|
28
|
+
});
|
|
29
|
+
};
|
|
30
|
+
exports.useTransferErc20 = useTransferErc20;
|
|
31
|
+
//# sourceMappingURL=useTransferErc20.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useTransferErc20.js","sourceRoot":"","sources":["../../../../../src/react/hooks/contracts/erc20/useTransferErc20.ts"],"names":[],"mappings":";;;AACA,2CAA8D;AAC9D,wEAA+D;AAC/D,kDAA8C;AAQvC,MAAM,gBAAgB,GAAG,CAAC,EAAE,YAAY,EAAE,OAAO,EAAE,QAAQ,EAAE,SAAS,KAA6B,EAAE,EAAE,EAAE;IAC5G,MAAM,EAAE,WAAW,EAAE,UAAU,EAAE,kBAAkB,EAAE,UAAU,EAAE,GAAG,IAAA,sCAAe,GAAE,CAAA;IACrF,MAAM,OAAO,GAAG,UAAU,EAAE,EAAE,IAAI,QAAQ,CAAA;IAC1C,MAAM,EAAE,IAAI,EAAE,YAAY,EAAE,GAAG,kBAAkB,EAAE,EAAE,IAAI,EAAE,CAAA;IAC3D,MAAM,EAAE,OAAO,EAAE,WAAW,EAAE,GAAG,UAAU,EAAE,EAAE,IAAI,EAAE,CAAA;IAErD,OAAO,WAAY,CAAC;QAChB,UAAU,EAAE,KAAK,EAAE,EAAE,MAAM,EAAsB,EAAE,EAAE;YACjD,IAAI,CAAC,YAAY,IAAI,CAAC,OAAO,IAAI,CAAC,SAAS;gBAAE,MAAM,IAAI,KAAK,CAAC,6CAA6C,CAAC,CAAA;YAC3G,IAAI,CAAC,YAAY;gBAAE,MAAM,IAAI,KAAK,CAAC,6BAA6B,CAAC,CAAA;YAEjE,MAAM,QAAQ,GAAG,IAAA,uBAAgB,EAAC,YAAY,EAAE,OAAO,EAAE,EAAE,YAAY,EAAE,CAAC,CAAA;YAC1E,MAAM,IAAI,GAAG,MAAM,QAAQ,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC,CAAA;YAE/D,OAAO,EAAE,IAAI,EAAE,CAAA;QACnB,CAAC;QACD,IAAI,EAAE;YACF,kBAAkB,EAAE;gBAChB,qBAAS,CAAC,KAAK,CAAC,OAAO,CAAC,YAAY,EAAE,WAAW,EAAE,OAAO,CAAC;gBAC3D,qBAAS,CAAC,KAAK,CAAC,OAAO,CAAC,YAAY,EAAE,SAAS,EAAE,OAAO,CAAC;aAC5D;SACJ;KACJ,CAAC,CAAA;AACN,CAAC,CAAA;AAvBY,QAAA,gBAAgB,oBAuB5B"}
|
|
@@ -14,6 +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("./erc20"), exports);
|
|
17
18
|
__exportStar(require("./useContracts"), exports);
|
|
18
19
|
__exportStar(require("./useLevrMarketContractAddresses"), exports);
|
|
19
20
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/react/hooks/contracts/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,iDAA8B;AAC9B,mEAAgD"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/react/hooks/contracts/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,0CAAuB;AACvB,iDAA8B;AAC9B,mEAAgD"}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { UseQueryResult } from "@tanstack/react-query";
|
|
2
|
-
import {
|
|
2
|
+
import { Address } from "viem";
|
|
3
|
+
import { getErc20Contract, getLevrContract, LevrChain } from "../../../core";
|
|
3
4
|
import { UseContractParams } from "../../types";
|
|
4
5
|
export interface UseContractsReturn {
|
|
5
6
|
levrConfigProvider: ReturnType<typeof getLevrContract<"levrConfigProvider">>;
|
|
@@ -108,3 +109,8 @@ export declare const useContractAddresses: (params?: UseContractParams) => {
|
|
|
108
109
|
readonly levrUtil: "0x5309dc7cc514ec962a0b203e57a1b9a79bf8d386";
|
|
109
110
|
readonly usdcToken: "0xf0444a84fcccab8154ee3f14c1a5e7305954d1dd";
|
|
110
111
|
};
|
|
112
|
+
export interface UseErc20ContractParams {
|
|
113
|
+
tokenAddress: Address;
|
|
114
|
+
chainId?: LevrChain;
|
|
115
|
+
}
|
|
116
|
+
export declare const useErc20Contract: (params: UseErc20ContractParams) => UseQueryResult<ReturnType<typeof getErc20Contract>, Error>;
|
|
@@ -3,10 +3,11 @@ 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.useContractAddresses = exports.useContracts = void 0;
|
|
6
|
+
exports.useErc20Contract = exports.useContractAddresses = exports.useContracts = void 0;
|
|
7
7
|
const lodash_1 = __importDefault(require("lodash"));
|
|
8
8
|
const core_1 = require("../../../core");
|
|
9
9
|
const injectedDependencies_1 = require("../../injectedDependencies");
|
|
10
|
+
const queryKeys_1 = require("../../queryKeys");
|
|
10
11
|
const useContracts = (params) => {
|
|
11
12
|
const { useQuery, useAccount, useChainId, useConnectorClient, levrEnv } = (0, injectedDependencies_1.getDependencies)();
|
|
12
13
|
const { chainId: _chainId } = params ?? {};
|
|
@@ -14,7 +15,7 @@ const useContracts = (params) => {
|
|
|
14
15
|
const chainId = useChainId?.() ?? _chainId;
|
|
15
16
|
const { data: walletClient } = useConnectorClient?.() ?? { data: undefined };
|
|
16
17
|
return useQuery({
|
|
17
|
-
queryKey:
|
|
18
|
+
queryKey: queryKeys_1.queryKeys.contracts.all(address, chainId, walletClient?.account?.address),
|
|
18
19
|
queryFn: async () => {
|
|
19
20
|
if (!chainId)
|
|
20
21
|
throw new Error("No chainId");
|
|
@@ -56,4 +57,25 @@ const useContractAddresses = (params) => {
|
|
|
56
57
|
return core_1.levrContractAddresses[levrEnv][chainId];
|
|
57
58
|
};
|
|
58
59
|
exports.useContractAddresses = useContractAddresses;
|
|
60
|
+
const useErc20Contract = (params) => {
|
|
61
|
+
const { useQuery, useAccount, useChainId, useConnectorClient } = (0, injectedDependencies_1.getDependencies)();
|
|
62
|
+
const { tokenAddress, chainId: _chainId } = params;
|
|
63
|
+
const { address } = useAccount?.() ?? { address: null };
|
|
64
|
+
const chainId = useChainId?.() ?? _chainId;
|
|
65
|
+
const { data: walletClient } = useConnectorClient?.() ?? { data: undefined };
|
|
66
|
+
return useQuery({
|
|
67
|
+
queryKey: queryKeys_1.queryKeys.contracts.erc20(tokenAddress, address, chainId, walletClient?.account?.address),
|
|
68
|
+
queryFn: async () => {
|
|
69
|
+
if (!chainId)
|
|
70
|
+
throw new Error("No chainId");
|
|
71
|
+
return (0, core_1.getErc20Contract)(tokenAddress, chainId, { walletClient });
|
|
72
|
+
},
|
|
73
|
+
enabled: !lodash_1.default.isNil(chainId) && !lodash_1.default.isNil(tokenAddress),
|
|
74
|
+
staleTime: Infinity,
|
|
75
|
+
gcTime: Infinity,
|
|
76
|
+
retry: false,
|
|
77
|
+
throwOnError: true,
|
|
78
|
+
});
|
|
79
|
+
};
|
|
80
|
+
exports.useErc20Contract = useErc20Contract;
|
|
59
81
|
//# sourceMappingURL=useContracts.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useContracts.js","sourceRoot":"","sources":["../../../../src/react/hooks/contracts/useContracts.ts"],"names":[],"mappings":";;;;;;AACA,oDAAsB;
|
|
1
|
+
{"version":3,"file":"useContracts.js","sourceRoot":"","sources":["../../../../src/react/hooks/contracts/useContracts.ts"],"names":[],"mappings":"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"}
|
package/dist/react/index.d.ts
CHANGED
package/dist/react/index.js
CHANGED
|
@@ -18,5 +18,6 @@ __exportStar(require("../core"), exports);
|
|
|
18
18
|
__exportStar(require("./hooks"), exports);
|
|
19
19
|
__exportStar(require("./injectedDependencies"), exports);
|
|
20
20
|
__exportStar(require("./queryClient"), exports);
|
|
21
|
+
__exportStar(require("./queryKeys"), exports);
|
|
21
22
|
__exportStar(require("./types"), exports);
|
|
22
23
|
//# sourceMappingURL=index.js.map
|
package/dist/react/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/react/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,0CAAuB;AACvB,0CAAuB;AACvB,yDAAsC;AACtC,gDAA6B;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/react/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,0CAAuB;AACvB,0CAAuB;AACvB,yDAAsC;AACtC,gDAA6B;AAC7B,8CAA2B;AAC3B,0CAAuB"}
|
|
@@ -19,16 +19,17 @@
|
|
|
19
19
|
* After injection, all hooks from this library will use the consumer's live React context and configuration.
|
|
20
20
|
*/
|
|
21
21
|
import { useIdentityToken, usePrivy, useUser } from "@privy-io/react-auth";
|
|
22
|
-
import type { useQuery } from "@tanstack/react-query";
|
|
23
|
-
import type { WalletClient } from "viem";
|
|
22
|
+
import type { useMutation, useQuery } from "@tanstack/react-query";
|
|
23
|
+
import type { Address, WalletClient } from "viem";
|
|
24
24
|
import { LevrChain, LevrEnv } from "../core";
|
|
25
25
|
export interface InjectedDependencies {
|
|
26
26
|
usePrivy: typeof usePrivy;
|
|
27
27
|
useIdentityToken: typeof useIdentityToken;
|
|
28
28
|
useUser: typeof useUser;
|
|
29
29
|
useQuery: typeof useQuery;
|
|
30
|
+
useMutation: typeof useMutation;
|
|
30
31
|
useAccount?: () => {
|
|
31
|
-
address?:
|
|
32
|
+
address?: Address;
|
|
32
33
|
};
|
|
33
34
|
useChainId?: () => LevrChain | undefined;
|
|
34
35
|
useConnectorClient?: () => {
|
|
@@ -57,8 +57,9 @@ function injectDependencies(dependencies) {
|
|
|
57
57
|
!dependencies.useIdentityToken ||
|
|
58
58
|
!dependencies.useUser ||
|
|
59
59
|
!dependencies.useQuery ||
|
|
60
|
+
!dependencies.useMutation ||
|
|
60
61
|
!dependencies.levrEnv) {
|
|
61
|
-
throw new Error("All dependencies must be provided: usePrivy, useIdentityToken, useUser, useQuery, and levrEnv");
|
|
62
|
+
throw new Error("All dependencies must be provided: usePrivy, useIdentityToken, useUser, useQuery, useMutation, and levrEnv");
|
|
62
63
|
}
|
|
63
64
|
injectedDependencies = dependencies;
|
|
64
65
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"injectedDependencies.js","sourceRoot":"","sources":["../../src/react/injectedDependencies.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;;;;;;;;;GAmBG;;
|
|
1
|
+
{"version":3,"file":"injectedDependencies.js","sourceRoot":"","sources":["../../src/react/injectedDependencies.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;;;;;;;;;GAmBG;;AA4CH,gDAuBC;AAaD,0CAWC;AAOD,8DAEC;AAjFD;;GAEG;AACH,IAAI,oBAAoB,GAAgC,IAAI,CAAA;AAE5D;;;;;;;;;;;;;;;;;;;GAmBG;AACH,SAAgB,kBAAkB,CAAC,YAAkC;IACjE,IAAI,oBAAoB,KAAK,IAAI,EAAE,CAAC;QAChC,OAAO,CAAC,IAAI,CACR,oDAAoD;YAChD,iFAAiF,CACxF,CAAA;IACL,CAAC;IAED,uDAAuD;IACvD,IACI,CAAC,YAAY,CAAC,QAAQ;QACtB,CAAC,YAAY,CAAC,gBAAgB;QAC9B,CAAC,YAAY,CAAC,OAAO;QACrB,CAAC,YAAY,CAAC,QAAQ;QACtB,CAAC,YAAY,CAAC,WAAW;QACzB,CAAC,YAAY,CAAC,OAAO,EACvB,CAAC;QACC,MAAM,IAAI,KAAK,CACX,4GAA4G,CAC/G,CAAA;IACL,CAAC;IAED,oBAAoB,GAAG,YAAY,CAAA;AACvC,CAAC;AAED;;;;;;;;;;GAUG;AACH,SAAgB,eAAe;IAC3B,IAAI,oBAAoB,KAAK,IAAI,EAAE,CAAC;QAChC,MAAM,IAAI,KAAK,CACX,uCAAuC;YACnC,6FAA6F;YAC7F,4CAA4C;YAC5C,iGAAiG,CACxG,CAAA;IACL,CAAC;IAED,OAAO,oBAAoB,CAAA;AAC/B,CAAC;AAED;;;;GAIG;AACH,SAAgB,yBAAyB;IACrC,oBAAoB,GAAG,IAAI,CAAA;AAC/B,CAAC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { Address } from "viem";
|
|
2
|
+
import { LevrAuth, LevrChain } from "../core";
|
|
3
|
+
export declare const queryKeys: {
|
|
4
|
+
readonly auth: {
|
|
5
|
+
readonly headers: (levrAuth: LevrAuth, userId?: string, address?: Address) => string[];
|
|
6
|
+
};
|
|
7
|
+
readonly contracts: {
|
|
8
|
+
readonly all: (address?: Address | string | null, chainId?: LevrChain, walletAddress?: Address | string) => (string | LevrChain)[];
|
|
9
|
+
readonly erc20: (tokenAddress: Address, address?: Address | string | null, chainId?: LevrChain, walletAddress?: Address | string) => (string | LevrChain)[];
|
|
10
|
+
};
|
|
11
|
+
readonly erc20: {
|
|
12
|
+
readonly decimals: (tokenAddress?: Address, chainId?: LevrChain) => (string | LevrChain)[];
|
|
13
|
+
readonly symbol: (tokenAddress?: Address, chainId?: LevrChain) => (string | LevrChain)[];
|
|
14
|
+
readonly balance: (tokenAddress?: Address, userAddress?: Address | string | null, chainId?: LevrChain) => (string | LevrChain)[];
|
|
15
|
+
readonly allowance: (tokenAddress?: Address, ownerAddress?: Address | string | null, spenderAddress?: Address | string | null, chainId?: LevrChain) => (string | LevrChain)[];
|
|
16
|
+
};
|
|
17
|
+
};
|
|
@@ -0,0 +1,23 @@
|
|
|
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.queryKeys = void 0;
|
|
7
|
+
const lodash_1 = __importDefault(require("lodash"));
|
|
8
|
+
exports.queryKeys = {
|
|
9
|
+
auth: {
|
|
10
|
+
headers: (levrAuth, userId, address) => ["authHeaders", levrAuth, userId, address].filter((k) => !lodash_1.default.isNil(k)),
|
|
11
|
+
},
|
|
12
|
+
contracts: {
|
|
13
|
+
all: (address, chainId, walletAddress) => ["contracts", address, chainId, walletAddress].filter((k) => !lodash_1.default.isNil(k)),
|
|
14
|
+
erc20: (tokenAddress, address, chainId, walletAddress) => ["erc20Contract", tokenAddress, address, chainId, walletAddress].filter((k) => !lodash_1.default.isNil(k)),
|
|
15
|
+
},
|
|
16
|
+
erc20: {
|
|
17
|
+
decimals: (tokenAddress, chainId) => ["erc20", "decimals", tokenAddress, chainId].filter((k) => !lodash_1.default.isNil(k)),
|
|
18
|
+
symbol: (tokenAddress, chainId) => ["erc20", "symbol", tokenAddress, chainId].filter((k) => !lodash_1.default.isNil(k)),
|
|
19
|
+
balance: (tokenAddress, userAddress, chainId) => ["erc20", "balance", tokenAddress, userAddress, chainId].filter((k) => !lodash_1.default.isNil(k)),
|
|
20
|
+
allowance: (tokenAddress, ownerAddress, spenderAddress, chainId) => ["erc20", "allowance", tokenAddress, ownerAddress, spenderAddress, chainId].filter((k) => !lodash_1.default.isNil(k)),
|
|
21
|
+
},
|
|
22
|
+
};
|
|
23
|
+
//# sourceMappingURL=queryKeys.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"queryKeys.js","sourceRoot":"","sources":["../../src/react/queryKeys.ts"],"names":[],"mappings":";;;;;;AAAA,oDAAsB;AAIT,QAAA,SAAS,GAAG;IACrB,IAAI,EAAE;QACF,OAAO,EAAE,CAAC,QAAkB,EAAE,MAAe,EAAE,OAAiB,EAAE,EAAE,CAChE,CAAC,aAAa,EAAE,QAAQ,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,gBAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;KAC5E;IACD,SAAS,EAAE;QACP,GAAG,EAAE,CAAC,OAAiC,EAAE,OAAmB,EAAE,aAAgC,EAAE,EAAE,CAC9F,CAAC,WAAW,EAAE,OAAO,EAAE,OAAO,EAAE,aAAa,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,gBAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QAC7E,KAAK,EAAE,CACH,YAAqB,EACrB,OAAiC,EACjC,OAAmB,EACnB,aAAgC,EAClC,EAAE,CAAC,CAAC,eAAe,EAAE,YAAY,EAAE,OAAO,EAAE,OAAO,EAAE,aAAa,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,gBAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;KACnG;IACD,KAAK,EAAE;QACH,QAAQ,EAAE,CAAC,YAAsB,EAAE,OAAmB,EAAE,EAAE,CACtD,CAAC,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,OAAO,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,gBAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QAC3E,MAAM,EAAE,CAAC,YAAsB,EAAE,OAAmB,EAAE,EAAE,CACpD,CAAC,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,OAAO,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,gBAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QACzE,OAAO,EAAE,CAAC,YAAsB,EAAE,WAAqC,EAAE,OAAmB,EAAE,EAAE,CAC5F,CAAC,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,WAAW,EAAE,OAAO,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,gBAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QACvF,SAAS,EAAE,CACP,YAAsB,EACtB,YAAsC,EACtC,cAAwC,EACxC,OAAmB,EACrB,EAAE,CAAC,CAAC,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,YAAY,EAAE,cAAc,EAAE,OAAO,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,gBAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;KAC9G;CACK,CAAA"}
|
|
@@ -51,7 +51,7 @@ declare class RedisClientManager {
|
|
|
51
51
|
init(options?: RedisOptions): void;
|
|
52
52
|
get primaryClient(): Redis;
|
|
53
53
|
get replicaClient(): Redis;
|
|
54
|
-
duplicateClient: () => Redis;
|
|
54
|
+
duplicateClient: (clientName: string) => Redis;
|
|
55
55
|
}
|
|
56
56
|
export declare const redisClientManager: RedisClientManager;
|
|
57
57
|
export {};
|
|
@@ -46,9 +46,15 @@ class RedisClientManager {
|
|
|
46
46
|
this.replicaClients = [];
|
|
47
47
|
this.initialized = false;
|
|
48
48
|
this.dbIndex = 0;
|
|
49
|
-
this.duplicateClient = () => {
|
|
50
|
-
const client = this.primaryClient;
|
|
51
|
-
client.select(this.dbIndex);
|
|
49
|
+
this.duplicateClient = (clientName) => {
|
|
50
|
+
const client = this.primaryClient.duplicate();
|
|
51
|
+
void client.select(this.dbIndex);
|
|
52
|
+
client.on("error", (err) => {
|
|
53
|
+
winston_1.default.error(`Redis ${clientName} client error:`, err);
|
|
54
|
+
});
|
|
55
|
+
client.on("connect", () => {
|
|
56
|
+
winston_1.default.info(`Connected to Redis ${clientName} client`);
|
|
57
|
+
});
|
|
52
58
|
return client;
|
|
53
59
|
};
|
|
54
60
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"redis.js","sourceRoot":"","sources":["../../../src/server/config/redis.ts"],"names":[],"mappings":";;;;;;AAAA,yBAAsB;AACtB,sDAAkD;AAClD,wBAA+B;AAC/B,qCAAmC;AACnC,wDAA8B;AAE9B,IAAY,OAOX;AAPD,WAAY,OAAO;IACf,yCAAU,CAAA;IACV,+CAAa,CAAA;IACb,qCAAQ,CAAA;IACR,iEAAsB,CAAA;IACtB,mDAAe,CAAA;IACf,mCAAO,CAAA;AACX,CAAC,EAPW,OAAO,uBAAP,OAAO,QAOlB;AAED;;;;;;;;;;;;;;;;;;;;;GAqBG;AACH,MAAM,kBAAkB;IAAxB;QACY,mBAAc,GAAiB,IAAI,CAAA;QACnC,mBAAc,GAAY,EAAE,CAAA;QAC5B,gBAAW,GAAG,KAAK,CAAA;QACnB,YAAO,GAAG,CAAC,CAAA;QAkEnB,oBAAe,GAAG,
|
|
1
|
+
{"version":3,"file":"redis.js","sourceRoot":"","sources":["../../../src/server/config/redis.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,6 +1,2 @@
|
|
|
1
1
|
import Redis from "ioredis";
|
|
2
|
-
|
|
3
|
-
export declare const LEVR_GAME_UPDATES = "game_updates";
|
|
4
|
-
export declare const LEVR_MARKET_UPDATES = "market_updates";
|
|
5
|
-
export declare const publishToGameUpdatesChannel: (redis: Redis, data: LevrScores) => Promise<void>;
|
|
6
|
-
export declare const publishToMarketUpdatesChannel: (redis: Redis, data: Odds) => Promise<void>;
|
|
2
|
+
export declare const publishToChannel: (redis: Redis, channel: string, data: unknown) => Promise<void>;
|
|
@@ -1,20 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
3
|
+
exports.publishToChannel = void 0;
|
|
4
4
|
const cache_keys_utils_1 = require("./cache.keys.utils");
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
// add different types as we need
|
|
8
|
-
const publishToGameUpdatesChannel = async (redis, data) => {
|
|
9
|
-
const success = (await redis.publish(exports.LEVR_GAME_UPDATES, JSON.stringify(data)));
|
|
5
|
+
const publishToChannel = async (redis, channel, data) => {
|
|
6
|
+
const success = (await redis.publish(channel, JSON.stringify(data)));
|
|
10
7
|
if (success <= cache_keys_utils_1.RedisNumStates.failure)
|
|
11
|
-
throw Error(
|
|
8
|
+
throw Error(`Failed to publish to redis channel ${channel}`);
|
|
12
9
|
};
|
|
13
|
-
exports.
|
|
14
|
-
const publishToMarketUpdatesChannel = async (redis, data) => {
|
|
15
|
-
const success = (await redis.publish(exports.LEVR_MARKET_UPDATES, JSON.stringify(data)));
|
|
16
|
-
if (success <= cache_keys_utils_1.RedisNumStates.failure)
|
|
17
|
-
throw Error("Failed to publish to redis channel");
|
|
18
|
-
};
|
|
19
|
-
exports.publishToMarketUpdatesChannel = publishToMarketUpdatesChannel;
|
|
10
|
+
exports.publishToChannel = publishToChannel;
|
|
20
11
|
//# sourceMappingURL=channels.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"channels.js","sourceRoot":"","sources":["../../../../src/server/oracle/redis-cache-manager/channels.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"channels.js","sourceRoot":"","sources":["../../../../src/server/oracle/redis-cache-manager/channels.ts"],"names":[],"mappings":";;;AACA,yDAAmD;AAE5C,MAAM,gBAAgB,GAAG,KAAK,EAAE,KAAY,EAAE,OAAe,EAAE,IAAa,EAAiB,EAAE;IAClG,MAAM,OAAO,GAAG,CAAC,MAAM,KAAK,CAAC,OAAO,CAAC,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAmB,CAAA;IACtF,IAAI,OAAO,IAAI,iCAAc,CAAC,OAAO;QAAE,MAAM,KAAK,CAAC,sCAAsC,OAAO,EAAE,CAAC,CAAA;AACvG,CAAC,CAAA;AAHY,QAAA,gBAAgB,oBAG5B"}
|
|
@@ -18,4 +18,5 @@ __exportStar(require("./cloudflare.service"), exports);
|
|
|
18
18
|
__exportStar(require("./crypto.service"), exports);
|
|
19
19
|
__exportStar(require("./hmac.service"), exports);
|
|
20
20
|
__exportStar(require("./privy.service"), exports);
|
|
21
|
+
__exportStar(require("./presigned.urls"), exports);
|
|
21
22
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/server/services/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,uDAAoC;AACpC,mDAAgC;AAChC,iDAA8B;AAC9B,kDAA+B"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/server/services/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,uDAAoC;AACpC,mDAAgC;AAChC,iDAA8B;AAC9B,kDAA+B;AAC/B,mDAAgC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Handles AWS S3 presigned URL generation
|
|
3
|
+
*/
|
|
4
|
+
declare class PresignedUrlService {
|
|
5
|
+
private initialized;
|
|
6
|
+
private s3?;
|
|
7
|
+
init(): void;
|
|
8
|
+
generatePresignedImageUrl(keyId: string): Promise<string>;
|
|
9
|
+
}
|
|
10
|
+
export declare const presignedUrlService: PresignedUrlService;
|
|
11
|
+
export {};
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.presignedUrlService = void 0;
|
|
4
|
+
const client_s3_1 = require("@aws-sdk/client-s3");
|
|
5
|
+
const s3_request_presigner_1 = require("@aws-sdk/s3-request-presigner");
|
|
6
|
+
const core_1 = require("../../core");
|
|
7
|
+
const config_1 = require("../config");
|
|
8
|
+
/**
|
|
9
|
+
* Handles AWS S3 presigned URL generation
|
|
10
|
+
*/
|
|
11
|
+
class PresignedUrlService {
|
|
12
|
+
constructor() {
|
|
13
|
+
this.initialized = false;
|
|
14
|
+
}
|
|
15
|
+
init() {
|
|
16
|
+
if (this.initialized)
|
|
17
|
+
return;
|
|
18
|
+
this.initialized = true;
|
|
19
|
+
const { AWS_ACCESS_KEY_ID, AWS_SECRET_ACCESS_KEY, AWS_REGION } = core_1.Config.init(config_1.awsCredsSchema);
|
|
20
|
+
this.s3 = new client_s3_1.S3Client({
|
|
21
|
+
region: AWS_REGION,
|
|
22
|
+
credentials: {
|
|
23
|
+
accessKeyId: AWS_ACCESS_KEY_ID,
|
|
24
|
+
secretAccessKey: AWS_SECRET_ACCESS_KEY,
|
|
25
|
+
},
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
async generatePresignedImageUrl(keyId) {
|
|
29
|
+
if (!this.s3) {
|
|
30
|
+
throw new Error("S3 client not initialized. Call presignedUrlService.init().");
|
|
31
|
+
}
|
|
32
|
+
const command = new client_s3_1.GetObjectCommand({
|
|
33
|
+
Bucket: "levr-v1-assets-dev",
|
|
34
|
+
Key: keyId,
|
|
35
|
+
});
|
|
36
|
+
const imageUrl = await (0, s3_request_presigner_1.getSignedUrl)(this.s3, command, { expiresIn: 172800 }); // 48 hour expiry
|
|
37
|
+
return imageUrl;
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
exports.presignedUrlService = new PresignedUrlService();
|
|
41
|
+
//# sourceMappingURL=presigned.urls.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"presigned.urls.js","sourceRoot":"","sources":["../../../src/server/services/presigned.urls.ts"],"names":[],"mappings":";;;AAAA,kDAA+D;AAC/D,wEAA4D;AAC5D,qCAAmC;AACnC,sCAA0C;AAE1C;;GAEG;AACH,MAAM,mBAAmB;IAAzB;QACY,gBAAW,GAAG,KAAK,CAAA;IA8B/B,CAAC;IA3BG,IAAI;QACA,IAAI,IAAI,CAAC,WAAW;YAAE,OAAM;QAC5B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAA;QAEvB,MAAM,EAAE,iBAAiB,EAAE,qBAAqB,EAAE,UAAU,EAAE,GAAG,aAAM,CAAC,IAAI,CAAC,uBAAc,CAAC,CAAA;QAC5F,IAAI,CAAC,EAAE,GAAG,IAAI,oBAAQ,CAAC;YACnB,MAAM,EAAE,UAAU;YAClB,WAAW,EAAE;gBACT,WAAW,EAAE,iBAAiB;gBAC9B,eAAe,EAAE,qBAAqB;aACzC;SACJ,CAAC,CAAA;IACN,CAAC;IAED,KAAK,CAAC,yBAAyB,CAAC,KAAa;QACzC,IAAI,CAAC,IAAI,CAAC,EAAE,EAAE,CAAC;YACX,MAAM,IAAI,KAAK,CAAC,6DAA6D,CAAC,CAAA;QAClF,CAAC;QAED,MAAM,OAAO,GAAG,IAAI,4BAAgB,CAAC;YACjC,MAAM,EAAE,oBAAoB;YAC5B,GAAG,EAAE,KAAK;SACb,CAAC,CAAA;QAEF,MAAM,QAAQ,GAAG,MAAM,IAAA,mCAAY,EAAC,IAAI,CAAC,EAAE,EAAE,OAAO,EAAE,EAAE,SAAS,EAAE,MAAM,EAAE,CAAC,CAAA,CAAC,iBAAiB;QAC9F,OAAO,QAAQ,CAAA;IACnB,CAAC;CACJ;AAEY,QAAA,mBAAmB,GAAG,IAAI,mBAAmB,EAAE,CAAA"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@levrbet/shared",
|
|
3
|
-
"version": "0.2.
|
|
3
|
+
"version": "0.2.45",
|
|
4
4
|
"main": "dist/index.js",
|
|
5
5
|
"types": "dist/index.d.ts",
|
|
6
6
|
"exports": {
|
|
@@ -30,13 +30,14 @@
|
|
|
30
30
|
],
|
|
31
31
|
"sideEffects": false,
|
|
32
32
|
"scripts": {
|
|
33
|
-
"build": "npm run clean && npx
|
|
33
|
+
"build": "npm run clean && npx tsc",
|
|
34
34
|
"dev": "npm run build && npm pack",
|
|
35
|
-
"
|
|
36
|
-
"
|
|
37
|
-
"
|
|
35
|
+
"clean": "rm -rf dist .tsbuildinfo",
|
|
36
|
+
"prepublishOnly": "npm run build",
|
|
37
|
+
"test-get-healthy-indexer": "tsx src/core/indexers/indexers.service.ts"
|
|
38
38
|
},
|
|
39
39
|
"peerDependencies": {
|
|
40
|
+
"@prisma/client": "^6.0.0",
|
|
40
41
|
"@privy-io/react-auth": ">=3.0.0",
|
|
41
42
|
"@tanstack/react-query": ">=5.0.0",
|
|
42
43
|
"@types/react": ">=18.0.0",
|
|
@@ -69,14 +70,16 @@
|
|
|
69
70
|
"cpx": "^1.5.0",
|
|
70
71
|
"cross-fetch": "^4.1.0",
|
|
71
72
|
"mkdirp": "^3.0.1",
|
|
72
|
-
"prisma": "^6.
|
|
73
|
+
"prisma": "^6.19.0",
|
|
73
74
|
"react": ">=18.0.0",
|
|
74
75
|
"tsx": "^4.20.6",
|
|
75
76
|
"typescript": "^5.9.3"
|
|
76
77
|
},
|
|
77
78
|
"dependencies": {
|
|
78
79
|
"@aws-sdk/client-kms": "^3.913.0",
|
|
80
|
+
"@aws-sdk/client-s3": "^3.926.0",
|
|
79
81
|
"@aws-sdk/client-sts": "^3.913.0",
|
|
82
|
+
"@aws-sdk/s3-request-presigner": "^3.926.0",
|
|
80
83
|
"@opentelemetry/api": "^1.9.0",
|
|
81
84
|
"@opentelemetry/auto-instrumentations-node": "0.65.0",
|
|
82
85
|
"@opentelemetry/exporter-metrics-otlp-http": "^0.206.0",
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export * from "./index"
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export * from "./index"
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export * from "./default"
|