@taruvi/sdk 1.3.3 → 1.3.4-beta.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.
- package/.claude/settings.local.json +19 -0
- package/.kiro/settings/lsp.json +198 -0
- package/MODULE_NAMING_CHANGES.md +81 -0
- package/PARAMETER_NAMING_CHANGES.md +106 -0
- package/README.md +4 -4
- package/USAGE_EXAMPLE.md +86 -0
- package/package.json +10 -9
- package/{dist/client.js → src/client.ts} +59 -39
- package/src/index.ts +54 -0
- package/src/lib/analytics/AnalyticsClient.ts +24 -0
- package/src/lib/analytics/types.ts +8 -0
- package/src/lib/app/AppClient.ts +54 -0
- package/src/lib/app/types.ts +50 -0
- package/{dist/lib/auth/AuthClient.js → src/lib/auth/AuthClient.ts} +106 -70
- package/src/lib/auth/types.ts +111 -0
- package/src/lib/database/DatabaseClient.ts +148 -0
- package/src/lib/database/types.ts +46 -0
- package/src/lib/functions/FunctionsClient.ts +27 -0
- package/src/lib/functions/types.ts +25 -0
- package/src/lib/graphs/GraphClient.ts +106 -0
- package/src/lib/graphs/types.ts +33 -0
- package/src/lib/policy/PolicyClient.ts +79 -0
- package/src/lib/policy/types.ts +40 -0
- package/src/lib/secrets/SecretsClient.ts +75 -0
- package/src/lib/secrets/types.ts +59 -0
- package/src/lib/settings/SettingsClient.ts +14 -0
- package/src/lib/settings/types.ts +9 -0
- package/src/lib/storage/StorageClient.ts +123 -0
- package/src/lib/storage/types.ts +86 -0
- package/src/lib/users/UserClient.ts +55 -0
- package/src/lib/users/types.ts +104 -0
- package/src/lib-internal/errors/ErrorClient.ts +102 -0
- package/src/lib-internal/errors/index.ts +3 -0
- package/src/lib-internal/errors/types.ts +28 -0
- package/src/lib-internal/http/HttpClient.ts +129 -0
- package/{dist/lib-internal/http/types.js → src/lib-internal/http/types.ts} +3 -2
- package/src/lib-internal/routes/AnalyticsRoutes.ts +3 -0
- package/src/lib-internal/routes/AppRoutes.ts +9 -0
- package/src/lib-internal/routes/AuthRoutes.ts +0 -0
- package/src/lib-internal/routes/DatabaseRoutes.ts +9 -0
- package/src/lib-internal/routes/FunctionRoutes.ts +3 -0
- package/src/lib-internal/routes/GraphRoutes.ts +14 -0
- package/src/lib-internal/routes/PolicyRoutes.ts +4 -0
- package/src/lib-internal/routes/SecretsRoutes.ts +5 -0
- package/{dist/lib-internal/routes/SettingsRoutes.js → src/lib-internal/routes/SettingsRoutes.ts} +1 -2
- package/src/lib-internal/routes/StorageRoutes.ts +15 -0
- package/src/lib-internal/routes/UserRoutes.ts +11 -0
- package/src/lib-internal/routes/index.ts +0 -0
- package/{dist/lib-internal/token/TokenClient.js → src/lib-internal/token/TokenClient.ts} +144 -99
- package/src/lib-internal/token/types.ts +0 -0
- package/src/types.ts +90 -0
- package/{dist/utils/enums.js → src/utils/enums.ts} +10 -4
- package/src/utils/utils.ts +37 -0
- package/tests/fixtures/mockClient.ts +19 -0
- package/tests/mocks/db.json +1 -0
- package/tests/unit/analytics/AnalyticsClient.test.ts +84 -0
- package/tests/unit/app/AppClient.test.ts +114 -0
- package/tests/unit/auth/AuthClient.test.ts +131 -0
- package/tests/unit/client/Client.test.ts +70 -0
- package/tests/unit/database/DatabaseClient.test.ts +304 -0
- package/tests/unit/edge-cases/robustness.test.ts +259 -0
- package/tests/unit/errors/errors.test.ts +209 -0
- package/tests/unit/functions/FunctionsClient.test.ts +99 -0
- package/tests/unit/graphs/GraphClient.test.ts +329 -0
- package/tests/unit/policy/PolicyClient.test.ts +184 -0
- package/tests/unit/secrets/SecretsClient.test.ts +146 -0
- package/tests/unit/settings/SettingsClient.test.ts +50 -0
- package/tests/unit/storage/StorageClient.test.ts +251 -0
- package/tests/unit/users/UserClient.test.ts +150 -0
- package/tsconfig.json +43 -0
- package/vitest.config.ts +7 -0
- package/dist/client.d.ts +0 -29
- package/dist/client.d.ts.map +0 -1
- package/dist/client.js.map +0 -1
- package/dist/index.d.ts +0 -25
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js +0 -15
- package/dist/index.js.map +0 -1
- package/dist/lib/Analytics/AnalyticsClient.d.ts +0 -9
- package/dist/lib/Analytics/AnalyticsClient.d.ts.map +0 -1
- package/dist/lib/Analytics/AnalyticsClient.js +0 -17
- package/dist/lib/Analytics/AnalyticsClient.js.map +0 -1
- package/dist/lib/Analytics/types.d.ts +0 -7
- package/dist/lib/Analytics/types.d.ts.map +0 -1
- package/dist/lib/Analytics/types.js +0 -2
- package/dist/lib/Analytics/types.js.map +0 -1
- package/dist/lib/App/AppClient.d.ts +0 -15
- package/dist/lib/App/AppClient.d.ts.map +0 -1
- package/dist/lib/App/AppClient.js +0 -41
- package/dist/lib/App/AppClient.js.map +0 -1
- package/dist/lib/App/types.d.ts +0 -36
- package/dist/lib/App/types.d.ts.map +0 -1
- package/dist/lib/App/types.js +0 -2
- package/dist/lib/App/types.js.map +0 -1
- package/dist/lib/Database/DatabaseClient.d.ts +0 -28
- package/dist/lib/Database/DatabaseClient.d.ts.map +0 -1
- package/dist/lib/Database/DatabaseClient.js +0 -116
- package/dist/lib/Database/DatabaseClient.js.map +0 -1
- package/dist/lib/Database/types.d.ts +0 -24
- package/dist/lib/Database/types.d.ts.map +0 -1
- package/dist/lib/Database/types.js +0 -2
- package/dist/lib/Database/types.js.map +0 -1
- package/dist/lib/Function/FunctionsClient.d.ts +0 -9
- package/dist/lib/Function/FunctionsClient.d.ts.map +0 -1
- package/dist/lib/Function/FunctionsClient.js +0 -20
- package/dist/lib/Function/FunctionsClient.js.map +0 -1
- package/dist/lib/Function/types.d.ts +0 -16
- package/dist/lib/Function/types.d.ts.map +0 -1
- package/dist/lib/Function/types.js +0 -2
- package/dist/lib/Function/types.js.map +0 -1
- package/dist/lib/Graphs/GraphClient.d.ts +0 -26
- package/dist/lib/Graphs/GraphClient.d.ts.map +0 -1
- package/dist/lib/Graphs/GraphClient.js +0 -86
- package/dist/lib/Graphs/GraphClient.js.map +0 -1
- package/dist/lib/Graphs/types.d.ts +0 -23
- package/dist/lib/Graphs/types.d.ts.map +0 -1
- package/dist/lib/Graphs/types.js +0 -2
- package/dist/lib/Graphs/types.js.map +0 -1
- package/dist/lib/Policy/PolicyClient.d.ts +0 -9
- package/dist/lib/Policy/PolicyClient.d.ts.map +0 -1
- package/dist/lib/Policy/PolicyClient.js +0 -24
- package/dist/lib/Policy/PolicyClient.js.map +0 -1
- package/dist/lib/Policy/types.d.ts +0 -22
- package/dist/lib/Policy/types.d.ts.map +0 -1
- package/dist/lib/Policy/types.js +0 -2
- package/dist/lib/Policy/types.js.map +0 -1
- package/dist/lib/Secrets/SecretsClient.d.ts +0 -14
- package/dist/lib/Secrets/SecretsClient.d.ts.map +0 -1
- package/dist/lib/Secrets/SecretsClient.js +0 -32
- package/dist/lib/Secrets/SecretsClient.js.map +0 -1
- package/dist/lib/Secrets/types.d.ts +0 -13
- package/dist/lib/Secrets/types.d.ts.map +0 -1
- package/dist/lib/Secrets/types.js +0 -2
- package/dist/lib/Secrets/types.js.map +0 -1
- package/dist/lib/Settings/SettingsClient.d.ts +0 -7
- package/dist/lib/Settings/SettingsClient.d.ts.map +0 -1
- package/dist/lib/Settings/SettingsClient.js +0 -11
- package/dist/lib/Settings/SettingsClient.js.map +0 -1
- package/dist/lib/Settings/types.d.ts +0 -4
- package/dist/lib/Settings/types.d.ts.map +0 -1
- package/dist/lib/Settings/types.js +0 -2
- package/dist/lib/Settings/types.js.map +0 -1
- package/dist/lib/Storage/StorageClient.d.ts +0 -26
- package/dist/lib/Storage/StorageClient.d.ts.map +0 -1
- package/dist/lib/Storage/StorageClient.js +0 -78
- package/dist/lib/Storage/StorageClient.js.map +0 -1
- package/dist/lib/Storage/types.d.ts +0 -35
- package/dist/lib/Storage/types.d.ts.map +0 -1
- package/dist/lib/Storage/types.js +0 -2
- package/dist/lib/Storage/types.js.map +0 -1
- package/dist/lib/auth/AuthClient.d.ts +0 -66
- package/dist/lib/auth/AuthClient.d.ts.map +0 -1
- package/dist/lib/auth/AuthClient.js.map +0 -1
- package/dist/lib/auth/types.d.ts +0 -9
- package/dist/lib/auth/types.d.ts.map +0 -1
- package/dist/lib/auth/types.js +0 -2
- package/dist/lib/auth/types.js.map +0 -1
- package/dist/lib/user/UserClient.d.ts +0 -16
- package/dist/lib/user/UserClient.d.ts.map +0 -1
- package/dist/lib/user/UserClient.js +0 -41
- package/dist/lib/user/UserClient.js.map +0 -1
- package/dist/lib/user/types.d.ts +0 -100
- package/dist/lib/user/types.d.ts.map +0 -1
- package/dist/lib/user/types.js +0 -2
- package/dist/lib/user/types.js.map +0 -1
- package/dist/lib-internal/errors/ErrorClient.d.ts +0 -4
- package/dist/lib-internal/errors/ErrorClient.d.ts.map +0 -1
- package/dist/lib-internal/errors/ErrorClient.js +0 -6
- package/dist/lib-internal/errors/ErrorClient.js.map +0 -1
- package/dist/lib-internal/errors/index.d.ts +0 -8
- package/dist/lib-internal/errors/index.d.ts.map +0 -1
- package/dist/lib-internal/errors/index.js +0 -23
- package/dist/lib-internal/errors/index.js.map +0 -1
- package/dist/lib-internal/errors/types.d.ts +0 -83
- package/dist/lib-internal/errors/types.d.ts.map +0 -1
- package/dist/lib-internal/errors/types.js +0 -65
- package/dist/lib-internal/errors/types.js.map +0 -1
- package/dist/lib-internal/http/HttpClient.d.ts +0 -22
- package/dist/lib-internal/http/HttpClient.d.ts.map +0 -1
- package/dist/lib-internal/http/HttpClient.js +0 -65
- package/dist/lib-internal/http/HttpClient.js.map +0 -1
- package/dist/lib-internal/http/types.d.ts +0 -12
- package/dist/lib-internal/http/types.d.ts.map +0 -1
- package/dist/lib-internal/http/types.js.map +0 -1
- package/dist/lib-internal/routes/AnalyticsRoutes.d.ts +0 -4
- package/dist/lib-internal/routes/AnalyticsRoutes.d.ts.map +0 -1
- package/dist/lib-internal/routes/AnalyticsRoutes.js +0 -4
- package/dist/lib-internal/routes/AnalyticsRoutes.js.map +0 -1
- package/dist/lib-internal/routes/AppRoutes.d.ts +0 -10
- package/dist/lib-internal/routes/AppRoutes.d.ts.map +0 -1
- package/dist/lib-internal/routes/AppRoutes.js +0 -6
- package/dist/lib-internal/routes/AppRoutes.js.map +0 -1
- package/dist/lib-internal/routes/AuthRoutes.d.ts +0 -2
- package/dist/lib-internal/routes/AuthRoutes.d.ts.map +0 -1
- package/dist/lib-internal/routes/AuthRoutes.js +0 -2
- package/dist/lib-internal/routes/AuthRoutes.js.map +0 -1
- package/dist/lib-internal/routes/DatabaseRoutes.d.ts +0 -10
- package/dist/lib-internal/routes/DatabaseRoutes.d.ts.map +0 -1
- package/dist/lib-internal/routes/DatabaseRoutes.js +0 -6
- package/dist/lib-internal/routes/DatabaseRoutes.js.map +0 -1
- package/dist/lib-internal/routes/FunctionRoutes.d.ts +0 -4
- package/dist/lib-internal/routes/FunctionRoutes.d.ts.map +0 -1
- package/dist/lib-internal/routes/FunctionRoutes.js +0 -4
- package/dist/lib-internal/routes/FunctionRoutes.js.map +0 -1
- package/dist/lib-internal/routes/GraphRoutes.d.ts +0 -14
- package/dist/lib-internal/routes/GraphRoutes.d.ts.map +0 -1
- package/dist/lib-internal/routes/GraphRoutes.js +0 -11
- package/dist/lib-internal/routes/GraphRoutes.js.map +0 -1
- package/dist/lib-internal/routes/PolicyRoutes.d.ts +0 -5
- package/dist/lib-internal/routes/PolicyRoutes.d.ts.map +0 -1
- package/dist/lib-internal/routes/PolicyRoutes.js +0 -5
- package/dist/lib-internal/routes/PolicyRoutes.js.map +0 -1
- package/dist/lib-internal/routes/SecretsRoutes.d.ts +0 -6
- package/dist/lib-internal/routes/SecretsRoutes.d.ts.map +0 -1
- package/dist/lib-internal/routes/SecretsRoutes.js +0 -6
- package/dist/lib-internal/routes/SecretsRoutes.js.map +0 -1
- package/dist/lib-internal/routes/SettingsRoutes.d.ts +0 -4
- package/dist/lib-internal/routes/SettingsRoutes.d.ts.map +0 -1
- package/dist/lib-internal/routes/SettingsRoutes.js.map +0 -1
- package/dist/lib-internal/routes/StorageRoutes.d.ts +0 -11
- package/dist/lib-internal/routes/StorageRoutes.d.ts.map +0 -1
- package/dist/lib-internal/routes/StorageRoutes.js +0 -8
- package/dist/lib-internal/routes/StorageRoutes.js.map +0 -1
- package/dist/lib-internal/routes/UserRoutes.d.ts +0 -11
- package/dist/lib-internal/routes/UserRoutes.d.ts.map +0 -1
- package/dist/lib-internal/routes/UserRoutes.js +0 -11
- package/dist/lib-internal/routes/UserRoutes.js.map +0 -1
- package/dist/lib-internal/routes/index.d.ts +0 -2
- package/dist/lib-internal/routes/index.d.ts.map +0 -1
- package/dist/lib-internal/routes/index.js +0 -2
- package/dist/lib-internal/routes/index.js.map +0 -1
- package/dist/lib-internal/token/TokenClient.d.ts +0 -71
- package/dist/lib-internal/token/TokenClient.d.ts.map +0 -1
- package/dist/lib-internal/token/TokenClient.js.map +0 -1
- package/dist/lib-internal/token/types.d.ts +0 -2
- package/dist/lib-internal/token/types.d.ts.map +0 -1
- package/dist/lib-internal/token/types.js +0 -2
- package/dist/lib-internal/token/types.js.map +0 -1
- package/dist/types.d.ts +0 -49
- package/dist/types.d.ts.map +0 -1
- package/dist/types.js +0 -2
- package/dist/types.js.map +0 -1
- package/dist/utils/enums.d.ts +0 -20
- package/dist/utils/enums.d.ts.map +0 -1
- package/dist/utils/enums.js.map +0 -1
- package/dist/utils/utils.d.ts +0 -5
- package/dist/utils/utils.d.ts.map +0 -1
- package/dist/utils/utils.js +0 -32
- package/dist/utils/utils.js.map +0 -1
|
@@ -0,0 +1,150 @@
|
|
|
1
|
+
import { describe, it, expect, vi, beforeEach } from 'vitest'
|
|
2
|
+
import { User } from '../../../src/lib/users/UserClient.js'
|
|
3
|
+
import { Client } from '../../../src/client.js'
|
|
4
|
+
|
|
5
|
+
const mockHttpClient = {
|
|
6
|
+
get: vi.fn(),
|
|
7
|
+
post: vi.fn(),
|
|
8
|
+
put: vi.fn(),
|
|
9
|
+
delete: vi.fn()
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
const mockClient = {
|
|
13
|
+
getConfig: () => ({ apiKey: 'test-key', appSlug: 'test-app', apiUrl: 'https://api.test.com' }),
|
|
14
|
+
httpClient: mockHttpClient
|
|
15
|
+
} as unknown as Client
|
|
16
|
+
|
|
17
|
+
describe('User', () => {
|
|
18
|
+
beforeEach(() => {
|
|
19
|
+
vi.clearAllMocks()
|
|
20
|
+
})
|
|
21
|
+
|
|
22
|
+
describe('getUser()', () => {
|
|
23
|
+
it('fetches user by username', async () => {
|
|
24
|
+
const userData = { username: 'john_doe', email: 'john@example.com' }
|
|
25
|
+
mockHttpClient.get.mockResolvedValue(userData)
|
|
26
|
+
|
|
27
|
+
const user = new User(mockClient)
|
|
28
|
+
const result = await user.getUser('john_doe')
|
|
29
|
+
|
|
30
|
+
expect(mockHttpClient.get).toHaveBeenCalledWith('api/users/john_doe/')
|
|
31
|
+
expect(result).toEqual(userData)
|
|
32
|
+
})
|
|
33
|
+
})
|
|
34
|
+
|
|
35
|
+
describe('createUser()', () => {
|
|
36
|
+
it('creates user with provided data', async () => {
|
|
37
|
+
const createData = {
|
|
38
|
+
username: 'new_user',
|
|
39
|
+
email: 'new@example.com',
|
|
40
|
+
password: 'pass123',
|
|
41
|
+
confirm_password: 'pass123',
|
|
42
|
+
first_name: 'New',
|
|
43
|
+
last_name: 'User',
|
|
44
|
+
is_active: true,
|
|
45
|
+
is_staff: false,
|
|
46
|
+
attributes: ''
|
|
47
|
+
}
|
|
48
|
+
const response = { id: '1', ...createData }
|
|
49
|
+
mockHttpClient.post.mockResolvedValue(response)
|
|
50
|
+
|
|
51
|
+
const user = new User(mockClient)
|
|
52
|
+
const result = await user.createUser(createData)
|
|
53
|
+
|
|
54
|
+
expect(mockHttpClient.post).toHaveBeenCalledWith('api/users/', createData)
|
|
55
|
+
expect(result).toEqual(response)
|
|
56
|
+
})
|
|
57
|
+
})
|
|
58
|
+
|
|
59
|
+
describe('updateUser()', () => {
|
|
60
|
+
it('updates user by username', async () => {
|
|
61
|
+
const updateData = { email: 'updated@example.com', first_name: 'Updated' }
|
|
62
|
+
const response = { username: 'john_doe', ...updateData }
|
|
63
|
+
mockHttpClient.put.mockResolvedValue(response)
|
|
64
|
+
|
|
65
|
+
const user = new User(mockClient)
|
|
66
|
+
const result = await user.updateUser('john_doe', updateData)
|
|
67
|
+
|
|
68
|
+
expect(mockHttpClient.put).toHaveBeenCalledWith('api/users/john_doe/', updateData)
|
|
69
|
+
expect(result).toEqual(response)
|
|
70
|
+
})
|
|
71
|
+
})
|
|
72
|
+
|
|
73
|
+
describe('deleteUser()', () => {
|
|
74
|
+
it('deletes user by username', async () => {
|
|
75
|
+
mockHttpClient.delete.mockResolvedValue(undefined)
|
|
76
|
+
|
|
77
|
+
const user = new User(mockClient)
|
|
78
|
+
await user.deleteUser('john_doe')
|
|
79
|
+
|
|
80
|
+
expect(mockHttpClient.delete).toHaveBeenCalledWith('api/users/john_doe/')
|
|
81
|
+
})
|
|
82
|
+
})
|
|
83
|
+
|
|
84
|
+
describe('list()', () => {
|
|
85
|
+
it('lists users with filters', async () => {
|
|
86
|
+
const users = [{ username: 'user1' }, { username: 'user2' }]
|
|
87
|
+
mockHttpClient.get.mockResolvedValue(users)
|
|
88
|
+
|
|
89
|
+
const user = new User(mockClient)
|
|
90
|
+
const result = await user.list({ search: 'john', is_active: true, page: 1, page_size: 20 })
|
|
91
|
+
|
|
92
|
+
expect(mockHttpClient.get).toHaveBeenCalledWith(
|
|
93
|
+
expect.stringContaining('api/users/')
|
|
94
|
+
)
|
|
95
|
+
expect(result).toEqual(users)
|
|
96
|
+
})
|
|
97
|
+
|
|
98
|
+
it('builds query string from filters', async () => {
|
|
99
|
+
mockHttpClient.get.mockResolvedValue([])
|
|
100
|
+
|
|
101
|
+
const user = new User(mockClient)
|
|
102
|
+
await user.list({ search: 'test', ordering: '-date_joined' })
|
|
103
|
+
|
|
104
|
+
const url = mockHttpClient.get.mock.calls[0][0]
|
|
105
|
+
expect(url).toContain('search=test')
|
|
106
|
+
expect(url).toContain('ordering=-date_joined')
|
|
107
|
+
})
|
|
108
|
+
})
|
|
109
|
+
|
|
110
|
+
describe('getUserApps()', () => {
|
|
111
|
+
it('fetches apps for user', async () => {
|
|
112
|
+
const apps = [{ name: 'App1', slug: 'app1' }, { name: 'App2', slug: 'app2' }]
|
|
113
|
+
mockHttpClient.get.mockResolvedValue(apps)
|
|
114
|
+
|
|
115
|
+
const user = new User(mockClient)
|
|
116
|
+
const result = await user.getUserApps('john_doe')
|
|
117
|
+
|
|
118
|
+
expect(mockHttpClient.get).toHaveBeenCalledWith('api/users/john_doe/apps/')
|
|
119
|
+
expect(result).toEqual(apps)
|
|
120
|
+
})
|
|
121
|
+
})
|
|
122
|
+
|
|
123
|
+
describe('assignRoles()', () => {
|
|
124
|
+
it('assigns roles to user', async () => {
|
|
125
|
+
const request = { username: 'john_doe', roles: ['admin', 'editor'] }
|
|
126
|
+
const response = { success: true }
|
|
127
|
+
mockHttpClient.post.mockResolvedValue(response)
|
|
128
|
+
|
|
129
|
+
const user = new User(mockClient)
|
|
130
|
+
const result = await user.assignRoles(request)
|
|
131
|
+
|
|
132
|
+
expect(mockHttpClient.post).toHaveBeenCalledWith('api/assign/roles/', request)
|
|
133
|
+
expect(result).toEqual(response)
|
|
134
|
+
})
|
|
135
|
+
})
|
|
136
|
+
|
|
137
|
+
describe('revokeRoles()', () => {
|
|
138
|
+
it('revokes roles from user', async () => {
|
|
139
|
+
const request = { username: 'john_doe', roles: ['admin'] }
|
|
140
|
+
const response = { success: true }
|
|
141
|
+
mockHttpClient.delete.mockResolvedValue(response)
|
|
142
|
+
|
|
143
|
+
const user = new User(mockClient)
|
|
144
|
+
const result = await user.revokeRoles(request)
|
|
145
|
+
|
|
146
|
+
expect(mockHttpClient.delete).toHaveBeenCalledWith('api/revoke/roles/', request)
|
|
147
|
+
expect(result).toEqual(response)
|
|
148
|
+
})
|
|
149
|
+
})
|
|
150
|
+
})
|
package/tsconfig.json
ADDED
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
{
|
|
2
|
+
// Visit https://aka.ms/tsconfig to read more about this file
|
|
3
|
+
"compilerOptions": {
|
|
4
|
+
// File Layout
|
|
5
|
+
"rootDir": "./src",
|
|
6
|
+
"outDir": "./dist",
|
|
7
|
+
|
|
8
|
+
// Environment Settings
|
|
9
|
+
// See also https://aka.ms/tsconfig/module
|
|
10
|
+
"module": "nodenext",
|
|
11
|
+
"target": "esnext",
|
|
12
|
+
"lib": ["esnext", "dom"],
|
|
13
|
+
"types": ["node"],
|
|
14
|
+
|
|
15
|
+
// Other Outputs
|
|
16
|
+
"sourceMap": true,
|
|
17
|
+
"declaration": true,
|
|
18
|
+
"declarationMap": true,
|
|
19
|
+
|
|
20
|
+
// Stricter Typechecking Options
|
|
21
|
+
"noUncheckedIndexedAccess": true,
|
|
22
|
+
"exactOptionalPropertyTypes": true,
|
|
23
|
+
|
|
24
|
+
// Style Options
|
|
25
|
+
// "noImplicitReturns": true,
|
|
26
|
+
// "noImplicitOverride": true,
|
|
27
|
+
// "noUnusedLocals": true,
|
|
28
|
+
// "noUnusedParameters": true,
|
|
29
|
+
// "noFallthroughCasesInSwitch": true,
|
|
30
|
+
// "noPropertyAccessFromIndexSignature": true,
|
|
31
|
+
|
|
32
|
+
// Recommended Options
|
|
33
|
+
"strict": true,
|
|
34
|
+
"jsx": "react-jsx",
|
|
35
|
+
"verbatimModuleSyntax": true,
|
|
36
|
+
"isolatedModules": true,
|
|
37
|
+
"noUncheckedSideEffectImports": true,
|
|
38
|
+
"moduleDetection": "force",
|
|
39
|
+
"skipLibCheck": true,
|
|
40
|
+
},
|
|
41
|
+
"include": ["src/**/*"],
|
|
42
|
+
"exclude": ["node_modules", "dist", "taruvi-platform", "tests"]
|
|
43
|
+
}
|
package/vitest.config.ts
ADDED
package/dist/client.d.ts
DELETED
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
import { HttpClient } from "./lib-internal/http/HttpClient.js";
|
|
2
|
-
import { TokenClient } from "./lib-internal/token/TokenClient.js";
|
|
3
|
-
import type { TaruviConfig } from "./types.js";
|
|
4
|
-
export declare class Client {
|
|
5
|
-
private readonly config;
|
|
6
|
-
private readonly _httpClient;
|
|
7
|
-
private readonly _tokenClient;
|
|
8
|
-
constructor(config: TaruviConfig);
|
|
9
|
-
/**
|
|
10
|
-
* Extracts authentication tokens from URL hash and stores them using TokenClient.
|
|
11
|
-
* This handles Web UI Flow callback URLs like:
|
|
12
|
-
* #session_token=xxx&access_token=yyy&refresh_token=zzz&expires_in=172800&token_type=Bearer
|
|
13
|
-
*
|
|
14
|
-
* After successful extraction, the URL hash is cleared to prevent token exposure.
|
|
15
|
-
*/
|
|
16
|
-
private extractTokensFromUrl;
|
|
17
|
-
/**
|
|
18
|
-
* @internal
|
|
19
|
-
* Internal use only - not part of public API
|
|
20
|
-
*/
|
|
21
|
-
get httpClient(): HttpClient;
|
|
22
|
-
/**
|
|
23
|
-
* @internal
|
|
24
|
-
* Internal use only - not part of public API
|
|
25
|
-
*/
|
|
26
|
-
get tokenClient(): TokenClient;
|
|
27
|
-
getConfig(): Readonly<TaruviConfig>;
|
|
28
|
-
}
|
|
29
|
-
//# sourceMappingURL=client.d.ts.map
|
package/dist/client.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../src/client.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,mCAAmC,CAAC;AAC/D,OAAO,EAAE,WAAW,EAAE,MAAM,qCAAqC,CAAC;AAClE,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAE/C,qBAAa,MAAM;IACf,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAc;IACrC,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAY;IACxC,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAa;gBAE9B,MAAM,EAAE,YAAY;IAyBhC;;;;;;OAMG;IACH,OAAO,CAAC,oBAAoB;IA8C5B;;;OAGG;IACH,IAAI,UAAU,IAAI,UAAU,CAE3B;IAED;;;OAGG;IACH,IAAI,WAAW,IAAI,WAAW,CAE7B;IAED,SAAS,IAAI,QAAQ,CAAC,YAAY,CAAC;CAGtC"}
|
package/dist/client.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"client.js","sourceRoot":"","sources":["../src/client.ts"],"names":[],"mappings":"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"}
|
package/dist/index.d.ts
DELETED
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
export { Client } from "./client.js";
|
|
2
|
-
export { Auth } from "./lib/auth/AuthClient.js";
|
|
3
|
-
export { User } from "./lib/user/UserClient.js";
|
|
4
|
-
export { Storage } from "./lib/Storage/StorageClient.js";
|
|
5
|
-
export { Database } from "./lib/Database/DatabaseClient.js";
|
|
6
|
-
export { Settings } from "./lib/Settings/SettingsClient.js";
|
|
7
|
-
export { Functions } from "./lib/Function/FunctionsClient.js";
|
|
8
|
-
export { Secrets } from "./lib/Secrets/SecretsClient.js";
|
|
9
|
-
export { Policy } from "./lib/Policy/PolicyClient.js";
|
|
10
|
-
export { App } from "./lib/App/AppClient.js";
|
|
11
|
-
export { Analytics } from "./lib/Analytics/AnalyticsClient.js";
|
|
12
|
-
export { Graph } from "./lib/Graphs/GraphClient.js";
|
|
13
|
-
export type { TaruviConfig, StorageFilters, DatabaseFilters } from "./types.js";
|
|
14
|
-
export type { AuthTokens } from "./lib-internal/token/TokenClient.js";
|
|
15
|
-
export type { UserCreateRequest, UserCreateResponse as UserResponse, UserDataResponse as TaruviUser, UserUpdateRequest, UserUpdateResponse, UserGroup, UserPermission, UserRole, UserList, UserApp, UserAppsResponse } from "./lib/user/types.js";
|
|
16
|
-
export type { Principal, Resource, Resources } from "./lib/Policy/types.js";
|
|
17
|
-
export type { RoleResponse, SettingsResponse as AppSettingsResponse } from "./lib/App/types.js";
|
|
18
|
-
export type { FunctionRequest, FunctionResponse, FunctionInvocation } from "./lib/Function/types.js";
|
|
19
|
-
export type { DatabaseRequest, DatabaseResponse, FilterOperator, SortOrder } from "./lib/Database/types.js";
|
|
20
|
-
export type { StorageRequest, StorageUpdateRequest, StorageResponse } from "./lib/Storage/types.js";
|
|
21
|
-
export type { SettingsResponse } from "./lib/Settings/types.js";
|
|
22
|
-
export type { SecretRequest, SecretResponse } from "./lib/Secrets/types.js";
|
|
23
|
-
export type { AnalyticsRequest, AnalyticsResponse } from "./lib/Analytics/types.js";
|
|
24
|
-
export type { GraphInclude, GraphFormat, GraphQueryParams, EdgeRequest, EdgeResponse } from "./lib/Graphs/types.js";
|
|
25
|
-
//# sourceMappingURL=index.d.ts.map
|
package/dist/index.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAA;AAGpC,OAAO,EAAE,IAAI,EAAE,MAAM,0BAA0B,CAAA;AAC/C,OAAO,EAAE,IAAI,EAAE,MAAM,0BAA0B,CAAA;AAC/C,OAAO,EAAE,OAAO,EAAE,MAAM,gCAAgC,CAAA;AACxD,OAAO,EAAE,QAAQ,EAAE,MAAM,kCAAkC,CAAA;AAC3D,OAAO,EAAE,QAAQ,EAAE,MAAM,kCAAkC,CAAA;AAC3D,OAAO,EAAE,SAAS,EAAE,MAAM,mCAAmC,CAAA;AAC7D,OAAO,EAAE,OAAO,EAAE,MAAM,gCAAgC,CAAA;AACxD,OAAO,EAAE,MAAM,EAAE,MAAM,8BAA8B,CAAA;AACrD,OAAO,EAAE,GAAG,EAAE,MAAM,wBAAwB,CAAA;AAC5C,OAAO,EAAE,SAAS,EAAE,MAAM,oCAAoC,CAAA;AAC9D,OAAO,EAAE,KAAK,EAAE,MAAM,6BAA6B,CAAA;AAGnD,YAAY,EAAE,YAAY,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAC/E,YAAY,EAAE,UAAU,EAAE,MAAM,qCAAqC,CAAA;AACrE,YAAY,EACV,iBAAiB,EACjB,kBAAkB,IAAI,YAAY,EAClC,gBAAgB,IAAI,UAAU,EAC9B,iBAAiB,EACjB,kBAAkB,EAClB,SAAS,EACT,cAAc,EACd,QAAQ,EACR,QAAQ,EACR,OAAO,EACP,gBAAgB,EACjB,MAAM,qBAAqB,CAAA;AAC5B,YAAY,EAAE,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAA;AAC3E,YAAY,EAAE,YAAY,EAAE,gBAAgB,IAAI,mBAAmB,EAAE,MAAM,oBAAoB,CAAA;AAC/F,YAAY,EAAE,eAAe,EAAE,gBAAgB,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAA;AACpG,YAAY,EAAE,eAAe,EAAE,gBAAgB,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAA;AAC3G,YAAY,EAAE,cAAc,EAAE,oBAAoB,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAA;AACnG,YAAY,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAA;AAC/D,YAAY,EAAE,aAAa,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAA;AAC3E,YAAY,EAAE,gBAAgB,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAA;AACnF,YAAY,EAAE,YAAY,EAAE,WAAW,EAAE,gBAAgB,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAA"}
|
package/dist/index.js
DELETED
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
// Export main client
|
|
2
|
-
export { Client } from "./client.js";
|
|
3
|
-
// Export public client classes
|
|
4
|
-
export { Auth } from "./lib/auth/AuthClient.js";
|
|
5
|
-
export { User } from "./lib/user/UserClient.js";
|
|
6
|
-
export { Storage } from "./lib/Storage/StorageClient.js";
|
|
7
|
-
export { Database } from "./lib/Database/DatabaseClient.js";
|
|
8
|
-
export { Settings } from "./lib/Settings/SettingsClient.js";
|
|
9
|
-
export { Functions } from "./lib/Function/FunctionsClient.js";
|
|
10
|
-
export { Secrets } from "./lib/Secrets/SecretsClient.js";
|
|
11
|
-
export { Policy } from "./lib/Policy/PolicyClient.js";
|
|
12
|
-
export { App } from "./lib/App/AppClient.js";
|
|
13
|
-
export { Analytics } from "./lib/Analytics/AnalyticsClient.js";
|
|
14
|
-
export { Graph } from "./lib/Graphs/GraphClient.js";
|
|
15
|
-
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,qBAAqB;AACrB,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAA;AAEpC,+BAA+B;AAC/B,OAAO,EAAE,IAAI,EAAE,MAAM,0BAA0B,CAAA;AAC/C,OAAO,EAAE,IAAI,EAAE,MAAM,0BAA0B,CAAA;AAC/C,OAAO,EAAE,OAAO,EAAE,MAAM,gCAAgC,CAAA;AACxD,OAAO,EAAE,QAAQ,EAAE,MAAM,kCAAkC,CAAA;AAC3D,OAAO,EAAE,QAAQ,EAAE,MAAM,kCAAkC,CAAA;AAC3D,OAAO,EAAE,SAAS,EAAE,MAAM,mCAAmC,CAAA;AAC7D,OAAO,EAAE,OAAO,EAAE,MAAM,gCAAgC,CAAA;AACxD,OAAO,EAAE,MAAM,EAAE,MAAM,8BAA8B,CAAA;AACrD,OAAO,EAAE,GAAG,EAAE,MAAM,wBAAwB,CAAA;AAC5C,OAAO,EAAE,SAAS,EAAE,MAAM,oCAAoC,CAAA;AAC9D,OAAO,EAAE,KAAK,EAAE,MAAM,6BAA6B,CAAA"}
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import type { Client } from "../../client.js";
|
|
2
|
-
import type { AnalyticsRequest, AnalyticsResponse } from "./types.js";
|
|
3
|
-
export declare class Analytics {
|
|
4
|
-
private client;
|
|
5
|
-
private config;
|
|
6
|
-
constructor(client: Client);
|
|
7
|
-
execute<T = unknown>(querySlug: string, options?: AnalyticsRequest): Promise<AnalyticsResponse<T>>;
|
|
8
|
-
}
|
|
9
|
-
//# sourceMappingURL=AnalyticsClient.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"AnalyticsClient.d.ts","sourceRoot":"","sources":["../../../src/lib/Analytics/AnalyticsClient.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAE9C,OAAO,KAAK,EAAE,gBAAgB,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAGtE,qBAAa,SAAS;IAClB,OAAO,CAAC,MAAM,CAAQ;IACtB,OAAO,CAAC,MAAM,CAAc;gBAEhB,MAAM,EAAE,MAAM;IAKpB,OAAO,CAAC,CAAC,GAAG,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,OAAO,GAAE,gBAAqB,GAAG,OAAO,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC;CAS/G"}
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
import { AnalyticsRoutes } from "../../lib-internal/routes/AnalyticsRoutes.js";
|
|
2
|
-
export class Analytics {
|
|
3
|
-
client;
|
|
4
|
-
config;
|
|
5
|
-
constructor(client) {
|
|
6
|
-
this.client = client;
|
|
7
|
-
this.config = this.client.getConfig();
|
|
8
|
-
}
|
|
9
|
-
async execute(querySlug, options = {}) {
|
|
10
|
-
const url = AnalyticsRoutes.baseUrl(this.config.appSlug, querySlug);
|
|
11
|
-
const body = {
|
|
12
|
-
params: options.params || {}
|
|
13
|
-
};
|
|
14
|
-
return await this.client.httpClient.post(url, body);
|
|
15
|
-
}
|
|
16
|
-
}
|
|
17
|
-
//# sourceMappingURL=AnalyticsClient.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"AnalyticsClient.js","sourceRoot":"","sources":["../../../src/lib/Analytics/AnalyticsClient.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,eAAe,EAAE,MAAM,8CAA8C,CAAC;AAE/E,MAAM,OAAO,SAAS;IACV,MAAM,CAAQ;IACd,MAAM,CAAc;IAE5B,YAAY,MAAc;QACtB,IAAI,CAAC,MAAM,GAAG,MAAM,CAAA;QACpB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,CAAA;IACzC,CAAC;IAED,KAAK,CAAC,OAAO,CAAc,SAAiB,EAAE,UAA4B,EAAE;QACxE,MAAM,GAAG,GAAG,eAAe,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,SAAS,CAAC,CAAA;QAEnE,MAAM,IAAI,GAAG;YACT,MAAM,EAAE,OAAO,CAAC,MAAM,IAAI,EAAE;SAC/B,CAAA;QAED,OAAO,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,IAAI,CAAuB,GAAG,EAAE,IAAI,CAAC,CAAA;IAC7E,CAAC;CACJ"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/lib/Analytics/types.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,gBAAgB;IAC7B,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;CACnC;AAED,MAAM,WAAW,iBAAiB,CAAC,CAAC,GAAG,OAAO;IAC1C,IAAI,EAAE,CAAC,GAAG,IAAI,CAAA;CACjB"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/lib/Analytics/types.ts"],"names":[],"mappings":""}
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import type { Client } from "../../client.js";
|
|
2
|
-
import { HttpMethod } from "../../lib-internal/http/types.js";
|
|
3
|
-
import type { UrlParams } from "./types.js";
|
|
4
|
-
export declare class App {
|
|
5
|
-
private client;
|
|
6
|
-
private urlParams;
|
|
7
|
-
private config;
|
|
8
|
-
private operation;
|
|
9
|
-
constructor(client: Client, urlParams?: UrlParams, operation?: HttpMethod | undefined);
|
|
10
|
-
roles(): App;
|
|
11
|
-
settings(): App;
|
|
12
|
-
private buildRoute;
|
|
13
|
-
execute(): Promise<unknown>;
|
|
14
|
-
}
|
|
15
|
-
//# sourceMappingURL=AppClient.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"AppClient.d.ts","sourceRoot":"","sources":["../../../src/lib/App/AppClient.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAE9C,OAAO,EAAE,UAAU,EAAE,MAAM,kCAAkC,CAAC;AAE9D,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC;AAE5C,qBAAa,GAAG;IACZ,OAAO,CAAC,MAAM,CAAQ;IACtB,OAAO,CAAC,SAAS,CAAW;IAC5B,OAAO,CAAC,MAAM,CAAc;IAC5B,OAAO,CAAC,SAAS,CAAwB;gBAE7B,MAAM,EAAE,MAAM,EAAE,SAAS,GAAE,SAAc,EAAE,SAAS,CAAC,EAAE,UAAU,GAAG,SAAS;IAOzF,KAAK;IAIL,QAAQ;IAIR,OAAO,CAAC,UAAU;IAgBZ,OAAO;CAUhB"}
|
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
import { AppRoutes } from "../../lib-internal/routes/AppRoutes.js";
|
|
2
|
-
import { HttpMethod } from "../../lib-internal/http/types.js";
|
|
3
|
-
export class App {
|
|
4
|
-
client;
|
|
5
|
-
urlParams;
|
|
6
|
-
config;
|
|
7
|
-
operation;
|
|
8
|
-
constructor(client, urlParams = {}, operation) {
|
|
9
|
-
this.client = client;
|
|
10
|
-
this.urlParams = urlParams;
|
|
11
|
-
this.operation = operation;
|
|
12
|
-
this.config = this.client.getConfig();
|
|
13
|
-
}
|
|
14
|
-
roles() {
|
|
15
|
-
return new App(this.client, { ...this.urlParams, roles: "roles" }, HttpMethod.GET);
|
|
16
|
-
}
|
|
17
|
-
settings() {
|
|
18
|
-
return new App(this.client, { ...this.urlParams, settings: "settings" }, HttpMethod.GET);
|
|
19
|
-
}
|
|
20
|
-
buildRoute() {
|
|
21
|
-
return (AppRoutes.baseUrl(this.config.appSlug) +
|
|
22
|
-
Object.keys(this.urlParams).reduce((acc, key) => {
|
|
23
|
-
const value = this.urlParams[key];
|
|
24
|
-
const routeBuilder = AppRoutes[key];
|
|
25
|
-
if (value && routeBuilder) {
|
|
26
|
-
acc += routeBuilder();
|
|
27
|
-
}
|
|
28
|
-
return acc;
|
|
29
|
-
}, ""));
|
|
30
|
-
}
|
|
31
|
-
async execute() {
|
|
32
|
-
const url = this.buildRoute();
|
|
33
|
-
const operation = this.operation || HttpMethod.GET;
|
|
34
|
-
switch (operation) {
|
|
35
|
-
case HttpMethod.GET:
|
|
36
|
-
default:
|
|
37
|
-
return await this.client.httpClient.get(url);
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
}
|
|
41
|
-
//# sourceMappingURL=AppClient.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"AppClient.js","sourceRoot":"","sources":["../../../src/lib/App/AppClient.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAoB,MAAM,wCAAwC,CAAC;AACrF,OAAO,EAAE,UAAU,EAAE,MAAM,kCAAkC,CAAC;AAI9D,MAAM,OAAO,GAAG;IACJ,MAAM,CAAQ;IACd,SAAS,CAAW;IACpB,MAAM,CAAc;IACpB,SAAS,CAAwB;IAEzC,YAAY,MAAc,EAAE,YAAuB,EAAE,EAAE,SAAkC;QACrF,IAAI,CAAC,MAAM,GAAG,MAAM,CAAA;QACpB,IAAI,CAAC,SAAS,GAAG,SAAS,CAAA;QAC1B,IAAI,CAAC,SAAS,GAAG,SAAS,CAAA;QAC1B,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,CAAA;IACzC,CAAC;IAED,KAAK;QACD,OAAO,IAAI,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE,GAAG,IAAI,CAAC,SAAS,EAAE,KAAK,EAAE,OAAO,EAAE,EAAE,UAAU,CAAC,GAAG,CAAC,CAAA;IACtF,CAAC;IAED,QAAQ;QACJ,OAAO,IAAI,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE,EAAC,GAAG,IAAI,CAAC,SAAS,EAAE,QAAQ,EAAE,UAAU,EAAC,EAAE,UAAU,CAAC,GAAG,CAAC,CAAA;IAC1F,CAAC;IAEO,UAAU;QACd,OAAO,CACH,SAAS,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC;YACrC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAmB,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE;gBAC/D,MAAM,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAA;gBACjC,MAAM,YAAY,GAAG,SAAS,CAAC,GAAG,CAAC,CAAA;gBAEnC,IAAI,KAAK,IAAI,YAAY,EAAE,CAAC;oBACxB,GAAG,IAAI,YAAY,EAAE,CAAA;gBACzB,CAAC;gBAED,OAAO,GAAG,CAAA;YACd,CAAC,EAAE,EAAE,CAAC,CACT,CAAA;IACL,CAAC;IAED,KAAK,CAAC,OAAO;QACT,MAAM,GAAG,GAAG,IAAI,CAAC,UAAU,EAAE,CAAA;QAC7B,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,IAAI,UAAU,CAAC,GAAG,CAAA;QAElD,QAAQ,SAAS,EAAE,CAAC;YAChB,KAAK,UAAU,CAAC,GAAG,CAAC;YACpB;gBACI,OAAO,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;QACpD,CAAC;IACL,CAAC;CACJ"}
|
package/dist/lib/App/types.d.ts
DELETED
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
import type { Client } from "../../client.js";
|
|
2
|
-
import { HttpMethod } from "../../lib-internal/http/types.js";
|
|
3
|
-
export type AppOperation = HttpMethod;
|
|
4
|
-
export interface UrlParams {
|
|
5
|
-
appSlug?: string;
|
|
6
|
-
roles?: string;
|
|
7
|
-
settings?: string;
|
|
8
|
-
}
|
|
9
|
-
export interface AppClientInterface {
|
|
10
|
-
client: Client;
|
|
11
|
-
urlParams?: UrlParams;
|
|
12
|
-
}
|
|
13
|
-
export interface RoleResponse {
|
|
14
|
-
id?: string | number;
|
|
15
|
-
name?: string;
|
|
16
|
-
permissions?: string[];
|
|
17
|
-
created_at?: string;
|
|
18
|
-
updated_at?: string;
|
|
19
|
-
[key: string]: unknown;
|
|
20
|
-
}
|
|
21
|
-
export interface SettingsResponse {
|
|
22
|
-
display_name: string;
|
|
23
|
-
icon: string | null;
|
|
24
|
-
icon_url: string | null;
|
|
25
|
-
primary_color: string;
|
|
26
|
-
secondary_color: string;
|
|
27
|
-
banner_image: string | null;
|
|
28
|
-
banner_image_url: string | null;
|
|
29
|
-
category: string;
|
|
30
|
-
documentation_url: string | null;
|
|
31
|
-
support_email: string | null;
|
|
32
|
-
default_frontend_worker_url: string | null;
|
|
33
|
-
created_at: string;
|
|
34
|
-
updated_at: string;
|
|
35
|
-
}
|
|
36
|
-
//# sourceMappingURL=types.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/lib/App/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAA;AAC7C,OAAO,EAAE,UAAU,EAAE,MAAM,kCAAkC,CAAA;AAE7D,MAAM,MAAM,YAAY,GAAG,UAAU,CAAA;AAGrC,MAAM,WAAW,SAAS;IACtB,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,QAAQ,CAAC,EAAE,MAAM,CAAA;CACpB;AAED,MAAM,WAAW,kBAAkB;IAC/B,MAAM,EAAE,MAAM,CAAA;IACd,SAAS,CAAC,EAAE,SAAS,CAAA;CACxB;AAGD,MAAM,WAAW,YAAY;IACzB,EAAE,CAAC,EAAE,MAAM,GAAG,MAAM,CAAA;IACpB,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,WAAW,CAAC,EAAE,MAAM,EAAE,CAAA;IACtB,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAA;CACzB;AAED,MAAM,WAAW,gBAAgB;IAC7B,YAAY,EAAE,MAAM,CAAA;IACpB,IAAI,EAAE,MAAM,GAAG,IAAI,CAAA;IACnB,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAA;IACvB,aAAa,EAAE,MAAM,CAAA;IACrB,eAAe,EAAE,MAAM,CAAA;IACvB,YAAY,EAAE,MAAM,GAAG,IAAI,CAAA;IAC3B,gBAAgB,EAAE,MAAM,GAAG,IAAI,CAAA;IAC/B,QAAQ,EAAE,MAAM,CAAA;IAChB,iBAAiB,EAAE,MAAM,GAAG,IAAI,CAAA;IAChC,aAAa,EAAE,MAAM,GAAG,IAAI,CAAA;IAC5B,2BAA2B,EAAE,MAAM,GAAG,IAAI,CAAA;IAC1C,UAAU,EAAE,MAAM,CAAA;IAClB,UAAU,EAAE,MAAM,CAAA;CACrB"}
|
package/dist/lib/App/types.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/lib/App/types.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,kCAAkC,CAAA"}
|
|
@@ -1,28 +0,0 @@
|
|
|
1
|
-
import type { Client } from "../../client.js";
|
|
2
|
-
import { HttpMethod } from "../../lib-internal/http/types.js";
|
|
3
|
-
import type { DatabaseFilters } from "../../types.js";
|
|
4
|
-
import type { UrlParams, FilterOperator, SortOrder } from "./types.js";
|
|
5
|
-
export declare class Database<T = Record<string, unknown>> {
|
|
6
|
-
private client;
|
|
7
|
-
private urlParams;
|
|
8
|
-
private config;
|
|
9
|
-
private operation;
|
|
10
|
-
private body;
|
|
11
|
-
private queryParams;
|
|
12
|
-
constructor(client: Client, urlParams?: UrlParams, operation?: HttpMethod | undefined, body?: object | undefined, queryParams?: DatabaseFilters);
|
|
13
|
-
from<U = Record<string, unknown>>(dataTables: string): Database<U>;
|
|
14
|
-
filter(field: string, operator: FilterOperator, value: string | number | boolean | (string | number)[]): Database<T>;
|
|
15
|
-
sort(field: string, order?: SortOrder): Database<T>;
|
|
16
|
-
pageSize(size: number): Database<T>;
|
|
17
|
-
page(num: number): Database<T>;
|
|
18
|
-
populate(populate: string[]): Database<T>;
|
|
19
|
-
get(recordId: string): Database<T>;
|
|
20
|
-
create(body: Partial<T> | Partial<T>[]): Database<T>;
|
|
21
|
-
update(body: Partial<T> | Partial<T>[]): Database<T>;
|
|
22
|
-
delete(recordId: string): Database<T>;
|
|
23
|
-
first(): Promise<T | null>;
|
|
24
|
-
count(): Promise<number>;
|
|
25
|
-
private buildRoute;
|
|
26
|
-
execute(): Promise<T | T[]>;
|
|
27
|
-
}
|
|
28
|
-
//# sourceMappingURL=DatabaseClient.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"DatabaseClient.d.ts","sourceRoot":"","sources":["../../../src/lib/Database/DatabaseClient.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAE9C,OAAO,EAAE,UAAU,EAAE,MAAM,kCAAkC,CAAC;AAC9D,OAAO,KAAK,EAAgB,eAAe,EAAE,MAAM,gBAAgB,CAAC;AACpE,OAAO,KAAK,EAAE,SAAS,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC;AAIvE,qBAAa,QAAQ,CAAC,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;IAC7C,OAAO,CAAC,MAAM,CAAQ;IACtB,OAAO,CAAC,SAAS,CAAW;IAC5B,OAAO,CAAC,MAAM,CAAc;IAC5B,OAAO,CAAC,SAAS,CAAwB;IACzC,OAAO,CAAC,IAAI,CAAoB;IAChC,OAAO,CAAC,WAAW,CAA6B;gBAEpC,MAAM,EAAE,MAAM,EAAE,SAAS,GAAE,SAAc,EAAE,SAAS,CAAC,EAAE,UAAU,GAAG,SAAS,EAAE,IAAI,CAAC,EAAE,MAAM,GAAG,SAAS,EAAE,WAAW,CAAC,EAAE,eAAe;IASnJ,IAAI,CAAC,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,UAAU,EAAE,MAAM,GAAG,QAAQ,CAAC,CAAC,CAAC;IAIlE,MAAM,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,cAAc,EAAE,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,CAAC,MAAM,GAAG,MAAM,CAAC,EAAE,GAAG,QAAQ,CAAC,CAAC,CAAC;IAUpH,IAAI,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,GAAE,SAAiB,GAAG,QAAQ,CAAC,CAAC,CAAC;IAQ1D,QAAQ,CAAC,IAAI,EAAE,MAAM,GAAG,QAAQ,CAAC,CAAC,CAAC;IAOnC,IAAI,CAAC,GAAG,EAAE,MAAM,GAAG,QAAQ,CAAC,CAAC,CAAC;IAO9B,QAAQ,CAAC,QAAQ,EAAE,MAAM,EAAE,GAAG,QAAQ,CAAC,CAAC,CAAC;IAOzC,GAAG,CAAC,QAAQ,EAAE,MAAM,GAAG,QAAQ,CAAC,CAAC,CAAC;IAIlC,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,EAAE,GAAG,QAAQ,CAAC,CAAC,CAAC;IAIpD,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,EAAE,GAAG,QAAQ,CAAC,CAAC,CAAC;IAIpD,MAAM,CAAC,QAAQ,EAAE,MAAM,GAAG,QAAQ,CAAC,CAAC,CAAC;IAI/B,KAAK,IAAI,OAAO,CAAC,CAAC,GAAG,IAAI,CAAC;IAQ1B,KAAK,IAAI,OAAO,CAAC,MAAM,CAAC;IAQ9B,OAAO,CAAC,UAAU;IAkBZ,OAAO,IAAI,OAAO,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC;CAwBpC"}
|
|
@@ -1,116 +0,0 @@
|
|
|
1
|
-
import { DatabaseRoutes } from "../../lib-internal/routes/DatabaseRoutes.js";
|
|
2
|
-
import { HttpMethod } from "../../lib-internal/http/types.js";
|
|
3
|
-
import { buildQueryString } from "../../utils/utils.js";
|
|
4
|
-
// Used to access app data
|
|
5
|
-
export class Database {
|
|
6
|
-
client;
|
|
7
|
-
urlParams;
|
|
8
|
-
config;
|
|
9
|
-
operation;
|
|
10
|
-
body;
|
|
11
|
-
queryParams;
|
|
12
|
-
constructor(client, urlParams = {}, operation, body, queryParams) {
|
|
13
|
-
this.client = client;
|
|
14
|
-
this.urlParams = urlParams;
|
|
15
|
-
this.operation = operation;
|
|
16
|
-
this.body = body;
|
|
17
|
-
this.config = this.client.getConfig();
|
|
18
|
-
this.queryParams = queryParams;
|
|
19
|
-
}
|
|
20
|
-
from(dataTables) {
|
|
21
|
-
return new Database(this.client, { ...this.urlParams, dataTables }, undefined, undefined);
|
|
22
|
-
}
|
|
23
|
-
filter(field, operator, value) {
|
|
24
|
-
const filterKey = operator === 'eq' ? field : `${field}__${operator}`;
|
|
25
|
-
// For 'in' and 'nin' operators, join array values with comma
|
|
26
|
-
const filterValue = Array.isArray(value) ? value.join(',') : value;
|
|
27
|
-
return new Database(this.client, { ...this.urlParams }, undefined, undefined, {
|
|
28
|
-
...this.queryParams,
|
|
29
|
-
[filterKey]: filterValue
|
|
30
|
-
});
|
|
31
|
-
}
|
|
32
|
-
sort(field, order = 'asc') {
|
|
33
|
-
const ordering = order === 'desc' ? `-${field}` : field;
|
|
34
|
-
return new Database(this.client, { ...this.urlParams }, undefined, undefined, {
|
|
35
|
-
...this.queryParams,
|
|
36
|
-
ordering
|
|
37
|
-
});
|
|
38
|
-
}
|
|
39
|
-
pageSize(size) {
|
|
40
|
-
return new Database(this.client, { ...this.urlParams }, undefined, undefined, {
|
|
41
|
-
...this.queryParams,
|
|
42
|
-
page_size: size
|
|
43
|
-
});
|
|
44
|
-
}
|
|
45
|
-
page(num) {
|
|
46
|
-
return new Database(this.client, { ...this.urlParams }, undefined, undefined, {
|
|
47
|
-
...this.queryParams,
|
|
48
|
-
page: num
|
|
49
|
-
});
|
|
50
|
-
}
|
|
51
|
-
populate(populate) {
|
|
52
|
-
return new Database(this.client, { ...this.urlParams }, undefined, undefined, {
|
|
53
|
-
...this.queryParams,
|
|
54
|
-
populate: populate.join(',')
|
|
55
|
-
});
|
|
56
|
-
}
|
|
57
|
-
get(recordId) {
|
|
58
|
-
return new Database(this.client, { ...this.urlParams, recordId }, HttpMethod.GET);
|
|
59
|
-
}
|
|
60
|
-
create(body) {
|
|
61
|
-
return new Database(this.client, { ...this.urlParams }, HttpMethod.POST, body);
|
|
62
|
-
}
|
|
63
|
-
update(body) {
|
|
64
|
-
return new Database(this.client, { ...this.urlParams }, HttpMethod.PATCH, body);
|
|
65
|
-
}
|
|
66
|
-
delete(recordId) {
|
|
67
|
-
return new Database(this.client, { ...this.urlParams, recordId }, HttpMethod.DELETE);
|
|
68
|
-
}
|
|
69
|
-
async first() {
|
|
70
|
-
const results = await this.execute();
|
|
71
|
-
if (Array.isArray(results)) {
|
|
72
|
-
return results[0] ?? null;
|
|
73
|
-
}
|
|
74
|
-
return results ?? null;
|
|
75
|
-
}
|
|
76
|
-
async count() {
|
|
77
|
-
const results = await this.execute();
|
|
78
|
-
if (Array.isArray(results)) {
|
|
79
|
-
return results.length;
|
|
80
|
-
}
|
|
81
|
-
return 0;
|
|
82
|
-
}
|
|
83
|
-
buildRoute() {
|
|
84
|
-
return (DatabaseRoutes.baseUrl(this.config.appSlug) +
|
|
85
|
-
Object.keys(this.urlParams).reduce((acc, key) => {
|
|
86
|
-
const value = this.urlParams[key];
|
|
87
|
-
const routeBuilder = DatabaseRoutes[key];
|
|
88
|
-
if (value && routeBuilder) {
|
|
89
|
-
acc += routeBuilder(value);
|
|
90
|
-
}
|
|
91
|
-
return acc;
|
|
92
|
-
}, "") +
|
|
93
|
-
"/" +
|
|
94
|
-
buildQueryString(this.queryParams));
|
|
95
|
-
}
|
|
96
|
-
async execute() {
|
|
97
|
-
// Build the API URL
|
|
98
|
-
const url = this.buildRoute();
|
|
99
|
-
const operation = this.operation || HttpMethod.GET;
|
|
100
|
-
switch (operation) {
|
|
101
|
-
case HttpMethod.POST:
|
|
102
|
-
return await this.client.httpClient.post(url, this.body);
|
|
103
|
-
case HttpMethod.PATCH:
|
|
104
|
-
if (!this.urlParams.recordId) {
|
|
105
|
-
throw new Error('PATCH operation requires a record ID.');
|
|
106
|
-
}
|
|
107
|
-
return await this.client.httpClient.patch(url, this.body);
|
|
108
|
-
case HttpMethod.DELETE:
|
|
109
|
-
return await this.client.httpClient.delete(url);
|
|
110
|
-
case HttpMethod.GET:
|
|
111
|
-
default:
|
|
112
|
-
return await this.client.httpClient.get(url);
|
|
113
|
-
}
|
|
114
|
-
}
|
|
115
|
-
}
|
|
116
|
-
//# sourceMappingURL=DatabaseClient.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"DatabaseClient.js","sourceRoot":"","sources":["../../../src/lib/Database/DatabaseClient.ts"],"names":[],"mappings":"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"}
|