@easyflow/javascript-sdk 2.1.7

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 (93) hide show
  1. package/.babelrc +5 -0
  2. package/.github/workflows/deploy-sdk-cf.yml +49 -0
  3. package/.github/workflows/release-sdk-cdn.yml +144 -0
  4. package/.github/workflows/release-sdk.yml +112 -0
  5. package/.prettierrc +6 -0
  6. package/CDN-DEPLOYMENT.md +175 -0
  7. package/DEMO.md +258 -0
  8. package/DEPLOYMENT.md +224 -0
  9. package/INTEGRATION-GUIDE.md +521 -0
  10. package/README.md +1013 -0
  11. package/coverage/base.css +224 -0
  12. package/coverage/block-navigation.js +87 -0
  13. package/coverage/easyflow-javascript-sdk/index.html +116 -0
  14. package/coverage/easyflow-javascript-sdk/libs/constants.mjs.html +268 -0
  15. package/coverage/easyflow-javascript-sdk/libs/errors.mjs.html +271 -0
  16. package/coverage/easyflow-javascript-sdk/libs/exception-handler.mjs.html +148 -0
  17. package/coverage/easyflow-javascript-sdk/libs/fingerprint.mjs.html +895 -0
  18. package/coverage/easyflow-javascript-sdk/libs/http.mjs.html +502 -0
  19. package/coverage/easyflow-javascript-sdk/libs/index.html +266 -0
  20. package/coverage/easyflow-javascript-sdk/libs/logger.mjs.html +568 -0
  21. package/coverage/easyflow-javascript-sdk/libs/sanitizer.mjs.html +1099 -0
  22. package/coverage/easyflow-javascript-sdk/libs/security.mjs.html +733 -0
  23. package/coverage/easyflow-javascript-sdk/libs/types.mjs.html +508 -0
  24. package/coverage/easyflow-javascript-sdk/libs/utils.mjs.html +379 -0
  25. package/coverage/easyflow-javascript-sdk/libs/validator.mjs.html +2623 -0
  26. package/coverage/easyflow-javascript-sdk/sdk.mjs.html +2434 -0
  27. package/coverage/favicon.png +0 -0
  28. package/coverage/index.html +131 -0
  29. package/coverage/lcov-report/base.css +224 -0
  30. package/coverage/lcov-report/block-navigation.js +87 -0
  31. package/coverage/lcov-report/easyflow-javascript-sdk/index.html +116 -0
  32. package/coverage/lcov-report/easyflow-javascript-sdk/libs/constants.mjs.html +268 -0
  33. package/coverage/lcov-report/easyflow-javascript-sdk/libs/errors.mjs.html +271 -0
  34. package/coverage/lcov-report/easyflow-javascript-sdk/libs/exception-handler.mjs.html +148 -0
  35. package/coverage/lcov-report/easyflow-javascript-sdk/libs/fingerprint.mjs.html +895 -0
  36. package/coverage/lcov-report/easyflow-javascript-sdk/libs/http.mjs.html +502 -0
  37. package/coverage/lcov-report/easyflow-javascript-sdk/libs/index.html +266 -0
  38. package/coverage/lcov-report/easyflow-javascript-sdk/libs/logger.mjs.html +568 -0
  39. package/coverage/lcov-report/easyflow-javascript-sdk/libs/sanitizer.mjs.html +1099 -0
  40. package/coverage/lcov-report/easyflow-javascript-sdk/libs/security.mjs.html +733 -0
  41. package/coverage/lcov-report/easyflow-javascript-sdk/libs/types.mjs.html +508 -0
  42. package/coverage/lcov-report/easyflow-javascript-sdk/libs/utils.mjs.html +379 -0
  43. package/coverage/lcov-report/easyflow-javascript-sdk/libs/validator.mjs.html +2623 -0
  44. package/coverage/lcov-report/easyflow-javascript-sdk/sdk.mjs.html +2434 -0
  45. package/coverage/lcov-report/favicon.png +0 -0
  46. package/coverage/lcov-report/index.html +131 -0
  47. package/coverage/lcov-report/prettify.css +1 -0
  48. package/coverage/lcov-report/prettify.js +2 -0
  49. package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  50. package/coverage/lcov-report/sorter.js +196 -0
  51. package/coverage/lcov.info +1429 -0
  52. package/coverage/prettify.css +1 -0
  53. package/coverage/prettify.js +2 -0
  54. package/coverage/sort-arrow-sprite.png +0 -0
  55. package/coverage/sorter.js +196 -0
  56. package/dist/435.easyflow-sdk.min.js +1 -0
  57. package/dist/easyflow-sdk.min.js +1 -0
  58. package/dist/easyflow-sdk.min.js.LICENSE.txt +1 -0
  59. package/dist/index.html +756 -0
  60. package/docs/index.html +775 -0
  61. package/examples/lovable-integration.html +410 -0
  62. package/index.html +981 -0
  63. package/jest.config.js +37 -0
  64. package/jsdoc.json +42 -0
  65. package/libs/auto-integration.mjs +333 -0
  66. package/libs/constants.mjs +61 -0
  67. package/libs/constants.spec.js +198 -0
  68. package/libs/errors.mjs +62 -0
  69. package/libs/errors.spec.js +178 -0
  70. package/libs/exception-handler.mjs +21 -0
  71. package/libs/exception-handler.spec.js +237 -0
  72. package/libs/fingerprint.mjs +270 -0
  73. package/libs/http.mjs +163 -0
  74. package/libs/http.spec.js +427 -0
  75. package/libs/integration-wrapper.mjs +285 -0
  76. package/libs/logger.mjs +161 -0
  77. package/libs/logger.spec.js +389 -0
  78. package/libs/sanitizer.mjs +340 -0
  79. package/libs/sanitizer.spec.js +583 -0
  80. package/libs/security.mjs +217 -0
  81. package/libs/types.mjs +141 -0
  82. package/libs/utils.mjs +368 -0
  83. package/libs/utils.spec.js +231 -0
  84. package/libs/validator.mjs +952 -0
  85. package/libs/validator.spec.js +615 -0
  86. package/mocks/offer.mock.js +77 -0
  87. package/package.json +72 -0
  88. package/scripts/publish-npm.sh +82 -0
  89. package/sdk.mjs +945 -0
  90. package/sdk.spec.js +796 -0
  91. package/test-setup.cjs +211 -0
  92. package/test.html +154 -0
  93. package/webpack.config.cjs +41 -0
package/test-setup.cjs ADDED
@@ -0,0 +1,211 @@
1
+ // Test setup file for Jest
2
+ // This file is referenced in jest.config.js
3
+
4
+ // Mock global objects that might not be available in Node.js environment
5
+ global.window = {
6
+ crypto: {
7
+ getRandomValues: jest.fn((array) => {
8
+ for (let i = 0; i < array.length; i++) {
9
+ array[i] = Math.floor(Math.random() * 256)
10
+ }
11
+ return array
12
+ }),
13
+ subtle: {
14
+ // Mock Web Crypto API methods if needed
15
+ },
16
+ },
17
+ location: {
18
+ protocol: 'https:',
19
+ hostname: 'localhost',
20
+ origin: 'https://localhost:443',
21
+ },
22
+ top: {},
23
+ self: {},
24
+ trustedTypes: undefined,
25
+ outerHeight: 800,
26
+ innerHeight: 600,
27
+ outerWidth: 1200,
28
+ innerWidth: 1000,
29
+ }
30
+
31
+ // Mock fetch globally
32
+ global.fetch = jest.fn()
33
+
34
+ // Mock console methods to prevent noise in tests
35
+ const originalConsole = { ...console }
36
+ global.console = {
37
+ ...originalConsole,
38
+ log: jest.fn(),
39
+ warn: jest.fn(),
40
+ error: jest.fn(),
41
+ debug: jest.fn(),
42
+ info: jest.fn(),
43
+ }
44
+
45
+ // Mock AbortController
46
+ global.AbortController = jest.fn().mockImplementation(() => ({
47
+ signal: {},
48
+ abort: jest.fn(),
49
+ }))
50
+
51
+ // Mock setTimeout and clearTimeout
52
+ global.setTimeout = jest.fn((callback, delay) => {
53
+ const id = Math.random()
54
+ setTimeout.mock.timers[id] = { callback, delay }
55
+ return id
56
+ })
57
+
58
+ global.clearTimeout = jest.fn((id) => {
59
+ delete setTimeout.mock.timers[id]
60
+ })
61
+
62
+ setTimeout.mock.timers = {}
63
+
64
+ // Mock URL and URLSearchParams
65
+ global.URL = jest.fn().mockImplementation((url, base) => ({
66
+ toString: () => url,
67
+ searchParams: new URLSearchParams(),
68
+ }))
69
+
70
+ global.URLSearchParams = jest.fn().mockImplementation((init) => ({
71
+ toString: () => {
72
+ if (!init) return ''
73
+ return Object.entries(init)
74
+ .map(([key, value]) => `${key}=${encodeURIComponent(value)}`)
75
+ .join('&')
76
+ },
77
+ }))
78
+
79
+ // Mock document for fingerprinting tests
80
+ global.document = {
81
+ createElement: jest.fn((tagName) => {
82
+ if (tagName === 'canvas') {
83
+ return {
84
+ getContext: jest.fn(() => ({
85
+ textBaseline: '',
86
+ font: '',
87
+ fillStyle: '',
88
+ fillRect: jest.fn(),
89
+ fillText: jest.fn(),
90
+ clearRect: jest.fn(),
91
+ clear: jest.fn(),
92
+ createBuffer: jest.fn(() => ({})),
93
+ bindBuffer: jest.fn(),
94
+ bufferData: jest.fn(),
95
+ createProgram: jest.fn(() => ({})),
96
+ createShader: jest.fn(() => ({})),
97
+ shaderSource: jest.fn(),
98
+ compileShader: jest.fn(),
99
+ attachShader: jest.fn(),
100
+ linkProgram: jest.fn(),
101
+ useProgram: jest.fn(),
102
+ getAttribLocation: jest.fn(),
103
+ getUniformLocation: jest.fn(),
104
+ enableVertexAttribArray: jest.fn(),
105
+ vertexAttribPointer: jest.fn(),
106
+ uniform2f: jest.fn(),
107
+ drawArrays: jest.fn(),
108
+ readPixels: jest.fn(),
109
+ getParameter: jest.fn(() => 'mock-parameter'),
110
+ getSupportedExtensions: jest.fn(() => ['mock-extension']),
111
+ ARRAY_BUFFER: 'ARRAY_BUFFER',
112
+ STATIC_DRAW: 'STATIC_DRAW',
113
+ VERTEX_SHADER: 'VERTEX_SHADER',
114
+ FRAGMENT_SHADER: 'FRAGMENT_SHADER',
115
+ TRIANGLE_STRIP: 'TRIANGLE_STRIP',
116
+ RGBA: 'RGBA',
117
+ UNSIGNED_BYTE: 'UNSIGNED_BYTE',
118
+ COLOR_BUFFER_BIT: 'COLOR_BUFFER_BIT',
119
+ DEPTH_BUFFER_BIT: 'DEPTH_BUFFER_BIT',
120
+ STENCIL_BUFFER_BIT: 'STENCIL_BUFFER_BIT',
121
+ VERSION: 'VERSION',
122
+ SHADING_LANGUAGE_VERSION: 'SHADING_LANGUAGE_VERSION',
123
+ VENDOR: 'VENDOR',
124
+ })),
125
+ toDataURL: jest.fn(() => 'data:image/png;base64,mock-data'),
126
+ width: 256,
127
+ height: 128,
128
+ }
129
+ }
130
+ return {}
131
+ }),
132
+ body: {
133
+ appendChild: jest.fn(),
134
+ },
135
+ }
136
+
137
+ // Mock navigator
138
+ global.navigator = {
139
+ cookieEnabled: true,
140
+ deviceMemory: 8,
141
+ doNotTrack: null,
142
+ hardwareConcurrency: 4,
143
+ language: 'en-US',
144
+ languages: ['en-US', 'en'],
145
+ maxTouchPoints: 0,
146
+ platform: 'Win32',
147
+ userAgent: 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36',
148
+ vendor: 'Google Inc.',
149
+ }
150
+
151
+ // Mock screen
152
+ global.screen = {
153
+ width: 1920,
154
+ height: 1080,
155
+ colorDepth: 24,
156
+ pixelDepth: 24,
157
+ }
158
+
159
+ // Mock Date
160
+ const originalDate = global.Date
161
+ global.Date = class extends originalDate {
162
+ constructor(...args) {
163
+ if (args.length === 0) {
164
+ return new originalDate('2023-01-01T00:00:00.000Z')
165
+ }
166
+ return new originalDate(...args)
167
+ }
168
+
169
+ static now() {
170
+ return new originalDate('2023-01-01T00:00:00.000Z').getTime()
171
+ }
172
+ }
173
+
174
+ // Mock Intl
175
+ global.Intl = {
176
+ DateTimeFormat: jest.fn(() => ({
177
+ resolvedOptions: jest.fn(() => ({
178
+ timeZone: 'America/New_York',
179
+ })),
180
+ })),
181
+ }
182
+
183
+ // Mock Math.random for consistent tests
184
+ const originalMathRandom = Math.random
185
+ Math.random = jest.fn(() => 0.5)
186
+
187
+ // Mock crypto.getRandomValues for consistent fingerprinting
188
+ const originalGetRandomValues = global.window.crypto.getRandomValues
189
+ global.window.crypto.getRandomValues = jest.fn((array) => {
190
+ for (let i = 0; i < array.length; i++) {
191
+ array[i] = i % 256 // Consistent values for testing
192
+ }
193
+ return array
194
+ })
195
+
196
+ // Cleanup function to restore mocks
197
+ afterEach(() => {
198
+ jest.clearAllMocks()
199
+ fetch.mockClear()
200
+ console.log.mockClear()
201
+ console.warn.mockClear()
202
+ console.error.mockClear()
203
+ console.debug.mockClear()
204
+ console.info.mockClear()
205
+ })
206
+
207
+ // Restore original functions after all tests
208
+ afterAll(() => {
209
+ Math.random = originalMathRandom
210
+ global.window.crypto.getRandomValues = originalGetRandomValues
211
+ })
package/test.html ADDED
@@ -0,0 +1,154 @@
1
+ <!DOCTYPE html>
2
+ <html lang="en">
3
+ <head>
4
+ <meta charset="UTF-8">
5
+ <meta content="width=device-width, initial-scale=1.0" name="viewport">
6
+ <title>Easyflow SDK Test</title>
7
+ </head>
8
+ <body>
9
+ <h1>Easyflow SDK Test</h1>
10
+ <button onclick="testPurchase()">Test Purchase</button>
11
+ <p id="result"></p>
12
+
13
+ <!-- Carregar o script ANTES de usá-lo -->
14
+ <script src="https://easyflow-sdk.pages.dev/easyflow-sdk.min.js"></script>
15
+
16
+ <script>
17
+ async function testPurchase() {
18
+ try {
19
+ debugger
20
+ const businessId = '6bbf1a80-6a6d-4a33-abdd-50c34860bcd3'
21
+ const sdk = new EasyflowSDK({ businessId })
22
+ const offerId = '290fef7a-5dba-4be1-8315-9e5426dcfe00'
23
+ const offer = await sdk.getOffer(offerId)
24
+ console.log('Offer Details:', offer)
25
+ const params = {
26
+ buyer: {
27
+ 'name': 'Eduardo Rotundaro',
28
+ 'email': 'diegomoura637@gmail.com',
29
+ 'document': {
30
+ 'number': '01234567890',
31
+ 'type': 'CPF',
32
+ },
33
+ 'phone': {
34
+ 'areaCode': '+55',
35
+ 'ddd': '92',
36
+ 'number': '984292191',
37
+ 'isMobile': true,
38
+ },
39
+ 'address': {
40
+ 'zipCode': '37537074',
41
+ 'street': 'Rua Richard Conrad Menezes de Alckmin',
42
+ 'complement': '',
43
+ 'neighborhood': 'Morada do Sol',
44
+ 'city': 'Santa Rita do Sapucaí',
45
+ 'state': 'MG',
46
+ 'number': '233',
47
+ },
48
+ },
49
+ 'payments': [
50
+ {
51
+ 'method': 'pix',
52
+ 'numberInstallments': 1,
53
+ 'valueInCents': 500,
54
+ // 'creditCard': {
55
+ // 'cardNumber': '',
56
+ // 'cvv': '',
57
+ // 'month': '',
58
+ // 'year': '',
59
+ // 'holderName': '',
60
+ // },
61
+ },
62
+ ],
63
+ items: [{
64
+ name: 'Carregador de Celular',
65
+ description: 'Carregador de celular com cabo USB-C',
66
+ quantity: 1,
67
+ priceInCents: 500,
68
+ }],
69
+ }
70
+ // const orderId = await sdk.charge(params)
71
+ // console.log('Order ID:', orderId)
72
+ // const order = await sdk.getOrder(orderId)
73
+ // console.log('Order ID:', orderId)
74
+ // console.log('Order Details:', order)
75
+
76
+ // const orderId2 = await sdk.placeOrder(offerId, params)
77
+ // const order2 = await sdk.getOrder(orderId)
78
+ // console.log('Order ID 2:', orderId2)
79
+ // console.log('Order 2 Details:', order2)
80
+
81
+ debugger
82
+ const newCustomer = await sdk.createCustomer({
83
+ 'businessId': '6bbf1a80-6a6d-4a33-abdd-50c34860bcd3',
84
+ 'name': 'Diego Moura',
85
+ 'email': 'diegomoura637+50@gmail.com',
86
+ 'deliveryAddress': {
87
+ 'zipCode': '37540114',
88
+ 'street': 'Rua Marechal Deodoro',
89
+ 'complement': 'Apt',
90
+ 'neighborhood': 'Centro',
91
+ 'city': 'Pouso Alegre',
92
+ 'state': 'MG',
93
+ 'number': '33',
94
+ },
95
+ 'address': {
96
+ 'zipCode': '37540114',
97
+ 'street': 'Rua Marechal Deodoro',
98
+ 'complement': 'Apt',
99
+ 'neighborhood': 'Centro',
100
+ 'city': 'Pouso Alegre',
101
+ 'state': 'MG',
102
+ 'number': '33',
103
+ },
104
+ 'document': {
105
+ 'type': 'CPF',
106
+ 'number': '01234567890',
107
+ },
108
+ 'phone': {
109
+ 'areaCode': '+55',
110
+ 'ddd': '11',
111
+ 'number': '998862782',
112
+ 'isMobile': true,
113
+ },
114
+ })
115
+
116
+ console.log('New Customer:', newCustomer)
117
+
118
+ await sdk.updateCustomer(newCustomer.id, { 'name': 'Diego Moura Updated' })
119
+
120
+ const updatedCustomer = await sdk.getCustomer(newCustomer.id)
121
+ console.log('Updated Customer:', updatedCustomer)
122
+
123
+ const creditCardEncrypted = await sdk.encrypt({
124
+ 'cardNumber': '4022827530107566',
125
+ 'cvv': '991',
126
+ 'month': '09',
127
+ 'year': '2026',
128
+ 'holderName': 'Fernando Barrows',
129
+ })
130
+
131
+ console.log('Encrypted Credit Card:', creditCardEncrypted)
132
+
133
+ const response = await sdk.addCreditCard(newCustomer.id, creditCardEncrypted)
134
+ console.log('Credit Card Added:', response)
135
+
136
+ const params2 = JSON.parse(JSON.stringify(params))
137
+ params2.buyer['customerId'] = newCustomer.id
138
+ params2.payments[0]['creditCard'] = {
139
+ 'cardId': response.id,
140
+ }
141
+
142
+ const orderId3 = await sdk.charge(params2)
143
+ const order3 = await sdk.getOrder(orderId3)
144
+ console.log('Order ID 3:', orderId3)
145
+ console.log('Order 3 Details:', order3)
146
+
147
+
148
+ } catch (error) {
149
+ console.error('Error:', error)
150
+ }
151
+ }
152
+ </script>
153
+ </body>
154
+ </html>
@@ -0,0 +1,41 @@
1
+ const path = require('path')
2
+ const TerserPlugin = require('terser-webpack-plugin')
3
+ const WebpackObfuscator = require('webpack-obfuscator')
4
+
5
+ const config = {
6
+ mode: 'production',
7
+ entry: './sdk.mjs',
8
+ output: {
9
+ filename: 'easyflow-sdk.min.js',
10
+ path: path.resolve(__dirname, 'dist'),
11
+ },
12
+ module: {
13
+ rules: [
14
+ {
15
+ test: /\.m?js$/,
16
+ include: /lib/,
17
+ exclude: /node_modules/,
18
+ use: {
19
+ loader: 'babel-loader',
20
+ options: {
21
+ presets: ['@babel/preset-env'],
22
+ },
23
+ },
24
+ },
25
+ ],
26
+ },
27
+ devtool: 'source-map',
28
+ optimization: {
29
+ minimize: true,
30
+ minimizer: [new TerserPlugin()],
31
+ },
32
+ plugins: [
33
+ new WebpackObfuscator({
34
+ rotateStringArray: true,
35
+ stringArray: true,
36
+ stringArrayThreshold: 0.75,
37
+ }),
38
+ ],
39
+ }
40
+
41
+ module.exports = config