@growsober/sdk 1.0.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 (129) hide show
  1. package/README.md +276 -0
  2. package/dist/__tests__/e2e.test.d.ts +7 -0
  3. package/dist/__tests__/e2e.test.js +472 -0
  4. package/dist/api/client.d.ts +11 -0
  5. package/dist/api/client.js +61 -0
  6. package/dist/api/mutations/admin.d.ts +167 -0
  7. package/dist/api/mutations/admin.js +326 -0
  8. package/dist/api/mutations/ambassadors.d.ts +52 -0
  9. package/dist/api/mutations/ambassadors.js +148 -0
  10. package/dist/api/mutations/auth.d.ts +267 -0
  11. package/dist/api/mutations/auth.js +332 -0
  12. package/dist/api/mutations/bookings.d.ts +59 -0
  13. package/dist/api/mutations/bookings.js +143 -0
  14. package/dist/api/mutations/event-chat.d.ts +35 -0
  15. package/dist/api/mutations/event-chat.js +147 -0
  16. package/dist/api/mutations/events.d.ts +87 -0
  17. package/dist/api/mutations/events.js +205 -0
  18. package/dist/api/mutations/grow90.d.ts +36 -0
  19. package/dist/api/mutations/grow90.js +132 -0
  20. package/dist/api/mutations/hubs.d.ts +111 -0
  21. package/dist/api/mutations/hubs.js +240 -0
  22. package/dist/api/mutations/index.d.ts +22 -0
  23. package/dist/api/mutations/index.js +39 -0
  24. package/dist/api/mutations/jack.d.ts +61 -0
  25. package/dist/api/mutations/jack.js +104 -0
  26. package/dist/api/mutations/library.d.ts +67 -0
  27. package/dist/api/mutations/library.js +168 -0
  28. package/dist/api/mutations/map.d.ts +153 -0
  29. package/dist/api/mutations/map.js +181 -0
  30. package/dist/api/mutations/matching.d.ts +130 -0
  31. package/dist/api/mutations/matching.js +204 -0
  32. package/dist/api/mutations/notifications.d.ts +63 -0
  33. package/dist/api/mutations/notifications.js +106 -0
  34. package/dist/api/mutations/offers.d.ts +26 -0
  35. package/dist/api/mutations/offers.js +47 -0
  36. package/dist/api/mutations/subscriptions.d.ts +127 -0
  37. package/dist/api/mutations/subscriptions.js +140 -0
  38. package/dist/api/mutations/support.d.ts +165 -0
  39. package/dist/api/mutations/support.js +307 -0
  40. package/dist/api/mutations/users.d.ts +211 -0
  41. package/dist/api/mutations/users.js +261 -0
  42. package/dist/api/queries/admin.d.ts +257 -0
  43. package/dist/api/queries/admin.js +320 -0
  44. package/dist/api/queries/ambassadors.d.ts +53 -0
  45. package/dist/api/queries/ambassadors.js +98 -0
  46. package/dist/api/queries/auth.d.ts +16 -0
  47. package/dist/api/queries/auth.js +25 -0
  48. package/dist/api/queries/bookings.d.ts +91 -0
  49. package/dist/api/queries/bookings.js +102 -0
  50. package/dist/api/queries/businesses.d.ts +212 -0
  51. package/dist/api/queries/businesses.js +154 -0
  52. package/dist/api/queries/event-chat.d.ts +19 -0
  53. package/dist/api/queries/event-chat.js +75 -0
  54. package/dist/api/queries/events.d.ts +322 -0
  55. package/dist/api/queries/events.js +221 -0
  56. package/dist/api/queries/grow90.d.ts +26 -0
  57. package/dist/api/queries/grow90.js +85 -0
  58. package/dist/api/queries/hubs.d.ts +165 -0
  59. package/dist/api/queries/hubs.js +143 -0
  60. package/dist/api/queries/index.d.ts +23 -0
  61. package/dist/api/queries/index.js +40 -0
  62. package/dist/api/queries/jack.d.ts +63 -0
  63. package/dist/api/queries/jack.js +92 -0
  64. package/dist/api/queries/library.d.ts +132 -0
  65. package/dist/api/queries/library.js +120 -0
  66. package/dist/api/queries/map.d.ts +216 -0
  67. package/dist/api/queries/map.js +278 -0
  68. package/dist/api/queries/matching.d.ts +136 -0
  69. package/dist/api/queries/matching.js +161 -0
  70. package/dist/api/queries/notifications.d.ts +78 -0
  71. package/dist/api/queries/notifications.js +88 -0
  72. package/dist/api/queries/offers.d.ts +91 -0
  73. package/dist/api/queries/offers.js +103 -0
  74. package/dist/api/queries/subscriptions.d.ts +56 -0
  75. package/dist/api/queries/subscriptions.js +73 -0
  76. package/dist/api/queries/support.d.ts +106 -0
  77. package/dist/api/queries/support.js +202 -0
  78. package/dist/api/queries/users.d.ts +293 -0
  79. package/dist/api/queries/users.js +370 -0
  80. package/dist/api/types.d.ts +464 -0
  81. package/dist/api/types.js +9 -0
  82. package/dist/hooks/useAuth.d.ts +5 -0
  83. package/dist/hooks/useAuth.js +39 -0
  84. package/dist/hooks/useUser.d.ts +43 -0
  85. package/dist/hooks/useUser.js +44 -0
  86. package/dist/index.d.ts +36 -0
  87. package/dist/index.js +67 -0
  88. package/package.json +62 -0
  89. package/src/__tests__/e2e.test.ts +502 -0
  90. package/src/api/client.ts +71 -0
  91. package/src/api/mutations/admin.ts +531 -0
  92. package/src/api/mutations/ambassadors.ts +185 -0
  93. package/src/api/mutations/auth.ts +350 -0
  94. package/src/api/mutations/bookings.ts +190 -0
  95. package/src/api/mutations/event-chat.ts +177 -0
  96. package/src/api/mutations/events.ts +273 -0
  97. package/src/api/mutations/grow90.ts +169 -0
  98. package/src/api/mutations/hubs.ts +385 -0
  99. package/src/api/mutations/index.ts +23 -0
  100. package/src/api/mutations/jack.ts +130 -0
  101. package/src/api/mutations/library.ts +212 -0
  102. package/src/api/mutations/map.ts +230 -0
  103. package/src/api/mutations/matching.ts +271 -0
  104. package/src/api/mutations/notifications.ts +114 -0
  105. package/src/api/mutations/offers.ts +73 -0
  106. package/src/api/mutations/subscriptions.ts +162 -0
  107. package/src/api/mutations/support.ts +390 -0
  108. package/src/api/mutations/users.ts +271 -0
  109. package/src/api/queries/admin.ts +480 -0
  110. package/src/api/queries/ambassadors.ts +139 -0
  111. package/src/api/queries/auth.ts +24 -0
  112. package/src/api/queries/bookings.ts +135 -0
  113. package/src/api/queries/businesses.ts +203 -0
  114. package/src/api/queries/event-chat.ts +78 -0
  115. package/src/api/queries/events.ts +272 -0
  116. package/src/api/queries/grow90.ts +98 -0
  117. package/src/api/queries/hubs.ts +211 -0
  118. package/src/api/queries/index.ts +24 -0
  119. package/src/api/queries/jack.ts +127 -0
  120. package/src/api/queries/library.ts +166 -0
  121. package/src/api/queries/map.ts +331 -0
  122. package/src/api/queries/matching.ts +238 -0
  123. package/src/api/queries/notifications.ts +103 -0
  124. package/src/api/queries/offers.ts +136 -0
  125. package/src/api/queries/subscriptions.ts +91 -0
  126. package/src/api/queries/support.ts +235 -0
  127. package/src/api/queries/users.ts +393 -0
  128. package/src/api/types.ts +596 -0
  129. package/src/index.ts +57 -0
@@ -0,0 +1,320 @@
1
+ "use strict";
2
+ /**
3
+ * Admin Query Hooks
4
+ *
5
+ * TanStack Query hooks for admin-related read operations.
6
+ * These hooks handle fetching data for the admin dashboard including
7
+ * users, hubs, events, businesses, content, and analytics.
8
+ *
9
+ * @module api/queries/admin
10
+ */
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.adminKeys = void 0;
13
+ exports.useAdminDashboard = useAdminDashboard;
14
+ exports.useAdminAnalytics = useAdminAnalytics;
15
+ exports.useAdminUsers = useAdminUsers;
16
+ exports.useAdminUser = useAdminUser;
17
+ exports.useAdminHubs = useAdminHubs;
18
+ exports.useAdminHub = useAdminHub;
19
+ exports.useAdminEvents = useAdminEvents;
20
+ exports.useAdminEvent = useAdminEvent;
21
+ exports.useAdminBusinesses = useAdminBusinesses;
22
+ exports.useAdminBusiness = useAdminBusiness;
23
+ exports.useAdminContent = useAdminContent;
24
+ exports.useAdminContentItem = useAdminContentItem;
25
+ const react_query_1 = require("@tanstack/react-query");
26
+ const client_1 = require("../client");
27
+ // ============================================================================
28
+ // QUERY KEYS
29
+ // ============================================================================
30
+ exports.adminKeys = {
31
+ all: ['admin'],
32
+ dashboard: () => [...exports.adminKeys.all, 'dashboard'],
33
+ analytics: (period) => [...exports.adminKeys.all, 'analytics', period],
34
+ users: {
35
+ all: () => [...exports.adminKeys.all, 'users'],
36
+ list: (filters) => [...exports.adminKeys.users.all(), 'list', filters],
37
+ detail: (id) => [...exports.adminKeys.users.all(), 'detail', id],
38
+ },
39
+ hubs: {
40
+ all: () => [...exports.adminKeys.all, 'hubs'],
41
+ list: (filters) => [...exports.adminKeys.hubs.all(), 'list', filters],
42
+ detail: (id) => [...exports.adminKeys.hubs.all(), 'detail', id],
43
+ },
44
+ events: {
45
+ all: () => [...exports.adminKeys.all, 'events'],
46
+ list: (filters) => [...exports.adminKeys.events.all(), 'list', filters],
47
+ detail: (id) => [...exports.adminKeys.events.all(), 'detail', id],
48
+ },
49
+ businesses: {
50
+ all: () => [...exports.adminKeys.all, 'businesses'],
51
+ list: (filters) => [...exports.adminKeys.businesses.all(), 'list', filters],
52
+ detail: (id) => [...exports.adminKeys.businesses.all(), 'detail', id],
53
+ },
54
+ content: {
55
+ all: () => [...exports.adminKeys.all, 'content'],
56
+ list: (filters) => [...exports.adminKeys.content.all(), 'list', filters],
57
+ detail: (id) => [...exports.adminKeys.content.all(), 'detail', id],
58
+ },
59
+ };
60
+ // ============================================================================
61
+ // DASHBOARD & ANALYTICS
62
+ // ============================================================================
63
+ /**
64
+ * Get admin dashboard statistics
65
+ *
66
+ * @description
67
+ * Retrieves key metrics for the admin dashboard including
68
+ * user counts, hub stats, event stats, and revenue data.
69
+ *
70
+ * @endpoint GET /api/v1/admin/dashboard
71
+ *
72
+ * @example
73
+ * ```tsx
74
+ * import { useAdminDashboard } from '@growsober/sdk';
75
+ *
76
+ * function AdminDashboard() {
77
+ * const { data: stats, isLoading } = useAdminDashboard();
78
+ *
79
+ * if (isLoading) return <Spinner />;
80
+ *
81
+ * return (
82
+ * <div>
83
+ * <StatCard label="Total Users" value={stats.totalUsers} />
84
+ * <StatCard label="Active Users" value={stats.activeUsers} />
85
+ * <StatCard label="Premium Users" value={stats.premiumUsers} />
86
+ * <StatCard label="Revenue This Month" value={stats.revenue.thisMonth} />
87
+ * </div>
88
+ * );
89
+ * }
90
+ * ```
91
+ */
92
+ function useAdminDashboard(options) {
93
+ return (0, react_query_1.useQuery)({
94
+ queryKey: exports.adminKeys.dashboard(),
95
+ queryFn: async () => {
96
+ const client = (0, client_1.getApiClient)();
97
+ const response = await client.get('/api/v1/admin/dashboard');
98
+ return response.data;
99
+ },
100
+ ...options,
101
+ });
102
+ }
103
+ /**
104
+ * Get admin analytics data
105
+ *
106
+ * @description
107
+ * Retrieves detailed analytics data for charts and reports.
108
+ *
109
+ * @endpoint GET /api/v1/admin/analytics
110
+ *
111
+ * @example
112
+ * ```tsx
113
+ * import { useAdminAnalytics } from '@growsober/sdk';
114
+ *
115
+ * function AnalyticsPage() {
116
+ * const { data: analytics } = useAdminAnalytics('30d');
117
+ *
118
+ * return (
119
+ * <div>
120
+ * <LineChart data={analytics?.userGrowth} />
121
+ * <BarChart data={analytics?.eventAttendance} />
122
+ * </div>
123
+ * );
124
+ * }
125
+ * ```
126
+ */
127
+ function useAdminAnalytics(period, options) {
128
+ return (0, react_query_1.useQuery)({
129
+ queryKey: exports.adminKeys.analytics(period),
130
+ queryFn: async () => {
131
+ const client = (0, client_1.getApiClient)();
132
+ const response = await client.get('/api/v1/admin/analytics', {
133
+ params: { period },
134
+ });
135
+ return response.data;
136
+ },
137
+ ...options,
138
+ });
139
+ }
140
+ // ============================================================================
141
+ // USER MANAGEMENT
142
+ // ============================================================================
143
+ /**
144
+ * List users for admin
145
+ *
146
+ * @endpoint GET /api/v1/admin/users
147
+ */
148
+ function useAdminUsers(filters, options) {
149
+ return (0, react_query_1.useQuery)({
150
+ queryKey: exports.adminKeys.users.list(filters),
151
+ queryFn: async () => {
152
+ const client = (0, client_1.getApiClient)();
153
+ const response = await client.get('/api/v1/admin/users', { params: filters });
154
+ return response.data;
155
+ },
156
+ ...options,
157
+ });
158
+ }
159
+ /**
160
+ * Get user detail for admin
161
+ *
162
+ * @endpoint GET /api/v1/admin/users/{id}
163
+ */
164
+ function useAdminUser(id, options) {
165
+ return (0, react_query_1.useQuery)({
166
+ queryKey: exports.adminKeys.users.detail(id),
167
+ queryFn: async () => {
168
+ const client = (0, client_1.getApiClient)();
169
+ const response = await client.get(`/api/v1/admin/users/${id}`);
170
+ return response.data;
171
+ },
172
+ enabled: !!id,
173
+ ...options,
174
+ });
175
+ }
176
+ // ============================================================================
177
+ // HUB MANAGEMENT
178
+ // ============================================================================
179
+ /**
180
+ * List hubs for admin
181
+ *
182
+ * @endpoint GET /api/v1/admin/hubs
183
+ */
184
+ function useAdminHubs(filters, options) {
185
+ return (0, react_query_1.useQuery)({
186
+ queryKey: exports.adminKeys.hubs.list(filters),
187
+ queryFn: async () => {
188
+ const client = (0, client_1.getApiClient)();
189
+ const response = await client.get('/api/v1/admin/hubs', { params: filters });
190
+ return response.data;
191
+ },
192
+ ...options,
193
+ });
194
+ }
195
+ /**
196
+ * Get hub detail for admin
197
+ *
198
+ * @endpoint GET /api/v1/admin/hubs/{id}
199
+ */
200
+ function useAdminHub(id, options) {
201
+ return (0, react_query_1.useQuery)({
202
+ queryKey: exports.adminKeys.hubs.detail(id),
203
+ queryFn: async () => {
204
+ const client = (0, client_1.getApiClient)();
205
+ const response = await client.get(`/api/v1/admin/hubs/${id}`);
206
+ return response.data;
207
+ },
208
+ enabled: !!id,
209
+ ...options,
210
+ });
211
+ }
212
+ // ============================================================================
213
+ // EVENT MANAGEMENT
214
+ // ============================================================================
215
+ /**
216
+ * List events for admin
217
+ *
218
+ * @endpoint GET /api/v1/admin/events
219
+ */
220
+ function useAdminEvents(filters, options) {
221
+ return (0, react_query_1.useQuery)({
222
+ queryKey: exports.adminKeys.events.list(filters),
223
+ queryFn: async () => {
224
+ const client = (0, client_1.getApiClient)();
225
+ const response = await client.get('/api/v1/admin/events', { params: filters });
226
+ return response.data;
227
+ },
228
+ ...options,
229
+ });
230
+ }
231
+ /**
232
+ * Get event detail for admin
233
+ *
234
+ * @endpoint GET /api/v1/admin/events/{id}
235
+ */
236
+ function useAdminEvent(id, options) {
237
+ return (0, react_query_1.useQuery)({
238
+ queryKey: exports.adminKeys.events.detail(id),
239
+ queryFn: async () => {
240
+ const client = (0, client_1.getApiClient)();
241
+ const response = await client.get(`/api/v1/admin/events/${id}`);
242
+ return response.data;
243
+ },
244
+ enabled: !!id,
245
+ ...options,
246
+ });
247
+ }
248
+ // ============================================================================
249
+ // BUSINESS MANAGEMENT
250
+ // ============================================================================
251
+ /**
252
+ * List businesses for admin
253
+ *
254
+ * @endpoint GET /api/v1/admin/businesses
255
+ */
256
+ function useAdminBusinesses(filters, options) {
257
+ return (0, react_query_1.useQuery)({
258
+ queryKey: exports.adminKeys.businesses.list(filters),
259
+ queryFn: async () => {
260
+ const client = (0, client_1.getApiClient)();
261
+ const response = await client.get('/api/v1/admin/businesses', { params: filters });
262
+ return response.data;
263
+ },
264
+ ...options,
265
+ });
266
+ }
267
+ /**
268
+ * Get business detail for admin
269
+ *
270
+ * @endpoint GET /api/v1/admin/businesses/{id}
271
+ */
272
+ function useAdminBusiness(id, options) {
273
+ return (0, react_query_1.useQuery)({
274
+ queryKey: exports.adminKeys.businesses.detail(id),
275
+ queryFn: async () => {
276
+ const client = (0, client_1.getApiClient)();
277
+ const response = await client.get(`/api/v1/admin/businesses/${id}`);
278
+ return response.data;
279
+ },
280
+ enabled: !!id,
281
+ ...options,
282
+ });
283
+ }
284
+ // ============================================================================
285
+ // CONTENT MANAGEMENT
286
+ // ============================================================================
287
+ /**
288
+ * List content for admin
289
+ *
290
+ * @endpoint GET /api/v1/admin/content
291
+ */
292
+ function useAdminContent(filters, options) {
293
+ return (0, react_query_1.useQuery)({
294
+ queryKey: exports.adminKeys.content.list(filters),
295
+ queryFn: async () => {
296
+ const client = (0, client_1.getApiClient)();
297
+ const response = await client.get('/api/v1/admin/content', { params: filters });
298
+ return response.data;
299
+ },
300
+ ...options,
301
+ });
302
+ }
303
+ /**
304
+ * Get content detail for admin
305
+ *
306
+ * @endpoint GET /api/v1/admin/content/{id}
307
+ */
308
+ function useAdminContentItem(id, options) {
309
+ return (0, react_query_1.useQuery)({
310
+ queryKey: exports.adminKeys.content.detail(id),
311
+ queryFn: async () => {
312
+ const client = (0, client_1.getApiClient)();
313
+ const response = await client.get(`/api/v1/admin/content/${id}`);
314
+ return response.data;
315
+ },
316
+ enabled: !!id,
317
+ ...options,
318
+ });
319
+ }
320
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"admin.js","sourceRoot":"","sources":["../../../src/api/queries/admin.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Admin Query Hooks\n *\n * TanStack Query hooks for admin-related read operations.\n * These hooks handle fetching data for the admin dashboard including\n * users, hubs, events, businesses, content, and analytics.\n *\n * @module api/queries/admin\n */\n\nimport { useQuery, UseQueryOptions, UseQueryResult } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport type {\n  UserResponse,\n  HubResponse,\n  EventResponse,\n  BusinessResponse,\n  LibraryContentResponse,\n} from '../types';\n\n// ============================================================================\n// ADMIN TYPES\n// ============================================================================\n\nexport interface AdminDashboardStats {\n  totalUsers: number;\n  activeUsers: number;\n  newUsersToday: number;\n  newUsersThisWeek: number;\n  totalHubs: number;\n  totalEvents: number;\n  upcomingEvents: number;\n  totalBusinesses: number;\n  verifiedBusinesses: number;\n  premiumUsers: number;\n  revenue: {\n    today: number;\n    thisWeek: number;\n    thisMonth: number;\n  };\n}\n\nexport interface AdminAnalyticsData {\n  period: string;\n  userGrowth: Array<{ date: string; count: number }>;\n  eventAttendance: Array<{ date: string; count: number }>;\n  hubActivity: Array<{ date: string; count: number }>;\n  revenue: Array<{ date: string; amount: number }>;\n  topHubs: Array<{ id: string; name: string; memberCount: number }>;\n  topEvents: Array<{ id: string; title: string; attendeeCount: number }>;\n}\n\nexport interface PaginatedResponse<T> {\n  data: T[];\n  meta: {\n    total: number;\n    page: number;\n    limit: number;\n    totalPages: number;\n  };\n}\n\nexport interface AdminUserFilters {\n  page?: number;\n  limit?: number;\n  search?: string;\n  status?: 'active' | 'suspended' | 'deleted';\n  isPremium?: boolean;\n  sortBy?: string;\n  sortOrder?: 'asc' | 'desc';\n}\n\nexport interface AdminHubFilters {\n  page?: number;\n  limit?: number;\n  search?: string;\n  status?: 'active' | 'inactive';\n  sortBy?: string;\n  sortOrder?: 'asc' | 'desc';\n}\n\nexport interface AdminEventFilters {\n  page?: number;\n  limit?: number;\n  search?: string;\n  status?: 'draft' | 'published' | 'cancelled';\n  hubId?: string;\n  upcoming?: boolean;\n  sortBy?: string;\n  sortOrder?: 'asc' | 'desc';\n}\n\nexport interface AdminBusinessFilters {\n  page?: number;\n  limit?: number;\n  search?: string;\n  isVerified?: boolean;\n  type?: string;\n  sortBy?: string;\n  sortOrder?: 'asc' | 'desc';\n}\n\nexport interface AdminContentFilters {\n  page?: number;\n  limit?: number;\n  search?: string;\n  type?: string;\n  category?: string;\n  isFeatured?: boolean;\n  sortBy?: string;\n  sortOrder?: 'asc' | 'desc';\n}\n\n// ============================================================================\n// QUERY KEYS\n// ============================================================================\n\nexport const adminKeys = {\n  all: ['admin'] as const,\n  dashboard: () => [...adminKeys.all, 'dashboard'] as const,\n  analytics: (period?: string) => [...adminKeys.all, 'analytics', period] as const,\n  users: {\n    all: () => [...adminKeys.all, 'users'] as const,\n    list: (filters?: AdminUserFilters) => [...adminKeys.users.all(), 'list', filters] as const,\n    detail: (id: string) => [...adminKeys.users.all(), 'detail', id] as const,\n  },\n  hubs: {\n    all: () => [...adminKeys.all, 'hubs'] as const,\n    list: (filters?: AdminHubFilters) => [...adminKeys.hubs.all(), 'list', filters] as const,\n    detail: (id: string) => [...adminKeys.hubs.all(), 'detail', id] as const,\n  },\n  events: {\n    all: () => [...adminKeys.all, 'events'] as const,\n    list: (filters?: AdminEventFilters) => [...adminKeys.events.all(), 'list', filters] as const,\n    detail: (id: string) => [...adminKeys.events.all(), 'detail', id] as const,\n  },\n  businesses: {\n    all: () => [...adminKeys.all, 'businesses'] as const,\n    list: (filters?: AdminBusinessFilters) =>\n      [...adminKeys.businesses.all(), 'list', filters] as const,\n    detail: (id: string) => [...adminKeys.businesses.all(), 'detail', id] as const,\n  },\n  content: {\n    all: () => [...adminKeys.all, 'content'] as const,\n    list: (filters?: AdminContentFilters) =>\n      [...adminKeys.content.all(), 'list', filters] as const,\n    detail: (id: string) => [...adminKeys.content.all(), 'detail', id] as const,\n  },\n};\n\n// ============================================================================\n// DASHBOARD & ANALYTICS\n// ============================================================================\n\n/**\n * Get admin dashboard statistics\n *\n * @description\n * Retrieves key metrics for the admin dashboard including\n * user counts, hub stats, event stats, and revenue data.\n *\n * @endpoint GET /api/v1/admin/dashboard\n *\n * @example\n * ```tsx\n * import { useAdminDashboard } from '@growsober/sdk';\n *\n * function AdminDashboard() {\n *   const { data: stats, isLoading } = useAdminDashboard();\n *\n *   if (isLoading) return <Spinner />;\n *\n *   return (\n *     <div>\n *       <StatCard label=\"Total Users\" value={stats.totalUsers} />\n *       <StatCard label=\"Active Users\" value={stats.activeUsers} />\n *       <StatCard label=\"Premium Users\" value={stats.premiumUsers} />\n *       <StatCard label=\"Revenue This Month\" value={stats.revenue.thisMonth} />\n *     </div>\n *   );\n * }\n * ```\n */\nexport function useAdminDashboard(\n  options?: Omit<UseQueryOptions<AdminDashboardStats>, 'queryKey' | 'queryFn'>\n): UseQueryResult<AdminDashboardStats> {\n  return useQuery({\n    queryKey: adminKeys.dashboard(),\n    queryFn: async (): Promise<AdminDashboardStats> => {\n      const client = getApiClient();\n      const response = await client.get<AdminDashboardStats>('/api/v1/admin/dashboard');\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get admin analytics data\n *\n * @description\n * Retrieves detailed analytics data for charts and reports.\n *\n * @endpoint GET /api/v1/admin/analytics\n *\n * @example\n * ```tsx\n * import { useAdminAnalytics } from '@growsober/sdk';\n *\n * function AnalyticsPage() {\n *   const { data: analytics } = useAdminAnalytics('30d');\n *\n *   return (\n *     <div>\n *       <LineChart data={analytics?.userGrowth} />\n *       <BarChart data={analytics?.eventAttendance} />\n *     </div>\n *   );\n * }\n * ```\n */\nexport function useAdminAnalytics(\n  period?: string,\n  options?: Omit<UseQueryOptions<AdminAnalyticsData>, 'queryKey' | 'queryFn'>\n): UseQueryResult<AdminAnalyticsData> {\n  return useQuery({\n    queryKey: adminKeys.analytics(period),\n    queryFn: async (): Promise<AdminAnalyticsData> => {\n      const client = getApiClient();\n      const response = await client.get<AdminAnalyticsData>('/api/v1/admin/analytics', {\n        params: { period },\n      });\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n// ============================================================================\n// USER MANAGEMENT\n// ============================================================================\n\n/**\n * List users for admin\n *\n * @endpoint GET /api/v1/admin/users\n */\nexport function useAdminUsers(\n  filters?: AdminUserFilters,\n  options?: Omit<UseQueryOptions<PaginatedResponse<UserResponse>>, 'queryKey' | 'queryFn'>\n): UseQueryResult<PaginatedResponse<UserResponse>> {\n  return useQuery({\n    queryKey: adminKeys.users.list(filters),\n    queryFn: async (): Promise<PaginatedResponse<UserResponse>> => {\n      const client = getApiClient();\n      const response = await client.get<PaginatedResponse<UserResponse>>(\n        '/api/v1/admin/users',\n        { params: filters }\n      );\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get user detail for admin\n *\n * @endpoint GET /api/v1/admin/users/{id}\n */\nexport function useAdminUser(\n  id: string,\n  options?: Omit<UseQueryOptions<UserResponse>, 'queryKey' | 'queryFn'>\n): UseQueryResult<UserResponse> {\n  return useQuery({\n    queryKey: adminKeys.users.detail(id),\n    queryFn: async (): Promise<UserResponse> => {\n      const client = getApiClient();\n      const response = await client.get<UserResponse>(`/api/v1/admin/users/${id}`);\n      return response.data;\n    },\n    enabled: !!id,\n    ...options,\n  });\n}\n\n// ============================================================================\n// HUB MANAGEMENT\n// ============================================================================\n\n/**\n * List hubs for admin\n *\n * @endpoint GET /api/v1/admin/hubs\n */\nexport function useAdminHubs(\n  filters?: AdminHubFilters,\n  options?: Omit<UseQueryOptions<PaginatedResponse<HubResponse>>, 'queryKey' | 'queryFn'>\n): UseQueryResult<PaginatedResponse<HubResponse>> {\n  return useQuery({\n    queryKey: adminKeys.hubs.list(filters),\n    queryFn: async (): Promise<PaginatedResponse<HubResponse>> => {\n      const client = getApiClient();\n      const response = await client.get<PaginatedResponse<HubResponse>>(\n        '/api/v1/admin/hubs',\n        { params: filters }\n      );\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get hub detail for admin\n *\n * @endpoint GET /api/v1/admin/hubs/{id}\n */\nexport function useAdminHub(\n  id: string,\n  options?: Omit<UseQueryOptions<HubResponse>, 'queryKey' | 'queryFn'>\n): UseQueryResult<HubResponse> {\n  return useQuery({\n    queryKey: adminKeys.hubs.detail(id),\n    queryFn: async (): Promise<HubResponse> => {\n      const client = getApiClient();\n      const response = await client.get<HubResponse>(`/api/v1/admin/hubs/${id}`);\n      return response.data;\n    },\n    enabled: !!id,\n    ...options,\n  });\n}\n\n// ============================================================================\n// EVENT MANAGEMENT\n// ============================================================================\n\n/**\n * List events for admin\n *\n * @endpoint GET /api/v1/admin/events\n */\nexport function useAdminEvents(\n  filters?: AdminEventFilters,\n  options?: Omit<UseQueryOptions<PaginatedResponse<EventResponse>>, 'queryKey' | 'queryFn'>\n): UseQueryResult<PaginatedResponse<EventResponse>> {\n  return useQuery({\n    queryKey: adminKeys.events.list(filters),\n    queryFn: async (): Promise<PaginatedResponse<EventResponse>> => {\n      const client = getApiClient();\n      const response = await client.get<PaginatedResponse<EventResponse>>(\n        '/api/v1/admin/events',\n        { params: filters }\n      );\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get event detail for admin\n *\n * @endpoint GET /api/v1/admin/events/{id}\n */\nexport function useAdminEvent(\n  id: string,\n  options?: Omit<UseQueryOptions<EventResponse>, 'queryKey' | 'queryFn'>\n): UseQueryResult<EventResponse> {\n  return useQuery({\n    queryKey: adminKeys.events.detail(id),\n    queryFn: async (): Promise<EventResponse> => {\n      const client = getApiClient();\n      const response = await client.get<EventResponse>(`/api/v1/admin/events/${id}`);\n      return response.data;\n    },\n    enabled: !!id,\n    ...options,\n  });\n}\n\n// ============================================================================\n// BUSINESS MANAGEMENT\n// ============================================================================\n\n/**\n * List businesses for admin\n *\n * @endpoint GET /api/v1/admin/businesses\n */\nexport function useAdminBusinesses(\n  filters?: AdminBusinessFilters,\n  options?: Omit<UseQueryOptions<PaginatedResponse<BusinessResponse>>, 'queryKey' | 'queryFn'>\n): UseQueryResult<PaginatedResponse<BusinessResponse>> {\n  return useQuery({\n    queryKey: adminKeys.businesses.list(filters),\n    queryFn: async (): Promise<PaginatedResponse<BusinessResponse>> => {\n      const client = getApiClient();\n      const response = await client.get<PaginatedResponse<BusinessResponse>>(\n        '/api/v1/admin/businesses',\n        { params: filters }\n      );\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get business detail for admin\n *\n * @endpoint GET /api/v1/admin/businesses/{id}\n */\nexport function useAdminBusiness(\n  id: string,\n  options?: Omit<UseQueryOptions<BusinessResponse>, 'queryKey' | 'queryFn'>\n): UseQueryResult<BusinessResponse> {\n  return useQuery({\n    queryKey: adminKeys.businesses.detail(id),\n    queryFn: async (): Promise<BusinessResponse> => {\n      const client = getApiClient();\n      const response = await client.get<BusinessResponse>(`/api/v1/admin/businesses/${id}`);\n      return response.data;\n    },\n    enabled: !!id,\n    ...options,\n  });\n}\n\n// ============================================================================\n// CONTENT MANAGEMENT\n// ============================================================================\n\n/**\n * List content for admin\n *\n * @endpoint GET /api/v1/admin/content\n */\nexport function useAdminContent(\n  filters?: AdminContentFilters,\n  options?: Omit<\n    UseQueryOptions<PaginatedResponse<LibraryContentResponse>>,\n    'queryKey' | 'queryFn'\n  >\n): UseQueryResult<PaginatedResponse<LibraryContentResponse>> {\n  return useQuery({\n    queryKey: adminKeys.content.list(filters),\n    queryFn: async (): Promise<PaginatedResponse<LibraryContentResponse>> => {\n      const client = getApiClient();\n      const response = await client.get<PaginatedResponse<LibraryContentResponse>>(\n        '/api/v1/admin/content',\n        { params: filters }\n      );\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get content detail for admin\n *\n * @endpoint GET /api/v1/admin/content/{id}\n */\nexport function useAdminContentItem(\n  id: string,\n  options?: Omit<UseQueryOptions<LibraryContentResponse>, 'queryKey' | 'queryFn'>\n): UseQueryResult<LibraryContentResponse> {\n  return useQuery({\n    queryKey: adminKeys.content.detail(id),\n    queryFn: async (): Promise<LibraryContentResponse> => {\n      const client = getApiClient();\n      const response = await client.get<LibraryContentResponse>(`/api/v1/admin/content/${id}`);\n      return response.data;\n    },\n    enabled: !!id,\n    ...options,\n  });\n}\n"]}
@@ -0,0 +1,53 @@
1
+ import { UseQueryOptions } from '@tanstack/react-query';
2
+ import type { AmbassadorResponse, AmbassadorLeaderboardResponse, AmbassadorStatus } from '../types';
3
+ export declare const ambassadorKeys: {
4
+ all: readonly ["ambassadors"];
5
+ lists: () => readonly ["ambassadors", "list"];
6
+ list: (filters?: AmbassadorListFilters) => readonly ["ambassadors", "list", AmbassadorListFilters | undefined];
7
+ details: () => readonly ["ambassadors", "detail"];
8
+ detail: (id: string) => readonly ["ambassadors", "detail", string];
9
+ me: () => readonly ["ambassadors", "me"];
10
+ leaderboard: (filters?: LeaderboardFilters) => readonly ["ambassadors", "leaderboard", LeaderboardFilters | undefined];
11
+ pending: () => readonly ["ambassadors", "pending"];
12
+ };
13
+ export interface AmbassadorListFilters {
14
+ page?: number;
15
+ limit?: number;
16
+ hubId?: string;
17
+ status?: AmbassadorStatus;
18
+ isVerified?: boolean;
19
+ isFoundingAmbassador?: boolean;
20
+ }
21
+ export interface LeaderboardFilters {
22
+ limit?: number;
23
+ hubId?: string;
24
+ }
25
+ export interface PaginatedAmbassadorsResponse {
26
+ ambassadors: AmbassadorResponse[];
27
+ meta: {
28
+ total: number;
29
+ page: number;
30
+ limit: number;
31
+ totalPages: number;
32
+ };
33
+ }
34
+ /**
35
+ * Get all ambassadors with pagination and filters
36
+ */
37
+ export declare function useAmbassadors(filters?: AmbassadorListFilters, options?: Omit<UseQueryOptions<PaginatedAmbassadorsResponse>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<PaginatedAmbassadorsResponse, Error>;
38
+ /**
39
+ * Get ambassador by ID
40
+ */
41
+ export declare function useAmbassador(id: string, options?: Omit<UseQueryOptions<AmbassadorResponse>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<AmbassadorResponse, Error>;
42
+ /**
43
+ * Get current user's ambassador status
44
+ */
45
+ export declare function useMyAmbassador(options?: Omit<UseQueryOptions<AmbassadorResponse | null>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<AmbassadorResponse | null, Error>;
46
+ /**
47
+ * Get ambassador leaderboard
48
+ */
49
+ export declare function useAmbassadorLeaderboard(filters?: LeaderboardFilters, options?: Omit<UseQueryOptions<AmbassadorLeaderboardResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<AmbassadorLeaderboardResponse[], Error>;
50
+ /**
51
+ * Get pending ambassador applications (admin)
52
+ */
53
+ export declare function usePendingAmbassadors(options?: Omit<UseQueryOptions<AmbassadorResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<AmbassadorResponse[], Error>;
@@ -0,0 +1,98 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ambassadorKeys = void 0;
4
+ exports.useAmbassadors = useAmbassadors;
5
+ exports.useAmbassador = useAmbassador;
6
+ exports.useMyAmbassador = useMyAmbassador;
7
+ exports.useAmbassadorLeaderboard = useAmbassadorLeaderboard;
8
+ exports.usePendingAmbassadors = usePendingAmbassadors;
9
+ const react_query_1 = require("@tanstack/react-query");
10
+ const client_1 = require("../client");
11
+ // ============================================================================
12
+ // QUERY KEYS
13
+ // ============================================================================
14
+ exports.ambassadorKeys = {
15
+ all: ['ambassadors'],
16
+ lists: () => [...exports.ambassadorKeys.all, 'list'],
17
+ list: (filters) => [...exports.ambassadorKeys.lists(), filters],
18
+ details: () => [...exports.ambassadorKeys.all, 'detail'],
19
+ detail: (id) => [...exports.ambassadorKeys.details(), id],
20
+ me: () => [...exports.ambassadorKeys.all, 'me'],
21
+ leaderboard: (filters) => [...exports.ambassadorKeys.all, 'leaderboard', filters],
22
+ pending: () => [...exports.ambassadorKeys.all, 'pending'],
23
+ };
24
+ // ============================================================================
25
+ // QUERY HOOKS
26
+ // ============================================================================
27
+ /**
28
+ * Get all ambassadors with pagination and filters
29
+ */
30
+ function useAmbassadors(filters, options) {
31
+ return (0, react_query_1.useQuery)({
32
+ queryKey: exports.ambassadorKeys.list(filters),
33
+ queryFn: async () => {
34
+ const client = (0, client_1.getApiClient)();
35
+ const response = await client.get('/api/v1/ambassadors', { params: filters });
36
+ return response.data;
37
+ },
38
+ ...options,
39
+ });
40
+ }
41
+ /**
42
+ * Get ambassador by ID
43
+ */
44
+ function useAmbassador(id, options) {
45
+ return (0, react_query_1.useQuery)({
46
+ queryKey: exports.ambassadorKeys.detail(id),
47
+ queryFn: async () => {
48
+ const client = (0, client_1.getApiClient)();
49
+ const response = await client.get(`/api/v1/ambassadors/${id}`);
50
+ return response.data;
51
+ },
52
+ enabled: !!id && (options?.enabled !== false),
53
+ ...options,
54
+ });
55
+ }
56
+ /**
57
+ * Get current user's ambassador status
58
+ */
59
+ function useMyAmbassador(options) {
60
+ return (0, react_query_1.useQuery)({
61
+ queryKey: exports.ambassadorKeys.me(),
62
+ queryFn: async () => {
63
+ const client = (0, client_1.getApiClient)();
64
+ const response = await client.get('/api/v1/ambassadors/me');
65
+ return response.data;
66
+ },
67
+ ...options,
68
+ });
69
+ }
70
+ /**
71
+ * Get ambassador leaderboard
72
+ */
73
+ function useAmbassadorLeaderboard(filters, options) {
74
+ return (0, react_query_1.useQuery)({
75
+ queryKey: exports.ambassadorKeys.leaderboard(filters),
76
+ queryFn: async () => {
77
+ const client = (0, client_1.getApiClient)();
78
+ const response = await client.get('/api/v1/ambassadors/leaderboard', { params: filters });
79
+ return response.data;
80
+ },
81
+ ...options,
82
+ });
83
+ }
84
+ /**
85
+ * Get pending ambassador applications (admin)
86
+ */
87
+ function usePendingAmbassadors(options) {
88
+ return (0, react_query_1.useQuery)({
89
+ queryKey: exports.ambassadorKeys.pending(),
90
+ queryFn: async () => {
91
+ const client = (0, client_1.getApiClient)();
92
+ const response = await client.get('/api/v1/ambassadors/pending');
93
+ return response.data;
94
+ },
95
+ ...options,
96
+ });
97
+ }
98
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ambassadors.js","sourceRoot":"","sources":["../../../src/api/queries/ambassadors.ts"],"names":[],"mappings":"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","sourcesContent":["import { useQuery, UseQueryOptions } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport type { AmbassadorResponse, AmbassadorLeaderboardResponse, AmbassadorStatus } from '../types';\n\n// ============================================================================\n// QUERY KEYS\n// ============================================================================\n\nexport const ambassadorKeys = {\n  all: ['ambassadors'] as const,\n  lists: () => [...ambassadorKeys.all, 'list'] as const,\n  list: (filters?: AmbassadorListFilters) => [...ambassadorKeys.lists(), filters] as const,\n  details: () => [...ambassadorKeys.all, 'detail'] as const,\n  detail: (id: string) => [...ambassadorKeys.details(), id] as const,\n  me: () => [...ambassadorKeys.all, 'me'] as const,\n  leaderboard: (filters?: LeaderboardFilters) => [...ambassadorKeys.all, 'leaderboard', filters] as const,\n  pending: () => [...ambassadorKeys.all, 'pending'] as const,\n};\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\nexport interface AmbassadorListFilters {\n  page?: number;\n  limit?: number;\n  hubId?: string;\n  status?: AmbassadorStatus;\n  isVerified?: boolean;\n  isFoundingAmbassador?: boolean;\n}\n\nexport interface LeaderboardFilters {\n  limit?: number;\n  hubId?: string;\n}\n\nexport interface PaginatedAmbassadorsResponse {\n  ambassadors: AmbassadorResponse[];\n  meta: {\n    total: number;\n    page: number;\n    limit: number;\n    totalPages: number;\n  };\n}\n\n// ============================================================================\n// QUERY HOOKS\n// ============================================================================\n\n/**\n * Get all ambassadors with pagination and filters\n */\nexport function useAmbassadors(\n  filters?: AmbassadorListFilters,\n  options?: Omit<UseQueryOptions<PaginatedAmbassadorsResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: ambassadorKeys.list(filters),\n    queryFn: async (): Promise<PaginatedAmbassadorsResponse> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/ambassadors', { params: filters });\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get ambassador by ID\n */\nexport function useAmbassador(\n  id: string,\n  options?: Omit<UseQueryOptions<AmbassadorResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: ambassadorKeys.detail(id),\n    queryFn: async (): Promise<AmbassadorResponse> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/ambassadors/${id}`);\n      return response.data;\n    },\n    enabled: !!id && (options?.enabled !== false),\n    ...options,\n  });\n}\n\n/**\n * Get current user's ambassador status\n */\nexport function useMyAmbassador(\n  options?: Omit<UseQueryOptions<AmbassadorResponse | null>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: ambassadorKeys.me(),\n    queryFn: async (): Promise<AmbassadorResponse | null> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/ambassadors/me');\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get ambassador leaderboard\n */\nexport function useAmbassadorLeaderboard(\n  filters?: LeaderboardFilters,\n  options?: Omit<UseQueryOptions<AmbassadorLeaderboardResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: ambassadorKeys.leaderboard(filters),\n    queryFn: async (): Promise<AmbassadorLeaderboardResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/ambassadors/leaderboard', { params: filters });\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get pending ambassador applications (admin)\n */\nexport function usePendingAmbassadors(\n  options?: Omit<UseQueryOptions<AmbassadorResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: ambassadorKeys.pending(),\n    queryFn: async (): Promise<AmbassadorResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/ambassadors/pending');\n      return response.data;\n    },\n    ...options,\n  });\n}\n"]}
@@ -0,0 +1,16 @@
1
+ /**
2
+ * Auth Query Hooks
3
+ *
4
+ * TanStack Query hooks for authentication-related read operations.
5
+ * These hooks handle fetching current user data and managing cache invalidation.
6
+ *
7
+ * @module api/queries/auth
8
+ */
9
+ /**
10
+ * Query key factory for auth-related queries
11
+ * @see https://tkdodo.eu/blog/effective-react-query-keys
12
+ */
13
+ export declare const authKeys: {
14
+ all: readonly ["auth"];
15
+ me: () => readonly ["auth", "me"];
16
+ };
@@ -0,0 +1,25 @@
1
+ "use strict";
2
+ /**
3
+ * Auth Query Hooks
4
+ *
5
+ * TanStack Query hooks for authentication-related read operations.
6
+ * These hooks handle fetching current user data and managing cache invalidation.
7
+ *
8
+ * @module api/queries/auth
9
+ */
10
+ Object.defineProperty(exports, "__esModule", { value: true });
11
+ exports.authKeys = void 0;
12
+ // ============================================================================
13
+ // QUERY KEYS
14
+ // ============================================================================
15
+ /**
16
+ * Query key factory for auth-related queries
17
+ * @see https://tkdodo.eu/blog/effective-react-query-keys
18
+ */
19
+ exports.authKeys = {
20
+ all: ['auth'],
21
+ me: () => [...exports.authKeys.all, 'me'],
22
+ };
23
+ // Note: useCurrentUser is exported from queries/users.ts
24
+ // It uses the /api/v1/users/me endpoint which is the correct endpoint for fetching user data
25
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9hcGkvcXVlcmllcy9hdXRoLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7Ozs7OztHQU9HOzs7QUFFSCwrRUFBK0U7QUFDL0UsYUFBYTtBQUNiLCtFQUErRTtBQUUvRTs7O0dBR0c7QUFDVSxRQUFBLFFBQVEsR0FBRztJQUN0QixHQUFHLEVBQUUsQ0FBQyxNQUFNLENBQVU7SUFDdEIsRUFBRSxFQUFFLEdBQUcsRUFBRSxDQUFDLENBQUMsR0FBRyxnQkFBUSxDQUFDLEdBQUcsRUFBRSxJQUFJLENBQVU7Q0FDM0MsQ0FBQztBQUVGLHlEQUF5RDtBQUN6RCw2RkFBNkYiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEF1dGggUXVlcnkgSG9va3NcbiAqXG4gKiBUYW5TdGFjayBRdWVyeSBob29rcyBmb3IgYXV0aGVudGljYXRpb24tcmVsYXRlZCByZWFkIG9wZXJhdGlvbnMuXG4gKiBUaGVzZSBob29rcyBoYW5kbGUgZmV0Y2hpbmcgY3VycmVudCB1c2VyIGRhdGEgYW5kIG1hbmFnaW5nIGNhY2hlIGludmFsaWRhdGlvbi5cbiAqXG4gKiBAbW9kdWxlIGFwaS9xdWVyaWVzL2F1dGhcbiAqL1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBRVUVSWSBLRVlTXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbi8qKlxuICogUXVlcnkga2V5IGZhY3RvcnkgZm9yIGF1dGgtcmVsYXRlZCBxdWVyaWVzXG4gKiBAc2VlIGh0dHBzOi8vdGtkb2RvLmV1L2Jsb2cvZWZmZWN0aXZlLXJlYWN0LXF1ZXJ5LWtleXNcbiAqL1xuZXhwb3J0IGNvbnN0IGF1dGhLZXlzID0ge1xuICBhbGw6IFsnYXV0aCddIGFzIGNvbnN0LFxuICBtZTogKCkgPT4gWy4uLmF1dGhLZXlzLmFsbCwgJ21lJ10gYXMgY29uc3QsXG59O1xuXG4vLyBOb3RlOiB1c2VDdXJyZW50VXNlciBpcyBleHBvcnRlZCBmcm9tIHF1ZXJpZXMvdXNlcnMudHNcbi8vIEl0IHVzZXMgdGhlIC9hcGkvdjEvdXNlcnMvbWUgZW5kcG9pbnQgd2hpY2ggaXMgdGhlIGNvcnJlY3QgZW5kcG9pbnQgZm9yIGZldGNoaW5nIHVzZXIgZGF0YVxuIl19