@symbo.ls/sdk 3.1.1 → 3.1.2

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 (55) hide show
  1. package/README.md +172 -11
  2. package/dist/cjs/config/environment.js +39 -33
  3. package/dist/cjs/index.js +35 -8
  4. package/dist/cjs/services/AuthService.js +44 -3
  5. package/dist/cjs/services/BasedService.js +530 -24
  6. package/dist/cjs/services/CoreService.js +1751 -0
  7. package/dist/cjs/services/SocketIOService.js +34 -36
  8. package/dist/cjs/services/SymstoryService.js +135 -49
  9. package/dist/cjs/services/index.js +4 -4
  10. package/dist/cjs/utils/TokenManager.js +374 -0
  11. package/dist/cjs/utils/basedQuerys.js +120 -0
  12. package/dist/cjs/utils/permission.js +4 -4
  13. package/dist/cjs/utils/services.js +32 -9
  14. package/dist/cjs/utils/symstoryClient.js +32 -1
  15. package/dist/esm/config/environment.js +39 -33
  16. package/dist/esm/index.js +8964 -11076
  17. package/dist/esm/services/AuthService.js +48 -7
  18. package/dist/esm/services/BasedService.js +683 -56
  19. package/dist/esm/services/CoreService.js +2264 -0
  20. package/dist/esm/services/SocketIOService.js +71 -68
  21. package/dist/esm/services/SymstoryService.js +293 -101
  22. package/dist/esm/services/index.js +8905 -11066
  23. package/dist/esm/utils/TokenManager.js +360 -0
  24. package/dist/esm/utils/basedQuerys.js +120 -0
  25. package/dist/esm/utils/permission.js +4 -4
  26. package/dist/esm/utils/services.js +32 -9
  27. package/dist/esm/utils/symstoryClient.js +69 -33
  28. package/dist/esm/utils/validation.js +89 -19
  29. package/dist/node/config/environment.js +39 -33
  30. package/dist/node/index.js +43 -10
  31. package/dist/node/services/AuthService.js +44 -3
  32. package/dist/node/services/BasedService.js +531 -25
  33. package/dist/node/services/CoreService.js +1722 -0
  34. package/dist/node/services/SocketIOService.js +34 -36
  35. package/dist/node/services/SymstoryService.js +135 -49
  36. package/dist/node/services/index.js +4 -4
  37. package/dist/node/utils/TokenManager.js +355 -0
  38. package/dist/node/utils/basedQuerys.js +120 -0
  39. package/dist/node/utils/permission.js +4 -4
  40. package/dist/node/utils/services.js +32 -9
  41. package/dist/node/utils/symstoryClient.js +32 -1
  42. package/package.json +16 -13
  43. package/src/config/environment.js +40 -35
  44. package/src/index.js +49 -10
  45. package/src/services/AuthService.js +52 -3
  46. package/src/services/BasedService.js +602 -23
  47. package/src/services/CoreService.js +1943 -0
  48. package/src/services/SocketIOService.js +49 -71
  49. package/src/services/SymstoryService.js +150 -64
  50. package/src/services/index.js +4 -4
  51. package/src/utils/TokenManager.js +424 -0
  52. package/src/utils/basedQuerys.js +123 -0
  53. package/src/utils/permission.js +4 -4
  54. package/src/utils/services.js +32 -9
  55. package/src/utils/symstoryClient.js +35 -1
@@ -0,0 +1,360 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
3
+ var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
4
+
5
+ // src/utils/TokenManager.js
6
+ var TokenManager = class {
7
+ constructor(options = {}) {
8
+ /**
9
+ * Memory storage fallback for server-side rendering
10
+ */
11
+ __publicField(this, "_memoryStorage", {
12
+ _data: {},
13
+ getItem: (key) => this._memoryStorage._data[key] || null,
14
+ setItem: (key, value) => {
15
+ this._memoryStorage._data[key] = value;
16
+ },
17
+ removeItem: (key) => {
18
+ delete this._memoryStorage._data[key];
19
+ },
20
+ clear: () => {
21
+ this._memoryStorage._data = {};
22
+ }
23
+ });
24
+ this.config = {
25
+ storagePrefix: "symbols_",
26
+ storageType: "localStorage",
27
+ // 'localStorage' | 'sessionStorage' | 'memory'
28
+ refreshBuffer: 60 * 1e3,
29
+ // Refresh 1 minute before expiry
30
+ maxRetries: 3,
31
+ apiUrl: options.apiUrl || "/api",
32
+ onTokenRefresh: options.onTokenRefresh || null,
33
+ onTokenExpired: options.onTokenExpired || null,
34
+ onTokenError: options.onTokenError || null,
35
+ ...options
36
+ };
37
+ this.tokens = {
38
+ accessToken: null,
39
+ refreshToken: null,
40
+ expiresAt: null,
41
+ expiresIn: null
42
+ };
43
+ this.refreshPromise = null;
44
+ this.refreshTimeout = null;
45
+ this.retryCount = 0;
46
+ this.loadTokens();
47
+ }
48
+ /**
49
+ * Storage keys
50
+ */
51
+ get storageKeys() {
52
+ return {
53
+ accessToken: `${this.config.storagePrefix}access_token`,
54
+ refreshToken: `${this.config.storagePrefix}refresh_token`,
55
+ expiresAt: `${this.config.storagePrefix}expires_at`,
56
+ expiresIn: `${this.config.storagePrefix}expires_in`
57
+ };
58
+ }
59
+ /**
60
+ * Get storage instance based on configuration
61
+ */
62
+ get storage() {
63
+ if (typeof window === "undefined") {
64
+ return this._memoryStorage;
65
+ }
66
+ switch (this.config.storageType) {
67
+ case "sessionStorage":
68
+ return window.sessionStorage;
69
+ case "memory":
70
+ return this._memoryStorage;
71
+ default:
72
+ return window.localStorage;
73
+ }
74
+ }
75
+ /**
76
+ * Set tokens and persist to storage
77
+ */
78
+ setTokens(tokenData) {
79
+ const {
80
+ access_token: accessToken,
81
+ refresh_token: refreshToken,
82
+ expires_in: expiresIn,
83
+ token_type: tokenType = "Bearer"
84
+ } = tokenData;
85
+ if (!accessToken) {
86
+ throw new Error("Access token is required");
87
+ }
88
+ const now = Date.now();
89
+ const expiresAt = expiresIn ? now + expiresIn * 1e3 : null;
90
+ this.tokens = {
91
+ accessToken,
92
+ refreshToken: refreshToken || this.tokens.refreshToken,
93
+ expiresAt,
94
+ expiresIn,
95
+ tokenType
96
+ };
97
+ this.saveTokens();
98
+ this.scheduleRefresh();
99
+ if (this.config.onTokenRefresh) {
100
+ this.config.onTokenRefresh(this.tokens);
101
+ }
102
+ return this.tokens;
103
+ }
104
+ /**
105
+ * Get current access token
106
+ */
107
+ getAccessToken() {
108
+ return this.tokens.accessToken;
109
+ }
110
+ /**
111
+ * Get current refresh token
112
+ */
113
+ getRefreshToken() {
114
+ return this.tokens.refreshToken;
115
+ }
116
+ /**
117
+ * Get authorization header value
118
+ */
119
+ getAuthHeader() {
120
+ const token = this.getAccessToken();
121
+ if (!token) {
122
+ return null;
123
+ }
124
+ return `${this.tokens.tokenType || "Bearer"} ${token}`;
125
+ }
126
+ /**
127
+ * Check if access token is valid and not expired
128
+ */
129
+ isAccessTokenValid() {
130
+ if (!this.tokens.accessToken) {
131
+ return false;
132
+ }
133
+ if (!this.tokens.expiresAt) {
134
+ return true;
135
+ }
136
+ const now = Date.now();
137
+ return now < this.tokens.expiresAt - this.config.refreshBuffer;
138
+ }
139
+ /**
140
+ * Check if tokens exist (regardless of expiry)
141
+ */
142
+ hasTokens() {
143
+ return Boolean(this.tokens.accessToken);
144
+ }
145
+ /**
146
+ * Check if refresh token exists
147
+ */
148
+ hasRefreshToken() {
149
+ return Boolean(this.tokens.refreshToken);
150
+ }
151
+ /**
152
+ * Automatically refresh tokens if needed
153
+ */
154
+ async ensureValidToken() {
155
+ if (!this.hasTokens()) {
156
+ return null;
157
+ }
158
+ if (this.isAccessTokenValid()) {
159
+ return this.getAccessToken();
160
+ }
161
+ if (!this.hasRefreshToken()) {
162
+ this.clearTokens();
163
+ if (this.config.onTokenExpired) {
164
+ this.config.onTokenExpired();
165
+ }
166
+ return null;
167
+ }
168
+ try {
169
+ await this.refreshTokens();
170
+ return this.getAccessToken();
171
+ } catch (error) {
172
+ this.clearTokens();
173
+ if (this.config.onTokenError) {
174
+ this.config.onTokenError(error);
175
+ }
176
+ throw error;
177
+ }
178
+ }
179
+ /**
180
+ * Refresh access token using refresh token
181
+ */
182
+ async refreshTokens() {
183
+ if (this.refreshPromise) {
184
+ return this.refreshPromise;
185
+ }
186
+ if (!this.hasRefreshToken()) {
187
+ throw new Error("No refresh token available");
188
+ }
189
+ if (this.retryCount >= this.config.maxRetries) {
190
+ throw new Error("Max refresh retries exceeded");
191
+ }
192
+ this.refreshPromise = this._performRefresh();
193
+ try {
194
+ const result = await this.refreshPromise;
195
+ this.retryCount = 0;
196
+ return result;
197
+ } catch (error) {
198
+ this.retryCount++;
199
+ throw error;
200
+ } finally {
201
+ this.refreshPromise = null;
202
+ }
203
+ }
204
+ /**
205
+ * Perform the actual token refresh request
206
+ */
207
+ async _performRefresh() {
208
+ var _a;
209
+ const refreshToken = this.getRefreshToken();
210
+ const response = await fetch(`${this.config.apiUrl}/core/auth/refresh`, {
211
+ method: "POST",
212
+ headers: {
213
+ "Content-Type": "application/json"
214
+ },
215
+ body: JSON.stringify({ refreshToken })
216
+ });
217
+ if (!response.ok) {
218
+ const errorData = await response.json().catch(() => ({}));
219
+ throw new Error(errorData.message || `Token refresh failed: ${response.status}`);
220
+ }
221
+ const responseData = await response.json();
222
+ if (responseData.success && responseData.data && responseData.data.tokens) {
223
+ const { tokens } = responseData.data;
224
+ const tokenData = {
225
+ access_token: tokens.accessToken,
226
+ refresh_token: tokens.refreshToken,
227
+ expires_in: (_a = tokens.accessTokenExp) == null ? void 0 : _a.expiresIn,
228
+ token_type: "Bearer"
229
+ };
230
+ return this.setTokens(tokenData);
231
+ }
232
+ return this.setTokens(responseData);
233
+ }
234
+ /**
235
+ * Schedule automatic token refresh
236
+ */
237
+ scheduleRefresh() {
238
+ if (this.refreshTimeout) {
239
+ clearTimeout(this.refreshTimeout);
240
+ this.refreshTimeout = null;
241
+ }
242
+ if (!this.tokens.expiresAt || !this.hasRefreshToken()) {
243
+ return;
244
+ }
245
+ const now = Date.now();
246
+ const refreshTime = this.tokens.expiresAt - this.config.refreshBuffer;
247
+ const delay = Math.max(0, refreshTime - now);
248
+ this.refreshTimeout = setTimeout(async () => {
249
+ try {
250
+ await this.refreshTokens();
251
+ } catch (error) {
252
+ console.error("Automatic token refresh failed:", error);
253
+ if (this.config.onTokenError) {
254
+ this.config.onTokenError(error);
255
+ }
256
+ }
257
+ }, delay);
258
+ }
259
+ /**
260
+ * Save tokens to storage
261
+ */
262
+ saveTokens() {
263
+ const { storage } = this;
264
+ const keys = this.storageKeys;
265
+ if (this.tokens.accessToken) {
266
+ storage.setItem(keys.accessToken, this.tokens.accessToken);
267
+ }
268
+ if (this.tokens.refreshToken) {
269
+ storage.setItem(keys.refreshToken, this.tokens.refreshToken);
270
+ }
271
+ if (this.tokens.expiresAt) {
272
+ storage.setItem(keys.expiresAt, this.tokens.expiresAt.toString());
273
+ }
274
+ if (this.tokens.expiresIn) {
275
+ storage.setItem(keys.expiresIn, this.tokens.expiresIn.toString());
276
+ }
277
+ }
278
+ /**
279
+ * Load tokens from storage
280
+ */
281
+ loadTokens() {
282
+ const { storage } = this;
283
+ const keys = this.storageKeys;
284
+ const accessToken = storage.getItem(keys.accessToken);
285
+ const refreshToken = storage.getItem(keys.refreshToken);
286
+ const expiresAt = storage.getItem(keys.expiresAt);
287
+ const expiresIn = storage.getItem(keys.expiresIn);
288
+ if (accessToken) {
289
+ this.tokens = {
290
+ accessToken,
291
+ refreshToken,
292
+ expiresAt: expiresAt ? parseInt(expiresAt, 10) : null,
293
+ expiresIn: expiresIn ? parseInt(expiresIn, 10) : null,
294
+ tokenType: "Bearer"
295
+ };
296
+ this.scheduleRefresh();
297
+ }
298
+ }
299
+ /**
300
+ * Clear all tokens
301
+ */
302
+ clearTokens() {
303
+ this.tokens = {
304
+ accessToken: null,
305
+ refreshToken: null,
306
+ expiresAt: null,
307
+ expiresIn: null
308
+ };
309
+ const { storage } = this;
310
+ const keys = this.storageKeys;
311
+ Object.values(keys).forEach((key) => {
312
+ storage.removeItem(key);
313
+ });
314
+ if (this.refreshTimeout) {
315
+ clearTimeout(this.refreshTimeout);
316
+ this.refreshTimeout = null;
317
+ }
318
+ this.retryCount = 0;
319
+ }
320
+ /**
321
+ * Get token status information
322
+ */
323
+ getTokenStatus() {
324
+ const hasTokens = this.hasTokens();
325
+ const isValid = this.isAccessTokenValid();
326
+ const { expiresAt } = this.tokens;
327
+ const timeToExpiry = expiresAt ? expiresAt - Date.now() : null;
328
+ return {
329
+ hasTokens,
330
+ isValid,
331
+ hasRefreshToken: this.hasRefreshToken(),
332
+ expiresAt,
333
+ timeToExpiry,
334
+ willExpireSoon: timeToExpiry ? timeToExpiry < this.config.refreshBuffer : false
335
+ };
336
+ }
337
+ /**
338
+ * Cleanup resources
339
+ */
340
+ destroy() {
341
+ if (this.refreshTimeout) {
342
+ clearTimeout(this.refreshTimeout);
343
+ this.refreshTimeout = null;
344
+ }
345
+ this.refreshPromise = null;
346
+ }
347
+ };
348
+ var defaultTokenManager = null;
349
+ var getTokenManager = (options) => {
350
+ if (!defaultTokenManager) {
351
+ defaultTokenManager = new TokenManager(options);
352
+ }
353
+ return defaultTokenManager;
354
+ };
355
+ var createTokenManager = (options) => new TokenManager(options);
356
+ export {
357
+ TokenManager,
358
+ createTokenManager,
359
+ getTokenManager
360
+ };
@@ -37,7 +37,127 @@ var buildUserQuery = (userId) => ({
37
37
  $all: true
38
38
  }
39
39
  });
40
+ var buildGetUserDataQuery = (userId) => ({
41
+ $id: userId,
42
+ id: true,
43
+ name: true,
44
+ email: true,
45
+ username: true,
46
+ globalRole: true,
47
+ updatedAt: true,
48
+ createdAt: true,
49
+ memberProjects: {
50
+ $list: true,
51
+ id: true,
52
+ role: true,
53
+ createdAt: true,
54
+ updatedAt: true,
55
+ project: {
56
+ id: true,
57
+ key: true,
58
+ name: true,
59
+ thumbnail: true,
60
+ icon: true,
61
+ tier: true,
62
+ visibility: true,
63
+ access: true,
64
+ members: {
65
+ $list: true,
66
+ user: {
67
+ id: true,
68
+ name: true,
69
+ email: true,
70
+ globalRole: true
71
+ },
72
+ role: true,
73
+ updatedAt: true,
74
+ createdAt: true
75
+ }
76
+ }
77
+ }
78
+ });
79
+ var buildGetProjectsByKeysQuery = (keys) => ({
80
+ projects: {
81
+ id: true,
82
+ key: true,
83
+ name: true,
84
+ thumbnail: true,
85
+ icon: true,
86
+ tier: true,
87
+ visibility: true,
88
+ access: true,
89
+ members: {
90
+ $list: true,
91
+ user: {
92
+ id: true,
93
+ name: true,
94
+ email: true,
95
+ globalRole: true
96
+ },
97
+ role: true,
98
+ updatedAt: true,
99
+ createdAt: true
100
+ },
101
+ $list: {
102
+ $find: {
103
+ $traverse: "children",
104
+ $filter: [
105
+ { $field: "type", $operator: "=", $value: "project" },
106
+ { $field: "key", $operator: "=", $value: keys }
107
+ ]
108
+ }
109
+ }
110
+ }
111
+ });
112
+ var GetProjectFields = {
113
+ id: true,
114
+ name: true,
115
+ key: true,
116
+ tier: true,
117
+ projectType: true,
118
+ icon: true,
119
+ package: true,
120
+ seats: true,
121
+ projectPassword: true,
122
+ stripe: true,
123
+ payments: {
124
+ $list: true,
125
+ id: true,
126
+ name: true
127
+ },
128
+ access: true,
129
+ isSharedLibrary: true,
130
+ framework: true,
131
+ designTool: true,
132
+ language: true,
133
+ visibility: true,
134
+ domains: true,
135
+ subscription: { id: true },
136
+ members: {
137
+ $list: true,
138
+ user: { id: true, name: true, email: true },
139
+ role: true
140
+ }
141
+ };
142
+ var buildGetProjectDataQuery = (projectId) => ({
143
+ $id: projectId,
144
+ ...GetProjectFields
145
+ });
146
+ var buildGetProjectByKeyDataQuery = (key) => ({
147
+ ...GetProjectFields,
148
+ $find: {
149
+ $traverse: "children",
150
+ $filter: [
151
+ { $field: "type", $operator: "=", $value: "project" },
152
+ { $field: "key", $operator: "=", $value: key }
153
+ ]
154
+ }
155
+ });
40
156
  export {
157
+ buildGetProjectByKeyDataQuery,
158
+ buildGetProjectDataQuery,
159
+ buildGetProjectsByKeysQuery,
160
+ buildGetUserDataQuery,
41
161
  buildProjectQuery,
42
162
  buildUserQuery
43
163
  };
@@ -78,12 +78,11 @@ var PERMISSION_MAP = {
78
78
  };
79
79
  var ROLE_PERMISSIONS = {
80
80
  guest: ["viewPublicProjects"],
81
- user: ["viewPublicProjects", "createProject"],
82
- admin: ["viewPublicProjects", "createProject", "manageUsers"],
81
+ user: ["viewPublicProjects"],
82
+ admin: ["viewPublicProjects", "governance"],
83
83
  superAdmin: [
84
84
  "viewPublicProjects",
85
- "createProject",
86
- "manageUsers",
85
+ "governance",
87
86
  "managePlatform"
88
87
  ]
89
88
  };
@@ -179,6 +178,7 @@ var TIER_FEATURES = {
179
178
  ]
180
179
  };
181
180
  var PROJECT_ROLE_PERMISSIONS = {
181
+ unauthenticated: ["platformSettings", "showContent"],
182
182
  guest: ["platformSettings", "showContent"],
183
183
  editor: [
184
184
  "platformSettings",
@@ -1,31 +1,32 @@
1
1
  // src/utils/services.js
2
2
  var SERVICE_METHODS = {
3
- // Auth service methods
3
+ // Auth service methods (legacy - keeping for backward compatibility)
4
4
  auth: "auth",
5
5
  login: "auth",
6
6
  register: "auth",
7
7
  googleAuth: "auth",
8
+ googleAuthCallback: "auth",
8
9
  githubAuth: "auth",
9
10
  confirmRegistration: "auth",
10
11
  logout: "auth",
11
12
  updateUserRole: "auth",
12
13
  hasPermission: "auth",
14
+ hasGlobalPermission: "auth",
13
15
  getProjectMembers: "auth",
14
16
  inviteMember: "auth",
15
17
  acceptInvite: "auth",
16
18
  updateMemberRole: "auth",
17
19
  removeMember: "auth",
18
20
  updateProjectTier: "auth",
19
- requestPasswordReset: "auth",
20
- confirmPasswordReset: "auth",
21
21
  subscribeToAuthChanges: "auth",
22
- getStoredAuthState: "auth",
22
+ getStoredAuthState: "core",
23
23
  // AI service methods
24
24
  prompt: "ai",
25
25
  // Based service methods
26
26
  query: "based",
27
27
  setProject: "based",
28
28
  setUser: "based",
29
+ setUserForced: "based",
29
30
  subscribe: "based",
30
31
  call: "based",
31
32
  getProject: "based",
@@ -61,30 +62,52 @@ var SERVICE_METHODS = {
61
62
  confirmPasswordChange: "based",
62
63
  updateUserProfile: "based",
63
64
  duplicateProject: "based",
65
+ listPlans: "based",
66
+ subscribeToPlan: "based",
67
+ getSubscriptionDetails: "based",
68
+ checkSubscriptionStatus: "based",
69
+ upgradeSubscription: "based",
70
+ downgradeSubscription: "based",
71
+ cancelSubscription: "based",
72
+ reactivateSubscription: "based",
73
+ generateInvoice: "based",
74
+ getUsageReport: "based",
75
+ inviteAccountOwner: "based",
76
+ acceptOwnerInvitation: "based",
77
+ removeAccountOwner: "based",
78
+ checkResourceLimit: "based",
79
+ checkFeatureAccess: "based",
80
+ getUserFeatures: "based",
81
+ getAvailableFeatures: "based",
82
+ listFeatureFlags: "based",
83
+ updateFeatureFlag: "based",
84
+ removeFeatureFlag: "based",
85
+ batchUpdateFeatureFlags: "based",
86
+ updatePlanDetails: "based",
87
+ updatePlanStatus: "based",
64
88
  // Symstory service methods
65
89
  set: "symstory",
66
90
  getData: "symstory",
67
91
  updateData: "symstory",
68
92
  getBranches: "symstory",
69
- createBranch: "symstory",
70
93
  editBranch: "symstory",
71
- deleteBranch: "symstory",
72
- mergeBranch: "symstory",
73
94
  restoreVersion: "symstory",
74
95
  getItem: "symstory",
75
96
  addItem: "symstory",
97
+ addMultipleItems: "symstory",
76
98
  updateItem: "symstory",
77
99
  deleteItem: "symstory",
78
100
  switchVersion: "symstory",
79
101
  switchBranch: "symstory",
80
102
  undo: "symstory",
81
103
  redo: "symstory",
104
+ publish: "symstory",
105
+ getChanges: "symstory",
82
106
  // Socket service methods
83
107
  send: "socket",
84
108
  subscribeChannel: "socket",
85
109
  connect: "socket",
86
- reconnect: "socket",
87
- destroy: "socket"
110
+ reconnect: "socket"
88
111
  };
89
112
  export {
90
113
  SERVICE_METHODS