@tellescope/sdk 1.247.0 → 1.248.0

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 (72) hide show
  1. package/lib/cjs/sdk.d.ts +6 -1
  2. package/lib/cjs/sdk.d.ts.map +1 -1
  3. package/lib/cjs/sdk.js +2 -0
  4. package/lib/cjs/sdk.js.map +1 -1
  5. package/lib/cjs/tests/api_tests/date_string_validation.test.d.ts +6 -0
  6. package/lib/cjs/tests/api_tests/date_string_validation.test.d.ts.map +1 -0
  7. package/lib/cjs/tests/api_tests/date_string_validation.test.js +142 -0
  8. package/lib/cjs/tests/api_tests/date_string_validation.test.js.map +1 -0
  9. package/lib/cjs/tests/api_tests/enduser_session_invalidation.test.d.ts +6 -0
  10. package/lib/cjs/tests/api_tests/enduser_session_invalidation.test.d.ts.map +1 -0
  11. package/lib/cjs/tests/api_tests/enduser_session_invalidation.test.js +243 -0
  12. package/lib/cjs/tests/api_tests/enduser_session_invalidation.test.js.map +1 -0
  13. package/lib/cjs/tests/api_tests/field_redaction.test.d.ts +13 -0
  14. package/lib/cjs/tests/api_tests/field_redaction.test.d.ts.map +1 -0
  15. package/lib/cjs/tests/api_tests/field_redaction.test.js +818 -0
  16. package/lib/cjs/tests/api_tests/field_redaction.test.js.map +1 -0
  17. package/lib/cjs/tests/api_tests/form_submitted_trigger.test.d.ts +6 -0
  18. package/lib/cjs/tests/api_tests/form_submitted_trigger.test.d.ts.map +1 -0
  19. package/lib/cjs/tests/api_tests/form_submitted_trigger.test.js +429 -0
  20. package/lib/cjs/tests/api_tests/form_submitted_trigger.test.js.map +1 -0
  21. package/lib/cjs/tests/api_tests/integrations_redacted.test.d.ts +6 -0
  22. package/lib/cjs/tests/api_tests/integrations_redacted.test.d.ts.map +1 -0
  23. package/lib/cjs/tests/api_tests/integrations_redacted.test.js +273 -0
  24. package/lib/cjs/tests/api_tests/integrations_redacted.test.js.map +1 -0
  25. package/lib/cjs/tests/api_tests/openloop_webhooks.test.d.ts.map +1 -1
  26. package/lib/cjs/tests/api_tests/openloop_webhooks.test.js +108 -24
  27. package/lib/cjs/tests/api_tests/openloop_webhooks.test.js.map +1 -1
  28. package/lib/cjs/tests/tests.d.ts.map +1 -1
  29. package/lib/cjs/tests/tests.js +294 -183
  30. package/lib/cjs/tests/tests.js.map +1 -1
  31. package/lib/esm/sdk.d.ts +6 -1
  32. package/lib/esm/sdk.d.ts.map +1 -1
  33. package/lib/esm/sdk.js +2 -0
  34. package/lib/esm/sdk.js.map +1 -1
  35. package/lib/esm/tests/api_tests/date_string_validation.test.d.ts +6 -0
  36. package/lib/esm/tests/api_tests/date_string_validation.test.d.ts.map +1 -0
  37. package/lib/esm/tests/api_tests/date_string_validation.test.js +138 -0
  38. package/lib/esm/tests/api_tests/date_string_validation.test.js.map +1 -0
  39. package/lib/esm/tests/api_tests/enduser_session_invalidation.test.d.ts +6 -0
  40. package/lib/esm/tests/api_tests/enduser_session_invalidation.test.d.ts.map +1 -0
  41. package/lib/esm/tests/api_tests/enduser_session_invalidation.test.js +239 -0
  42. package/lib/esm/tests/api_tests/enduser_session_invalidation.test.js.map +1 -0
  43. package/lib/esm/tests/api_tests/field_redaction.test.d.ts +13 -0
  44. package/lib/esm/tests/api_tests/field_redaction.test.d.ts.map +1 -0
  45. package/lib/esm/tests/api_tests/field_redaction.test.js +814 -0
  46. package/lib/esm/tests/api_tests/field_redaction.test.js.map +1 -0
  47. package/lib/esm/tests/api_tests/form_submitted_trigger.test.d.ts +6 -0
  48. package/lib/esm/tests/api_tests/form_submitted_trigger.test.d.ts.map +1 -0
  49. package/lib/esm/tests/api_tests/form_submitted_trigger.test.js +425 -0
  50. package/lib/esm/tests/api_tests/form_submitted_trigger.test.js.map +1 -0
  51. package/lib/esm/tests/api_tests/integrations_redacted.test.d.ts +6 -0
  52. package/lib/esm/tests/api_tests/integrations_redacted.test.d.ts.map +1 -0
  53. package/lib/esm/tests/api_tests/integrations_redacted.test.js +269 -0
  54. package/lib/esm/tests/api_tests/integrations_redacted.test.js.map +1 -0
  55. package/lib/esm/tests/api_tests/openloop_webhooks.test.d.ts.map +1 -1
  56. package/lib/esm/tests/api_tests/openloop_webhooks.test.js +108 -24
  57. package/lib/esm/tests/api_tests/openloop_webhooks.test.js.map +1 -1
  58. package/lib/esm/tests/tests.d.ts.map +1 -1
  59. package/lib/esm/tests/tests.js +294 -183
  60. package/lib/esm/tests/tests.js.map +1 -1
  61. package/lib/tsconfig.tsbuildinfo +1 -1
  62. package/package.json +10 -10
  63. package/src/sdk.ts +10 -0
  64. package/src/tests/api_tests/date_string_validation.test.ts +107 -0
  65. package/src/tests/api_tests/enduser_session_invalidation.test.ts +138 -0
  66. package/src/tests/api_tests/field_redaction.test.ts +669 -0
  67. package/src/tests/api_tests/form_started_trigger.test.ts +1 -1
  68. package/src/tests/api_tests/form_submitted_trigger.test.ts +281 -0
  69. package/src/tests/api_tests/integrations_redacted.test.ts +245 -0
  70. package/src/tests/api_tests/openloop_webhooks.test.ts +64 -0
  71. package/src/tests/tests.ts +86 -6
  72. package/test_generated.pdf +0 -0
@@ -0,0 +1,107 @@
1
+ require('source-map-support').install();
2
+
3
+ import { Session } from "../../sdk"
4
+ import {
5
+ assert,
6
+ log_header,
7
+ } from "@tellescope/testing"
8
+ import { setup_tests } from "../setup"
9
+ import { is_valid_mm_dd_yyyy } from "@tellescope/validation"
10
+
11
+ const host = process.env.API_URL || 'http://localhost:8080' as const
12
+
13
+ export const date_string_validation_tests = async ({ sdk, sdkNonAdmin } : { sdk: Session, sdkNonAdmin: Session }) => {
14
+ log_header("Date String Validation Tests (is_valid_mm_dd_yyyy)")
15
+
16
+ // --- Valid standard dates ---
17
+ assert(is_valid_mm_dd_yyyy('01-15-1990') === true, 'Expected 01-15-1990 to be valid', 'valid: 01-15-1990')
18
+ assert(is_valid_mm_dd_yyyy('12-31-2024') === true, 'Expected 12-31-2024 to be valid', 'valid: 12-31-2024')
19
+ assert(is_valid_mm_dd_yyyy('06-15-2000') === true, 'Expected 06-15-2000 to be valid', 'valid: 06-15-2000')
20
+ assert(is_valid_mm_dd_yyyy('01-01-2000') === true, 'Expected 01-01-2000 to be valid', 'valid: 01-01-2000')
21
+
22
+ // --- Leap year: Feb 29 accepted ---
23
+ assert(is_valid_mm_dd_yyyy('02-29-2024') === true, 'Expected 02-29-2024 to be valid (2024 is leap year, div by 4)', 'valid: 02-29-2024 (leap year)')
24
+ assert(is_valid_mm_dd_yyyy('02-29-2000') === true, 'Expected 02-29-2000 to be valid (2000 is leap year, div by 400)', 'valid: 02-29-2000 (leap year)')
25
+ assert(is_valid_mm_dd_yyyy('02-29-2400') === true, 'Expected 02-29-2400 to be valid (2400 is leap year, div by 400)', 'valid: 02-29-2400 (leap year)')
26
+
27
+ // --- Non-leap year: Feb 29 rejected ---
28
+ assert(is_valid_mm_dd_yyyy('02-29-2023') === false, 'Expected 02-29-2023 to be invalid (2023 is not a leap year)', 'invalid: 02-29-2023 (not leap year)')
29
+ assert(is_valid_mm_dd_yyyy('02-29-1900') === false, 'Expected 02-29-1900 to be invalid (1900 div by 100 but not 400)', 'invalid: 02-29-1900 (not leap year)')
30
+ assert(is_valid_mm_dd_yyyy('02-29-2100') === false, 'Expected 02-29-2100 to be invalid (2100 div by 100 but not 400)', 'invalid: 02-29-2100 (not leap year)')
31
+ assert(is_valid_mm_dd_yyyy('02-29-2025') === false, 'Expected 02-29-2025 to be invalid (2025 is not a leap year)', 'invalid: 02-29-2025 (not leap year)')
32
+
33
+ // --- Feb 30 and Feb 31 always rejected (the original bug) ---
34
+ assert(is_valid_mm_dd_yyyy('02-30-2024') === false, 'Expected 02-30-2024 to be invalid (Feb never has 30 days)', 'invalid: 02-30-2024 (Feb 30 leap year)')
35
+ assert(is_valid_mm_dd_yyyy('02-31-2024') === false, 'Expected 02-31-2024 to be invalid (Feb never has 31 days)', 'invalid: 02-31-2024 (Feb 31 leap year)')
36
+ assert(is_valid_mm_dd_yyyy('02-30-2023') === false, 'Expected 02-30-2023 to be invalid (Feb never has 30 days)', 'invalid: 02-30-2023 (Feb 30 non-leap)')
37
+ assert(is_valid_mm_dd_yyyy('02-31-2023') === false, 'Expected 02-31-2023 to be invalid (Feb never has 31 days)', 'invalid: 02-31-2023 (Feb 31 non-leap)')
38
+
39
+ // --- Feb 28 always valid ---
40
+ assert(is_valid_mm_dd_yyyy('02-28-2024') === true, 'Expected 02-28-2024 to be valid', 'valid: 02-28-2024')
41
+ assert(is_valid_mm_dd_yyyy('02-28-2023') === true, 'Expected 02-28-2023 to be valid', 'valid: 02-28-2023')
42
+
43
+ // --- 30-day months: day 31 rejected ---
44
+ assert(is_valid_mm_dd_yyyy('04-31-2024') === false, 'Expected 04-31-2024 to be invalid (April has 30 days)', 'invalid: 04-31 (April)')
45
+ assert(is_valid_mm_dd_yyyy('06-31-2024') === false, 'Expected 06-31-2024 to be invalid (June has 30 days)', 'invalid: 06-31 (June)')
46
+ assert(is_valid_mm_dd_yyyy('09-31-2024') === false, 'Expected 09-31-2024 to be invalid (September has 30 days)', 'invalid: 09-31 (September)')
47
+ assert(is_valid_mm_dd_yyyy('11-31-2024') === false, 'Expected 11-31-2024 to be invalid (November has 30 days)', 'invalid: 11-31 (November)')
48
+
49
+ // --- 30-day months: day 30 accepted ---
50
+ assert(is_valid_mm_dd_yyyy('04-30-2024') === true, 'Expected 04-30-2024 to be valid', 'valid: 04-30 (April)')
51
+ assert(is_valid_mm_dd_yyyy('06-30-2024') === true, 'Expected 06-30-2024 to be valid', 'valid: 06-30 (June)')
52
+ assert(is_valid_mm_dd_yyyy('09-30-2024') === true, 'Expected 09-30-2024 to be valid', 'valid: 09-30 (September)')
53
+ assert(is_valid_mm_dd_yyyy('11-30-2024') === true, 'Expected 11-30-2024 to be valid', 'valid: 11-30 (November)')
54
+
55
+ // --- 31-day months: day 31 accepted ---
56
+ assert(is_valid_mm_dd_yyyy('01-31-2024') === true, 'Expected 01-31-2024 to be valid', 'valid: 01-31 (January)')
57
+ assert(is_valid_mm_dd_yyyy('03-31-2024') === true, 'Expected 03-31-2024 to be valid', 'valid: 03-31 (March)')
58
+ assert(is_valid_mm_dd_yyyy('05-31-2024') === true, 'Expected 05-31-2024 to be valid', 'valid: 05-31 (May)')
59
+ assert(is_valid_mm_dd_yyyy('07-31-2024') === true, 'Expected 07-31-2024 to be valid', 'valid: 07-31 (July)')
60
+ assert(is_valid_mm_dd_yyyy('08-31-2024') === true, 'Expected 08-31-2024 to be valid', 'valid: 08-31 (August)')
61
+ assert(is_valid_mm_dd_yyyy('10-31-2024') === true, 'Expected 10-31-2024 to be valid', 'valid: 10-31 (October)')
62
+ assert(is_valid_mm_dd_yyyy('12-31-2024') === true, 'Expected 12-31-2024 to be valid', 'valid: 12-31 (December)')
63
+
64
+ // --- Invalid month values ---
65
+ assert(is_valid_mm_dd_yyyy('00-15-2024') === false, 'Expected month 00 to be invalid', 'invalid: month 00')
66
+ assert(is_valid_mm_dd_yyyy('13-15-2024') === false, 'Expected month 13 to be invalid', 'invalid: month 13')
67
+
68
+ // --- Invalid day values ---
69
+ assert(is_valid_mm_dd_yyyy('01-00-2024') === false, 'Expected day 00 to be invalid', 'invalid: day 00')
70
+ assert(is_valid_mm_dd_yyyy('01-32-2024') === false, 'Expected day 32 to be invalid', 'invalid: day 32')
71
+
72
+ // --- Malformed strings ---
73
+ assert(is_valid_mm_dd_yyyy('') === false, 'Expected empty string to be invalid', 'invalid: empty string')
74
+ assert(is_valid_mm_dd_yyyy('not-a-date') === false, 'Expected text to be invalid', 'invalid: text')
75
+ assert(is_valid_mm_dd_yyyy('2024-01-15') === false, 'Expected YYYY-MM-DD to be invalid', 'invalid: YYYY-MM-DD format')
76
+ assert(is_valid_mm_dd_yyyy('1-15-2024') === false, 'Expected single-digit month to be invalid', 'invalid: single-digit month')
77
+ assert(is_valid_mm_dd_yyyy('01/15/2024') === false, 'Expected slashes to be invalid', 'invalid: slashes')
78
+ assert(is_valid_mm_dd_yyyy('01-15-24') === false, 'Expected 2-digit year to be invalid', 'invalid: 2-digit year')
79
+ assert(is_valid_mm_dd_yyyy('01-5-2024') === false, 'Expected single-digit day to be invalid', 'invalid: single-digit day')
80
+ assert(is_valid_mm_dd_yyyy('01-15-20240') === false, 'Expected 5-digit year to be invalid', 'invalid: 5-digit year')
81
+
82
+ // --- Whitespace trimming ---
83
+ assert(is_valid_mm_dd_yyyy(' 01-15-1990 ') === true, 'Expected trimmed whitespace to be valid', 'valid: whitespace trimmed')
84
+ assert(is_valid_mm_dd_yyyy(' 02-28-2024 ') === true, 'Expected trimmed whitespace to be valid', 'valid: whitespace trimmed (2)')
85
+ }
86
+
87
+ // Allow running this test file independently
88
+ if (require.main === module) {
89
+ console.log(`Using API URL: ${host}`)
90
+ const sdk = new Session({ host })
91
+ const sdkNonAdmin = new Session({ host })
92
+
93
+ const runTests = async () => {
94
+ await setup_tests(sdk, sdkNonAdmin)
95
+ await date_string_validation_tests({ sdk, sdkNonAdmin })
96
+ }
97
+
98
+ runTests()
99
+ .then(() => {
100
+ console.log("Date string validation test suite completed successfully")
101
+ process.exit(0)
102
+ })
103
+ .catch((error) => {
104
+ console.error("Date string validation test suite failed:", error)
105
+ process.exit(1)
106
+ })
107
+ }
@@ -0,0 +1,138 @@
1
+ require('source-map-support').install();
2
+
3
+ import { Session, EnduserSession } from "../../sdk"
4
+ import {
5
+ async_test,
6
+ handleAnyError,
7
+ log_header,
8
+ wait,
9
+ } from "@tellescope/testing"
10
+ import { setup_tests } from "../setup"
11
+
12
+ const host = process.env.API_URL || 'http://localhost:8080' as const
13
+ const businessId = '60398b1131a295e64f084ff6'
14
+
15
+ // Main test function that can be called independently
16
+ export const enduser_session_invalidation_tests = async ({ sdk, sdkNonAdmin } : { sdk: Session, sdkNonAdmin: Session }) => {
17
+ log_header("Enduser Session Invalidation Tests")
18
+
19
+ // Create test enduser
20
+ const testEnduser = await sdk.api.endusers.createOne({ email: `session-invalidation-test-${Date.now()}@tellescope.com` })
21
+
22
+ try {
23
+ // Generate auth token for the enduser
24
+ const { authToken } = await sdk.api.endusers.generate_auth_token({ id: testEnduser.id })
25
+ const enduserSDK = new EnduserSession({ host, authToken, businessId: sdk.userInfo.businessId })
26
+
27
+ // Test 1: Enduser authenticated before invalidation
28
+ await async_test(
29
+ 'enduser authenticated before invalidation',
30
+ () => enduserSDK.test_authenticated(),
31
+ { expectedResult: 'Authenticated!' }
32
+ )
33
+
34
+ // Wait to ensure time separation between token creation and invalidation
35
+ await wait(undefined, 2000)
36
+
37
+ // Test 2: Setting invalidateSessionsBefore rejects old token (401)
38
+ await async_test(
39
+ 'setting invalidateSessionsBefore rejects old token',
40
+ async () => {
41
+ await sdk.api.endusers.updateOne(testEnduser.id, { invalidateSessionsBefore: new Date() })
42
+
43
+ // Old token should now be rejected
44
+ try {
45
+ await enduserSDK.test_authenticated()
46
+ return 'should have thrown'
47
+ } catch (e) {
48
+ return 'rejected'
49
+ }
50
+ },
51
+ { expectedResult: 'rejected' }
52
+ )
53
+
54
+ // Test 3: New token after invalidation works
55
+ await async_test(
56
+ 'new token after invalidation works',
57
+ async () => {
58
+ // Wait to ensure new token iat is after invalidateSessionsBefore
59
+ await wait(undefined, 2000)
60
+
61
+ const { authToken: newAuthToken } = await sdk.api.endusers.generate_auth_token({ id: testEnduser.id })
62
+ const newEnduserSDK = new EnduserSession({ host, authToken: newAuthToken, businessId: sdk.userInfo.businessId })
63
+
64
+ return await newEnduserSDK.test_authenticated()
65
+ },
66
+ { expectedResult: 'Authenticated!' }
67
+ )
68
+
69
+ // Test 4: Cannot set invalidateSessionsBefore backwards (constraint error)
70
+ await async_test(
71
+ 'cannot set invalidateSessionsBefore backwards',
72
+ async () => {
73
+ // Try to set invalidateSessionsBefore to a date in the past (before current value)
74
+ const pastDate = new Date(Date.now() - 24 * 60 * 60 * 1000) // 1 day ago
75
+ await sdk.api.endusers.updateOne(testEnduser.id, { invalidateSessionsBefore: pastDate })
76
+ },
77
+ handleAnyError
78
+ )
79
+
80
+ // Test 5: Deleted enduser token rejected (401)
81
+ await async_test(
82
+ 'deleted enduser token rejected',
83
+ async () => {
84
+ // Create a separate enduser, get token, then delete enduser
85
+ const tempEnduser = await sdk.api.endusers.createOne({ email: `temp-session-test-${Date.now()}@tellescope.com` })
86
+ const { authToken: tempAuthToken } = await sdk.api.endusers.generate_auth_token({ id: tempEnduser.id })
87
+ const tempEnduserSDK = new EnduserSession({ host, authToken: tempAuthToken, businessId: sdk.userInfo.businessId })
88
+
89
+ // Verify token works before deletion
90
+ await tempEnduserSDK.test_authenticated()
91
+
92
+ // Delete the enduser
93
+ await sdk.api.endusers.deleteOne(tempEnduser.id)
94
+
95
+ // Token should now be rejected
96
+ try {
97
+ await tempEnduserSDK.test_authenticated()
98
+ return 'should have thrown'
99
+ } catch (e) {
100
+ return 'rejected'
101
+ }
102
+ },
103
+ { expectedResult: 'rejected' }
104
+ )
105
+
106
+ console.log("✅ All Enduser Session Invalidation tests passed!")
107
+
108
+ } finally {
109
+ // Cleanup: Delete test enduser
110
+ try {
111
+ await sdk.api.endusers.deleteOne(testEnduser.id)
112
+ } catch (error) {
113
+ console.error('Cleanup error:', error)
114
+ }
115
+ }
116
+ }
117
+
118
+ // Allow running this test file independently
119
+ if (require.main === module) {
120
+ console.log(`🌐 Using API URL: ${host}`)
121
+ const sdk = new Session({ host })
122
+ const sdkNonAdmin = new Session({ host })
123
+
124
+ const runTests = async () => {
125
+ await setup_tests(sdk, sdkNonAdmin)
126
+ await enduser_session_invalidation_tests({ sdk, sdkNonAdmin })
127
+ }
128
+
129
+ runTests()
130
+ .then(() => {
131
+ console.log("✅ Enduser session invalidation test suite completed successfully")
132
+ process.exit(0)
133
+ })
134
+ .catch((error) => {
135
+ console.error("❌ Enduser session invalidation test suite failed:", error)
136
+ process.exit(1)
137
+ })
138
+ }