@nivo-lat/sdk 0.1.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/README.md ADDED
@@ -0,0 +1,92 @@
1
+ # @nivo-lat/sdk
2
+
3
+ Official Node.js SDK for [Nivo](https://nivo.lat).
4
+
5
+ ## Installation
6
+
7
+ ```bash
8
+ npm install @nivo-lat/sdk
9
+ ```
10
+
11
+ ## Usage
12
+
13
+ ```ts
14
+ import { NivoAPI } from '@nivo-lat/sdk'
15
+
16
+ const nivo = new NivoAPI('your-api-key')
17
+ ```
18
+
19
+ Get your API key from the Nivo dashboard under **Settings > API Keys**.
20
+
21
+ ## Apps
22
+
23
+ ```ts
24
+ // List all apps
25
+ const apps = await nivo.apps.list()
26
+
27
+ // Create an app
28
+ const app = await nivo.apps.create({
29
+ name: 'my-app',
30
+ type: 'site',
31
+ buildSystem: 'nivopack',
32
+ runtime: 'node20',
33
+ startCmd: 'npm start',
34
+ projectId: 'PROJECT_ID',
35
+ sourceType: 'zip',
36
+ })
37
+
38
+ // Deploy and wait for completion
39
+ const deployment = await nivo.apps.deployAndWait(app.id)
40
+
41
+ // Fetch runtime logs
42
+ const logs = await nivo.apps.logs(app.id)
43
+ ```
44
+
45
+ ## Databases
46
+
47
+ ```ts
48
+ // List databases
49
+ const databases = await nivo.databases.list()
50
+
51
+ // Create a database
52
+ const db = await nivo.databases.create({ name: 'my-db', projectId: 'PROJECT_ID' })
53
+
54
+ // Execute a query
55
+ const result = await nivo.databases.query(db.id, 'SELECT * FROM users LIMIT 10')
56
+
57
+ // List tables
58
+ const tables = await nivo.databases.tables(db.id)
59
+
60
+ // Get rows from a table
61
+ const rows = await nivo.databases.tableRows(db.id, 'users', { limit: 50 })
62
+ ```
63
+
64
+ ## Storage
65
+
66
+ ```ts
67
+ // List buckets
68
+ const buckets = await nivo.storage.listBuckets()
69
+
70
+ // Create a bucket
71
+ const bucket = await nivo.storage.createBucket({ name: 'my-bucket', projectId: 'PROJECT_ID' })
72
+
73
+ // Upload a file
74
+ await nivo.storage.upload(bucket.id, { key: 'photo.png', body: fileBuffer, contentType: 'image/png' })
75
+
76
+ // List files
77
+ const files = await nivo.storage.listFiles(bucket.id)
78
+ ```
79
+
80
+ ## Error handling
81
+
82
+ ```ts
83
+ import { NivoAPI, NivoError } from '@nivo-lat/sdk'
84
+
85
+ try {
86
+ await nivo.apps.get('invalid-id')
87
+ } catch (err) {
88
+ if (err instanceof NivoError) {
89
+ console.error(err.status, err.message)
90
+ }
91
+ }
92
+ ```
@@ -0,0 +1,14 @@
1
+ import { DatabasesResource } from './resources/databases';
2
+ import { AppsResource } from './resources/apps';
3
+ import { StorageResource } from './resources/storage';
4
+ export interface NivoAPIOptions {
5
+ baseUrl?: string;
6
+ }
7
+ export declare class NivoAPI {
8
+ readonly databases: DatabasesResource;
9
+ readonly apps: AppsResource;
10
+ readonly storage: StorageResource;
11
+ private readonly client;
12
+ constructor(apiKey: string, options?: NivoAPIOptions);
13
+ }
14
+ //# sourceMappingURL=NivoAPI.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NivoAPI.d.ts","sourceRoot":"","sources":["../src/NivoAPI.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAA;AACzD,OAAO,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAA;AAC/C,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AAErD,MAAM,WAAW,cAAc;IAC7B,OAAO,CAAC,EAAE,MAAM,CAAA;CACjB;AAID,qBAAa,OAAO;IAClB,QAAQ,CAAC,SAAS,EAAE,iBAAiB,CAAA;IACrC,QAAQ,CAAC,IAAI,EAAE,YAAY,CAAA;IAC3B,QAAQ,CAAC,OAAO,EAAE,eAAe,CAAA;IAEjC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAY;gBAEvB,MAAM,EAAE,MAAM,EAAE,OAAO,GAAE,cAAmB;CAOzD"}
@@ -0,0 +1,20 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.NivoAPI = void 0;
4
+ const client_1 = require("./client");
5
+ const databases_1 = require("./resources/databases");
6
+ const apps_1 = require("./resources/apps");
7
+ const storage_1 = require("./resources/storage");
8
+ const DEFAULT_BASE_URL = 'https://api.nivo.lat/api';
9
+ class NivoAPI {
10
+ constructor(apiKey, options = {}) {
11
+ if (!apiKey)
12
+ throw new Error('NivoAPI requires an API key');
13
+ this.client = new client_1.NivoClient(apiKey, options.baseUrl ?? DEFAULT_BASE_URL);
14
+ this.databases = new databases_1.DatabasesResource(this.client);
15
+ this.apps = new apps_1.AppsResource(this.client);
16
+ this.storage = new storage_1.StorageResource(this.client);
17
+ }
18
+ }
19
+ exports.NivoAPI = NivoAPI;
20
+ //# sourceMappingURL=NivoAPI.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NivoAPI.js","sourceRoot":"","sources":["../src/NivoAPI.ts"],"names":[],"mappings":";;;AAAA,qCAAqC;AACrC,qDAAyD;AACzD,2CAA+C;AAC/C,iDAAqD;AAMrD,MAAM,gBAAgB,GAAG,0BAA0B,CAAA;AAEnD,MAAa,OAAO;IAOlB,YAAY,MAAc,EAAE,UAA0B,EAAE;QACtD,IAAI,CAAC,MAAM;YAAE,MAAM,IAAI,KAAK,CAAC,6BAA6B,CAAC,CAAA;QAC3D,IAAI,CAAC,MAAM,GAAG,IAAI,mBAAU,CAAC,MAAM,EAAE,OAAO,CAAC,OAAO,IAAI,gBAAgB,CAAC,CAAA;QACzE,IAAI,CAAC,SAAS,GAAG,IAAI,6BAAiB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;QACnD,IAAI,CAAC,IAAI,GAAG,IAAI,mBAAY,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;QACzC,IAAI,CAAC,OAAO,GAAG,IAAI,yBAAe,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;IACjD,CAAC;CACF;AAdD,0BAcC"}
package/dist/auth.d.ts ADDED
@@ -0,0 +1,117 @@
1
+ export type AuthChangeEvent = 'SIGNED_IN' | 'SIGNED_OUT' | 'TOKEN_REFRESHED' | 'USER_UPDATED';
2
+ export interface Session {
3
+ access_token: string;
4
+ refresh_token: string;
5
+ expires_in: number;
6
+ token_type: 'bearer';
7
+ expires_at?: number;
8
+ }
9
+ export interface AuthUser {
10
+ id: string;
11
+ email: string;
12
+ name?: string | null;
13
+ avatarUrl?: string | null;
14
+ phone?: string | null;
15
+ emailVerified: boolean;
16
+ metadata: Record<string, unknown>;
17
+ appMetadata: Record<string, unknown>;
18
+ lastSignInAt?: string | null;
19
+ createdAt: string;
20
+ }
21
+ export interface AuthError {
22
+ message: string;
23
+ status?: number;
24
+ }
25
+ type Listener = (event: AuthChangeEvent, session: Session | null) => void;
26
+ export declare class NivoAuthClient {
27
+ private readonly baseUrl;
28
+ private readonly anonKey;
29
+ private session;
30
+ private listeners;
31
+ private refreshTimer;
32
+ constructor(baseUrl: string, anonKey: string);
33
+ private _loadSession;
34
+ private _saveSession;
35
+ private _clearSession;
36
+ private _scheduleRefresh;
37
+ private _silentRefresh;
38
+ private _notify;
39
+ private _request;
40
+ signUp(credentials: {
41
+ email: string;
42
+ password: string;
43
+ name?: string;
44
+ }): Promise<{
45
+ data: {
46
+ user: AuthUser;
47
+ session: Session;
48
+ } | null;
49
+ error: AuthError | null;
50
+ }>;
51
+ readonly signIn: {
52
+ withPassword: (credentials: {
53
+ email: string;
54
+ password: string;
55
+ }) => Promise<{
56
+ data: {
57
+ user: AuthUser;
58
+ session: Session;
59
+ } | null;
60
+ error: AuthError | null;
61
+ }>;
62
+ withMagicLink: (options: {
63
+ email: string;
64
+ redirectTo?: string;
65
+ }) => Promise<{
66
+ data: {
67
+ message: string;
68
+ } | null;
69
+ error: AuthError | null;
70
+ }>;
71
+ withOAuth: (options: {
72
+ provider: "github" | "google";
73
+ redirectTo?: string;
74
+ }) => void;
75
+ };
76
+ verifyOtp(params: {
77
+ token: string;
78
+ type: 'magic_link' | 'email_verification';
79
+ }): Promise<{
80
+ data: {
81
+ user: AuthUser;
82
+ session: Session;
83
+ } | null;
84
+ error: AuthError | null;
85
+ }>;
86
+ signOut(): Promise<{
87
+ error: null;
88
+ }>;
89
+ refreshSession(refreshToken?: string): Promise<{
90
+ data: Session | null;
91
+ error: AuthError | null;
92
+ }>;
93
+ getUser(): Promise<{
94
+ data: {
95
+ user: AuthUser;
96
+ } | null;
97
+ error: AuthError | null;
98
+ }>;
99
+ updateUser(updates: {
100
+ name?: string;
101
+ phone?: string;
102
+ avatarUrl?: string;
103
+ password?: string;
104
+ metadata?: Record<string, unknown>;
105
+ }): Promise<{
106
+ data: {
107
+ user: AuthUser;
108
+ } | null;
109
+ error: AuthError | null;
110
+ }>;
111
+ getSession(): Session | null;
112
+ onAuthStateChange(listener: Listener): {
113
+ unsubscribe: () => void;
114
+ };
115
+ }
116
+ export {};
117
+ //# sourceMappingURL=auth.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth.d.ts","sourceRoot":"","sources":["../src/auth.ts"],"names":[],"mappings":"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"}
package/dist/auth.js ADDED
@@ -0,0 +1,185 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.NivoAuthClient = void 0;
4
+ const STORAGE_KEY = 'nivo_auth_session';
5
+ class NivoAuthClient {
6
+ constructor(baseUrl, anonKey) {
7
+ this.session = null;
8
+ this.listeners = [];
9
+ this.refreshTimer = null;
10
+ this.signIn = {
11
+ withPassword: async (credentials) => {
12
+ const { data, error } = await this._request('/v1/auth/signin/password', {
13
+ method: 'POST', body: JSON.stringify(credentials),
14
+ });
15
+ if (data?.session) {
16
+ this._saveSession(data.session);
17
+ this._notify('SIGNED_IN', data.session);
18
+ }
19
+ return { data: data ?? null, error };
20
+ },
21
+ withMagicLink: async (options) => {
22
+ const { data, error } = await this._request('/v1/auth/signin/magiclink', {
23
+ method: 'POST', body: JSON.stringify(options),
24
+ });
25
+ return { data: data ?? null, error };
26
+ },
27
+ withOAuth: (options) => {
28
+ const url = new URL(`${this.baseUrl}/v1/auth/oauth/${options.provider}`);
29
+ url.searchParams.set('anon_key', this.anonKey);
30
+ if (options.redirectTo)
31
+ url.searchParams.set('redirectTo', options.redirectTo);
32
+ if (typeof window !== 'undefined')
33
+ window.location.href = url.toString();
34
+ },
35
+ };
36
+ this.baseUrl = baseUrl.replace(/\/$/, '');
37
+ this.anonKey = anonKey;
38
+ this._loadSession();
39
+ }
40
+ // ── Session ───────────────────────────────────────────────────────────────
41
+ _loadSession() {
42
+ if (typeof localStorage === 'undefined')
43
+ return;
44
+ try {
45
+ const raw = localStorage.getItem(STORAGE_KEY);
46
+ if (!raw)
47
+ return;
48
+ const s = JSON.parse(raw);
49
+ if (s.expires_at && s.expires_at < Date.now() / 1000) {
50
+ localStorage.removeItem(STORAGE_KEY);
51
+ return;
52
+ }
53
+ this.session = s;
54
+ this._scheduleRefresh();
55
+ }
56
+ catch { }
57
+ }
58
+ _saveSession(session) {
59
+ this.session = { ...session, expires_at: Math.floor(Date.now() / 1000) + session.expires_in };
60
+ if (typeof localStorage !== 'undefined') {
61
+ localStorage.setItem(STORAGE_KEY, JSON.stringify(this.session));
62
+ }
63
+ this._scheduleRefresh();
64
+ }
65
+ _clearSession() {
66
+ this.session = null;
67
+ if (typeof localStorage !== 'undefined')
68
+ localStorage.removeItem(STORAGE_KEY);
69
+ if (this.refreshTimer) {
70
+ clearTimeout(this.refreshTimer);
71
+ this.refreshTimer = null;
72
+ }
73
+ }
74
+ _scheduleRefresh() {
75
+ if (this.refreshTimer)
76
+ clearTimeout(this.refreshTimer);
77
+ if (!this.session?.expires_at)
78
+ return;
79
+ const ms = (this.session.expires_at - 60 - Math.floor(Date.now() / 1000)) * 1000;
80
+ if (ms <= 0)
81
+ return;
82
+ this.refreshTimer = setTimeout(() => this._silentRefresh(), ms);
83
+ }
84
+ async _silentRefresh() {
85
+ if (!this.session)
86
+ return;
87
+ try {
88
+ const { data } = await this.refreshSession(this.session.refresh_token);
89
+ if (data)
90
+ this._notify('TOKEN_REFRESHED', this.session);
91
+ }
92
+ catch { }
93
+ }
94
+ _notify(event, session) {
95
+ for (const l of this.listeners) {
96
+ try {
97
+ l(event, session);
98
+ }
99
+ catch { }
100
+ }
101
+ }
102
+ // ── HTTP ─────────────────────────────────────────────────────────────────
103
+ async _request(path, options = {}) {
104
+ try {
105
+ const headers = {
106
+ 'Content-Type': 'application/json',
107
+ 'x-nivo-anon-key': this.anonKey,
108
+ ...options.headers,
109
+ };
110
+ if (this.session?.access_token) {
111
+ headers['Authorization'] = `Bearer ${this.session.access_token}`;
112
+ }
113
+ const res = await fetch(`${this.baseUrl}${path}`, { ...options, headers });
114
+ const json = await res.json().catch(() => ({}));
115
+ if (!res.ok)
116
+ return { data: null, error: { message: json?.error ?? 'Request failed', status: res.status } };
117
+ return { data: json, error: null };
118
+ }
119
+ catch (err) {
120
+ return { data: null, error: { message: err?.message ?? 'Network error' } };
121
+ }
122
+ }
123
+ // ── Public API ────────────────────────────────────────────────────────────
124
+ async signUp(credentials) {
125
+ const { data, error } = await this._request('/v1/auth/signup', {
126
+ method: 'POST', body: JSON.stringify(credentials),
127
+ });
128
+ if (data?.session) {
129
+ this._saveSession(data.session);
130
+ this._notify('SIGNED_IN', data.session);
131
+ }
132
+ return { data: data ?? null, error };
133
+ }
134
+ async verifyOtp(params) {
135
+ const { data, error } = await this._request(`/v1/auth/verify?token=${params.token}&type=${params.type}`);
136
+ if (data?.session) {
137
+ this._saveSession(data.session);
138
+ this._notify('SIGNED_IN', data.session);
139
+ }
140
+ return { data: data ?? null, error };
141
+ }
142
+ async signOut() {
143
+ const refreshToken = this.session?.refresh_token;
144
+ this._clearSession();
145
+ this._notify('SIGNED_OUT', null);
146
+ if (refreshToken) {
147
+ await this._request('/v1/auth/signout', { method: 'POST', body: JSON.stringify({ refresh_token: refreshToken }) });
148
+ }
149
+ return { error: null };
150
+ }
151
+ async refreshSession(refreshToken) {
152
+ const token = refreshToken ?? this.session?.refresh_token;
153
+ if (!token)
154
+ return { data: null, error: { message: 'No refresh token.' } };
155
+ const { data, error } = await this._request('/v1/auth/token/refresh', {
156
+ method: 'POST', body: JSON.stringify({ refresh_token: token }),
157
+ });
158
+ if (data) {
159
+ this._saveSession(data);
160
+ this._notify('TOKEN_REFRESHED', this.session);
161
+ }
162
+ return { data: data ?? null, error };
163
+ }
164
+ async getUser() {
165
+ const { data, error } = await this._request('/v1/auth/user');
166
+ return { data: data ? { user: data } : null, error };
167
+ }
168
+ async updateUser(updates) {
169
+ const { data, error } = await this._request('/v1/auth/user', {
170
+ method: 'PATCH', body: JSON.stringify(updates),
171
+ });
172
+ if (data)
173
+ this._notify('USER_UPDATED', this.session);
174
+ return { data: data ? { user: data } : null, error };
175
+ }
176
+ getSession() {
177
+ return this.session;
178
+ }
179
+ onAuthStateChange(listener) {
180
+ this.listeners.push(listener);
181
+ return { unsubscribe: () => { this.listeners = this.listeners.filter((l) => l !== listener); } };
182
+ }
183
+ }
184
+ exports.NivoAuthClient = NivoAuthClient;
185
+ //# sourceMappingURL=auth.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth.js","sourceRoot":"","sources":["../src/auth.ts"],"names":[],"mappings":";;;AAAA,MAAM,WAAW,GAAG,mBAAmB,CAAA;AAgCvC,MAAa,cAAc;IAOzB,YAAY,OAAe,EAAE,OAAe;QAJpC,YAAO,GAAmB,IAAI,CAAA;QAC9B,cAAS,GAAe,EAAE,CAAA;QAC1B,iBAAY,GAAyC,IAAI,CAAA;QA6FxD,WAAM,GAAG;YAChB,YAAY,EAAE,KAAK,EAAE,WAAgD,EAAE,EAAE;gBACvE,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAuC,0BAA0B,EAAE;oBAC5G,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC;iBAClD,CAAC,CAAA;gBACF,IAAI,IAAI,EAAE,OAAO,EAAE,CAAC;oBAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;oBAAC,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,IAAI,CAAC,OAAO,CAAC,CAAA;gBAAC,CAAC;gBAC/F,OAAO,EAAE,IAAI,EAAE,IAAI,IAAI,IAAI,EAAE,KAAK,EAAE,CAAA;YACtC,CAAC;YAED,aAAa,EAAE,KAAK,EAAE,OAA+C,EAAE,EAAE;gBACvE,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAsB,2BAA2B,EAAE;oBAC5F,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC;iBAC9C,CAAC,CAAA;gBACF,OAAO,EAAE,IAAI,EAAE,IAAI,IAAI,IAAI,EAAE,KAAK,EAAE,CAAA;YACtC,CAAC;YAED,SAAS,EAAE,CAAC,OAA+D,EAAE,EAAE;gBAC7E,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,GAAG,IAAI,CAAC,OAAO,kBAAkB,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAA;gBACxE,GAAG,CAAC,YAAY,CAAC,GAAG,CAAC,UAAU,EAAE,IAAI,CAAC,OAAO,CAAC,CAAA;gBAC9C,IAAI,OAAO,CAAC,UAAU;oBAAE,GAAG,CAAC,YAAY,CAAC,GAAG,CAAC,YAAY,EAAE,OAAO,CAAC,UAAU,CAAC,CAAA;gBAC9E,IAAI,OAAO,MAAM,KAAK,WAAW;oBAAE,MAAM,CAAC,QAAQ,CAAC,IAAI,GAAG,GAAG,CAAC,QAAQ,EAAE,CAAA;YAC1E,CAAC;SACF,CAAA;QAhHC,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,CAAA;QACzC,IAAI,CAAC,OAAO,GAAG,OAAO,CAAA;QACtB,IAAI,CAAC,YAAY,EAAE,CAAA;IACrB,CAAC;IAED,6EAA6E;IAErE,YAAY;QAClB,IAAI,OAAO,YAAY,KAAK,WAAW;YAAE,OAAM;QAC/C,IAAI,CAAC;YACH,MAAM,GAAG,GAAG,YAAY,CAAC,OAAO,CAAC,WAAW,CAAC,CAAA;YAC7C,IAAI,CAAC,GAAG;gBAAE,OAAM;YAChB,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAY,CAAA;YACpC,IAAI,CAAC,CAAC,UAAU,IAAI,CAAC,CAAC,UAAU,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,EAAE,CAAC;gBACrD,YAAY,CAAC,UAAU,CAAC,WAAW,CAAC,CAAA;gBACpC,OAAM;YACR,CAAC;YACD,IAAI,CAAC,OAAO,GAAG,CAAC,CAAA;YAChB,IAAI,CAAC,gBAAgB,EAAE,CAAA;QACzB,CAAC;QAAC,MAAM,CAAC,CAAA,CAAC;IACZ,CAAC;IAEO,YAAY,CAAC,OAAgB;QACnC,IAAI,CAAC,OAAO,GAAG,EAAE,GAAG,OAAO,EAAE,UAAU,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,GAAG,OAAO,CAAC,UAAU,EAAE,CAAA;QAC7F,IAAI,OAAO,YAAY,KAAK,WAAW,EAAE,CAAC;YACxC,YAAY,CAAC,OAAO,CAAC,WAAW,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAA;QACjE,CAAC;QACD,IAAI,CAAC,gBAAgB,EAAE,CAAA;IACzB,CAAC;IAEO,aAAa;QACnB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAA;QACnB,IAAI,OAAO,YAAY,KAAK,WAAW;YAAE,YAAY,CAAC,UAAU,CAAC,WAAW,CAAC,CAAA;QAC7E,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YAAC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAA;QAAC,CAAC;IACtF,CAAC;IAEO,gBAAgB;QACtB,IAAI,IAAI,CAAC,YAAY;YAAE,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAA;QACtD,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,UAAU;YAAE,OAAM;QACrC,MAAM,EAAE,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,GAAG,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAA;QAChF,IAAI,EAAE,IAAI,CAAC;YAAE,OAAM;QACnB,IAAI,CAAC,YAAY,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,cAAc,EAAE,EAAE,EAAE,CAAC,CAAA;IACjE,CAAC;IAEO,KAAK,CAAC,cAAc;QAC1B,IAAI,CAAC,IAAI,CAAC,OAAO;YAAE,OAAM;QACzB,IAAI,CAAC;YACH,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,CAAA;YACtE,IAAI,IAAI;gBAAE,IAAI,CAAC,OAAO,CAAC,iBAAiB,EAAE,IAAI,CAAC,OAAO,CAAC,CAAA;QACzD,CAAC;QAAC,MAAM,CAAC,CAAA,CAAC;IACZ,CAAC;IAEO,OAAO,CAAC,KAAsB,EAAE,OAAuB;QAC7D,KAAK,MAAM,CAAC,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YAAC,IAAI,CAAC;gBAAC,CAAC,CAAC,KAAK,EAAE,OAAO,CAAC,CAAA;YAAC,CAAC;YAAC,MAAM,CAAC,CAAA,CAAC;QAAC,CAAC;IACxE,CAAC;IAED,4EAA4E;IAEpE,KAAK,CAAC,QAAQ,CACpB,IAAY,EACZ,UAAuB,EAAE;QAEzB,IAAI,CAAC;YACH,MAAM,OAAO,GAA2B;gBACtC,cAAc,EAAE,kBAAkB;gBAClC,iBAAiB,EAAE,IAAI,CAAC,OAAO;gBAC/B,GAAI,OAAO,CAAC,OAAkC;aAC/C,CAAA;YACD,IAAI,IAAI,CAAC,OAAO,EAAE,YAAY,EAAE,CAAC;gBAC/B,OAAO,CAAC,eAAe,CAAC,GAAG,UAAU,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE,CAAA;YAClE,CAAC;YACD,MAAM,GAAG,GAAG,MAAM,KAAK,CAAC,GAAG,IAAI,CAAC,OAAO,GAAG,IAAI,EAAE,EAAE,EAAE,GAAG,OAAO,EAAE,OAAO,EAAE,CAAC,CAAA;YAC1E,MAAM,IAAI,GAAG,MAAM,GAAG,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC,CAAQ,CAAA;YACtD,IAAI,CAAC,GAAG,CAAC,EAAE;gBAAE,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,KAAK,IAAI,gBAAgB,EAAE,MAAM,EAAE,GAAG,CAAC,MAAM,EAAE,EAAE,CAAA;YAC3G,OAAO,EAAE,IAAI,EAAE,IAAS,EAAE,KAAK,EAAE,IAAI,EAAE,CAAA;QACzC,CAAC;QAAC,OAAO,GAAQ,EAAE,CAAC;YAClB,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,GAAG,EAAE,OAAO,IAAI,eAAe,EAAE,EAAE,CAAA;QAC5E,CAAC;IACH,CAAC;IAED,6EAA6E;IAE7E,KAAK,CAAC,MAAM,CAAC,WAA+D;QAC1E,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAuC,iBAAiB,EAAE;YACnG,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC;SAClD,CAAC,CAAA;QACF,IAAI,IAAI,EAAE,OAAO,EAAE,CAAC;YAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAAC,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,IAAI,CAAC,OAAO,CAAC,CAAA;QAAC,CAAC;QAC/F,OAAO,EAAE,IAAI,EAAE,IAAI,IAAI,IAAI,EAAE,KAAK,EAAE,CAAA;IACtC,CAAC;IA0BD,KAAK,CAAC,SAAS,CAAC,MAAoE;QAClF,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,QAAQ,CACzC,yBAAyB,MAAM,CAAC,KAAK,SAAS,MAAM,CAAC,IAAI,EAAE,CAC5D,CAAA;QACD,IAAI,IAAI,EAAE,OAAO,EAAE,CAAC;YAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAAC,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,IAAI,CAAC,OAAO,CAAC,CAAA;QAAC,CAAC;QAC/F,OAAO,EAAE,IAAI,EAAE,IAAI,IAAI,IAAI,EAAE,KAAK,EAAE,CAAA;IACtC,CAAC;IAED,KAAK,CAAC,OAAO;QACX,MAAM,YAAY,GAAG,IAAI,CAAC,OAAO,EAAE,aAAa,CAAA;QAChD,IAAI,CAAC,aAAa,EAAE,CAAA;QACpB,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE,IAAI,CAAC,CAAA;QAChC,IAAI,YAAY,EAAE,CAAC;YACjB,MAAM,IAAI,CAAC,QAAQ,CAAC,kBAAkB,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,aAAa,EAAE,YAAY,EAAE,CAAC,EAAE,CAAC,CAAA;QACpH,CAAC;QACD,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,CAAA;IACxB,CAAC;IAED,KAAK,CAAC,cAAc,CAAC,YAAqB;QACxC,MAAM,KAAK,GAAG,YAAY,IAAI,IAAI,CAAC,OAAO,EAAE,aAAa,CAAA;QACzD,IAAI,CAAC,KAAK;YAAE,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,mBAAmB,EAAE,EAAE,CAAA;QAC1E,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAU,wBAAwB,EAAE;YAC7E,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,aAAa,EAAE,KAAK,EAAE,CAAC;SAC/D,CAAC,CAAA;QACF,IAAI,IAAI,EAAE,CAAC;YAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;YAAC,IAAI,CAAC,OAAO,CAAC,iBAAiB,EAAE,IAAI,CAAC,OAAO,CAAC,CAAA;QAAC,CAAC;QACpF,OAAO,EAAE,IAAI,EAAE,IAAI,IAAI,IAAI,EAAE,KAAK,EAAE,CAAA;IACtC,CAAC;IAED,KAAK,CAAC,OAAO;QACX,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAW,eAAe,CAAC,CAAA;QACtE,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,CAAA;IACtD,CAAC;IAED,KAAK,CAAC,UAAU,CAAC,OAAqH;QACpI,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAW,eAAe,EAAE;YACrE,MAAM,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC;SAC/C,CAAC,CAAA;QACF,IAAI,IAAI;YAAE,IAAI,CAAC,OAAO,CAAC,cAAc,EAAE,IAAI,CAAC,OAAO,CAAC,CAAA;QACpD,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,CAAA;IACtD,CAAC;IAED,UAAU;QACR,OAAO,IAAI,CAAC,OAAO,CAAA;IACrB,CAAC;IAED,iBAAiB,CAAC,QAAkB;QAClC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;QAC7B,OAAO,EAAE,WAAW,EAAE,GAAG,EAAE,GAAG,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,QAAQ,CAAC,CAAA,CAAC,CAAC,EAAE,CAAA;IACjG,CAAC;CACF;AA3KD,wCA2KC"}
@@ -0,0 +1,22 @@
1
+ import { Readable } from 'stream';
2
+ export declare function encodePathSegment(value: string | number): string;
3
+ export declare class NivoError extends Error {
4
+ readonly status: number;
5
+ readonly detail?: string | undefined;
6
+ constructor(message: string, status: number, detail?: string | undefined);
7
+ }
8
+ export declare class NivoClient {
9
+ private readonly apiKey;
10
+ private readonly base;
11
+ constructor(apiKey: string, baseUrl: string);
12
+ private url;
13
+ private headers;
14
+ private handleResponse;
15
+ get<T>(pathname: string, query?: Record<string, string | undefined>): Promise<T>;
16
+ post<T>(pathname: string, body?: unknown): Promise<T>;
17
+ patch<T>(pathname: string, body?: unknown): Promise<T>;
18
+ deleteWithBody<T>(pathname: string, body: unknown): Promise<T>;
19
+ delete<T>(pathname: string, query?: Record<string, string | undefined>): Promise<T>;
20
+ upload<T>(pathname: string, file: Buffer | string | Readable, filename?: string, field?: string, extraFields?: Record<string, string>): Promise<T>;
21
+ }
22
+ //# sourceMappingURL=client.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../src/client.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAA;AAEjC,wBAAgB,iBAAiB,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,CAEhE;AAYD,qBAAa,SAAU,SAAQ,KAAK;aAGhB,MAAM,EAAE,MAAM;aACd,MAAM,CAAC,EAAE,MAAM;gBAF/B,OAAO,EAAE,MAAM,EACC,MAAM,EAAE,MAAM,EACd,MAAM,CAAC,EAAE,MAAM,YAAA;CAKlC;AAED,qBAAa,UAAU;IAInB,OAAO,CAAC,QAAQ,CAAC,MAAM;IAHzB,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAQ;gBAGV,MAAM,EAAE,MAAM,EAC/B,OAAO,EAAE,MAAM;IAKjB,OAAO,CAAC,GAAG;IAIX,OAAO,CAAC,OAAO;YAOD,cAAc;IAUtB,GAAG,CAAC,CAAC,EAAE,QAAQ,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,SAAS,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC;IAWhF,IAAI,CAAC,CAAC,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,CAAC,CAAC;IASrD,KAAK,CAAC,CAAC,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,CAAC,CAAC;IAStD,cAAc,CAAC,CAAC,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,GAAG,OAAO,CAAC,CAAC,CAAC;IAS9D,MAAM,CAAC,CAAC,EAAE,QAAQ,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,SAAS,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC;IAcnF,MAAM,CAAC,CAAC,EACZ,QAAQ,EAAE,MAAM,EAChB,IAAI,EAAE,MAAM,GAAG,MAAM,GAAG,QAAQ,EAChC,QAAQ,SAAW,EACnB,KAAK,SAAS,EACd,WAAW,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GACnC,OAAO,CAAC,CAAC,CAAC;CAyBd"}
package/dist/client.js ADDED
@@ -0,0 +1,162 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.NivoClient = exports.NivoError = void 0;
37
+ exports.encodePathSegment = encodePathSegment;
38
+ const fs = __importStar(require("fs"));
39
+ const path = __importStar(require("path"));
40
+ function encodePathSegment(value) {
41
+ return encodeURIComponent(String(value));
42
+ }
43
+ async function readableToBuffer(readable) {
44
+ const chunks = [];
45
+ for await (const chunk of readable) {
46
+ chunks.push(Buffer.isBuffer(chunk) ? chunk : Buffer.from(chunk));
47
+ }
48
+ return Buffer.concat(chunks);
49
+ }
50
+ class NivoError extends Error {
51
+ constructor(message, status, detail) {
52
+ super(message);
53
+ this.status = status;
54
+ this.detail = detail;
55
+ this.name = 'NivoError';
56
+ }
57
+ }
58
+ exports.NivoError = NivoError;
59
+ class NivoClient {
60
+ constructor(apiKey, baseUrl) {
61
+ this.apiKey = apiKey;
62
+ this.base = baseUrl.replace(/\/$/, '');
63
+ }
64
+ url(pathname) {
65
+ return `${this.base}${pathname.startsWith('/') ? pathname : '/' + pathname}`;
66
+ }
67
+ headers() {
68
+ return {
69
+ 'x-api-key': this.apiKey,
70
+ 'Content-Type': 'application/json',
71
+ };
72
+ }
73
+ async handleResponse(res) {
74
+ if (!res.ok) {
75
+ let body = {};
76
+ try {
77
+ body = await res.json();
78
+ }
79
+ catch { }
80
+ throw new NivoError(body.error ?? res.statusText, res.status, body.detail);
81
+ }
82
+ if (res.status === 204)
83
+ return undefined;
84
+ return res.json();
85
+ }
86
+ async get(pathname, query) {
87
+ const url = new URL(this.url(pathname));
88
+ if (query) {
89
+ for (const [k, v] of Object.entries(query)) {
90
+ if (v !== undefined)
91
+ url.searchParams.set(k, v);
92
+ }
93
+ }
94
+ const res = await fetch(url.toString(), { headers: this.headers() });
95
+ return this.handleResponse(res);
96
+ }
97
+ async post(pathname, body) {
98
+ const res = await fetch(this.url(pathname), {
99
+ method: 'POST',
100
+ headers: this.headers(),
101
+ body: body !== undefined ? JSON.stringify(body) : undefined,
102
+ });
103
+ return this.handleResponse(res);
104
+ }
105
+ async patch(pathname, body) {
106
+ const res = await fetch(this.url(pathname), {
107
+ method: 'PATCH',
108
+ headers: this.headers(),
109
+ body: body !== undefined ? JSON.stringify(body) : undefined,
110
+ });
111
+ return this.handleResponse(res);
112
+ }
113
+ async deleteWithBody(pathname, body) {
114
+ const res = await fetch(this.url(pathname), {
115
+ method: 'DELETE',
116
+ headers: { 'x-api-key': this.apiKey, 'Content-Type': 'application/json' },
117
+ body: JSON.stringify(body),
118
+ });
119
+ return this.handleResponse(res);
120
+ }
121
+ async delete(pathname, query) {
122
+ const url = new URL(this.url(pathname));
123
+ if (query) {
124
+ for (const [k, v] of Object.entries(query)) {
125
+ if (v !== undefined)
126
+ url.searchParams.set(k, v);
127
+ }
128
+ }
129
+ const res = await fetch(url.toString(), {
130
+ method: 'DELETE',
131
+ headers: { 'x-api-key': this.apiKey },
132
+ });
133
+ return this.handleResponse(res);
134
+ }
135
+ async upload(pathname, file, filename = 'upload', field = 'file', extraFields) {
136
+ const form = new FormData();
137
+ if (typeof file === 'string') {
138
+ const resolvedFilename = filename || path.basename(file);
139
+ const buffer = await fs.promises.readFile(file);
140
+ form.append(field, new Blob([buffer]), resolvedFilename);
141
+ }
142
+ else if (Buffer.isBuffer(file)) {
143
+ form.append(field, new Blob([file]), filename);
144
+ }
145
+ else {
146
+ const buffer = await readableToBuffer(file);
147
+ form.append(field, new Blob([buffer]), filename);
148
+ }
149
+ if (extraFields) {
150
+ for (const [k, v] of Object.entries(extraFields))
151
+ form.append(k, v);
152
+ }
153
+ const res = await fetch(this.url(pathname), {
154
+ method: 'POST',
155
+ headers: { 'x-api-key': this.apiKey },
156
+ body: form,
157
+ });
158
+ return this.handleResponse(res);
159
+ }
160
+ }
161
+ exports.NivoClient = NivoClient;
162
+ //# sourceMappingURL=client.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"client.js","sourceRoot":"","sources":["../src/client.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAIA,8CAEC;AAND,uCAAwB;AACxB,2CAA4B;AAG5B,SAAgB,iBAAiB,CAAC,KAAsB;IACtD,OAAO,kBAAkB,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAA;AAC1C,CAAC;AAED,KAAK,UAAU,gBAAgB,CAAC,QAAkB;IAChD,MAAM,MAAM,GAAa,EAAE,CAAA;IAE3B,IAAI,KAAK,EAAE,MAAM,KAAK,IAAI,QAAQ,EAAE,CAAC;QACnC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAA;IAClE,CAAC;IAED,OAAO,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;AAC9B,CAAC;AAED,MAAa,SAAU,SAAQ,KAAK;IAClC,YACE,OAAe,EACC,MAAc,EACd,MAAe;QAE/B,KAAK,CAAC,OAAO,CAAC,CAAA;QAHE,WAAM,GAAN,MAAM,CAAQ;QACd,WAAM,GAAN,MAAM,CAAS;QAG/B,IAAI,CAAC,IAAI,GAAG,WAAW,CAAA;IACzB,CAAC;CACF;AATD,8BASC;AAED,MAAa,UAAU;IAGrB,YACmB,MAAc,EAC/B,OAAe;QADE,WAAM,GAAN,MAAM,CAAQ;QAG/B,IAAI,CAAC,IAAI,GAAG,OAAO,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,CAAA;IACxC,CAAC;IAEO,GAAG,CAAC,QAAgB;QAC1B,OAAO,GAAG,IAAI,CAAC,IAAI,GAAG,QAAQ,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,GAAG,QAAQ,EAAE,CAAA;IAC9E,CAAC;IAEO,OAAO;QACb,OAAO;YACL,WAAW,EAAE,IAAI,CAAC,MAAM;YACxB,cAAc,EAAE,kBAAkB;SACnC,CAAA;IACH,CAAC;IAEO,KAAK,CAAC,cAAc,CAAI,GAAa;QAC3C,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC;YACZ,IAAI,IAAI,GAAQ,EAAE,CAAA;YAClB,IAAI,CAAC;gBAAC,IAAI,GAAG,MAAM,GAAG,CAAC,IAAI,EAAE,CAAA;YAAC,CAAC;YAAC,MAAM,CAAC,CAAA,CAAC;YACxC,MAAM,IAAI,SAAS,CAAC,IAAI,CAAC,KAAK,IAAI,GAAG,CAAC,UAAU,EAAE,GAAG,CAAC,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,CAAA;QAC5E,CAAC;QACD,IAAI,GAAG,CAAC,MAAM,KAAK,GAAG;YAAE,OAAO,SAAyB,CAAA;QACxD,OAAO,GAAG,CAAC,IAAI,EAAgB,CAAA;IACjC,CAAC;IAED,KAAK,CAAC,GAAG,CAAI,QAAgB,EAAE,KAA0C;QACvE,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAA;QACvC,IAAI,KAAK,EAAE,CAAC;YACV,KAAK,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;gBAC3C,IAAI,CAAC,KAAK,SAAS;oBAAE,GAAG,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAA;YACjD,CAAC;QACH,CAAC;QACD,MAAM,GAAG,GAAG,MAAM,KAAK,CAAC,GAAG,CAAC,QAAQ,EAAE,EAAE,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC,CAAA;QACpE,OAAO,IAAI,CAAC,cAAc,CAAI,GAAG,CAAC,CAAA;IACpC,CAAC;IAED,KAAK,CAAC,IAAI,CAAI,QAAgB,EAAE,IAAc;QAC5C,MAAM,GAAG,GAAG,MAAM,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE;YAC1C,MAAM,EAAE,MAAM;YACd,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE;YACvB,IAAI,EAAE,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,SAAS;SAC5D,CAAC,CAAA;QACF,OAAO,IAAI,CAAC,cAAc,CAAI,GAAG,CAAC,CAAA;IACpC,CAAC;IAED,KAAK,CAAC,KAAK,CAAI,QAAgB,EAAE,IAAc;QAC7C,MAAM,GAAG,GAAG,MAAM,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE;YAC1C,MAAM,EAAE,OAAO;YACf,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE;YACvB,IAAI,EAAE,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,SAAS;SAC5D,CAAC,CAAA;QACF,OAAO,IAAI,CAAC,cAAc,CAAI,GAAG,CAAC,CAAA;IACpC,CAAC;IAED,KAAK,CAAC,cAAc,CAAI,QAAgB,EAAE,IAAa;QACrD,MAAM,GAAG,GAAG,MAAM,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE;YAC1C,MAAM,EAAE,QAAQ;YAChB,OAAO,EAAE,EAAE,WAAW,EAAE,IAAI,CAAC,MAAM,EAAE,cAAc,EAAE,kBAAkB,EAAE;YACzE,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;SAC3B,CAAC,CAAA;QACF,OAAO,IAAI,CAAC,cAAc,CAAI,GAAG,CAAC,CAAA;IACpC,CAAC;IAED,KAAK,CAAC,MAAM,CAAI,QAAgB,EAAE,KAA0C;QAC1E,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAA;QACvC,IAAI,KAAK,EAAE,CAAC;YACV,KAAK,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;gBAC3C,IAAI,CAAC,KAAK,SAAS;oBAAE,GAAG,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAA;YACjD,CAAC;QACH,CAAC;QACD,MAAM,GAAG,GAAG,MAAM,KAAK,CAAC,GAAG,CAAC,QAAQ,EAAE,EAAE;YACtC,MAAM,EAAE,QAAQ;YAChB,OAAO,EAAE,EAAE,WAAW,EAAE,IAAI,CAAC,MAAM,EAAE;SACtC,CAAC,CAAA;QACF,OAAO,IAAI,CAAC,cAAc,CAAI,GAAG,CAAC,CAAA;IACpC,CAAC;IAED,KAAK,CAAC,MAAM,CACV,QAAgB,EAChB,IAAgC,EAChC,QAAQ,GAAG,QAAQ,EACnB,KAAK,GAAG,MAAM,EACd,WAAoC;QAEpC,MAAM,IAAI,GAAG,IAAI,QAAQ,EAAE,CAAA;QAE3B,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE,CAAC;YAC7B,MAAM,gBAAgB,GAAG,QAAQ,IAAI,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAA;YACxD,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAA;YAC/C,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,IAAI,IAAI,CAAC,CAAC,MAAa,CAAC,CAAC,EAAE,gBAAgB,CAAC,CAAA;QACjE,CAAC;aAAM,IAAI,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;YACjC,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,IAAI,IAAI,CAAC,CAAC,IAAW,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAA;QACvD,CAAC;aAAM,CAAC;YACN,MAAM,MAAM,GAAG,MAAM,gBAAgB,CAAC,IAAI,CAAC,CAAA;YAC3C,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,IAAI,IAAI,CAAC,CAAC,MAAa,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAA;QACzD,CAAC;QAED,IAAI,WAAW,EAAE,CAAC;YAChB,KAAK,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,WAAW,CAAC;gBAAE,IAAI,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,CAAA;QACrE,CAAC;QAED,MAAM,GAAG,GAAG,MAAM,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE;YAC1C,MAAM,EAAE,MAAM;YACd,OAAO,EAAE,EAAE,WAAW,EAAE,IAAI,CAAC,MAAM,EAAE;YACrC,IAAI,EAAE,IAAI;SACX,CAAC,CAAA;QACF,OAAO,IAAI,CAAC,cAAc,CAAI,GAAG,CAAC,CAAA;IACpC,CAAC;CACF;AAlHD,gCAkHC"}