@frak-labs/core-sdk 0.1.0-beta.afa252b0 → 0.1.0-beta.dd44738a

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 (77) hide show
  1. package/cdn/bundle.js +3 -3
  2. package/dist/bundle.cjs +1 -1
  3. package/dist/bundle.js +1 -1
  4. package/dist/index.cjs +1 -1
  5. package/dist/index.js +1 -1
  6. package/package.json +4 -2
  7. package/src/actions/displayEmbeddedWallet.ts +20 -0
  8. package/src/actions/displayModal.ts +131 -0
  9. package/src/actions/getProductInformation.ts +14 -0
  10. package/src/actions/index.ts +29 -0
  11. package/src/actions/openSso.ts +116 -0
  12. package/src/actions/prepareSso.ts +48 -0
  13. package/src/actions/referral/processReferral.ts +230 -0
  14. package/src/actions/referral/referralInteraction.ts +57 -0
  15. package/src/actions/sendInteraction.ts +32 -0
  16. package/src/actions/trackPurchaseStatus.ts +53 -0
  17. package/src/actions/watchWalletStatus.ts +94 -0
  18. package/src/actions/wrapper/modalBuilder.ts +212 -0
  19. package/src/actions/wrapper/sendTransaction.ts +62 -0
  20. package/src/actions/wrapper/siweAuthenticate.ts +94 -0
  21. package/src/bundle.ts +3 -0
  22. package/src/clients/DebugInfo.ts +182 -0
  23. package/src/clients/createIFrameFrakClient.ts +287 -0
  24. package/src/clients/index.ts +3 -0
  25. package/src/clients/setupClient.ts +71 -0
  26. package/src/clients/transports/iframeLifecycleManager.ts +88 -0
  27. package/src/constants/interactionTypes.ts +44 -0
  28. package/src/constants/locales.ts +14 -0
  29. package/src/constants/productTypes.ts +33 -0
  30. package/src/index.ts +103 -0
  31. package/src/interactions/index.ts +5 -0
  32. package/src/interactions/pressEncoder.ts +53 -0
  33. package/src/interactions/purchaseEncoder.ts +94 -0
  34. package/src/interactions/referralEncoder.ts +47 -0
  35. package/src/interactions/retailEncoder.ts +37 -0
  36. package/src/interactions/webshopEncoder.ts +30 -0
  37. package/src/types/client.ts +14 -0
  38. package/src/types/compression.ts +22 -0
  39. package/src/types/config.ts +111 -0
  40. package/src/types/context.ts +13 -0
  41. package/src/types/index.ts +70 -0
  42. package/src/types/lifecycle/client.ts +46 -0
  43. package/src/types/lifecycle/iframe.ts +35 -0
  44. package/src/types/lifecycle/index.ts +2 -0
  45. package/src/types/rpc/displayModal.ts +84 -0
  46. package/src/types/rpc/embedded/index.ts +68 -0
  47. package/src/types/rpc/embedded/loggedIn.ts +55 -0
  48. package/src/types/rpc/embedded/loggedOut.ts +28 -0
  49. package/src/types/rpc/interaction.ts +43 -0
  50. package/src/types/rpc/modal/final.ts +46 -0
  51. package/src/types/rpc/modal/generic.ts +46 -0
  52. package/src/types/rpc/modal/index.ts +20 -0
  53. package/src/types/rpc/modal/login.ts +32 -0
  54. package/src/types/rpc/modal/openSession.ts +25 -0
  55. package/src/types/rpc/modal/siweAuthenticate.ts +37 -0
  56. package/src/types/rpc/modal/transaction.ts +33 -0
  57. package/src/types/rpc/productInformation.ts +59 -0
  58. package/src/types/rpc/sso.ts +80 -0
  59. package/src/types/rpc/walletStatus.ts +35 -0
  60. package/src/types/rpc.ts +158 -0
  61. package/src/types/transport.ts +34 -0
  62. package/src/utils/FrakContext.ts +152 -0
  63. package/src/utils/compression/b64.ts +29 -0
  64. package/src/utils/compression/compress.ts +11 -0
  65. package/src/utils/compression/decompress.ts +11 -0
  66. package/src/utils/compression/index.ts +3 -0
  67. package/src/utils/computeProductId.ts +11 -0
  68. package/src/utils/constants.ts +4 -0
  69. package/src/utils/formatAmount.ts +18 -0
  70. package/src/utils/getCurrencyAmountKey.ts +15 -0
  71. package/src/utils/getSupportedCurrency.ts +14 -0
  72. package/src/utils/getSupportedLocale.ts +16 -0
  73. package/src/utils/iframeHelper.ts +142 -0
  74. package/src/utils/index.ts +21 -0
  75. package/src/utils/sso.ts +119 -0
  76. package/src/utils/ssoUrlListener.ts +60 -0
  77. package/src/utils/trackEvent.ts +26 -0
@@ -0,0 +1,287 @@
1
+ import {
2
+ FrakRpcError,
3
+ type RpcClient,
4
+ RpcErrorCodes,
5
+ createRpcClient,
6
+ } from "@frak-labs/frame-connector";
7
+ import { createClientCompressionMiddleware } from "@frak-labs/frame-connector/middleware";
8
+ import { OpenPanel } from "@openpanel/web";
9
+ import type { FrakLifecycleEvent } from "../types";
10
+ import type { FrakClient } from "../types/client";
11
+ import type { FrakWalletSdkConfig } from "../types/config";
12
+ import type { IFrameRpcSchema } from "../types/rpc";
13
+ import { BACKUP_KEY } from "../utils/constants";
14
+ import { setupSsoUrlListener } from "../utils/ssoUrlListener";
15
+ import { DebugInfoGatherer } from "./DebugInfo";
16
+ import {
17
+ type IframeLifecycleManager,
18
+ createIFrameLifecycleManager,
19
+ } from "./transports/iframeLifecycleManager";
20
+
21
+ type SdkRpcClient = RpcClient<IFrameRpcSchema, FrakLifecycleEvent>;
22
+
23
+ /**
24
+ * Create a new iframe Frak client
25
+ * @param args
26
+ * @param args.config - The configuration to use for the Frak Wallet SDK
27
+ * @param args.iframe - The iframe to use for the communication
28
+ * @returns The created Frak Client
29
+ *
30
+ * @example
31
+ * const frakConfig: FrakWalletSdkConfig = {
32
+ * metadata: {
33
+ * name: "My app title",
34
+ * },
35
+ * }
36
+ * const iframe = await createIframe({ config: frakConfig });
37
+ * const client = createIFrameFrakClient({ config: frakConfig, iframe });
38
+ */
39
+ export function createIFrameFrakClient({
40
+ config,
41
+ iframe,
42
+ }: {
43
+ config: FrakWalletSdkConfig;
44
+ iframe: HTMLIFrameElement;
45
+ }): FrakClient {
46
+ const frakWalletUrl = config?.walletUrl ?? "https://wallet.frak.id";
47
+
48
+ // Create lifecycle manager
49
+ const lifecycleManager = createIFrameLifecycleManager({ iframe });
50
+
51
+ // Create our debug info gatherer
52
+ const debugInfo = new DebugInfoGatherer(config, iframe);
53
+
54
+ // Validate iframe
55
+ if (!iframe.contentWindow) {
56
+ throw new FrakRpcError(
57
+ RpcErrorCodes.configError,
58
+ "The iframe does not have a content window"
59
+ );
60
+ }
61
+
62
+ // Create RPC client with middleware and lifecycle handlers
63
+ const rpcClient = createRpcClient<IFrameRpcSchema, FrakLifecycleEvent>({
64
+ emittingTransport: iframe.contentWindow,
65
+ listeningTransport: window,
66
+ targetOrigin: frakWalletUrl,
67
+ // Add compression middleware to handle request/response compression
68
+ middleware: [
69
+ // Ensure we are connected before sending request
70
+ {
71
+ async onRequest(_message, ctx) {
72
+ // Ensure the iframe is connected
73
+ const isConnected = await lifecycleManager.isConnected;
74
+ if (!isConnected) {
75
+ throw new FrakRpcError(
76
+ RpcErrorCodes.clientNotConnected,
77
+ "The iframe provider isn't connected yet"
78
+ );
79
+ }
80
+ return ctx;
81
+ },
82
+ },
83
+ createClientCompressionMiddleware(),
84
+ // Save debug info
85
+ {
86
+ onRequest(message, ctx) {
87
+ debugInfo.setLastRequest(message);
88
+ return ctx;
89
+ },
90
+ onResponse(message, response) {
91
+ debugInfo.setLastResponse(message, response);
92
+ return response;
93
+ },
94
+ },
95
+ ],
96
+ // Add lifecycle handlers to process iframe lifecycle events
97
+ lifecycleHandlers: {
98
+ iframeLifecycle: async (event, _context) => {
99
+ // Delegate to lifecycle manager (cast for type compatibility)
100
+ await lifecycleManager.handleEvent(event);
101
+ },
102
+ },
103
+ });
104
+
105
+ // Setup heartbeat
106
+ const stopHeartbeat = setupHeartbeat(rpcClient, lifecycleManager);
107
+
108
+ // Build our destroy function
109
+ const destroy = async () => {
110
+ // Stop heartbeat
111
+ stopHeartbeat();
112
+ // Cleanup the RPC client
113
+ rpcClient.cleanup();
114
+ // Remove the iframe
115
+ iframe.remove();
116
+ };
117
+
118
+ // Init open panel
119
+ let openPanel: OpenPanel | undefined;
120
+ if (
121
+ process.env.OPEN_PANEL_API_URL &&
122
+ process.env.OPEN_PANEL_SDK_CLIENT_ID
123
+ ) {
124
+ console.log("[Frak SDK] Initializing OpenPanel");
125
+ openPanel = new OpenPanel({
126
+ apiUrl: process.env.OPEN_PANEL_API_URL,
127
+ clientId: process.env.OPEN_PANEL_SDK_CLIENT_ID,
128
+ trackScreenViews: true,
129
+ trackOutgoingLinks: true,
130
+ trackAttributes: false,
131
+ // We use a filter to ensure we got the open panel instance initialized
132
+ // A bit hacky, but this way we are sure that we got everything needed for the first event ever sent
133
+ filter: ({ type, payload }) => {
134
+ if (type !== "track") return true;
135
+ if (!payload?.properties) return true;
136
+
137
+ // Check if we we got the properties once initialized
138
+ if (!("sdkVersion" in payload.properties)) {
139
+ payload.properties = {
140
+ ...payload.properties,
141
+ sdkVersion: process.env.SDK_VERSION,
142
+ };
143
+ }
144
+
145
+ return true;
146
+ },
147
+ });
148
+ openPanel.setGlobalProperties({
149
+ sdkVersion: process.env.SDK_VERSION,
150
+ });
151
+ openPanel.init();
152
+ }
153
+
154
+ // Perform the post connection setup
155
+ const waitForSetup = postConnectionSetup({
156
+ config,
157
+ rpcClient,
158
+ lifecycleManager,
159
+ }).then(() => debugInfo.updateSetupStatus(true));
160
+
161
+ return {
162
+ config,
163
+ debugInfo,
164
+ waitForConnection: lifecycleManager.isConnected,
165
+ waitForSetup,
166
+ request: rpcClient.request,
167
+ listenerRequest: rpcClient.listen,
168
+ destroy,
169
+ openPanel,
170
+ };
171
+ }
172
+
173
+ /**
174
+ * Setup the heartbeat
175
+ * @param rpcClient - RPC client to send lifecycle events
176
+ * @param lifecycleManager - Lifecycle manager to track connection
177
+ */
178
+ function setupHeartbeat(
179
+ rpcClient: SdkRpcClient,
180
+ lifecycleManager: IframeLifecycleManager
181
+ ) {
182
+ const HEARTBEAT_INTERVAL = 1_000; // Send heartbeat every 100ms until we are connected
183
+ const HEARTBEAT_TIMEOUT = 30_000; // 30 seconds timeout
184
+ let heartbeatInterval: NodeJS.Timeout;
185
+ let timeoutId: NodeJS.Timeout;
186
+
187
+ const sendHeartbeat = () =>
188
+ rpcClient.sendLifecycle({
189
+ clientLifecycle: "heartbeat",
190
+ });
191
+
192
+ // Start sending heartbeats
193
+ async function startHeartbeat() {
194
+ sendHeartbeat(); // Send initial heartbeat
195
+ heartbeatInterval = setInterval(sendHeartbeat, HEARTBEAT_INTERVAL);
196
+
197
+ // Set up timeout
198
+ timeoutId = setTimeout(() => {
199
+ stopHeartbeat();
200
+ console.log("Heartbeat timeout: connection failed");
201
+ }, HEARTBEAT_TIMEOUT);
202
+
203
+ // Once connected, stop it
204
+ await lifecycleManager.isConnected;
205
+
206
+ // We are now connected, stop the heartbeat
207
+ stopHeartbeat();
208
+ }
209
+
210
+ // Stop sending heartbeats
211
+ function stopHeartbeat() {
212
+ if (heartbeatInterval) {
213
+ clearInterval(heartbeatInterval);
214
+ }
215
+ if (timeoutId) {
216
+ clearTimeout(timeoutId);
217
+ }
218
+ }
219
+
220
+ startHeartbeat();
221
+
222
+ // Return cleanup function
223
+ return stopHeartbeat;
224
+ }
225
+
226
+ /**
227
+ * Perform the post connection setup
228
+ * @param config - SDK configuration
229
+ * @param rpcClient - RPC client to send lifecycle events
230
+ * @param lifecycleManager - Lifecycle manager to track connection
231
+ */
232
+ async function postConnectionSetup({
233
+ config,
234
+ rpcClient,
235
+ lifecycleManager,
236
+ }: {
237
+ config: FrakWalletSdkConfig;
238
+ rpcClient: SdkRpcClient;
239
+ lifecycleManager: IframeLifecycleManager;
240
+ }): Promise<void> {
241
+ // Wait for the handler to be connected
242
+ await lifecycleManager.isConnected;
243
+
244
+ // Setup SSO URL listener to detect and forward SSO redirects
245
+ // This checks for ?sso= parameter and forwards compressed data to iframe
246
+ setupSsoUrlListener(rpcClient, lifecycleManager.isConnected);
247
+
248
+ // Push raw CSS if needed
249
+ async function pushCss() {
250
+ const cssLink = config.customizations?.css;
251
+ if (!cssLink) return;
252
+
253
+ const message = {
254
+ clientLifecycle: "modal-css" as const,
255
+ data: { cssLink },
256
+ };
257
+ rpcClient.sendLifecycle(message);
258
+ }
259
+
260
+ // Push i18n if needed
261
+ async function pushI18n() {
262
+ const i18n = config.customizations?.i18n;
263
+ if (!i18n) return;
264
+
265
+ const message = {
266
+ clientLifecycle: "modal-i18n" as const,
267
+ data: { i18n },
268
+ };
269
+ rpcClient.sendLifecycle(message);
270
+ }
271
+
272
+ // Push local backup if needed
273
+ async function pushBackup() {
274
+ if (typeof window === "undefined") return;
275
+
276
+ const backup = window.localStorage.getItem(BACKUP_KEY);
277
+ if (!backup) return;
278
+
279
+ const message = {
280
+ clientLifecycle: "restore-backup" as const,
281
+ data: { backup },
282
+ };
283
+ rpcClient.sendLifecycle(message);
284
+ }
285
+
286
+ await Promise.allSettled([pushCss(), pushI18n(), pushBackup()]);
287
+ }
@@ -0,0 +1,3 @@
1
+ export { createIFrameFrakClient } from "./createIFrameFrakClient";
2
+ export { setupClient } from "./setupClient";
3
+ export { DebugInfoGatherer } from "./DebugInfo";
@@ -0,0 +1,71 @@
1
+ import { createIFrameFrakClient } from "../clients";
2
+ import type { FrakClient, FrakWalletSdkConfig } from "../types";
3
+ import { createIframe, getSupportedCurrency } from "../utils";
4
+
5
+ /**
6
+ * Directly setup the Frak client with an iframe
7
+ * Return when the FrakClient is ready (setup and communication estbalished with the wallet)
8
+ *
9
+ * @param config - The configuration to use for the Frak Wallet SDK
10
+ * @returns a Promise with the Frak Client
11
+ *
12
+ * @example
13
+ * const frakConfig: FrakWalletSdkConfig = {
14
+ * metadata: {
15
+ * name: "My app title",
16
+ * },
17
+ * }
18
+ * const client = await setupClient({ config: frakConfig });
19
+ */
20
+ export async function setupClient({
21
+ config,
22
+ }: { config: FrakWalletSdkConfig }): Promise<FrakClient | undefined> {
23
+ // Prepare the config
24
+ const preparedConfig = prepareConfig(config);
25
+
26
+ // Create our iframe
27
+ const iframe = await createIframe({
28
+ config: preparedConfig,
29
+ });
30
+
31
+ if (!iframe) {
32
+ console.error("Failed to create iframe");
33
+ return;
34
+ }
35
+
36
+ // Create our client
37
+ const client = createIFrameFrakClient({
38
+ config: preparedConfig,
39
+ iframe,
40
+ });
41
+
42
+ // Wait for the client to be all setup
43
+ await client.waitForSetup;
44
+
45
+ // Wait for the connection to be established
46
+ const waitForConnection = await client.waitForConnection;
47
+ if (!waitForConnection) {
48
+ console.error("Failed to connect to client");
49
+ return;
50
+ }
51
+
52
+ return client;
53
+ }
54
+
55
+ /**
56
+ * Prepare the config for the Frak Client
57
+ * @param config - The configuration to use for the Frak Wallet SDK
58
+ * @returns The prepared configuration with the supported currency
59
+ */
60
+ function prepareConfig(config: FrakWalletSdkConfig): FrakWalletSdkConfig {
61
+ // Get the supported currency (e.g. "eur")
62
+ const supportedCurrency = getSupportedCurrency(config.metadata?.currency);
63
+
64
+ return {
65
+ ...config,
66
+ metadata: {
67
+ ...config.metadata,
68
+ currency: supportedCurrency,
69
+ },
70
+ };
71
+ }
@@ -0,0 +1,88 @@
1
+ import { Deferred } from "@frak-labs/frame-connector";
2
+ import type { FrakLifecycleEvent } from "../../types";
3
+ import { BACKUP_KEY } from "../../utils/constants";
4
+ import { changeIframeVisibility } from "../../utils/iframeHelper";
5
+
6
+ /** @ignore */
7
+ export type IframeLifecycleManager = {
8
+ isConnected: Promise<boolean>;
9
+ handleEvent: (messageEvent: FrakLifecycleEvent) => Promise<void>;
10
+ };
11
+
12
+ /**
13
+ * Create a new iframe lifecycle handler
14
+ * @ignore
15
+ */
16
+ export function createIFrameLifecycleManager({
17
+ iframe,
18
+ }: { iframe: HTMLIFrameElement }): IframeLifecycleManager {
19
+ // Create the isConnected listener
20
+ const isConnectedDeferred = new Deferred<boolean>();
21
+
22
+ // Build the handler itself
23
+ const handler = async (messageEvent: FrakLifecycleEvent) => {
24
+ if (!("iframeLifecycle" in messageEvent)) return;
25
+
26
+ const { iframeLifecycle: event, data } = messageEvent;
27
+
28
+ switch (event) {
29
+ // Resolve the isConnected promise
30
+ case "connected":
31
+ isConnectedDeferred.resolve(true);
32
+ break;
33
+ // Perform a frak backup
34
+ case "do-backup":
35
+ if (data.backup) {
36
+ localStorage.setItem(BACKUP_KEY, data.backup);
37
+ } else {
38
+ localStorage.removeItem(BACKUP_KEY);
39
+ }
40
+ break;
41
+ // Remove frak backup
42
+ case "remove-backup":
43
+ localStorage.removeItem(BACKUP_KEY);
44
+ break;
45
+ // Change iframe visibility
46
+ case "show":
47
+ case "hide":
48
+ changeIframeVisibility({
49
+ iframe,
50
+ isVisible: event === "show",
51
+ });
52
+ break;
53
+ // Handshake handling
54
+ case "handshake": {
55
+ iframe.contentWindow?.postMessage(
56
+ {
57
+ clientLifecycle: "handshake-response",
58
+ data: {
59
+ token: data.token,
60
+ currentUrl: window.location.href,
61
+ },
62
+ },
63
+ "*"
64
+ );
65
+ break;
66
+ }
67
+ // Redirect handling
68
+ case "redirect": {
69
+ const redirectUrl = new URL(data.baseRedirectUrl);
70
+
71
+ // If we got a u append the current location dynamicly
72
+ if (redirectUrl.searchParams.has("u")) {
73
+ redirectUrl.searchParams.delete("u");
74
+ redirectUrl.searchParams.append("u", window.location.href);
75
+ window.location.href = redirectUrl.toString();
76
+ } else {
77
+ window.location.href = data.baseRedirectUrl;
78
+ }
79
+ break;
80
+ }
81
+ }
82
+ };
83
+
84
+ return {
85
+ handleEvent: handler,
86
+ isConnected: isConnectedDeferred.promise,
87
+ };
88
+ }
@@ -0,0 +1,44 @@
1
+ /**
2
+ * The final keys for each interaction types (e.g. `openArticle`) -> interaction type
3
+ * @inline
4
+ */
5
+ export type InteractionTypesKey = {
6
+ [K in keyof typeof interactionTypes]: keyof (typeof interactionTypes)[K];
7
+ }[keyof typeof interactionTypes];
8
+
9
+ /**
10
+ * The keys for each interaction types (e.g. `press.openArticle`) -> category_type.interaction_type
11
+ * @inline
12
+ */
13
+ export type FullInteractionTypesKey = {
14
+ [Category in keyof typeof interactionTypes]: `${Category & string}.${keyof (typeof interactionTypes)[Category] & string}`;
15
+ }[keyof typeof interactionTypes];
16
+
17
+ /**
18
+ * Each interactions types according to the product types
19
+ */
20
+ export const interactionTypes = {
21
+ press: {
22
+ openArticle: "0xc0a24ffb",
23
+ readArticle: "0xd5bd0fbe",
24
+ },
25
+ dapp: {
26
+ proofVerifiableStorageUpdate: "0x2ab2aeef",
27
+ callableVerifiableStorageUpdate: "0xa07da986",
28
+ },
29
+ webshop: {
30
+ open: "0xb311798f",
31
+ },
32
+ referral: {
33
+ referred: "0x010cc3b9",
34
+ createLink: "0xb2c0f17c",
35
+ },
36
+ purchase: {
37
+ started: "0xd87e90c3",
38
+ completed: "0x8403aeb4",
39
+ unsafeCompleted: "0x4d5b14e0",
40
+ },
41
+ retail: {
42
+ customerMeeting: "0x74489004",
43
+ },
44
+ } as const;
@@ -0,0 +1,14 @@
1
+ /**
2
+ * The keys for each locales
3
+ * @inline
4
+ */
5
+ export type LocalesKey = keyof typeof locales;
6
+
7
+ /**
8
+ * Map the currency to the locale
9
+ */
10
+ export const locales = {
11
+ eur: "fr-FR",
12
+ usd: "en-US",
13
+ gbp: "en-GB",
14
+ } as const;
@@ -0,0 +1,33 @@
1
+ /**
2
+ * The keys for each product types
3
+ * @inline
4
+ */
5
+ export type ProductTypesKey = keyof typeof productTypes;
6
+
7
+ /**
8
+ * List of the product types per denominator
9
+ */
10
+ export const productTypes = {
11
+ // content type
12
+ dapp: 1,
13
+ press: 2,
14
+ webshop: 3,
15
+ retail: 4,
16
+
17
+ // feature type
18
+ referral: 30,
19
+ purchase: 31,
20
+ };
21
+
22
+ /**
23
+ * Bitmask for each product types
24
+ */
25
+ export const productTypesMask: Record<ProductTypesKey, bigint> = Object.entries(
26
+ productTypes
27
+ ).reduce(
28
+ (acc, [key, value]) => {
29
+ acc[key as ProductTypesKey] = BigInt(1) << BigInt(value);
30
+ return acc;
31
+ },
32
+ {} as Record<ProductTypesKey, bigint>
33
+ );
package/src/index.ts ADDED
@@ -0,0 +1,103 @@
1
+ // Clients
2
+ export {
3
+ createIFrameFrakClient,
4
+ setupClient,
5
+ DebugInfoGatherer,
6
+ } from "./clients";
7
+
8
+ // Utils
9
+ export {
10
+ compressJsonToB64,
11
+ decompressJsonFromB64,
12
+ createIframe,
13
+ FrakContextManager,
14
+ baseIframeProps,
15
+ findIframeInOpener,
16
+ getSupportedCurrency,
17
+ getSupportedLocale,
18
+ getCurrencyAmountKey,
19
+ formatAmount,
20
+ base64urlDecode,
21
+ base64urlEncode,
22
+ trackEvent,
23
+ generateSsoUrl,
24
+ type CompressedSsoData,
25
+ type FullSsoParams,
26
+ type AppSpecificSsoMetadata,
27
+ } from "./utils";
28
+
29
+ // Constants
30
+ export {
31
+ type ProductTypesKey,
32
+ productTypes,
33
+ productTypesMask,
34
+ } from "./constants/productTypes";
35
+ export {
36
+ interactionTypes,
37
+ type InteractionTypesKey,
38
+ type FullInteractionTypesKey,
39
+ } from "./constants/interactionTypes";
40
+ export { locales, type LocalesKey } from "./constants/locales";
41
+ export { ssoPopupFeatures, ssoPopupName } from "./actions/openSso";
42
+
43
+ // Types
44
+ export type {
45
+ // Rpc
46
+ WalletStatusReturnType,
47
+ IFrameRpcSchema,
48
+ PreparedInteraction,
49
+ SendInteractionParamsType,
50
+ SendInteractionReturnType,
51
+ SsoMetadata,
52
+ PrepareSsoParamsType,
53
+ PrepareSsoReturnType,
54
+ OpenSsoParamsType,
55
+ OpenSsoReturnType,
56
+ Currency,
57
+ Language,
58
+ I18nConfig,
59
+ LocalizedI18nConfig,
60
+ TokenAmountType,
61
+ GetProductInformationReturnType,
62
+ // RPC Embedded wallet
63
+ DisplayEmbeddedWalletParamsType,
64
+ DisplayEmbeddedWalletResultType,
65
+ LoggedOutEmbeddedView,
66
+ LoggedInEmbeddedView,
67
+ EmbeddedViewActionReferred,
68
+ EmbeddedViewActionSharing,
69
+ // RPC Modal generics
70
+ ModalStepTypes,
71
+ ModalRpcMetadata,
72
+ DisplayModalParamsType,
73
+ ModalRpcStepsInput,
74
+ ModalRpcStepsResultType,
75
+ // RPC Modal types
76
+ ModalStepMetadata,
77
+ LoginModalStepType,
78
+ SiweAuthenticateModalStepType,
79
+ SiweAuthenticationParams,
80
+ SiweAuthenticateReturnType,
81
+ SendTransactionTxType,
82
+ SendTransactionModalStepType,
83
+ SendTransactionReturnType,
84
+ OpenInteractionSessionReturnType,
85
+ OpenInteractionSessionModalStepType,
86
+ FinalModalStepType,
87
+ FinalActionType,
88
+ // Client
89
+ FrakClient,
90
+ // Transport
91
+ IFrameTransport,
92
+ IFrameLifecycleEvent,
93
+ ClientLifecycleEvent,
94
+ FrakLifecycleEvent,
95
+ // Config
96
+ FrakWalletSdkConfig,
97
+ // Compression
98
+ KeyProvider,
99
+ CompressedData,
100
+ HashProtectedData,
101
+ // Utils
102
+ FrakContext,
103
+ } from "./types";
@@ -0,0 +1,5 @@
1
+ export { PressInteractionEncoder } from "./pressEncoder";
2
+ export { ReferralInteractionEncoder } from "./referralEncoder";
3
+ export { PurchaseInteractionEncoder } from "./purchaseEncoder";
4
+ export { WebShopInteractionEncoder } from "./webshopEncoder";
5
+ export { RetailInteractionEncoder } from "./retailEncoder";