@coinflowlabs/angular 0.1.2 → 0.1.4
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/README.md +5 -16
- package/esm2022/lib/coinflow-iframe.component.mjs +4 -4
- package/esm2022/lib/coinflow-purchase-history.component.mjs +4 -4
- package/esm2022/lib/coinflow-purchase-protection.component.mjs +4 -4
- package/esm2022/lib/coinflow-purchase.component.mjs +4 -4
- package/esm2022/lib/coinflow-withdraw-history.component.mjs +4 -4
- package/esm2022/lib/coinflow-withdraw.component.mjs +4 -4
- package/esm2022/lib/common/CoinflowTypes.mjs +8 -1
- package/esm2022/lib/common/CoinflowUtils.mjs +56 -13
- package/esm2022/lib/common/card-form/TokenEx.mjs +11 -0
- package/esm2022/lib/common/card-form/tokenexHelpers.mjs +153 -0
- package/esm2022/lib/common/index.mjs +3 -1
- package/fesm2022/coinflowlabs-angular.mjs +241 -30
- package/fesm2022/coinflowlabs-angular.mjs.map +1 -1
- package/lib/common/CoinflowTypes.d.ts +34 -9
- package/lib/common/CoinflowUtils.d.ts +7 -2
- package/lib/common/card-form/TokenEx.d.ts +154 -0
- package/lib/common/card-form/tokenexHelpers.d.ts +28 -0
- package/lib/common/index.d.ts +2 -0
- package/package.json +4 -3
|
@@ -0,0 +1,153 @@
|
|
|
1
|
+
import { TokenExCvvContainerID, CARD_TYPE_MAPPING, TokenExCardNumberIframeId, } from './TokenEx';
|
|
2
|
+
import { CoinflowUtils } from '../CoinflowUtils';
|
|
3
|
+
export async function getIframeConfig({ token, origins, env, }) {
|
|
4
|
+
return new Promise((resolve, reject) => {
|
|
5
|
+
fetch(new CoinflowUtils(env).url + '/api/checkout/authentication-key', {
|
|
6
|
+
method: 'POST',
|
|
7
|
+
headers: {
|
|
8
|
+
'Content-Type': 'application/json',
|
|
9
|
+
},
|
|
10
|
+
body: JSON.stringify({
|
|
11
|
+
origins: [...(origins ?? []), window.location.origin],
|
|
12
|
+
token,
|
|
13
|
+
}),
|
|
14
|
+
})
|
|
15
|
+
.then(async (res) => {
|
|
16
|
+
resolve((await res.json()));
|
|
17
|
+
})
|
|
18
|
+
.catch(e => reject(e));
|
|
19
|
+
});
|
|
20
|
+
}
|
|
21
|
+
export function setTokenExScriptTag({ env, setTokenExScriptLoaded, }) {
|
|
22
|
+
const scriptTagId = 'tokenex-script';
|
|
23
|
+
if (document.head.querySelector(`#${scriptTagId}`))
|
|
24
|
+
return;
|
|
25
|
+
const sdkScriptTag = document.createElement('script');
|
|
26
|
+
sdkScriptTag.src =
|
|
27
|
+
env === 'prod'
|
|
28
|
+
? 'https://htp.tokenex.com/iframe/iframe-v3.min.js'
|
|
29
|
+
: 'https://test-htp.tokenex.com/iframe/iframe-v3.min.js';
|
|
30
|
+
sdkScriptTag.id = scriptTagId;
|
|
31
|
+
document.head.appendChild(sdkScriptTag);
|
|
32
|
+
document.getElementById(scriptTagId).addEventListener('load', () => {
|
|
33
|
+
console.log('Setting tokenExScriptLoaded to true!');
|
|
34
|
+
setTokenExScriptLoaded(true);
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
function loadIframe({ iframe, setCachedToken, setLoaded, }) {
|
|
38
|
+
const tokenize = async () => {
|
|
39
|
+
iframe.tokenize();
|
|
40
|
+
return await new Promise((resolve, reject) => {
|
|
41
|
+
iframe.on('tokenize', (data) => {
|
|
42
|
+
setCachedToken(data.token);
|
|
43
|
+
resolve(data);
|
|
44
|
+
});
|
|
45
|
+
iframe.on('validate', (data) => {
|
|
46
|
+
// noinspection PointlessBooleanExpressionJS
|
|
47
|
+
const isInvalid = !data.isValid || data.isCvvValid === false;
|
|
48
|
+
if (isInvalid)
|
|
49
|
+
reject(data);
|
|
50
|
+
});
|
|
51
|
+
});
|
|
52
|
+
};
|
|
53
|
+
iframe.on('change', () => setCachedToken(undefined));
|
|
54
|
+
iframe.on('cvvChange', () => setCachedToken(undefined));
|
|
55
|
+
iframe.on('load', () => {
|
|
56
|
+
setTimeout(() => setLoaded(true), 350);
|
|
57
|
+
const el = document.querySelector('#tx_iframe_tokenExCardNumber');
|
|
58
|
+
if (el) {
|
|
59
|
+
// noinspection JSDeprecatedSymbols
|
|
60
|
+
el.scrolling = 'no';
|
|
61
|
+
}
|
|
62
|
+
});
|
|
63
|
+
iframe.on('focus', () => {
|
|
64
|
+
iframe.focus();
|
|
65
|
+
});
|
|
66
|
+
iframe.on('cvvFocus', () => {
|
|
67
|
+
iframe.cvvFocus();
|
|
68
|
+
});
|
|
69
|
+
setLoaded(false);
|
|
70
|
+
iframe.load();
|
|
71
|
+
return { ...iframe, tokenize };
|
|
72
|
+
}
|
|
73
|
+
export async function doInitializeCvvOnlyTokenExIframe(args) {
|
|
74
|
+
const { token, cardType } = args;
|
|
75
|
+
return await doInitialize(TokenExCvvContainerID, args, {
|
|
76
|
+
cvvOnly: true,
|
|
77
|
+
cvv: true,
|
|
78
|
+
cvvContainerID: TokenExCvvContainerID,
|
|
79
|
+
placeholder: 'CVV',
|
|
80
|
+
token,
|
|
81
|
+
cardType: CARD_TYPE_MAPPING[cardType],
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
export async function doInitializeTokenExIframe(args) {
|
|
85
|
+
return await doInitialize(TokenExCardNumberIframeId, args, {
|
|
86
|
+
cvv: true,
|
|
87
|
+
cvvContainerID: TokenExCvvContainerID,
|
|
88
|
+
cvvPlaceholder: 'CVV',
|
|
89
|
+
});
|
|
90
|
+
}
|
|
91
|
+
export async function doInitializeTokenExCardOnlyIframe(args) {
|
|
92
|
+
return await doInitialize(TokenExCardNumberIframeId, args, { cvv: false });
|
|
93
|
+
}
|
|
94
|
+
async function doInitialize(id, { tokenExScriptLoaded, origins, env, css, debug, font, setCachedToken, setLoaded, }, configOverrides) {
|
|
95
|
+
if (!tokenExScriptLoaded && typeof TokenEx === 'undefined') {
|
|
96
|
+
console.warn('Warning Unable to load TokenEx on first attempt waiting for load event from document.head.script#tokenex-script');
|
|
97
|
+
return;
|
|
98
|
+
}
|
|
99
|
+
const iframeConfig = await getIframeConfig({
|
|
100
|
+
token: configOverrides.token,
|
|
101
|
+
origins,
|
|
102
|
+
env,
|
|
103
|
+
});
|
|
104
|
+
const { styles } = getStyles(css);
|
|
105
|
+
const config = {
|
|
106
|
+
...iframeConfig,
|
|
107
|
+
placeholder: '0000 0000 0000 0000',
|
|
108
|
+
enablePrettyFormat: true,
|
|
109
|
+
styles,
|
|
110
|
+
font,
|
|
111
|
+
debug: debug ?? false,
|
|
112
|
+
...configOverrides,
|
|
113
|
+
};
|
|
114
|
+
const iframe = TokenEx.Iframe(id, config);
|
|
115
|
+
return loadIframe({ iframe, setCachedToken, setLoaded });
|
|
116
|
+
}
|
|
117
|
+
function getStyles(s) {
|
|
118
|
+
const css = JSON.parse(s);
|
|
119
|
+
const styles = {
|
|
120
|
+
base: CSSPropertiesToComponent(css.base),
|
|
121
|
+
focus: CSSPropertiesToComponent(css.focus),
|
|
122
|
+
error: CSSPropertiesToComponent(css.error),
|
|
123
|
+
placeholder: CSSPropertiesToComponent(css.placeholder),
|
|
124
|
+
cvv: {
|
|
125
|
+
base: CSSPropertiesToComponent(css.cvv?.base),
|
|
126
|
+
focus: CSSPropertiesToComponent(css.cvv?.focus),
|
|
127
|
+
error: CSSPropertiesToComponent(css.cvv?.error),
|
|
128
|
+
placeholder: CSSPropertiesToComponent(css?.placeholder),
|
|
129
|
+
},
|
|
130
|
+
};
|
|
131
|
+
return { styles };
|
|
132
|
+
}
|
|
133
|
+
function CSSPropertiesToComponent(dict) {
|
|
134
|
+
if (!dict)
|
|
135
|
+
return '';
|
|
136
|
+
if (typeof dict === 'string')
|
|
137
|
+
return dict;
|
|
138
|
+
let str = '';
|
|
139
|
+
for (const [key, value] of Object.entries(dict)) {
|
|
140
|
+
let clo = '';
|
|
141
|
+
key.split('').forEach(lt => {
|
|
142
|
+
if (lt.toUpperCase() === lt) {
|
|
143
|
+
clo += '-' + lt.toLowerCase();
|
|
144
|
+
}
|
|
145
|
+
else {
|
|
146
|
+
clo += lt;
|
|
147
|
+
}
|
|
148
|
+
});
|
|
149
|
+
str += clo + ':' + value + ';';
|
|
150
|
+
}
|
|
151
|
+
return str;
|
|
152
|
+
}
|
|
153
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tokenexHelpers.js","sourceRoot":"","sources":["../../../../../../projects/coinflowlabs/src/lib/common/card-form/tokenexHelpers.ts"],"names":[],"mappings":"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","sourcesContent":["import {CSSProperties} from 'react';\nimport {\n  TokenizationResponse,\n  TokenExCvvContainerID,\n  TokenExIframe,\n  TokenExIFrameConfiguration,\n  CARD_TYPE_MAPPING,\n  TokenExCardNumberIframeId,\n} from './TokenEx';\nimport {CoinflowUtils} from '../CoinflowUtils';\nimport {CardType, CoinflowEnvs} from '../CoinflowTypes';\n\nexport interface DoInitializeTokenExIframeArgs {\n  css: string;\n  debug?: boolean;\n  font?: string;\n  origins: string[] | undefined;\n  tokenExScriptLoaded: boolean;\n  env: CoinflowEnvs;\n  setCachedToken: (s: string | undefined) => void;\n  setLoaded: (b: boolean) => void;\n}\n\nexport interface DoInitializeCvvOnlyTokenExIframeArgs\n  extends DoInitializeTokenExIframeArgs {\n  token: string;\n  cardType: CardType;\n}\n\nexport async function getIframeConfig({\n  token,\n  origins,\n  env,\n}: {\n  token?: string;\n  origins: string[] | undefined;\n  env: CoinflowEnvs;\n}): Promise<TokenExIFrameConfiguration> {\n  return new Promise((resolve, reject) => {\n    fetch(new CoinflowUtils(env).url + '/api/checkout/authentication-key', {\n      method: 'POST',\n      headers: {\n        'Content-Type': 'application/json',\n      },\n      body: JSON.stringify({\n        origins: [...(origins ?? []), window.location.origin],\n        token,\n      }),\n    })\n      .then(async res => {\n        resolve((await res.json()) as TokenExIFrameConfiguration);\n      })\n      .catch(e => reject(e));\n  });\n}\n\nexport function setTokenExScriptTag({\n  env,\n  setTokenExScriptLoaded,\n}: {\n  env: CoinflowEnvs;\n  setTokenExScriptLoaded: (b: boolean) => void;\n}) {\n  const scriptTagId = 'tokenex-script';\n  if (document.head.querySelector(`#${scriptTagId}`)) return;\n\n  const sdkScriptTag = document.createElement('script');\n  sdkScriptTag.src =\n    env === 'prod'\n      ? 'https://htp.tokenex.com/iframe/iframe-v3.min.js'\n      : 'https://test-htp.tokenex.com/iframe/iframe-v3.min.js';\n  sdkScriptTag.id = scriptTagId;\n\n  document.head.appendChild(sdkScriptTag);\n\n  document.getElementById(scriptTagId)!.addEventListener('load', () => {\n    console.log('Setting tokenExScriptLoaded to true!');\n    setTokenExScriptLoaded(true);\n  });\n}\n\nfunction loadIframe({\n  iframe,\n  setCachedToken,\n  setLoaded,\n}: {\n  setCachedToken: (s: string | undefined) => void;\n  setLoaded: (b: boolean) => void;\n  iframe: ReturnType<typeof TokenEx.Iframe>;\n}): TokenExIframe {\n  const tokenize = async (): Promise<TokenizationResponse> => {\n    iframe.tokenize();\n    return await new Promise<TokenizationResponse>((resolve, reject) => {\n      iframe.on('tokenize', (data: TokenizationResponse) => {\n        setCachedToken(data.token);\n        resolve(data);\n      });\n      iframe.on('validate', (data: {isValid: boolean; isCvvValid: boolean}) => {\n        // noinspection PointlessBooleanExpressionJS\n        const isInvalid = !data.isValid || data.isCvvValid === false;\n        if (isInvalid) reject(data);\n      });\n    });\n  };\n\n  iframe.on('change', () => setCachedToken(undefined));\n  iframe.on('cvvChange', () => setCachedToken(undefined));\n\n  iframe.on('load', () => {\n    setTimeout(() => setLoaded(true), 350);\n    const el: HTMLIFrameElement | null = document.querySelector(\n      '#tx_iframe_tokenExCardNumber'\n    );\n    if (el) {\n      // noinspection JSDeprecatedSymbols\n      el.scrolling = 'no';\n    }\n  });\n\n  iframe.on('focus', () => {\n    iframe.focus();\n  });\n  iframe.on('cvvFocus', () => {\n    iframe.cvvFocus();\n  });\n\n  setLoaded(false);\n  iframe.load();\n\n  return {...iframe, tokenize};\n}\n\nexport async function doInitializeCvvOnlyTokenExIframe(\n  args: DoInitializeCvvOnlyTokenExIframeArgs\n) {\n  const {token, cardType} = args;\n  return await doInitialize(TokenExCvvContainerID, args, {\n    cvvOnly: true,\n    cvv: true,\n    cvvContainerID: TokenExCvvContainerID,\n    placeholder: 'CVV',\n    token,\n    cardType: CARD_TYPE_MAPPING[cardType],\n  });\n}\n\nexport async function doInitializeTokenExIframe(\n  args: DoInitializeTokenExIframeArgs\n) {\n  return await doInitialize(TokenExCardNumberIframeId, args, {\n    cvv: true,\n    cvvContainerID: TokenExCvvContainerID,\n    cvvPlaceholder: 'CVV',\n  });\n}\n\nexport async function doInitializeTokenExCardOnlyIframe(\n  args: DoInitializeTokenExIframeArgs\n) {\n  return await doInitialize(TokenExCardNumberIframeId, args, {cvv: false});\n}\n\nasync function doInitialize(\n  id: string,\n  {\n    tokenExScriptLoaded,\n    origins,\n    env,\n    css,\n    debug,\n    font,\n    setCachedToken,\n    setLoaded,\n  }: DoInitializeTokenExIframeArgs,\n  configOverrides: Partial<TokenEx.Config>\n) {\n  if (!tokenExScriptLoaded && typeof TokenEx === 'undefined') {\n    console.warn(\n      'Warning Unable to load TokenEx on first attempt waiting for load event from document.head.script#tokenex-script'\n    );\n    return;\n  }\n  const iframeConfig = await getIframeConfig({\n    token: configOverrides.token,\n    origins,\n    env,\n  });\n  const {styles} = getStyles(css);\n  const config = {\n    ...iframeConfig,\n    placeholder: '0000 0000 0000 0000',\n    enablePrettyFormat: true,\n    styles,\n    font,\n    debug: debug ?? false,\n    ...configOverrides,\n  };\n  const iframe: ReturnType<typeof TokenEx.Iframe> = TokenEx.Iframe(id, config);\n\n  return loadIframe({iframe, setCachedToken, setLoaded});\n}\n\nfunction getStyles(s: string) {\n  const css = JSON.parse(s);\n  const styles = {\n    base: CSSPropertiesToComponent(css.base),\n    focus: CSSPropertiesToComponent(css.focus),\n    error: CSSPropertiesToComponent(css.error),\n    placeholder: CSSPropertiesToComponent(css.placeholder),\n    cvv: {\n      base: CSSPropertiesToComponent(css.cvv?.base),\n      focus: CSSPropertiesToComponent(css.cvv?.focus),\n      error: CSSPropertiesToComponent(css.cvv?.error),\n      placeholder: CSSPropertiesToComponent(css?.placeholder),\n    },\n  };\n\n  return {styles};\n}\n\nfunction CSSPropertiesToComponent(\n  dict: CSSProperties | string | undefined\n): string {\n  if (!dict) return '';\n  if (typeof dict === 'string') return dict;\n\n  let str = '';\n  for (const [key, value] of Object.entries(dict)) {\n    let clo = '';\n    key.split('').forEach(lt => {\n      if (lt.toUpperCase() === lt) {\n        clo += '-' + lt.toLowerCase();\n      } else {\n        clo += lt;\n      }\n    });\n    str += clo + ':' + value + ';';\n  }\n  return str;\n}\n"]}
|
|
@@ -1,4 +1,6 @@
|
|
|
1
1
|
export * from './CoinflowTypes';
|
|
2
2
|
export * from './CoinflowUtils';
|
|
3
3
|
export * from './CoinflowLibMessageHandlers';
|
|
4
|
-
|
|
4
|
+
export * from './card-form/TokenEx';
|
|
5
|
+
export * from './card-form/tokenexHelpers';
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb2luZmxvd2xhYnMvc3JjL2xpYi9jb21tb24vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxpQkFBaUIsQ0FBQztBQUNoQyxjQUFjLGlCQUFpQixDQUFDO0FBQ2hDLGNBQWMsOEJBQThCLENBQUM7QUFDN0MsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLDRCQUE0QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9Db2luZmxvd1R5cGVzJztcbmV4cG9ydCAqIGZyb20gJy4vQ29pbmZsb3dVdGlscyc7XG5leHBvcnQgKiBmcm9tICcuL0NvaW5mbG93TGliTWVzc2FnZUhhbmRsZXJzJztcbmV4cG9ydCAqIGZyb20gJy4vY2FyZC1mb3JtL1Rva2VuRXgnO1xuZXhwb3J0ICogZnJvbSAnLi9jYXJkLWZvcm0vdG9rZW5leEhlbHBlcnMnO1xuIl19
|
|
@@ -1,8 +1,10 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
2
|
import { Component, Input, ViewChild, HostListener } from '@angular/core';
|
|
3
3
|
import * as SolanaWeb3Js from '@solana/web3.js';
|
|
4
|
+
import { Keypair, Transaction } from '@solana/web3.js';
|
|
4
5
|
import base58Imported from 'bs58';
|
|
5
6
|
import LZString from 'lz-string';
|
|
7
|
+
import { sign } from 'tweetnacl';
|
|
6
8
|
import * as i1 from '@angular/platform-browser';
|
|
7
9
|
|
|
8
10
|
var SettlementType;
|
|
@@ -17,6 +19,13 @@ var MerchantStyle;
|
|
|
17
19
|
MerchantStyle["Sharp"] = "sharp";
|
|
18
20
|
MerchantStyle["Pill"] = "pill";
|
|
19
21
|
})(MerchantStyle || (MerchantStyle = {}));
|
|
22
|
+
var CardType;
|
|
23
|
+
(function (CardType) {
|
|
24
|
+
CardType["VISA"] = "VISA";
|
|
25
|
+
CardType["MASTERCARD"] = "MSTR";
|
|
26
|
+
CardType["AMEX"] = "AMEX";
|
|
27
|
+
CardType["DISCOVER"] = "DISC";
|
|
28
|
+
})(CardType || (CardType = {}));
|
|
20
29
|
|
|
21
30
|
// This works in angular, but not react
|
|
22
31
|
// let web3: typeof import('@solana/web3.js') | undefined;
|
|
@@ -76,7 +85,7 @@ class CoinflowUtils {
|
|
|
76
85
|
return 'http://localhost:5000';
|
|
77
86
|
return `https://api-${env}.coinflow.cash`;
|
|
78
87
|
}
|
|
79
|
-
static getCoinflowUrl({ walletPubkey, route, routePrefix, env, amount, transaction, blockchain,
|
|
88
|
+
static getCoinflowUrl({ walletPubkey, route, routePrefix, env, amount, transaction, blockchain, webhookInfo, email, loaderBackground, handleHeightChange, bankAccountLinkRedirect, additionalWallets, nearDeposit, chargebackProtectionData, merchantCss, color, rent, lockDefaultToken, token, tokens, planCode, disableApplePay, disableGooglePay, customerInfo, settlementType, lockAmount, nativeSolToConvert, theme, usePermit, transactionSigner, authOnly, deviceId, jwtToken, origins, }) {
|
|
80
89
|
const prefix = routePrefix
|
|
81
90
|
? `/${routePrefix}/${blockchain}`
|
|
82
91
|
: `/${blockchain}`;
|
|
@@ -88,9 +97,6 @@ class CoinflowUtils {
|
|
|
88
97
|
if (amount) {
|
|
89
98
|
url.searchParams.append('amount', amount.toString());
|
|
90
99
|
}
|
|
91
|
-
if (supportsVersionedTransactions) {
|
|
92
|
-
url.searchParams.append('supportsVersionedTransactions', 'true');
|
|
93
|
-
}
|
|
94
100
|
if (webhookInfo) {
|
|
95
101
|
url.searchParams.append('webhookInfo', LZString.compressToEncodedURIComponent(JSON.stringify(webhookInfo)));
|
|
96
102
|
}
|
|
@@ -164,6 +170,8 @@ class CoinflowUtils {
|
|
|
164
170
|
url.searchParams.append('authOnly', 'true');
|
|
165
171
|
if (jwtToken)
|
|
166
172
|
url.searchParams.append('jwtToken', jwtToken);
|
|
173
|
+
if (origins)
|
|
174
|
+
url.searchParams.append('origins', LZString.compressToEncodedURIComponent(JSON.stringify(origins)));
|
|
167
175
|
return url.toString();
|
|
168
176
|
}
|
|
169
177
|
static getTransaction(props) {
|
|
@@ -176,14 +184,12 @@ class CoinflowUtils {
|
|
|
176
184
|
throw new Error('@solana/web3.js dependency is required for Solana');
|
|
177
185
|
if (!base58)
|
|
178
186
|
throw new Error('bs58 dependency is required for Solana');
|
|
179
|
-
if (transaction
|
|
180
|
-
return
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
return base58.encode(transaction.serialize());
|
|
186
|
-
return undefined;
|
|
187
|
+
if (!transaction)
|
|
188
|
+
return undefined;
|
|
189
|
+
return base58.encode(transaction.serialize({
|
|
190
|
+
requireAllSignatures: false,
|
|
191
|
+
verifySignatures: false,
|
|
192
|
+
}));
|
|
187
193
|
},
|
|
188
194
|
polygon: () => {
|
|
189
195
|
if (!('transaction' in props))
|
|
@@ -227,6 +233,50 @@ class CoinflowUtils {
|
|
|
227
233
|
throw new Error('blockchain not supported!');
|
|
228
234
|
}
|
|
229
235
|
}
|
|
236
|
+
static async getWalletFromEmail({ email, merchantId, env, }) {
|
|
237
|
+
const buffer = new TextEncoder().encode(email);
|
|
238
|
+
const crypto = window.crypto.subtle;
|
|
239
|
+
const hash = await crypto.digest('SHA-256', buffer);
|
|
240
|
+
const seed = new Uint8Array(hash);
|
|
241
|
+
const keypair = Keypair.fromSeed(seed);
|
|
242
|
+
return {
|
|
243
|
+
publicKey: keypair.publicKey,
|
|
244
|
+
signMessage: (message) => Promise.resolve(sign.detached(message, keypair.secretKey)),
|
|
245
|
+
signTransaction: async (transaction) => {
|
|
246
|
+
if (transaction instanceof Transaction) {
|
|
247
|
+
transaction.sign(keypair);
|
|
248
|
+
return transaction;
|
|
249
|
+
}
|
|
250
|
+
else {
|
|
251
|
+
transaction.sign([keypair]);
|
|
252
|
+
return transaction;
|
|
253
|
+
}
|
|
254
|
+
},
|
|
255
|
+
sendTransaction: async (transaction) => {
|
|
256
|
+
if (transaction instanceof Transaction) {
|
|
257
|
+
transaction.sign(keypair);
|
|
258
|
+
}
|
|
259
|
+
else {
|
|
260
|
+
transaction.sign([keypair]);
|
|
261
|
+
}
|
|
262
|
+
const coinflowBaseUrl = this.getCoinflowApiUrl(env);
|
|
263
|
+
const options = {
|
|
264
|
+
method: 'POST',
|
|
265
|
+
headers: {
|
|
266
|
+
'content-type': 'application/json',
|
|
267
|
+
'x-coinflow-auth-wallet': keypair.publicKey.toString(),
|
|
268
|
+
'x-coinflow-auth-blockchain': 'solana',
|
|
269
|
+
},
|
|
270
|
+
body: JSON.stringify({
|
|
271
|
+
merchantId,
|
|
272
|
+
signedTransaction: base58?.encode(transaction.serialize()),
|
|
273
|
+
}),
|
|
274
|
+
};
|
|
275
|
+
const { signature } = await fetch(coinflowBaseUrl + '/api/utils/send-coinflow-tx', options).then(res => res.json());
|
|
276
|
+
return signature;
|
|
277
|
+
},
|
|
278
|
+
};
|
|
279
|
+
}
|
|
230
280
|
}
|
|
231
281
|
|
|
232
282
|
var IFrameMessageMethods;
|
|
@@ -366,6 +416,167 @@ function getEvmWalletHandlers({ wallet, onSuccess, }) {
|
|
|
366
416
|
};
|
|
367
417
|
}
|
|
368
418
|
|
|
419
|
+
// Type definitions for TokenEx iframe integration
|
|
420
|
+
const TokenExCardNumberIframeId = 'tokenExCardNumber';
|
|
421
|
+
const TokenExCvvContainerID = 'tokenExCardCvv';
|
|
422
|
+
const CARD_TYPE_MAPPING = {
|
|
423
|
+
[CardType.VISA]: 'visa',
|
|
424
|
+
[CardType.MASTERCARD]: 'masterCard',
|
|
425
|
+
[CardType.AMEX]: 'americanExpress',
|
|
426
|
+
[CardType.DISCOVER]: 'discover',
|
|
427
|
+
};
|
|
428
|
+
|
|
429
|
+
async function getIframeConfig({ token, origins, env, }) {
|
|
430
|
+
return new Promise((resolve, reject) => {
|
|
431
|
+
fetch(new CoinflowUtils(env).url + '/api/checkout/authentication-key', {
|
|
432
|
+
method: 'POST',
|
|
433
|
+
headers: {
|
|
434
|
+
'Content-Type': 'application/json',
|
|
435
|
+
},
|
|
436
|
+
body: JSON.stringify({
|
|
437
|
+
origins: [...(origins ?? []), window.location.origin],
|
|
438
|
+
token,
|
|
439
|
+
}),
|
|
440
|
+
})
|
|
441
|
+
.then(async (res) => {
|
|
442
|
+
resolve((await res.json()));
|
|
443
|
+
})
|
|
444
|
+
.catch(e => reject(e));
|
|
445
|
+
});
|
|
446
|
+
}
|
|
447
|
+
function setTokenExScriptTag({ env, setTokenExScriptLoaded, }) {
|
|
448
|
+
const scriptTagId = 'tokenex-script';
|
|
449
|
+
if (document.head.querySelector(`#${scriptTagId}`))
|
|
450
|
+
return;
|
|
451
|
+
const sdkScriptTag = document.createElement('script');
|
|
452
|
+
sdkScriptTag.src =
|
|
453
|
+
env === 'prod'
|
|
454
|
+
? 'https://htp.tokenex.com/iframe/iframe-v3.min.js'
|
|
455
|
+
: 'https://test-htp.tokenex.com/iframe/iframe-v3.min.js';
|
|
456
|
+
sdkScriptTag.id = scriptTagId;
|
|
457
|
+
document.head.appendChild(sdkScriptTag);
|
|
458
|
+
document.getElementById(scriptTagId).addEventListener('load', () => {
|
|
459
|
+
console.log('Setting tokenExScriptLoaded to true!');
|
|
460
|
+
setTokenExScriptLoaded(true);
|
|
461
|
+
});
|
|
462
|
+
}
|
|
463
|
+
function loadIframe({ iframe, setCachedToken, setLoaded, }) {
|
|
464
|
+
const tokenize = async () => {
|
|
465
|
+
iframe.tokenize();
|
|
466
|
+
return await new Promise((resolve, reject) => {
|
|
467
|
+
iframe.on('tokenize', (data) => {
|
|
468
|
+
setCachedToken(data.token);
|
|
469
|
+
resolve(data);
|
|
470
|
+
});
|
|
471
|
+
iframe.on('validate', (data) => {
|
|
472
|
+
// noinspection PointlessBooleanExpressionJS
|
|
473
|
+
const isInvalid = !data.isValid || data.isCvvValid === false;
|
|
474
|
+
if (isInvalid)
|
|
475
|
+
reject(data);
|
|
476
|
+
});
|
|
477
|
+
});
|
|
478
|
+
};
|
|
479
|
+
iframe.on('change', () => setCachedToken(undefined));
|
|
480
|
+
iframe.on('cvvChange', () => setCachedToken(undefined));
|
|
481
|
+
iframe.on('load', () => {
|
|
482
|
+
setTimeout(() => setLoaded(true), 350);
|
|
483
|
+
const el = document.querySelector('#tx_iframe_tokenExCardNumber');
|
|
484
|
+
if (el) {
|
|
485
|
+
// noinspection JSDeprecatedSymbols
|
|
486
|
+
el.scrolling = 'no';
|
|
487
|
+
}
|
|
488
|
+
});
|
|
489
|
+
iframe.on('focus', () => {
|
|
490
|
+
iframe.focus();
|
|
491
|
+
});
|
|
492
|
+
iframe.on('cvvFocus', () => {
|
|
493
|
+
iframe.cvvFocus();
|
|
494
|
+
});
|
|
495
|
+
setLoaded(false);
|
|
496
|
+
iframe.load();
|
|
497
|
+
return { ...iframe, tokenize };
|
|
498
|
+
}
|
|
499
|
+
async function doInitializeCvvOnlyTokenExIframe(args) {
|
|
500
|
+
const { token, cardType } = args;
|
|
501
|
+
return await doInitialize(TokenExCvvContainerID, args, {
|
|
502
|
+
cvvOnly: true,
|
|
503
|
+
cvv: true,
|
|
504
|
+
cvvContainerID: TokenExCvvContainerID,
|
|
505
|
+
placeholder: 'CVV',
|
|
506
|
+
token,
|
|
507
|
+
cardType: CARD_TYPE_MAPPING[cardType],
|
|
508
|
+
});
|
|
509
|
+
}
|
|
510
|
+
async function doInitializeTokenExIframe(args) {
|
|
511
|
+
return await doInitialize(TokenExCardNumberIframeId, args, {
|
|
512
|
+
cvv: true,
|
|
513
|
+
cvvContainerID: TokenExCvvContainerID,
|
|
514
|
+
cvvPlaceholder: 'CVV',
|
|
515
|
+
});
|
|
516
|
+
}
|
|
517
|
+
async function doInitializeTokenExCardOnlyIframe(args) {
|
|
518
|
+
return await doInitialize(TokenExCardNumberIframeId, args, { cvv: false });
|
|
519
|
+
}
|
|
520
|
+
async function doInitialize(id, { tokenExScriptLoaded, origins, env, css, debug, font, setCachedToken, setLoaded, }, configOverrides) {
|
|
521
|
+
if (!tokenExScriptLoaded && typeof TokenEx === 'undefined') {
|
|
522
|
+
console.warn('Warning Unable to load TokenEx on first attempt waiting for load event from document.head.script#tokenex-script');
|
|
523
|
+
return;
|
|
524
|
+
}
|
|
525
|
+
const iframeConfig = await getIframeConfig({
|
|
526
|
+
token: configOverrides.token,
|
|
527
|
+
origins,
|
|
528
|
+
env,
|
|
529
|
+
});
|
|
530
|
+
const { styles } = getStyles(css);
|
|
531
|
+
const config = {
|
|
532
|
+
...iframeConfig,
|
|
533
|
+
placeholder: '0000 0000 0000 0000',
|
|
534
|
+
enablePrettyFormat: true,
|
|
535
|
+
styles,
|
|
536
|
+
font,
|
|
537
|
+
debug: debug ?? false,
|
|
538
|
+
...configOverrides,
|
|
539
|
+
};
|
|
540
|
+
const iframe = TokenEx.Iframe(id, config);
|
|
541
|
+
return loadIframe({ iframe, setCachedToken, setLoaded });
|
|
542
|
+
}
|
|
543
|
+
function getStyles(s) {
|
|
544
|
+
const css = JSON.parse(s);
|
|
545
|
+
const styles = {
|
|
546
|
+
base: CSSPropertiesToComponent(css.base),
|
|
547
|
+
focus: CSSPropertiesToComponent(css.focus),
|
|
548
|
+
error: CSSPropertiesToComponent(css.error),
|
|
549
|
+
placeholder: CSSPropertiesToComponent(css.placeholder),
|
|
550
|
+
cvv: {
|
|
551
|
+
base: CSSPropertiesToComponent(css.cvv?.base),
|
|
552
|
+
focus: CSSPropertiesToComponent(css.cvv?.focus),
|
|
553
|
+
error: CSSPropertiesToComponent(css.cvv?.error),
|
|
554
|
+
placeholder: CSSPropertiesToComponent(css?.placeholder),
|
|
555
|
+
},
|
|
556
|
+
};
|
|
557
|
+
return { styles };
|
|
558
|
+
}
|
|
559
|
+
function CSSPropertiesToComponent(dict) {
|
|
560
|
+
if (!dict)
|
|
561
|
+
return '';
|
|
562
|
+
if (typeof dict === 'string')
|
|
563
|
+
return dict;
|
|
564
|
+
let str = '';
|
|
565
|
+
for (const [key, value] of Object.entries(dict)) {
|
|
566
|
+
let clo = '';
|
|
567
|
+
key.split('').forEach(lt => {
|
|
568
|
+
if (lt.toUpperCase() === lt) {
|
|
569
|
+
clo += '-' + lt.toLowerCase();
|
|
570
|
+
}
|
|
571
|
+
else {
|
|
572
|
+
clo += lt;
|
|
573
|
+
}
|
|
574
|
+
});
|
|
575
|
+
str += clo + ':' + value + ';';
|
|
576
|
+
}
|
|
577
|
+
return str;
|
|
578
|
+
}
|
|
579
|
+
|
|
369
580
|
class CoinflowIFrameComponent {
|
|
370
581
|
constructor(sanitizer) {
|
|
371
582
|
this.sanitizer = sanitizer;
|
|
@@ -390,8 +601,8 @@ class CoinflowIFrameComponent {
|
|
|
390
601
|
return;
|
|
391
602
|
this.iframe.nativeElement.contentWindow.postMessage(message, '*');
|
|
392
603
|
}
|
|
393
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.
|
|
394
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.
|
|
604
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: CoinflowIFrameComponent, deps: [{ token: i1.DomSanitizer }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
605
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.10", type: CoinflowIFrameComponent, isStandalone: true, selector: "lib-coinflow-iframe", inputs: { iframeProps: "iframeProps", messageHandlers: "messageHandlers" }, host: { listeners: { "window:message": "onPostMessage($event)" } }, viewQueries: [{ propertyName: "iframe", first: true, predicate: ["iframe"], descendants: true }], ngImport: i0, template: ` <iframe
|
|
395
606
|
width="100%"
|
|
396
607
|
height="100%"
|
|
397
608
|
#iframe
|
|
@@ -402,7 +613,7 @@ class CoinflowIFrameComponent {
|
|
|
402
613
|
[src]="dynamicUrl"
|
|
403
614
|
></iframe>`, isInline: true }); }
|
|
404
615
|
}
|
|
405
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.
|
|
616
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: CoinflowIFrameComponent, decorators: [{
|
|
406
617
|
type: Component,
|
|
407
618
|
args: [{
|
|
408
619
|
selector: 'lib-coinflow-iframe',
|
|
@@ -444,10 +655,10 @@ class CoinflowPurchaseComponent {
|
|
|
444
655
|
transaction: CoinflowUtils.getTransaction(this.purchaseProps),
|
|
445
656
|
};
|
|
446
657
|
}
|
|
447
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.
|
|
448
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.
|
|
658
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: CoinflowPurchaseComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
659
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.10", type: CoinflowPurchaseComponent, isStandalone: true, selector: "lib-coinflow-purchase", inputs: { purchaseProps: "purchaseProps" }, ngImport: i0, template: ' <lib-coinflow-iframe ng-if="iframeProps && messageHandlers" [iframeProps]="iframeProps!" [messageHandlers]="messageHandlers!"></lib-coinflow-iframe> ', isInline: true, dependencies: [{ kind: "component", type: CoinflowIFrameComponent, selector: "lib-coinflow-iframe", inputs: ["iframeProps", "messageHandlers"] }] }); }
|
|
449
660
|
}
|
|
450
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.
|
|
661
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: CoinflowPurchaseComponent, decorators: [{
|
|
451
662
|
type: Component,
|
|
452
663
|
args: [{
|
|
453
664
|
selector: 'lib-coinflow-purchase',
|
|
@@ -460,10 +671,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
|
|
|
460
671
|
}] } });
|
|
461
672
|
|
|
462
673
|
class CoinflowPurchaseHistoryComponent {
|
|
463
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.
|
|
464
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.
|
|
674
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: CoinflowPurchaseHistoryComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
675
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.10", type: CoinflowPurchaseHistoryComponent, isStandalone: true, selector: "lib-coinflow-purchase-history", ngImport: i0, template: ' <p>coinflow-purchase-history works!</p> ', isInline: true }); }
|
|
465
676
|
}
|
|
466
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.
|
|
677
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: CoinflowPurchaseHistoryComponent, decorators: [{
|
|
467
678
|
type: Component,
|
|
468
679
|
args: [{
|
|
469
680
|
selector: 'lib-coinflow-purchase-history',
|
|
@@ -474,10 +685,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
|
|
|
474
685
|
}] });
|
|
475
686
|
|
|
476
687
|
class CoinflowPurchaseProtectionComponent {
|
|
477
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.
|
|
478
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.
|
|
688
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: CoinflowPurchaseProtectionComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
689
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.10", type: CoinflowPurchaseProtectionComponent, isStandalone: true, selector: "lib-coinflow-purchase-protection", ngImport: i0, template: ' <p>coinflow-purchase-protection works!</p> ', isInline: true }); }
|
|
479
690
|
}
|
|
480
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.
|
|
691
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: CoinflowPurchaseProtectionComponent, decorators: [{
|
|
481
692
|
type: Component,
|
|
482
693
|
args: [{
|
|
483
694
|
selector: 'lib-coinflow-purchase-protection',
|
|
@@ -500,10 +711,10 @@ class CoinflowWithdrawComponent {
|
|
|
500
711
|
transaction: undefined,
|
|
501
712
|
};
|
|
502
713
|
}
|
|
503
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.
|
|
504
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.
|
|
714
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: CoinflowWithdrawComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
715
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.10", type: CoinflowWithdrawComponent, isStandalone: true, selector: "lib-coinflow-withdraw", inputs: { withdrawProps: "withdrawProps" }, ngImport: i0, template: ' <lib-coinflow-iframe ng-if="iframeProps && messageHandlers" [iframeProps]="iframeProps!" [messageHandlers]="messageHandlers!"></lib-coinflow-iframe> ', isInline: true, dependencies: [{ kind: "component", type: CoinflowIFrameComponent, selector: "lib-coinflow-iframe", inputs: ["iframeProps", "messageHandlers"] }] }); }
|
|
505
716
|
}
|
|
506
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.
|
|
717
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: CoinflowWithdrawComponent, decorators: [{
|
|
507
718
|
type: Component,
|
|
508
719
|
args: [{
|
|
509
720
|
selector: 'lib-coinflow-withdraw',
|
|
@@ -516,10 +727,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
|
|
|
516
727
|
}] } });
|
|
517
728
|
|
|
518
729
|
class CoinflowWithdrawHistoryComponent {
|
|
519
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.
|
|
520
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.
|
|
730
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: CoinflowWithdrawHistoryComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
731
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.10", type: CoinflowWithdrawHistoryComponent, isStandalone: true, selector: "lib-coinflow-withdraw-history", ngImport: i0, template: ' <p>coinflow-withdraw-history works!</p> ', isInline: true }); }
|
|
521
732
|
}
|
|
522
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.
|
|
733
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: CoinflowWithdrawHistoryComponent, decorators: [{
|
|
523
734
|
type: Component,
|
|
524
735
|
args: [{
|
|
525
736
|
selector: 'lib-coinflow-withdraw-history',
|