tonightpass 0.0.4 → 0.0.6
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/.turbo/turbo-build.log +8 -8
- package/CHANGELOG.md +12 -0
- package/dist/index.d.mts +110 -116
- package/dist/index.d.ts +110 -116
- package/dist/index.js +7 -7
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +3 -3
- package/dist/index.mjs.map +1 -1
- package/package.json +1 -1
- package/src/index.ts +1 -0
- package/src/rest/client.ts +2 -23
- package/src/rest/endpoints.ts +2 -0
- package/src/rest/types/auth/index.ts +9 -0
- package/src/rest/types/index.ts +1 -0
- package/src/sdk/auth.ts +9 -0
- package/src/sdk/careers.ts +2 -1
- package/src/tonightpass.ts +2 -1
- package/src/rest/types/api/index.ts +0 -0
package/.turbo/turbo-build.log
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
|
|
2
|
-
> tonightpass@0.0.
|
|
2
|
+
> tonightpass@0.0.6 build /home/runner/work/tonightpass/tonightpass/packages/node
|
|
3
3
|
> tsup
|
|
4
4
|
|
|
5
5
|
[34mCLI[39m Building entry: src/index.ts
|
|
@@ -10,12 +10,12 @@
|
|
|
10
10
|
[34mCJS[39m Build start
|
|
11
11
|
[34mESM[39m Build start
|
|
12
12
|
[32mESM[39m [1mdist/index.mjs [22m[32m6.54 KB[39m
|
|
13
|
-
[32mESM[39m [1mdist/index.mjs.map [22m[
|
|
14
|
-
[32mESM[39m ⚡️ Build success in
|
|
13
|
+
[32mESM[39m [1mdist/index.mjs.map [22m[32m24.87 KB[39m
|
|
14
|
+
[32mESM[39m ⚡️ Build success in 209ms
|
|
15
15
|
[32mCJS[39m [1mdist/index.js [22m[32m7.42 KB[39m
|
|
16
|
-
[32mCJS[39m [1mdist/index.js.map [22m[
|
|
17
|
-
[32mCJS[39m ⚡️ Build success in
|
|
16
|
+
[32mCJS[39m [1mdist/index.js.map [22m[32m24.87 KB[39m
|
|
17
|
+
[32mCJS[39m ⚡️ Build success in 209ms
|
|
18
18
|
[34mDTS[39m Build start
|
|
19
|
-
[32mDTS[39m ⚡️ Build success in
|
|
20
|
-
[32mDTS[39m [1mdist/index.d.ts [22m[
|
|
21
|
-
[32mDTS[39m [1mdist/index.d.mts [22m[
|
|
19
|
+
[32mDTS[39m ⚡️ Build success in 2352ms
|
|
20
|
+
[32mDTS[39m [1mdist/index.d.ts [22m[32m18.53 KB[39m
|
|
21
|
+
[32mDTS[39m [1mdist/index.d.mts [22m[32m18.53 KB[39m
|
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,17 @@
|
|
|
1
1
|
# tonightpass
|
|
2
2
|
|
|
3
|
+
## 0.0.6
|
|
4
|
+
|
|
5
|
+
### Patch Changes
|
|
6
|
+
|
|
7
|
+
- [`24d1f03`](https://github.com/tonightpass/tonightpass/commit/24d1f0323507b176c8b5b19f64f1b63c874e9a31) Thanks [@AntoineKM](https://github.com/AntoineKM)! - Add auth sdk
|
|
8
|
+
|
|
9
|
+
## 0.0.5
|
|
10
|
+
|
|
11
|
+
### Patch Changes
|
|
12
|
+
|
|
13
|
+
- [`8f7a766`](https://github.com/tonightpass/tonightpass/commit/8f7a7661541f3927f4a4f31c119f8a866abd7133) Thanks [@AntoineKM](https://github.com/AntoineKM)! - Fix query types by using pathcat types
|
|
14
|
+
|
|
3
15
|
## 0.0.4
|
|
4
16
|
|
|
5
17
|
### Patch Changes
|
package/dist/index.d.mts
CHANGED
|
@@ -1,5 +1,7 @@
|
|
|
1
|
+
import * as pathcat from 'pathcat';
|
|
2
|
+
import { ParamValue, Query } from 'pathcat';
|
|
3
|
+
export * from 'pathcat';
|
|
1
4
|
import { Options, Response } from 'redaxios';
|
|
2
|
-
import { ParamValue } from 'pathcat';
|
|
3
5
|
|
|
4
6
|
declare const DEFAULT_API_URL = "https://api.tonightpass.com";
|
|
5
7
|
|
|
@@ -29,7 +31,90 @@ type Endpoint<M extends Options["method"], Path extends string, Res, Body = unde
|
|
|
29
31
|
res: Res;
|
|
30
32
|
body: Body;
|
|
31
33
|
};
|
|
32
|
-
type Endpoints = CareersEndpoints | HealthEndpoints | ProfileEndpoints | UserEndpoints;
|
|
34
|
+
type Endpoints = AuthEndpoints | CareersEndpoints | HealthEndpoints | ProfileEndpoints | UserEndpoints;
|
|
35
|
+
|
|
36
|
+
type User = {
|
|
37
|
+
id: string;
|
|
38
|
+
identifier: UserIdentifier;
|
|
39
|
+
password: string;
|
|
40
|
+
identity: UserIdentity;
|
|
41
|
+
role: UserRole;
|
|
42
|
+
addresses: Location$1[];
|
|
43
|
+
preferences: UserPreferences;
|
|
44
|
+
connections: UserConnection[];
|
|
45
|
+
verified: boolean;
|
|
46
|
+
updatedAt: Date;
|
|
47
|
+
createdAt: Date;
|
|
48
|
+
};
|
|
49
|
+
type UserIdentifier = {
|
|
50
|
+
email?: string;
|
|
51
|
+
phoneNumber?: string;
|
|
52
|
+
username: string;
|
|
53
|
+
[key: string]: string | undefined;
|
|
54
|
+
};
|
|
55
|
+
type UserIdentity = Profile & {
|
|
56
|
+
firstName: string;
|
|
57
|
+
lastName: string;
|
|
58
|
+
fullName: string;
|
|
59
|
+
gender: UserIdentityGender;
|
|
60
|
+
birthDate: Date;
|
|
61
|
+
metadata: ProfileMetadata & {
|
|
62
|
+
followingCount: number;
|
|
63
|
+
hasPassPlus: boolean;
|
|
64
|
+
idValid: boolean;
|
|
65
|
+
};
|
|
66
|
+
};
|
|
67
|
+
declare enum UserRole {
|
|
68
|
+
USER = 0,
|
|
69
|
+
DEVELOPER = 8,
|
|
70
|
+
ADMINISTRATOR = 10
|
|
71
|
+
}
|
|
72
|
+
type UserIdentityGender = "male" | "female" | "non-binary" | "gender-fluid" | "neutral" | "other" | string;
|
|
73
|
+
type UserPreferences = {
|
|
74
|
+
language: Language;
|
|
75
|
+
currency: Currency;
|
|
76
|
+
notifications: {
|
|
77
|
+
email: {
|
|
78
|
+
newsletter: boolean;
|
|
79
|
+
message: boolean;
|
|
80
|
+
};
|
|
81
|
+
push: {
|
|
82
|
+
message: boolean;
|
|
83
|
+
};
|
|
84
|
+
};
|
|
85
|
+
};
|
|
86
|
+
type UserConnection = {
|
|
87
|
+
ip: string;
|
|
88
|
+
os: UserConnectionOS;
|
|
89
|
+
device: UserConnectionDevice;
|
|
90
|
+
client: UserConnectionClient;
|
|
91
|
+
updatedAt: Date;
|
|
92
|
+
createdAt: Date;
|
|
93
|
+
};
|
|
94
|
+
type UserConnectionOS = {
|
|
95
|
+
name: string;
|
|
96
|
+
version: string;
|
|
97
|
+
};
|
|
98
|
+
type UserConnectionDevice = {
|
|
99
|
+
type: string;
|
|
100
|
+
brand: string;
|
|
101
|
+
};
|
|
102
|
+
type UserConnectionClient = {
|
|
103
|
+
name: string;
|
|
104
|
+
version: string;
|
|
105
|
+
};
|
|
106
|
+
type UserEndpoints = Endpoint<"GET", "/users", User[]> | Endpoint<"GET", "/users/:id", User, {
|
|
107
|
+
id: string;
|
|
108
|
+
}> | Endpoint<"GET", "/users/me", User> | Endpoint<"GET", "/users/check/:identifier", {
|
|
109
|
+
exists: boolean;
|
|
110
|
+
identifier: UserIdentifier;
|
|
111
|
+
suggestions?: string[];
|
|
112
|
+
}, {
|
|
113
|
+
identifier: boolean;
|
|
114
|
+
suggestions?: boolean;
|
|
115
|
+
}> | Endpoint<"PUT", "/users/:id", User, UpdateUserDto>;
|
|
116
|
+
|
|
117
|
+
type AuthEndpoints = Endpoint<"POST", "/auth/sign-up", User, CreateUserDto> | Endpoint<"POST", "/auth/sign-in", User, SignInUserDto> | Endpoint<"POST", "/auth/sign-out", void> | Endpoint<"POST", "/auth/refresh-token", User>;
|
|
33
118
|
|
|
34
119
|
type CareersOffice = {
|
|
35
120
|
id: number | null;
|
|
@@ -123,87 +208,6 @@ declare enum EventTicketCategory {
|
|
|
123
208
|
OTHER = "other"
|
|
124
209
|
}
|
|
125
210
|
|
|
126
|
-
type User = {
|
|
127
|
-
id: string;
|
|
128
|
-
identifier: UserIdentifier;
|
|
129
|
-
password: string;
|
|
130
|
-
identity: UserIdentity;
|
|
131
|
-
role: UserRole;
|
|
132
|
-
addresses: Location$1[];
|
|
133
|
-
preferences: UserPreferences;
|
|
134
|
-
connections: UserConnection[];
|
|
135
|
-
verified: boolean;
|
|
136
|
-
updatedAt: Date;
|
|
137
|
-
createdAt: Date;
|
|
138
|
-
};
|
|
139
|
-
type UserIdentifier = {
|
|
140
|
-
email?: string;
|
|
141
|
-
phoneNumber?: string;
|
|
142
|
-
username: string;
|
|
143
|
-
[key: string]: string | undefined;
|
|
144
|
-
};
|
|
145
|
-
type UserIdentity = Profile & {
|
|
146
|
-
firstName: string;
|
|
147
|
-
lastName: string;
|
|
148
|
-
fullName: string;
|
|
149
|
-
gender: UserIdentityGender;
|
|
150
|
-
birthDate: Date;
|
|
151
|
-
metadata: ProfileMetadata & {
|
|
152
|
-
followingCount: number;
|
|
153
|
-
hasPassPlus: boolean;
|
|
154
|
-
idValid: boolean;
|
|
155
|
-
};
|
|
156
|
-
};
|
|
157
|
-
declare enum UserRole {
|
|
158
|
-
USER = 0,
|
|
159
|
-
DEVELOPER = 8,
|
|
160
|
-
ADMINISTRATOR = 10
|
|
161
|
-
}
|
|
162
|
-
type UserIdentityGender = "male" | "female" | "non-binary" | "gender-fluid" | "neutral" | "other" | string;
|
|
163
|
-
type UserPreferences = {
|
|
164
|
-
language: Language;
|
|
165
|
-
currency: Currency;
|
|
166
|
-
notifications: {
|
|
167
|
-
email: {
|
|
168
|
-
newsletter: boolean;
|
|
169
|
-
message: boolean;
|
|
170
|
-
};
|
|
171
|
-
push: {
|
|
172
|
-
message: boolean;
|
|
173
|
-
};
|
|
174
|
-
};
|
|
175
|
-
};
|
|
176
|
-
type UserConnection = {
|
|
177
|
-
ip: string;
|
|
178
|
-
os: UserConnectionOS;
|
|
179
|
-
device: UserConnectionDevice;
|
|
180
|
-
client: UserConnectionClient;
|
|
181
|
-
updatedAt: Date;
|
|
182
|
-
createdAt: Date;
|
|
183
|
-
};
|
|
184
|
-
type UserConnectionOS = {
|
|
185
|
-
name: string;
|
|
186
|
-
version: string;
|
|
187
|
-
};
|
|
188
|
-
type UserConnectionDevice = {
|
|
189
|
-
type: string;
|
|
190
|
-
brand: string;
|
|
191
|
-
};
|
|
192
|
-
type UserConnectionClient = {
|
|
193
|
-
name: string;
|
|
194
|
-
version: string;
|
|
195
|
-
};
|
|
196
|
-
type UserEndpoints = Endpoint<"GET", "/users", User[]> | Endpoint<"GET", "/users/:id", User, {
|
|
197
|
-
id: string;
|
|
198
|
-
}> | Endpoint<"GET", "/users/me", User> | Endpoint<"GET", "/users/check/:identifier", {
|
|
199
|
-
exists: boolean;
|
|
200
|
-
identifier: UserIdentifier;
|
|
201
|
-
suggestions?: string[];
|
|
202
|
-
}, {
|
|
203
|
-
identifier: boolean;
|
|
204
|
-
suggestions?: boolean;
|
|
205
|
-
}> | Endpoint<"PUT", "/users/:id", User, UpdateUserDto>;
|
|
206
|
-
|
|
207
211
|
type Organization = {
|
|
208
212
|
id: string;
|
|
209
213
|
slug: string;
|
|
@@ -450,19 +454,9 @@ interface APIRequestOptions extends Options {
|
|
|
450
454
|
}
|
|
451
455
|
declare const request: <T>(url: string, options?: Options) => Promise<Response<APIResponse<T>>>;
|
|
452
456
|
|
|
453
|
-
type ExtractRouteParams<T extends string> = string extends T ? Record<string, string | number | boolean | undefined> : T extends `${string}:${infer Param}/${infer Rest}` ? {
|
|
454
|
-
[k in Param | keyof ExtractRouteParams<Rest>]: string | number | boolean;
|
|
455
|
-
} : T extends `${string}:${infer Param}` ? {
|
|
456
|
-
[k in Param]: string | number | boolean;
|
|
457
|
-
} : object;
|
|
458
|
-
type ExtractEndpoint<Method extends string, Path extends string> = Extract<Endpoints, {
|
|
459
|
-
path: Path;
|
|
460
|
-
method: Method;
|
|
461
|
-
}>;
|
|
462
457
|
type PathsFor<M extends Options["method"]> = Extract<Endpoints, {
|
|
463
458
|
method: M;
|
|
464
459
|
}>["path"];
|
|
465
|
-
type Query<Path extends string> = ExtractRouteParams<Path> & Record<string, string | number | boolean | undefined>;
|
|
466
460
|
declare class TonightPassAPIError<T> extends Error {
|
|
467
461
|
readonly response: Response<APIResponse<T>>;
|
|
468
462
|
readonly data: ErroredAPIResponse;
|
|
@@ -551,7 +545,19 @@ declare class Client {
|
|
|
551
545
|
}>["path"]>(path: Path, body: Extract<Endpoints, {
|
|
552
546
|
path: Path;
|
|
553
547
|
method: "POST";
|
|
554
|
-
}>["body"], query?: Query<Path>, options?: APIRequestOptions): Promise<
|
|
548
|
+
}>["body"], query?: Query<Path>, options?: APIRequestOptions): Promise<(Extract<Endpoint<"POST", "/auth/sign-up", User, CreateUserDto>, {
|
|
549
|
+
path: Path;
|
|
550
|
+
method: "POST";
|
|
551
|
+
}> | Extract<Endpoint<"POST", "/auth/sign-in", User, SignInUserDto>, {
|
|
552
|
+
path: Path;
|
|
553
|
+
method: "POST";
|
|
554
|
+
}> | Extract<Endpoint<"POST", "/auth/sign-out", void>, {
|
|
555
|
+
path: Path;
|
|
556
|
+
method: "POST";
|
|
557
|
+
}> | Extract<Endpoint<"POST", "/auth/refresh-token", User>, {
|
|
558
|
+
path: Path;
|
|
559
|
+
method: "POST";
|
|
560
|
+
}>)["res"]>;
|
|
555
561
|
put<Path extends Extract<Endpoints, {
|
|
556
562
|
method: "PUT";
|
|
557
563
|
}>["path"]>(path: Path, body: Extract<Endpoints, {
|
|
@@ -582,13 +588,9 @@ declare const health: (client: Client) => {
|
|
|
582
588
|
|
|
583
589
|
declare const users: (client: Client) => {
|
|
584
590
|
getAll: () => Promise<User[]>;
|
|
585
|
-
get: (id: string) => Promise<
|
|
586
|
-
exists: boolean;
|
|
587
|
-
identifier: UserIdentifier;
|
|
588
|
-
suggestions?: string[] | undefined;
|
|
589
|
-
}>;
|
|
591
|
+
get: (id: string) => Promise<User[]>;
|
|
590
592
|
me: () => Promise<User>;
|
|
591
|
-
check: (identifier: string, suggestions?: boolean) => Promise<
|
|
593
|
+
check: (identifier: string, suggestions?: boolean) => Promise<{
|
|
592
594
|
exists: boolean;
|
|
593
595
|
identifier: UserIdentifier;
|
|
594
596
|
suggestions?: string[] | undefined;
|
|
@@ -600,17 +602,17 @@ declare class TonightPass {
|
|
|
600
602
|
readonly client: Client;
|
|
601
603
|
readonly careers: {
|
|
602
604
|
categories: {
|
|
603
|
-
getAll: (query?: Query<"/careers/categories"> | undefined) => Promise<CareersCategory[]>;
|
|
605
|
+
getAll: (query?: pathcat.Query<"/careers/categories"> | undefined) => Promise<CareersCategory[]>;
|
|
604
606
|
};
|
|
605
607
|
employmentTypes: {
|
|
606
|
-
getAll: (query?: Query<"/careers/employmentTypes"> | undefined) => Promise<CareersEmploymentType[]>;
|
|
608
|
+
getAll: (query?: pathcat.Query<"/careers/employmentTypes"> | undefined) => Promise<CareersEmploymentType[]>;
|
|
607
609
|
};
|
|
608
610
|
jobs: {
|
|
609
|
-
getAll: (query?: Query<"/careers/jobs"> | undefined) => Promise<CareersJob[]>;
|
|
611
|
+
getAll: (query?: pathcat.Query<"/careers/jobs"> | undefined) => Promise<CareersJob[]>;
|
|
610
612
|
get: (id: number) => Promise<CareersJob>;
|
|
611
613
|
};
|
|
612
614
|
offices: {
|
|
613
|
-
getAll: (query?: Query<"/careers/offices"> | undefined) => Promise<CareersOffice[]>;
|
|
615
|
+
getAll: (query?: pathcat.Query<"/careers/offices"> | undefined) => Promise<CareersOffice[]>;
|
|
614
616
|
};
|
|
615
617
|
};
|
|
616
618
|
readonly health: {
|
|
@@ -618,21 +620,13 @@ declare class TonightPass {
|
|
|
618
620
|
http: () => Promise<Health<"app">>;
|
|
619
621
|
};
|
|
620
622
|
readonly profiles: {
|
|
621
|
-
get: (username: string) => Promise<
|
|
622
|
-
exists: boolean;
|
|
623
|
-
identifier: UserIdentifier;
|
|
624
|
-
suggestions?: string[] | undefined;
|
|
625
|
-
}>;
|
|
623
|
+
get: (username: string) => Promise<UserIdentity>;
|
|
626
624
|
};
|
|
627
625
|
readonly users: {
|
|
628
626
|
getAll: () => Promise<User[]>;
|
|
629
|
-
get: (id: string) => Promise<
|
|
630
|
-
exists: boolean;
|
|
631
|
-
identifier: UserIdentifier;
|
|
632
|
-
suggestions?: string[] | undefined;
|
|
633
|
-
}>;
|
|
627
|
+
get: (id: string) => Promise<User[]>;
|
|
634
628
|
me: () => Promise<User>;
|
|
635
|
-
check: (identifier: string, suggestions?: boolean | undefined) => Promise<
|
|
629
|
+
check: (identifier: string, suggestions?: boolean | undefined) => Promise<{
|
|
636
630
|
exists: boolean;
|
|
637
631
|
identifier: UserIdentifier;
|
|
638
632
|
suggestions?: string[] | undefined;
|
|
@@ -644,4 +638,4 @@ declare class TonightPass {
|
|
|
644
638
|
|
|
645
639
|
declare const isBrowser: boolean;
|
|
646
640
|
|
|
647
|
-
export { type APIRequestOptions, type APIResponse, BCRYPT_HASH, type CareersCategory, type CareersEmploymentType, type CareersEndpoints, type CareersJob, type CareersOffice, Client, type ClientOptions, CreateUserDto, Currency, DEFAULT_API_URL, EMAIL_REGEX, type Endpoint, type Endpoints, type ErroredAPIResponse, type Event, type EventStyle, EventStyleType, type EventTicket, EventTicketCategory, type EventTicketType, EventType, type
|
|
641
|
+
export { type APIRequestOptions, type APIResponse, type AuthEndpoints, BCRYPT_HASH, type CareersCategory, type CareersEmploymentType, type CareersEndpoints, type CareersJob, type CareersOffice, Client, type ClientOptions, CreateUserDto, Currency, DEFAULT_API_URL, EMAIL_REGEX, type Endpoint, type Endpoints, type ErroredAPIResponse, type Event, type EventStyle, EventStyleType, type EventTicket, EventTicketCategory, type EventTicketType, EventType, type Health, type HealthEndpoints, IMAGE_URL_REGEX, Language, type Location$1 as Location, NAME_REGEX, type Order, type OrderItem, OrderStatus, type Organization, type OrganizationIdentity, type OrganizationMember, OrganizationMemberRole, type OrganizationSocialLink, OrganizationSocialType, PASSWORD_REGEX, PHONE_NUMBER_REGEX, type PathsFor, type Profile, type ProfileEndpoints, type ProfileMetadata, type PromoCode, SLUG_REGEX, SignInUserDto, type SuccessfulAPIResponse, TonightPass, TonightPassAPIError, UpdateUserDto, type User, type UserConnection, type UserConnectionClient, type UserConnectionDevice, type UserConnectionOS, type UserEndpoints, type UserIdentifier, type UserIdentity, type UserIdentityGender, type UserPreferences, UserRole, type UserToken, UserTokenType, health, isBrowser, request, sdk, users };
|
package/dist/index.d.ts
CHANGED
|
@@ -1,5 +1,7 @@
|
|
|
1
|
+
import * as pathcat from 'pathcat';
|
|
2
|
+
import { ParamValue, Query } from 'pathcat';
|
|
3
|
+
export * from 'pathcat';
|
|
1
4
|
import { Options, Response } from 'redaxios';
|
|
2
|
-
import { ParamValue } from 'pathcat';
|
|
3
5
|
|
|
4
6
|
declare const DEFAULT_API_URL = "https://api.tonightpass.com";
|
|
5
7
|
|
|
@@ -29,7 +31,90 @@ type Endpoint<M extends Options["method"], Path extends string, Res, Body = unde
|
|
|
29
31
|
res: Res;
|
|
30
32
|
body: Body;
|
|
31
33
|
};
|
|
32
|
-
type Endpoints = CareersEndpoints | HealthEndpoints | ProfileEndpoints | UserEndpoints;
|
|
34
|
+
type Endpoints = AuthEndpoints | CareersEndpoints | HealthEndpoints | ProfileEndpoints | UserEndpoints;
|
|
35
|
+
|
|
36
|
+
type User = {
|
|
37
|
+
id: string;
|
|
38
|
+
identifier: UserIdentifier;
|
|
39
|
+
password: string;
|
|
40
|
+
identity: UserIdentity;
|
|
41
|
+
role: UserRole;
|
|
42
|
+
addresses: Location$1[];
|
|
43
|
+
preferences: UserPreferences;
|
|
44
|
+
connections: UserConnection[];
|
|
45
|
+
verified: boolean;
|
|
46
|
+
updatedAt: Date;
|
|
47
|
+
createdAt: Date;
|
|
48
|
+
};
|
|
49
|
+
type UserIdentifier = {
|
|
50
|
+
email?: string;
|
|
51
|
+
phoneNumber?: string;
|
|
52
|
+
username: string;
|
|
53
|
+
[key: string]: string | undefined;
|
|
54
|
+
};
|
|
55
|
+
type UserIdentity = Profile & {
|
|
56
|
+
firstName: string;
|
|
57
|
+
lastName: string;
|
|
58
|
+
fullName: string;
|
|
59
|
+
gender: UserIdentityGender;
|
|
60
|
+
birthDate: Date;
|
|
61
|
+
metadata: ProfileMetadata & {
|
|
62
|
+
followingCount: number;
|
|
63
|
+
hasPassPlus: boolean;
|
|
64
|
+
idValid: boolean;
|
|
65
|
+
};
|
|
66
|
+
};
|
|
67
|
+
declare enum UserRole {
|
|
68
|
+
USER = 0,
|
|
69
|
+
DEVELOPER = 8,
|
|
70
|
+
ADMINISTRATOR = 10
|
|
71
|
+
}
|
|
72
|
+
type UserIdentityGender = "male" | "female" | "non-binary" | "gender-fluid" | "neutral" | "other" | string;
|
|
73
|
+
type UserPreferences = {
|
|
74
|
+
language: Language;
|
|
75
|
+
currency: Currency;
|
|
76
|
+
notifications: {
|
|
77
|
+
email: {
|
|
78
|
+
newsletter: boolean;
|
|
79
|
+
message: boolean;
|
|
80
|
+
};
|
|
81
|
+
push: {
|
|
82
|
+
message: boolean;
|
|
83
|
+
};
|
|
84
|
+
};
|
|
85
|
+
};
|
|
86
|
+
type UserConnection = {
|
|
87
|
+
ip: string;
|
|
88
|
+
os: UserConnectionOS;
|
|
89
|
+
device: UserConnectionDevice;
|
|
90
|
+
client: UserConnectionClient;
|
|
91
|
+
updatedAt: Date;
|
|
92
|
+
createdAt: Date;
|
|
93
|
+
};
|
|
94
|
+
type UserConnectionOS = {
|
|
95
|
+
name: string;
|
|
96
|
+
version: string;
|
|
97
|
+
};
|
|
98
|
+
type UserConnectionDevice = {
|
|
99
|
+
type: string;
|
|
100
|
+
brand: string;
|
|
101
|
+
};
|
|
102
|
+
type UserConnectionClient = {
|
|
103
|
+
name: string;
|
|
104
|
+
version: string;
|
|
105
|
+
};
|
|
106
|
+
type UserEndpoints = Endpoint<"GET", "/users", User[]> | Endpoint<"GET", "/users/:id", User, {
|
|
107
|
+
id: string;
|
|
108
|
+
}> | Endpoint<"GET", "/users/me", User> | Endpoint<"GET", "/users/check/:identifier", {
|
|
109
|
+
exists: boolean;
|
|
110
|
+
identifier: UserIdentifier;
|
|
111
|
+
suggestions?: string[];
|
|
112
|
+
}, {
|
|
113
|
+
identifier: boolean;
|
|
114
|
+
suggestions?: boolean;
|
|
115
|
+
}> | Endpoint<"PUT", "/users/:id", User, UpdateUserDto>;
|
|
116
|
+
|
|
117
|
+
type AuthEndpoints = Endpoint<"POST", "/auth/sign-up", User, CreateUserDto> | Endpoint<"POST", "/auth/sign-in", User, SignInUserDto> | Endpoint<"POST", "/auth/sign-out", void> | Endpoint<"POST", "/auth/refresh-token", User>;
|
|
33
118
|
|
|
34
119
|
type CareersOffice = {
|
|
35
120
|
id: number | null;
|
|
@@ -123,87 +208,6 @@ declare enum EventTicketCategory {
|
|
|
123
208
|
OTHER = "other"
|
|
124
209
|
}
|
|
125
210
|
|
|
126
|
-
type User = {
|
|
127
|
-
id: string;
|
|
128
|
-
identifier: UserIdentifier;
|
|
129
|
-
password: string;
|
|
130
|
-
identity: UserIdentity;
|
|
131
|
-
role: UserRole;
|
|
132
|
-
addresses: Location$1[];
|
|
133
|
-
preferences: UserPreferences;
|
|
134
|
-
connections: UserConnection[];
|
|
135
|
-
verified: boolean;
|
|
136
|
-
updatedAt: Date;
|
|
137
|
-
createdAt: Date;
|
|
138
|
-
};
|
|
139
|
-
type UserIdentifier = {
|
|
140
|
-
email?: string;
|
|
141
|
-
phoneNumber?: string;
|
|
142
|
-
username: string;
|
|
143
|
-
[key: string]: string | undefined;
|
|
144
|
-
};
|
|
145
|
-
type UserIdentity = Profile & {
|
|
146
|
-
firstName: string;
|
|
147
|
-
lastName: string;
|
|
148
|
-
fullName: string;
|
|
149
|
-
gender: UserIdentityGender;
|
|
150
|
-
birthDate: Date;
|
|
151
|
-
metadata: ProfileMetadata & {
|
|
152
|
-
followingCount: number;
|
|
153
|
-
hasPassPlus: boolean;
|
|
154
|
-
idValid: boolean;
|
|
155
|
-
};
|
|
156
|
-
};
|
|
157
|
-
declare enum UserRole {
|
|
158
|
-
USER = 0,
|
|
159
|
-
DEVELOPER = 8,
|
|
160
|
-
ADMINISTRATOR = 10
|
|
161
|
-
}
|
|
162
|
-
type UserIdentityGender = "male" | "female" | "non-binary" | "gender-fluid" | "neutral" | "other" | string;
|
|
163
|
-
type UserPreferences = {
|
|
164
|
-
language: Language;
|
|
165
|
-
currency: Currency;
|
|
166
|
-
notifications: {
|
|
167
|
-
email: {
|
|
168
|
-
newsletter: boolean;
|
|
169
|
-
message: boolean;
|
|
170
|
-
};
|
|
171
|
-
push: {
|
|
172
|
-
message: boolean;
|
|
173
|
-
};
|
|
174
|
-
};
|
|
175
|
-
};
|
|
176
|
-
type UserConnection = {
|
|
177
|
-
ip: string;
|
|
178
|
-
os: UserConnectionOS;
|
|
179
|
-
device: UserConnectionDevice;
|
|
180
|
-
client: UserConnectionClient;
|
|
181
|
-
updatedAt: Date;
|
|
182
|
-
createdAt: Date;
|
|
183
|
-
};
|
|
184
|
-
type UserConnectionOS = {
|
|
185
|
-
name: string;
|
|
186
|
-
version: string;
|
|
187
|
-
};
|
|
188
|
-
type UserConnectionDevice = {
|
|
189
|
-
type: string;
|
|
190
|
-
brand: string;
|
|
191
|
-
};
|
|
192
|
-
type UserConnectionClient = {
|
|
193
|
-
name: string;
|
|
194
|
-
version: string;
|
|
195
|
-
};
|
|
196
|
-
type UserEndpoints = Endpoint<"GET", "/users", User[]> | Endpoint<"GET", "/users/:id", User, {
|
|
197
|
-
id: string;
|
|
198
|
-
}> | Endpoint<"GET", "/users/me", User> | Endpoint<"GET", "/users/check/:identifier", {
|
|
199
|
-
exists: boolean;
|
|
200
|
-
identifier: UserIdentifier;
|
|
201
|
-
suggestions?: string[];
|
|
202
|
-
}, {
|
|
203
|
-
identifier: boolean;
|
|
204
|
-
suggestions?: boolean;
|
|
205
|
-
}> | Endpoint<"PUT", "/users/:id", User, UpdateUserDto>;
|
|
206
|
-
|
|
207
211
|
type Organization = {
|
|
208
212
|
id: string;
|
|
209
213
|
slug: string;
|
|
@@ -450,19 +454,9 @@ interface APIRequestOptions extends Options {
|
|
|
450
454
|
}
|
|
451
455
|
declare const request: <T>(url: string, options?: Options) => Promise<Response<APIResponse<T>>>;
|
|
452
456
|
|
|
453
|
-
type ExtractRouteParams<T extends string> = string extends T ? Record<string, string | number | boolean | undefined> : T extends `${string}:${infer Param}/${infer Rest}` ? {
|
|
454
|
-
[k in Param | keyof ExtractRouteParams<Rest>]: string | number | boolean;
|
|
455
|
-
} : T extends `${string}:${infer Param}` ? {
|
|
456
|
-
[k in Param]: string | number | boolean;
|
|
457
|
-
} : object;
|
|
458
|
-
type ExtractEndpoint<Method extends string, Path extends string> = Extract<Endpoints, {
|
|
459
|
-
path: Path;
|
|
460
|
-
method: Method;
|
|
461
|
-
}>;
|
|
462
457
|
type PathsFor<M extends Options["method"]> = Extract<Endpoints, {
|
|
463
458
|
method: M;
|
|
464
459
|
}>["path"];
|
|
465
|
-
type Query<Path extends string> = ExtractRouteParams<Path> & Record<string, string | number | boolean | undefined>;
|
|
466
460
|
declare class TonightPassAPIError<T> extends Error {
|
|
467
461
|
readonly response: Response<APIResponse<T>>;
|
|
468
462
|
readonly data: ErroredAPIResponse;
|
|
@@ -551,7 +545,19 @@ declare class Client {
|
|
|
551
545
|
}>["path"]>(path: Path, body: Extract<Endpoints, {
|
|
552
546
|
path: Path;
|
|
553
547
|
method: "POST";
|
|
554
|
-
}>["body"], query?: Query<Path>, options?: APIRequestOptions): Promise<
|
|
548
|
+
}>["body"], query?: Query<Path>, options?: APIRequestOptions): Promise<(Extract<Endpoint<"POST", "/auth/sign-up", User, CreateUserDto>, {
|
|
549
|
+
path: Path;
|
|
550
|
+
method: "POST";
|
|
551
|
+
}> | Extract<Endpoint<"POST", "/auth/sign-in", User, SignInUserDto>, {
|
|
552
|
+
path: Path;
|
|
553
|
+
method: "POST";
|
|
554
|
+
}> | Extract<Endpoint<"POST", "/auth/sign-out", void>, {
|
|
555
|
+
path: Path;
|
|
556
|
+
method: "POST";
|
|
557
|
+
}> | Extract<Endpoint<"POST", "/auth/refresh-token", User>, {
|
|
558
|
+
path: Path;
|
|
559
|
+
method: "POST";
|
|
560
|
+
}>)["res"]>;
|
|
555
561
|
put<Path extends Extract<Endpoints, {
|
|
556
562
|
method: "PUT";
|
|
557
563
|
}>["path"]>(path: Path, body: Extract<Endpoints, {
|
|
@@ -582,13 +588,9 @@ declare const health: (client: Client) => {
|
|
|
582
588
|
|
|
583
589
|
declare const users: (client: Client) => {
|
|
584
590
|
getAll: () => Promise<User[]>;
|
|
585
|
-
get: (id: string) => Promise<
|
|
586
|
-
exists: boolean;
|
|
587
|
-
identifier: UserIdentifier;
|
|
588
|
-
suggestions?: string[] | undefined;
|
|
589
|
-
}>;
|
|
591
|
+
get: (id: string) => Promise<User[]>;
|
|
590
592
|
me: () => Promise<User>;
|
|
591
|
-
check: (identifier: string, suggestions?: boolean) => Promise<
|
|
593
|
+
check: (identifier: string, suggestions?: boolean) => Promise<{
|
|
592
594
|
exists: boolean;
|
|
593
595
|
identifier: UserIdentifier;
|
|
594
596
|
suggestions?: string[] | undefined;
|
|
@@ -600,17 +602,17 @@ declare class TonightPass {
|
|
|
600
602
|
readonly client: Client;
|
|
601
603
|
readonly careers: {
|
|
602
604
|
categories: {
|
|
603
|
-
getAll: (query?: Query<"/careers/categories"> | undefined) => Promise<CareersCategory[]>;
|
|
605
|
+
getAll: (query?: pathcat.Query<"/careers/categories"> | undefined) => Promise<CareersCategory[]>;
|
|
604
606
|
};
|
|
605
607
|
employmentTypes: {
|
|
606
|
-
getAll: (query?: Query<"/careers/employmentTypes"> | undefined) => Promise<CareersEmploymentType[]>;
|
|
608
|
+
getAll: (query?: pathcat.Query<"/careers/employmentTypes"> | undefined) => Promise<CareersEmploymentType[]>;
|
|
607
609
|
};
|
|
608
610
|
jobs: {
|
|
609
|
-
getAll: (query?: Query<"/careers/jobs"> | undefined) => Promise<CareersJob[]>;
|
|
611
|
+
getAll: (query?: pathcat.Query<"/careers/jobs"> | undefined) => Promise<CareersJob[]>;
|
|
610
612
|
get: (id: number) => Promise<CareersJob>;
|
|
611
613
|
};
|
|
612
614
|
offices: {
|
|
613
|
-
getAll: (query?: Query<"/careers/offices"> | undefined) => Promise<CareersOffice[]>;
|
|
615
|
+
getAll: (query?: pathcat.Query<"/careers/offices"> | undefined) => Promise<CareersOffice[]>;
|
|
614
616
|
};
|
|
615
617
|
};
|
|
616
618
|
readonly health: {
|
|
@@ -618,21 +620,13 @@ declare class TonightPass {
|
|
|
618
620
|
http: () => Promise<Health<"app">>;
|
|
619
621
|
};
|
|
620
622
|
readonly profiles: {
|
|
621
|
-
get: (username: string) => Promise<
|
|
622
|
-
exists: boolean;
|
|
623
|
-
identifier: UserIdentifier;
|
|
624
|
-
suggestions?: string[] | undefined;
|
|
625
|
-
}>;
|
|
623
|
+
get: (username: string) => Promise<UserIdentity>;
|
|
626
624
|
};
|
|
627
625
|
readonly users: {
|
|
628
626
|
getAll: () => Promise<User[]>;
|
|
629
|
-
get: (id: string) => Promise<
|
|
630
|
-
exists: boolean;
|
|
631
|
-
identifier: UserIdentifier;
|
|
632
|
-
suggestions?: string[] | undefined;
|
|
633
|
-
}>;
|
|
627
|
+
get: (id: string) => Promise<User[]>;
|
|
634
628
|
me: () => Promise<User>;
|
|
635
|
-
check: (identifier: string, suggestions?: boolean | undefined) => Promise<
|
|
629
|
+
check: (identifier: string, suggestions?: boolean | undefined) => Promise<{
|
|
636
630
|
exists: boolean;
|
|
637
631
|
identifier: UserIdentifier;
|
|
638
632
|
suggestions?: string[] | undefined;
|
|
@@ -644,4 +638,4 @@ declare class TonightPass {
|
|
|
644
638
|
|
|
645
639
|
declare const isBrowser: boolean;
|
|
646
640
|
|
|
647
|
-
export { type APIRequestOptions, type APIResponse, BCRYPT_HASH, type CareersCategory, type CareersEmploymentType, type CareersEndpoints, type CareersJob, type CareersOffice, Client, type ClientOptions, CreateUserDto, Currency, DEFAULT_API_URL, EMAIL_REGEX, type Endpoint, type Endpoints, type ErroredAPIResponse, type Event, type EventStyle, EventStyleType, type EventTicket, EventTicketCategory, type EventTicketType, EventType, type
|
|
641
|
+
export { type APIRequestOptions, type APIResponse, type AuthEndpoints, BCRYPT_HASH, type CareersCategory, type CareersEmploymentType, type CareersEndpoints, type CareersJob, type CareersOffice, Client, type ClientOptions, CreateUserDto, Currency, DEFAULT_API_URL, EMAIL_REGEX, type Endpoint, type Endpoints, type ErroredAPIResponse, type Event, type EventStyle, EventStyleType, type EventTicket, EventTicketCategory, type EventTicketType, EventType, type Health, type HealthEndpoints, IMAGE_URL_REGEX, Language, type Location$1 as Location, NAME_REGEX, type Order, type OrderItem, OrderStatus, type Organization, type OrganizationIdentity, type OrganizationMember, OrganizationMemberRole, type OrganizationSocialLink, OrganizationSocialType, PASSWORD_REGEX, PHONE_NUMBER_REGEX, type PathsFor, type Profile, type ProfileEndpoints, type ProfileMetadata, type PromoCode, SLUG_REGEX, SignInUserDto, type SuccessfulAPIResponse, TonightPass, TonightPassAPIError, UpdateUserDto, type User, type UserConnection, type UserConnectionClient, type UserConnectionDevice, type UserConnectionOS, type UserEndpoints, type UserIdentifier, type UserIdentity, type UserIdentityGender, type UserPreferences, UserRole, type UserToken, UserTokenType, health, isBrowser, request, sdk, users };
|
package/dist/index.js
CHANGED
|
@@ -3,14 +3,14 @@
|
|
|
3
3
|
require('reflect-metadata');
|
|
4
4
|
var classTransformer = require('class-transformer');
|
|
5
5
|
var classValidator = require('class-validator');
|
|
6
|
-
var
|
|
6
|
+
var V = require('redaxios');
|
|
7
7
|
var pathcat = require('pathcat');
|
|
8
8
|
|
|
9
9
|
function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
|
|
10
10
|
|
|
11
|
-
var
|
|
11
|
+
var V__default = /*#__PURE__*/_interopDefault(V);
|
|
12
12
|
|
|
13
|
-
var j=Object.defineProperty;var F=Object.getOwnPropertyDescriptor;var a=(r,e,s,t)=>{for(var
|
|
13
|
+
var j=Object.defineProperty;var F=Object.getOwnPropertyDescriptor;var a=(r,e,s,t)=>{for(var o=t>1?void 0:t?F(e,s):e,i=r.length-1,d;i>=0;i--)(d=r[i])&&(o=(t?d(e,s,o):d(o))||o);return t&&o&&j(e,s,o),o};var I="https://api.tonightpass.com";var ie=/^[a-z0-9._%+-]+@[a-z0-9.-]+\.[a-z]{2,4}$/,ae=/((?=.*\d)|(?=.*\W+))(?![.\n])(?=.*[A-Z])(?=.*[a-z]).*$/,b=/(^[\p{L}\d'\\.\s\\-]*$)/u,pe=/^[a-z\d]+(?:(\.|-|_)[a-z\d]+)*$/,de=/\$2[abxy]?\$\d{1,2}\$[A-Za-z\d\\./]{53}/,me=/^\s*(?:\+?(\d{1,3}))?([-. (]*(\d{3})[-. )]*)?((\d{3})[-. ]*(\d{2,4})(?:[-.x ]*(\d+))?)\s*$/,ce=/(((http:\/\/www)|(http:\/\/)|(www))[-a-zA-Z0-9@:%_\\+.~#?&//=]+)\.(jpg|jpeg|gif|png|bmp|tiff|tga|svg)/i;var U=class{identifier;password;identity;addresses};var C=class{identifier;password};var h=class{identifier;identity;password};a([classValidator.IsOptional(),classValidator.IsObject(),classValidator.ValidateNested(),classTransformer.Type(()=>f)],h.prototype,"identifier",2),a([classValidator.IsOptional(),classValidator.IsObject(),classValidator.ValidateNested(),classTransformer.Type(()=>m)],h.prototype,"identity",2),a([classValidator.IsOptional(),classValidator.IsString(),classValidator.MinLength(6),classValidator.MaxLength(130)],h.prototype,"password",2);var f=class{email;phoneNumber;username};a([classValidator.IsOptional(),classValidator.IsString(),classValidator.IsEmail()],f.prototype,"email",2),a([classValidator.IsOptional(),classValidator.IsString(),classValidator.IsPhoneNumber()],f.prototype,"phoneNumber",2),a([classValidator.IsOptional(),classValidator.IsString(),classValidator.MinLength(3)],f.prototype,"username",2);var m=class{firstName;lastName;displayName;description;profilePictureUrl;bannerUrl;gender;birthDate};a([classValidator.IsOptional(),classValidator.IsString(),classValidator.Length(2,50),classValidator.Matches(b,{message:"First name must be composed of letters only"})],m.prototype,"firstName",2),a([classValidator.IsOptional(),classValidator.IsString(),classValidator.Length(2,50),classValidator.Matches(b,{message:"Last name must be composed of letters only"})],m.prototype,"lastName",2),a([classValidator.IsOptional(),classValidator.IsString(),classValidator.Length(1,32)],m.prototype,"displayName",2),a([classValidator.IsOptional(),classValidator.IsString(),classValidator.Length(15,500)],m.prototype,"description",2),a([classValidator.IsOptional(),classValidator.IsUrl()],m.prototype,"profilePictureUrl",2),a([classValidator.IsOptional(),classValidator.IsUrl()],m.prototype,"bannerUrl",2),a([classValidator.IsOptional()],m.prototype,"gender",2),a([classValidator.IsOptional(),classValidator.IsDateString()],m.prototype,"birthDate",2);var y=typeof window<"u";var $=V__default.default.create({headers:{"Content-Type":"application/json",Accept:"application/json",...!y&&{"User-Agent":"tonightpass-api-client"}},responseType:"json",transformRequest:[function(r){return JSON.stringify(r)}],withCredentials:y}),k=async(r,e)=>$(r,{...e}).then(t=>t).catch(t=>{throw t.data});var B=(c=>(c.ENTRY="entry",c.PACKAGE="package",c.MEAL="meal",c.DRINK="drink",c.PARKING="parking",c.ACCOMMODATION="accommodation",c.CAMPING="camping",c.LOCKER="locker",c.SHUTTLE="shuttle",c.OTHER="other",c))(B||{});var X=(n=>(n.Clubbing="clubbing",n.Concert="concert",n.Afterwork="afterwork",n.DancingLunch="dancing_lunch",n.Diner="diner",n.Garden="garden",n.AfterBeach="after_beach",n.Festival="festival",n.Spectacle="spectacle",n.Cruise="cruise",n.OutsideAnimation="outside_animation",n.Sport="sport",n.Match="match",n.Seminar="seminar",n.Conference="conference",n.WellnessDay="wellness_day",n.Workshop="workshop",n.TradeFair="trade_fair",n.ConsumerShow="consumer_show",n.Membership="membership",n))(X||{}),W=(i=>(i.Music="music",i.Dress="dress",i.Sport="sport",i.Food="food",i.Art="art",i))(W||{});var K=(d=>(d.Facebook="facebook",d.Twitter="twitter",d.Instagram="instagram",d.Linkedin="linkedin",d.Youtube="youtube",d.Website="website",d))(K||{}),Y=(o=>(o[o.EMPLOYEE=0]="EMPLOYEE",o[o.MANAGER=1]="MANAGER",o[o.ADMINISTRATOR=2]="ADMINISTRATOR",o[o.OWNER=3]="OWNER",o))(Y||{});var Z=(i=>(i.Authentication="authentication",i.OrganizationInvite="organization_invite",i.PasswordRecovery="password_recovery",i.EmailValidation="email_validation",i.PhoneValidation="phone_validation",i))(Z||{});var J=(t=>(t[t.USER=0]="USER",t[t.DEVELOPER=8]="DEVELOPER",t[t.ADMINISTRATOR=10]="ADMINISTRATOR",t))(J||{});var ee=(u=>(u.Created="created",u.Cancelled="cancelled",u.Completed="completed",u.Pending="pending",u.Confirmed="confirmed",u.Declined="declined",u.Refunded="refunded",u.PartiallyRefunded="partially_refunded",u.Expired="expired",u))(ee||{});var te=(t=>(t.EUR="EUR",t.USD="USD",t.GBP="GBP",t))(te||{}),re=(s=>(s.FR="fr",s.EN="en",s))(re||{});var A=class extends Error{constructor(s,t){super(t.message);this.response=s;this.data=t;this.status=s.status;}status},x=class{options;url;constructor(e){this.options=e,this.url=(s,t)=>{let o=this.options.baseURL||I;return pathcat.pathcat(o,s,t)};}setOptions(e){this.options=e;}async get(e,s,t){return this.requester("GET",e,void 0,s,t)}async post(e,s,t,o){return this.requester("POST",e,s,t,o)}async put(e,s,t,o){return this.requester("PUT",e,s,t,o)}async patch(e,s,t,o){return this.requester("PATCH",e,s,t,o)}async delete(e,s,t){return this.requester("DELETE",e,void 0,s,t)}async requester(e,s,t,o={},i={}){let d=this.url(s,o);if(t!==void 0&&e==="GET")throw new Error("Cannot send a GET request with a body");let R=await k(d,{method:e,data:t,...i}),E=R.data;if(!E.success)throw new A(R,E);return E.data}};function P(r){return r}var _=r=>({database:async()=>r.get("/health/database"),http:async()=>r.get("/health/http")});var T=r=>({getAll:async()=>r.get("/users"),get:async e=>r.get("/users",{id:e}),me:async()=>r.get("/users/me"),check:async(e,s)=>r.get("/users/check/:identifier",{identifier:e,suggestions:s}),update:async(e,s)=>r.put("/users/:id",s,{id:e})});var M=r=>({categories:{getAll:async e=>r.get("/careers/categories",e)},employmentTypes:{getAll:async e=>r.get("/careers/employmentTypes",e)},jobs:{getAll:async e=>r.get("/careers/jobs",e),get:async e=>r.get("/careers/jobs/:id",{id:e})},offices:{getAll:async e=>r.get("/careers/offices",e)}});var q=r=>({get:async e=>r.get("/profiles/:username",{username:e})});var Q=class{client;careers;health;profiles;users;constructor(e){this.client=new x(e),this.careers=M(this.client),this.health=_(this.client),this.profiles=q(this.client),this.users=T(this.client);}};
|
|
14
14
|
|
|
15
15
|
exports.BCRYPT_HASH = de;
|
|
16
16
|
exports.Client = x;
|
|
@@ -23,7 +23,7 @@ exports.EventTicketCategory = B;
|
|
|
23
23
|
exports.EventType = X;
|
|
24
24
|
exports.IMAGE_URL_REGEX = ce;
|
|
25
25
|
exports.Language = re;
|
|
26
|
-
exports.NAME_REGEX =
|
|
26
|
+
exports.NAME_REGEX = b;
|
|
27
27
|
exports.OrderStatus = ee;
|
|
28
28
|
exports.OrganizationMemberRole = Y;
|
|
29
29
|
exports.OrganizationSocialType = K;
|
|
@@ -31,14 +31,14 @@ exports.PASSWORD_REGEX = ae;
|
|
|
31
31
|
exports.PHONE_NUMBER_REGEX = me;
|
|
32
32
|
exports.SLUG_REGEX = pe;
|
|
33
33
|
exports.SignInUserDto = C;
|
|
34
|
-
exports.TonightPass =
|
|
34
|
+
exports.TonightPass = Q;
|
|
35
35
|
exports.TonightPassAPIError = A;
|
|
36
|
-
exports.UpdateUserDto =
|
|
36
|
+
exports.UpdateUserDto = h;
|
|
37
37
|
exports.UserRole = J;
|
|
38
38
|
exports.UserTokenType = Z;
|
|
39
39
|
exports.health = _;
|
|
40
40
|
exports.isBrowser = y;
|
|
41
|
-
exports.request =
|
|
41
|
+
exports.request = k;
|
|
42
42
|
exports.sdk = P;
|
|
43
43
|
exports.users = T;
|
|
44
44
|
//# sourceMappingURL=out.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/constants/api.ts","../src/constants/regex.ts","../src/rest/dtos/index.ts","../src/rest/dtos/users/create-user.dto.ts","../src/rest/dtos/users/sign-in-user.dto.ts","../src/rest/dtos/users/update-user.dto.ts","../src/rest/request/request.ts","../src/utils/index.ts","../src/rest/types/event/ticket/index.ts","../src/rest/types/event/index.ts","../src/rest/types/organizations/index.ts","../src/rest/types/token/index.ts","../src/rest/types/users/index.ts","../src/rest/types/order/index.ts","../src/rest/types/index.ts","../src/rest/client.ts","../src/sdk/builder.ts","../src/sdk/health.ts","../src/sdk/users.ts","../src/sdk/careers.ts","../src/sdk/profiles.ts","../src/tonightpass.ts"],"names":["DEFAULT_API_URL","EMAIL_REGEX","PASSWORD_REGEX","NAME_REGEX","SLUG_REGEX","BCRYPT_HASH","PHONE_NUMBER_REGEX","IMAGE_URL_REGEX","CreateUserDto","SignInUserDto","Type","IsDateString","IsEmail","IsObject","IsOptional","IsPhoneNumber","IsString","IsUrl","Length","Matches","MaxLength","MinLength","ValidateNested","UpdateUserDto","__decorateClass","UpdateIdentifierDto","UpdateIdentityDto","axios","isBrowser","instance","data","request","url","options","response","error","EventTicketCategory","EventType","EventStyleType","OrganizationSocialType","OrganizationMemberRole","UserTokenType","UserRole","OrderStatus","Currency","Language","pathcat","TonightPassAPIError","Client","path","params","baseURL","query","body","method","result","sdk","builder","health","client","users","id","identifier","suggestions","careers","profiles","username","TonightPass"],"mappings":"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","sourcesContent":["export const DEFAULT_API_URL = \"https://api.tonightpass.com\";\n","export const EMAIL_REGEX = /^[a-z0-9._%+-]+@[a-z0-9.-]+\\.[a-z]{2,4}$/;\n\n// checks if a password has at least one uppercase letter and a number or special character\nexport const PASSWORD_REGEX =\n /((?=.*\\d)|(?=.*\\W+))(?![.\\n])(?=.*[A-Z])(?=.*[a-z]).*$/;\n\n// checks if a string has only letters, numbers, spaces, apostrophes, dots and dashes\nexport const NAME_REGEX = /(^[\\p{L}\\d'\\\\.\\s\\\\-]*$)/u;\n\n// checks if a string is a valid slug, useful for usernames\nexport const SLUG_REGEX = /^[a-z\\d]+(?:(\\.|-|_)[a-z\\d]+)*$/;\n\n// validates if passwords are valid bcrypt hashes\nexport const BCRYPT_HASH = /\\$2[abxy]?\\$\\d{1,2}\\$[A-Za-z\\d\\\\./]{53}/;\n\nexport const PHONE_NUMBER_REGEX =\n /^\\s*(?:\\+?(\\d{1,3}))?([-. (]*(\\d{3})[-. )]*)?((\\d{3})[-. ]*(\\d{2,4})(?:[-.x ]*(\\d+))?)\\s*$/;\n\nexport const IMAGE_URL_REGEX =\n /(((http:\\/\\/www)|(http:\\/\\/)|(www))[-a-zA-Z0-9@:%_\\\\+.~#?&//=]+)\\.(jpg|jpeg|gif|png|bmp|tiff|tga|svg)/i;\n","import \"reflect-metadata\";\n\nexport * from \"./users\";\n","import { UserIdentifier, UserIdentityGender } from \"../../types\";\n\nexport class CreateUserDto {\n identifier: UserIdentifier;\n password: string;\n identity: CreateUserIdentituDto;\n addresses: Location[];\n}\n\nclass CreateUserIdentituDto {\n firstName: string;\n lastName: string;\n gender: UserIdentityGender;\n profilePictureUrl?: string;\n birthDate: Date;\n}\n","export class SignInUserDto {\n identifier: string;\n password: string;\n}\n","import { Type } from \"class-transformer\";\nimport {\n IsDateString,\n IsEmail,\n IsObject,\n IsOptional,\n IsPhoneNumber,\n IsString,\n IsUrl,\n Length,\n Matches,\n MaxLength,\n MinLength,\n ValidateNested,\n} from \"class-validator\";\n\nimport { NAME_REGEX } from \"../../../constants/regex\";\nimport { UserIdentifier, UserIdentity } from \"../../types\";\n\nexport class UpdateUserDto {\n @IsOptional()\n @IsObject()\n @ValidateNested()\n @Type(() => UpdateIdentifierDto)\n identifier?: UpdateIdentifierDto;\n\n @IsOptional()\n @IsObject()\n @ValidateNested()\n @Type(() => UpdateIdentityDto)\n identity?: UpdateIdentityDto;\n\n @IsOptional()\n @IsString()\n @MinLength(6)\n @MaxLength(130)\n password?: string;\n}\n\nclass UpdateIdentifierDto\n implements\n Partial<Pick<UserIdentifier, \"email\" | \"phoneNumber\" | \"username\">>\n{\n @IsOptional()\n @IsString()\n @IsEmail()\n email?: string;\n\n @IsOptional()\n @IsString()\n @IsPhoneNumber()\n phoneNumber?: string;\n\n @IsOptional()\n @IsString()\n @MinLength(3)\n username?: string;\n}\n\nclass UpdateIdentityDto\n implements\n Partial<\n Pick<\n UserIdentity,\n | \"firstName\"\n | \"lastName\"\n | \"displayName\"\n | \"description\"\n | \"profilePictureUrl\"\n | \"bannerUrl\"\n | \"gender\"\n | \"birthDate\"\n >\n >\n{\n @IsOptional()\n @IsString()\n @Length(2, 50)\n @Matches(NAME_REGEX, {\n message: \"First name must be composed of letters only\",\n })\n firstName?: string;\n\n @IsOptional()\n @IsString()\n @Length(2, 50)\n @Matches(NAME_REGEX, {\n message: \"Last name must be composed of letters only\",\n })\n lastName?: string;\n\n @IsOptional()\n @IsString()\n @Length(1, 32)\n displayName?: string;\n\n @IsOptional()\n @IsString()\n @Length(15, 500)\n description?: string;\n\n @IsOptional()\n @IsUrl()\n profilePictureUrl?: string | undefined;\n\n @IsOptional()\n @IsUrl()\n bannerUrl?: string | undefined;\n\n @IsOptional()\n gender?: string;\n\n @IsOptional()\n @IsDateString()\n birthDate?: Date;\n}\n","import axios, { Options, Response } from \"redaxios\";\n\nimport { isBrowser } from \"../../utils\";\nimport { APIResponse, ErroredAPIResponse } from \"../endpoints\";\n\nconst instance = axios.create({\n headers: {\n \"Content-Type\": \"application/json\",\n Accept: \"application/json\",\n ...(!isBrowser && { \"User-Agent\": \"tonightpass-api-client\" }),\n },\n responseType: \"json\",\n transformRequest: [\n function (data) {\n return JSON.stringify(data);\n },\n ],\n withCredentials: isBrowser,\n});\n\nexport interface APIRequestOptions extends Options {}\n\nexport const request = async <T>(url: string, options?: Options) => {\n const response = instance<APIResponse<T>>(url, { ...options })\n .then((response) => response)\n .catch((error: Response<ErroredAPIResponse>) => {\n throw error.data;\n });\n\n return response;\n};\n","export const isBrowser = typeof window !== \"undefined\";\n","import { Currency } from \"../..\";\n\nexport type EventTicket = {\n id: string;\n name: string;\n description?: string;\n price: number;\n displayPrice: number;\n quantity: number;\n type: EventTicketType;\n category: EventTicketCategory;\n currency: Currency;\n vatRate: number;\n externalId?: string;\n isVisible: boolean;\n isFeesIncluded: boolean;\n startAt: Date;\n endAt: Date;\n updatedAt: Date;\n createdAt: Date;\n};\n\nexport type EventTicketType = \"e-ticket\" | \"other\";\n\nexport enum EventTicketCategory {\n ENTRY = \"entry\",\n PACKAGE = \"package\",\n MEAL = \"meal\",\n DRINK = \"drink\",\n PARKING = \"parking\",\n ACCOMMODATION = \"accommodation\",\n CAMPING = \"camping\",\n LOCKER = \"locker\",\n SHUTTLE = \"shuttle\",\n OTHER = \"other\",\n}\n","import { EventTicket } from \"./ticket\";\nimport { Location } from \"..\";\nimport { Organization } from \"../organizations\";\n\nexport * from \"./ticket\";\n\nexport type Event = {\n title: string;\n description: string;\n slug: string;\n organization: Organization;\n type: EventType;\n public: boolean;\n flyers: string[];\n trailers: string[];\n location: Location;\n tickets: EventTicket[];\n styles: EventStyle[];\n startAt: Date;\n endAt: Date;\n updatedAt: Date;\n createdAt: Date;\n};\n\nexport enum EventType {\n Clubbing = \"clubbing\",\n Concert = \"concert\",\n Afterwork = \"afterwork\",\n DancingLunch = \"dancing_lunch\",\n Diner = \"diner\",\n Garden = \"garden\",\n AfterBeach = \"after_beach\",\n Festival = \"festival\",\n Spectacle = \"spectacle\",\n Cruise = \"cruise\",\n OutsideAnimation = \"outside_animation\",\n Sport = \"sport\",\n Match = \"match\",\n Seminar = \"seminar\",\n Conference = \"conference\",\n WellnessDay = \"wellness_day\",\n Workshop = \"workshop\",\n TradeFair = \"trade_fair\",\n ConsumerShow = \"consumer_show\",\n Membership = \"membership\",\n}\n\nexport type EventStyle = {\n type: EventStyleType;\n emoji: string;\n name: string;\n};\n\nexport enum EventStyleType {\n Music = \"music\",\n Dress = \"dress\",\n Sport = \"sport\",\n Food = \"food\",\n Art = \"art\",\n}\n","import { Location, Profile, ProfileMetadata } from \"..\";\nimport { Event } from \"../event\";\nimport { EventTicket } from \"../event/ticket\";\nimport { User } from \"../users\";\n\nexport type Organization = {\n id: string;\n slug: string;\n identity: OrganizationIdentity;\n members: OrganizationMember[];\n location?: Location;\n events: Event[];\n savedTickets: EventTicket[];\n verified: boolean;\n updatedAt: Date;\n createdAt: Date;\n};\n\nexport type OrganizationIdentity = Profile & {\n socialLinks: OrganizationSocialLink[];\n\n metadata: ProfileMetadata & {\n eventsCount: number;\n viewsCount: number;\n membersCount: number;\n };\n};\n\nexport type OrganizationSocialLink = {\n type: OrganizationSocialType;\n url: string;\n};\n\nexport enum OrganizationSocialType {\n Facebook = \"facebook\",\n Twitter = \"twitter\",\n Instagram = \"instagram\",\n Linkedin = \"linkedin\",\n Youtube = \"youtube\",\n Website = \"website\",\n}\n\nexport type OrganizationMember = {\n user: User;\n role: OrganizationMemberRole;\n createdAt: Date;\n};\n\nexport enum OrganizationMemberRole {\n EMPLOYEE = 0,\n MANAGER = 1,\n ADMINISTRATOR = 2,\n OWNER = 3,\n}\n","export type UserToken = {\n id: string;\n type: UserTokenType;\n value: string;\n createdAt: Date;\n expiresAt: Date;\n};\n\nexport enum UserTokenType {\n Authentication = \"authentication\",\n OrganizationInvite = \"organization_invite\",\n PasswordRecovery = \"password_recovery\",\n EmailValidation = \"email_validation\",\n PhoneValidation = \"phone_validation\",\n}\n","import { Currency, Language, Location, Profile, ProfileMetadata } from \"..\";\nimport { UpdateUserDto } from \"../../dtos\";\nimport { Endpoint } from \"../../endpoints\";\n\nexport type User = {\n id: string;\n identifier: UserIdentifier;\n password: string;\n identity: UserIdentity;\n role: UserRole;\n addresses: Location[];\n preferences: UserPreferences;\n connections: UserConnection[];\n verified: boolean;\n updatedAt: Date;\n createdAt: Date;\n};\n\nexport type UserIdentifier = {\n email?: string;\n phoneNumber?: string;\n username: string;\n\n [key: string]: string | undefined;\n};\n\nexport type UserIdentity = Profile & {\n firstName: string;\n lastName: string;\n fullName: string;\n gender: UserIdentityGender;\n birthDate: Date;\n\n metadata: ProfileMetadata & {\n followingCount: number;\n hasPassPlus: boolean;\n idValid: boolean;\n };\n};\n\nexport enum UserRole {\n USER = 0,\n DEVELOPER = 8,\n ADMINISTRATOR = 10,\n}\n\nexport type UserIdentityGender =\n | \"male\"\n | \"female\"\n | \"non-binary\"\n | \"gender-fluid\"\n | \"neutral\"\n | \"other\"\n | string;\n\nexport type UserPreferences = {\n language: Language;\n currency: Currency;\n notifications: {\n email: {\n newsletter: boolean;\n message: boolean;\n };\n push: {\n message: boolean;\n };\n };\n};\n\nexport type UserConnection = {\n ip: string;\n os: UserConnectionOS;\n device: UserConnectionDevice;\n client: UserConnectionClient;\n updatedAt: Date;\n createdAt: Date;\n};\n\nexport type UserConnectionOS = {\n name: string;\n version: string;\n};\n\nexport type UserConnectionDevice = {\n type: string;\n brand: string;\n};\n\nexport type UserConnectionClient = {\n name: string;\n version: string;\n};\n\nexport type UserEndpoints =\n | Endpoint<\"GET\", \"/users\", User[]>\n | Endpoint<\"GET\", \"/users/:id\", User, { id: string }>\n | Endpoint<\"GET\", \"/users/me\", User>\n | Endpoint<\n \"GET\",\n \"/users/check/:identifier\",\n {\n exists: boolean;\n identifier: UserIdentifier;\n suggestions?: string[];\n },\n { identifier: boolean; suggestions?: boolean }\n >\n | Endpoint<\"PUT\", \"/users/:id\", User, UpdateUserDto>;\n","import { Currency } from \"..\";\nimport { Event, EventTicket } from \"../event\";\nimport { User } from \"../users\";\n\nexport enum OrderStatus {\n Created = \"created\",\n Cancelled = \"cancelled\",\n Completed = \"completed\",\n Pending = \"pending\",\n Confirmed = \"confirmed\",\n Declined = \"declined\",\n Refunded = \"refunded\",\n PartiallyRefunded = \"partially_refunded\",\n Expired = \"expired\",\n}\n\nexport type OrderItem = {\n id: string;\n ticket: EventTicket;\n isUsed: boolean;\n updatedAt: Date;\n createdAt: Date;\n};\n\nexport type Order = {\n id: string;\n owner: User;\n members: User[];\n status: OrderStatus;\n event: Event;\n items: OrderItem[];\n promoCode?: PromoCode;\n total: number;\n currency: Currency;\n createdAt: Date;\n};\n\nexport type PromoCode = {\n id: string;\n code: string;\n used: number;\n discount: number;\n isActive: boolean;\n expirationAt: Date;\n createdAt: Date;\n};\n","export * from \"./careers\";\nexport * from \"./event\";\nexport * from \"./health\";\nexport * from \"./organizations\";\nexport * from \"./token\";\nexport * from \"./users\";\nexport * from \"./order\";\nexport * from \"./profiles\";\n\nexport type Location = {\n name?: string;\n address: string;\n zipCode: string;\n city: string;\n country: string;\n geometry?: {\n latitude: number;\n longitude: number;\n };\n};\n\n// Currency\nexport enum Currency {\n EUR = \"EUR\",\n USD = \"USD\",\n GBP = \"GBP\",\n}\n\n// I18n\nexport enum Language {\n FR = \"fr\",\n EN = \"en\",\n}\n","import { ParamValue, pathcat } from \"pathcat\";\nimport { Options, Response } from \"redaxios\";\n\nimport { APIResponse, Endpoints, ErroredAPIResponse } from \"./endpoints\";\nimport { APIRequestOptions, request } from \"./request\";\nimport { DEFAULT_API_URL } from \"../constants\";\n\nexport type ExtractRouteParams<T extends string> = string extends T\n ? Record<string, string | number | boolean | undefined>\n : T extends `${string}:${infer Param}/${infer Rest}`\n ? {\n [k in Param | keyof ExtractRouteParams<Rest>]:\n | string\n | number\n | boolean;\n }\n : T extends `${string}:${infer Param}`\n ? { [k in Param]: string | number | boolean }\n : object;\n\nexport type ExtractEndpoint<\n Method extends string,\n Path extends string,\n> = Extract<Endpoints, { path: Path; method: Method }>;\n\nexport type PathsFor<M extends Options[\"method\"]> = Extract<\n Endpoints,\n { method: M }\n>[\"path\"];\n\nexport type Query<Path extends string> = ExtractRouteParams<Path> &\n Record<string, string | number | boolean | undefined>;\n\nexport class TonightPassAPIError<T> extends Error {\n public readonly status: number;\n\n constructor(\n public readonly response: Response<APIResponse<T>>,\n public readonly data: ErroredAPIResponse,\n ) {\n super(data.message);\n\n this.status = response.status;\n }\n}\n\nexport interface ClientOptions {\n readonly baseURL: string;\n}\n\nexport class Client {\n private options;\n public readonly url;\n\n constructor(options: ClientOptions) {\n this.options = options;\n this.url = (path: string, params: Record<string, ParamValue>) => {\n const baseURL = this.options.baseURL || DEFAULT_API_URL;\n return pathcat(baseURL, path, params);\n };\n }\n\n setOptions(options: ClientOptions) {\n this.options = options;\n }\n\n async get<Path extends PathsFor<\"GET\">>(\n path: Path,\n query?: Query<Path>,\n options?: APIRequestOptions,\n ) {\n return this.requester<\n Extract<Endpoints, { path: Path; method: \"GET\" }>[\"res\"]\n >(\"GET\", path, undefined, query, options);\n }\n\n async post<Path extends Extract<Endpoints, { method: \"POST\" }>[\"path\"]>(\n path: Path,\n body: Extract<Endpoints, { path: Path; method: \"POST\" }>[\"body\"],\n query?: Query<Path>,\n options?: APIRequestOptions,\n ) {\n return this.requester<\n Extract<Endpoints, { path: Path; method: \"POST\" }>[\"res\"]\n >(\"POST\", path, body, query, options);\n }\n\n async put<Path extends Extract<Endpoints, { method: \"PUT\" }>[\"path\"]>(\n path: Path,\n body: Extract<Endpoints, { path: Path; method: \"PUT\" }>[\"body\"],\n query?: Query<Path>,\n options?: APIRequestOptions,\n ) {\n return this.requester<\n Extract<Endpoints, { path: Path; method: \"PUT\" }>[\"res\"]\n >(\"PUT\", path, body, query, options);\n }\n\n async patch<Path extends Extract<Endpoints, { method: \"PATCH\" }>[\"path\"]>(\n path: Path,\n body: Extract<Endpoints, { path: Path; method: \"PATCH\" }>[\"body\"],\n query?: Query<Path>,\n options?: APIRequestOptions,\n ) {\n return this.requester<\n Extract<Endpoints, { path: Path; method: \"PATCH\" }>[\"res\"]\n >(\"PATCH\", path, body, query, options);\n }\n\n async delete<Path extends Extract<Endpoints, { method: \"DELETE\" }>[\"path\"]>(\n path: Path,\n query?: Query<Path>,\n options?: APIRequestOptions,\n ) {\n return this.requester<\n Extract<Endpoints, { path: Path; method: \"DELETE\" }>[\"res\"]\n >(\"DELETE\", path, undefined, query, options);\n }\n\n private async requester<T>(\n method: Options[\"method\"],\n path: string,\n body: unknown,\n query: Record<string, string | number | boolean | undefined> = {},\n options: APIRequestOptions = {},\n ) {\n const url = this.url(path, query);\n\n if (body !== undefined) {\n if (method === \"GET\") {\n throw new Error(\"Cannot send a GET request with a body\");\n }\n }\n\n const response: Response<APIResponse<T>> = await request<T>(url, {\n method,\n data: body,\n ...options,\n });\n\n const result = response.data;\n\n if (!result.success) {\n throw new TonightPassAPIError<T>(response, result);\n }\n\n return result.data;\n }\n}\n","import { Client } from \"../rest\";\n\nexport function sdk<T>(builder: (client: Client) => T) {\n return builder;\n}\n","import { sdk } from \"./builder\";\n\nexport const health = sdk((client) => ({\n database: async () => client.get(\"/health/database\"),\n http: async () => client.get(\"/health/http\"),\n}));\n","import { sdk } from \"./builder\";\nimport { UpdateUserDto } from \"../rest\";\n\nexport const users = sdk((client) => ({\n getAll: async () => client.get(\"/users\"),\n get: async (id: string) => client.get(\"/users\", { id }),\n me: async () => client.get(\"/users/me\"),\n check: async (identifier: string, suggestions?: boolean) =>\n client.get(\"/users/check/:identifier\", { identifier, suggestions }),\n update: async (id: string, data: UpdateUserDto) =>\n client.put(\"/users/:id\", data, { id }),\n}));\n","import { sdk } from \"./builder\";\nimport { Query } from \"../rest\";\n\nexport const careers = sdk((client) => ({\n categories: {\n getAll: async (query?: Query<\"/careers/categories\">) =>\n client.get(\"/careers/categories\", query),\n },\n employmentTypes: {\n getAll: async (query?: Query<\"/careers/employmentTypes\">) =>\n client.get(\"/careers/employmentTypes\", query),\n },\n jobs: {\n getAll: async (query?: Query<\"/careers/jobs\">) =>\n client.get(\"/careers/jobs\", query),\n get: async (id: number) => client.get(\"/careers/jobs/:id\", { id }),\n },\n offices: {\n getAll: async (query?: Query<\"/careers/offices\">) =>\n client.get(\"/careers/offices\", query),\n },\n}));\n","import { sdk } from \"./builder\";\n\nexport const profiles = sdk((client) => ({\n get: async (username: string) =>\n client.get(\"/profiles/:username\", { username }),\n}));\n","import { Client, ClientOptions } from \"./rest\";\nimport { health, users } from \"./sdk\";\nimport { careers } from \"./sdk/careers\";\nimport { profiles } from \"./sdk/profiles\";\n\nexport class TonightPass {\n public readonly client: Client;\n\n public readonly careers;\n public readonly health;\n public readonly profiles;\n public readonly users;\n\n constructor(options: ClientOptions) {\n this.client = new Client(options);\n\n this.careers = careers(this.client);\n this.health = health(this.client);\n this.profiles = profiles(this.client);\n this.users = users(this.client);\n }\n}\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/constants/api.ts","../src/constants/regex.ts","../src/rest/dtos/index.ts","../src/rest/dtos/users/create-user.dto.ts","../src/rest/dtos/users/sign-in-user.dto.ts","../src/rest/dtos/users/update-user.dto.ts","../src/rest/request/request.ts","../src/utils/index.ts","../src/rest/types/event/ticket/index.ts","../src/rest/types/event/index.ts","../src/rest/types/organizations/index.ts","../src/rest/types/token/index.ts","../src/rest/types/users/index.ts","../src/rest/types/order/index.ts","../src/rest/types/index.ts","../src/rest/client.ts","../src/sdk/builder.ts","../src/sdk/health.ts","../src/sdk/users.ts","../src/sdk/careers.ts","../src/sdk/profiles.ts","../src/tonightpass.ts"],"names":["DEFAULT_API_URL","EMAIL_REGEX","PASSWORD_REGEX","NAME_REGEX","SLUG_REGEX","BCRYPT_HASH","PHONE_NUMBER_REGEX","IMAGE_URL_REGEX","CreateUserDto","SignInUserDto","Type","IsDateString","IsEmail","IsObject","IsOptional","IsPhoneNumber","IsString","IsUrl","Length","Matches","MaxLength","MinLength","ValidateNested","UpdateUserDto","__decorateClass","UpdateIdentifierDto","UpdateIdentityDto","axios","isBrowser","instance","data","request","url","options","response","error","EventTicketCategory","EventType","EventStyleType","OrganizationSocialType","OrganizationMemberRole","UserTokenType","UserRole","OrderStatus","Currency","Language","pathcat","TonightPassAPIError","Client","path","params","baseURL","query","body","method","result","sdk","builder","health","client","users","id","identifier","suggestions","careers","profiles","username","TonightPass"],"mappings":"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","sourcesContent":["export const DEFAULT_API_URL = \"https://api.tonightpass.com\";\n","export const EMAIL_REGEX = /^[a-z0-9._%+-]+@[a-z0-9.-]+\\.[a-z]{2,4}$/;\n\n// checks if a password has at least one uppercase letter and a number or special character\nexport const PASSWORD_REGEX =\n /((?=.*\\d)|(?=.*\\W+))(?![.\\n])(?=.*[A-Z])(?=.*[a-z]).*$/;\n\n// checks if a string has only letters, numbers, spaces, apostrophes, dots and dashes\nexport const NAME_REGEX = /(^[\\p{L}\\d'\\\\.\\s\\\\-]*$)/u;\n\n// checks if a string is a valid slug, useful for usernames\nexport const SLUG_REGEX = /^[a-z\\d]+(?:(\\.|-|_)[a-z\\d]+)*$/;\n\n// validates if passwords are valid bcrypt hashes\nexport const BCRYPT_HASH = /\\$2[abxy]?\\$\\d{1,2}\\$[A-Za-z\\d\\\\./]{53}/;\n\nexport const PHONE_NUMBER_REGEX =\n /^\\s*(?:\\+?(\\d{1,3}))?([-. (]*(\\d{3})[-. )]*)?((\\d{3})[-. ]*(\\d{2,4})(?:[-.x ]*(\\d+))?)\\s*$/;\n\nexport const IMAGE_URL_REGEX =\n /(((http:\\/\\/www)|(http:\\/\\/)|(www))[-a-zA-Z0-9@:%_\\\\+.~#?&//=]+)\\.(jpg|jpeg|gif|png|bmp|tiff|tga|svg)/i;\n","import \"reflect-metadata\";\n\nexport * from \"./users\";\n","import { UserIdentifier, UserIdentityGender } from \"../../types\";\n\nexport class CreateUserDto {\n identifier: UserIdentifier;\n password: string;\n identity: CreateUserIdentituDto;\n addresses: Location[];\n}\n\nclass CreateUserIdentituDto {\n firstName: string;\n lastName: string;\n gender: UserIdentityGender;\n profilePictureUrl?: string;\n birthDate: Date;\n}\n","export class SignInUserDto {\n identifier: string;\n password: string;\n}\n","import { Type } from \"class-transformer\";\nimport {\n IsDateString,\n IsEmail,\n IsObject,\n IsOptional,\n IsPhoneNumber,\n IsString,\n IsUrl,\n Length,\n Matches,\n MaxLength,\n MinLength,\n ValidateNested,\n} from \"class-validator\";\n\nimport { NAME_REGEX } from \"../../../constants/regex\";\nimport { UserIdentifier, UserIdentity } from \"../../types\";\n\nexport class UpdateUserDto {\n @IsOptional()\n @IsObject()\n @ValidateNested()\n @Type(() => UpdateIdentifierDto)\n identifier?: UpdateIdentifierDto;\n\n @IsOptional()\n @IsObject()\n @ValidateNested()\n @Type(() => UpdateIdentityDto)\n identity?: UpdateIdentityDto;\n\n @IsOptional()\n @IsString()\n @MinLength(6)\n @MaxLength(130)\n password?: string;\n}\n\nclass UpdateIdentifierDto\n implements\n Partial<Pick<UserIdentifier, \"email\" | \"phoneNumber\" | \"username\">>\n{\n @IsOptional()\n @IsString()\n @IsEmail()\n email?: string;\n\n @IsOptional()\n @IsString()\n @IsPhoneNumber()\n phoneNumber?: string;\n\n @IsOptional()\n @IsString()\n @MinLength(3)\n username?: string;\n}\n\nclass UpdateIdentityDto\n implements\n Partial<\n Pick<\n UserIdentity,\n | \"firstName\"\n | \"lastName\"\n | \"displayName\"\n | \"description\"\n | \"profilePictureUrl\"\n | \"bannerUrl\"\n | \"gender\"\n | \"birthDate\"\n >\n >\n{\n @IsOptional()\n @IsString()\n @Length(2, 50)\n @Matches(NAME_REGEX, {\n message: \"First name must be composed of letters only\",\n })\n firstName?: string;\n\n @IsOptional()\n @IsString()\n @Length(2, 50)\n @Matches(NAME_REGEX, {\n message: \"Last name must be composed of letters only\",\n })\n lastName?: string;\n\n @IsOptional()\n @IsString()\n @Length(1, 32)\n displayName?: string;\n\n @IsOptional()\n @IsString()\n @Length(15, 500)\n description?: string;\n\n @IsOptional()\n @IsUrl()\n profilePictureUrl?: string | undefined;\n\n @IsOptional()\n @IsUrl()\n bannerUrl?: string | undefined;\n\n @IsOptional()\n gender?: string;\n\n @IsOptional()\n @IsDateString()\n birthDate?: Date;\n}\n","import axios, { Options, Response } from \"redaxios\";\n\nimport { isBrowser } from \"../../utils\";\nimport { APIResponse, ErroredAPIResponse } from \"../endpoints\";\n\nconst instance = axios.create({\n headers: {\n \"Content-Type\": \"application/json\",\n Accept: \"application/json\",\n ...(!isBrowser && { \"User-Agent\": \"tonightpass-api-client\" }),\n },\n responseType: \"json\",\n transformRequest: [\n function (data) {\n return JSON.stringify(data);\n },\n ],\n withCredentials: isBrowser,\n});\n\nexport interface APIRequestOptions extends Options {}\n\nexport const request = async <T>(url: string, options?: Options) => {\n const response = instance<APIResponse<T>>(url, { ...options })\n .then((response) => response)\n .catch((error: Response<ErroredAPIResponse>) => {\n throw error.data;\n });\n\n return response;\n};\n","export const isBrowser = typeof window !== \"undefined\";\n","import { Currency } from \"../..\";\n\nexport type EventTicket = {\n id: string;\n name: string;\n description?: string;\n price: number;\n displayPrice: number;\n quantity: number;\n type: EventTicketType;\n category: EventTicketCategory;\n currency: Currency;\n vatRate: number;\n externalId?: string;\n isVisible: boolean;\n isFeesIncluded: boolean;\n startAt: Date;\n endAt: Date;\n updatedAt: Date;\n createdAt: Date;\n};\n\nexport type EventTicketType = \"e-ticket\" | \"other\";\n\nexport enum EventTicketCategory {\n ENTRY = \"entry\",\n PACKAGE = \"package\",\n MEAL = \"meal\",\n DRINK = \"drink\",\n PARKING = \"parking\",\n ACCOMMODATION = \"accommodation\",\n CAMPING = \"camping\",\n LOCKER = \"locker\",\n SHUTTLE = \"shuttle\",\n OTHER = \"other\",\n}\n","import { EventTicket } from \"./ticket\";\nimport { Location } from \"..\";\nimport { Organization } from \"../organizations\";\n\nexport * from \"./ticket\";\n\nexport type Event = {\n title: string;\n description: string;\n slug: string;\n organization: Organization;\n type: EventType;\n public: boolean;\n flyers: string[];\n trailers: string[];\n location: Location;\n tickets: EventTicket[];\n styles: EventStyle[];\n startAt: Date;\n endAt: Date;\n updatedAt: Date;\n createdAt: Date;\n};\n\nexport enum EventType {\n Clubbing = \"clubbing\",\n Concert = \"concert\",\n Afterwork = \"afterwork\",\n DancingLunch = \"dancing_lunch\",\n Diner = \"diner\",\n Garden = \"garden\",\n AfterBeach = \"after_beach\",\n Festival = \"festival\",\n Spectacle = \"spectacle\",\n Cruise = \"cruise\",\n OutsideAnimation = \"outside_animation\",\n Sport = \"sport\",\n Match = \"match\",\n Seminar = \"seminar\",\n Conference = \"conference\",\n WellnessDay = \"wellness_day\",\n Workshop = \"workshop\",\n TradeFair = \"trade_fair\",\n ConsumerShow = \"consumer_show\",\n Membership = \"membership\",\n}\n\nexport type EventStyle = {\n type: EventStyleType;\n emoji: string;\n name: string;\n};\n\nexport enum EventStyleType {\n Music = \"music\",\n Dress = \"dress\",\n Sport = \"sport\",\n Food = \"food\",\n Art = \"art\",\n}\n","import { Location, Profile, ProfileMetadata } from \"..\";\nimport { Event } from \"../event\";\nimport { EventTicket } from \"../event/ticket\";\nimport { User } from \"../users\";\n\nexport type Organization = {\n id: string;\n slug: string;\n identity: OrganizationIdentity;\n members: OrganizationMember[];\n location?: Location;\n events: Event[];\n savedTickets: EventTicket[];\n verified: boolean;\n updatedAt: Date;\n createdAt: Date;\n};\n\nexport type OrganizationIdentity = Profile & {\n socialLinks: OrganizationSocialLink[];\n\n metadata: ProfileMetadata & {\n eventsCount: number;\n viewsCount: number;\n membersCount: number;\n };\n};\n\nexport type OrganizationSocialLink = {\n type: OrganizationSocialType;\n url: string;\n};\n\nexport enum OrganizationSocialType {\n Facebook = \"facebook\",\n Twitter = \"twitter\",\n Instagram = \"instagram\",\n Linkedin = \"linkedin\",\n Youtube = \"youtube\",\n Website = \"website\",\n}\n\nexport type OrganizationMember = {\n user: User;\n role: OrganizationMemberRole;\n createdAt: Date;\n};\n\nexport enum OrganizationMemberRole {\n EMPLOYEE = 0,\n MANAGER = 1,\n ADMINISTRATOR = 2,\n OWNER = 3,\n}\n","export type UserToken = {\n id: string;\n type: UserTokenType;\n value: string;\n createdAt: Date;\n expiresAt: Date;\n};\n\nexport enum UserTokenType {\n Authentication = \"authentication\",\n OrganizationInvite = \"organization_invite\",\n PasswordRecovery = \"password_recovery\",\n EmailValidation = \"email_validation\",\n PhoneValidation = \"phone_validation\",\n}\n","import { Currency, Language, Location, Profile, ProfileMetadata } from \"..\";\nimport { UpdateUserDto } from \"../../dtos\";\nimport { Endpoint } from \"../../endpoints\";\n\nexport type User = {\n id: string;\n identifier: UserIdentifier;\n password: string;\n identity: UserIdentity;\n role: UserRole;\n addresses: Location[];\n preferences: UserPreferences;\n connections: UserConnection[];\n verified: boolean;\n updatedAt: Date;\n createdAt: Date;\n};\n\nexport type UserIdentifier = {\n email?: string;\n phoneNumber?: string;\n username: string;\n\n [key: string]: string | undefined;\n};\n\nexport type UserIdentity = Profile & {\n firstName: string;\n lastName: string;\n fullName: string;\n gender: UserIdentityGender;\n birthDate: Date;\n\n metadata: ProfileMetadata & {\n followingCount: number;\n hasPassPlus: boolean;\n idValid: boolean;\n };\n};\n\nexport enum UserRole {\n USER = 0,\n DEVELOPER = 8,\n ADMINISTRATOR = 10,\n}\n\nexport type UserIdentityGender =\n | \"male\"\n | \"female\"\n | \"non-binary\"\n | \"gender-fluid\"\n | \"neutral\"\n | \"other\"\n | string;\n\nexport type UserPreferences = {\n language: Language;\n currency: Currency;\n notifications: {\n email: {\n newsletter: boolean;\n message: boolean;\n };\n push: {\n message: boolean;\n };\n };\n};\n\nexport type UserConnection = {\n ip: string;\n os: UserConnectionOS;\n device: UserConnectionDevice;\n client: UserConnectionClient;\n updatedAt: Date;\n createdAt: Date;\n};\n\nexport type UserConnectionOS = {\n name: string;\n version: string;\n};\n\nexport type UserConnectionDevice = {\n type: string;\n brand: string;\n};\n\nexport type UserConnectionClient = {\n name: string;\n version: string;\n};\n\nexport type UserEndpoints =\n | Endpoint<\"GET\", \"/users\", User[]>\n | Endpoint<\"GET\", \"/users/:id\", User, { id: string }>\n | Endpoint<\"GET\", \"/users/me\", User>\n | Endpoint<\n \"GET\",\n \"/users/check/:identifier\",\n {\n exists: boolean;\n identifier: UserIdentifier;\n suggestions?: string[];\n },\n { identifier: boolean; suggestions?: boolean }\n >\n | Endpoint<\"PUT\", \"/users/:id\", User, UpdateUserDto>;\n","import { Currency } from \"..\";\nimport { Event, EventTicket } from \"../event\";\nimport { User } from \"../users\";\n\nexport enum OrderStatus {\n Created = \"created\",\n Cancelled = \"cancelled\",\n Completed = \"completed\",\n Pending = \"pending\",\n Confirmed = \"confirmed\",\n Declined = \"declined\",\n Refunded = \"refunded\",\n PartiallyRefunded = \"partially_refunded\",\n Expired = \"expired\",\n}\n\nexport type OrderItem = {\n id: string;\n ticket: EventTicket;\n isUsed: boolean;\n updatedAt: Date;\n createdAt: Date;\n};\n\nexport type Order = {\n id: string;\n owner: User;\n members: User[];\n status: OrderStatus;\n event: Event;\n items: OrderItem[];\n promoCode?: PromoCode;\n total: number;\n currency: Currency;\n createdAt: Date;\n};\n\nexport type PromoCode = {\n id: string;\n code: string;\n used: number;\n discount: number;\n isActive: boolean;\n expirationAt: Date;\n createdAt: Date;\n};\n","export * from \"./auth\";\nexport * from \"./careers\";\nexport * from \"./event\";\nexport * from \"./health\";\nexport * from \"./organizations\";\nexport * from \"./token\";\nexport * from \"./users\";\nexport * from \"./order\";\nexport * from \"./profiles\";\n\nexport type Location = {\n name?: string;\n address: string;\n zipCode: string;\n city: string;\n country: string;\n geometry?: {\n latitude: number;\n longitude: number;\n };\n};\n\n// Currency\nexport enum Currency {\n EUR = \"EUR\",\n USD = \"USD\",\n GBP = \"GBP\",\n}\n\n// I18n\nexport enum Language {\n FR = \"fr\",\n EN = \"en\",\n}\n","import { ParamValue, Query, pathcat } from \"pathcat\";\nimport { Options, Response } from \"redaxios\";\n\nimport { APIResponse, Endpoints, ErroredAPIResponse } from \"./endpoints\";\nimport { APIRequestOptions, request } from \"./request\";\nimport { DEFAULT_API_URL } from \"../constants\";\n\nexport type PathsFor<M extends Options[\"method\"]> = Extract<\n Endpoints,\n { method: M }\n>[\"path\"];\n\nexport class TonightPassAPIError<T> extends Error {\n public readonly status: number;\n\n constructor(\n public readonly response: Response<APIResponse<T>>,\n public readonly data: ErroredAPIResponse,\n ) {\n super(data.message);\n\n this.status = response.status;\n }\n}\n\nexport interface ClientOptions {\n readonly baseURL: string;\n}\n\nexport class Client {\n private options;\n public readonly url;\n\n constructor(options: ClientOptions) {\n this.options = options;\n this.url = (path: string, params: Record<string, ParamValue>) => {\n const baseURL = this.options.baseURL || DEFAULT_API_URL;\n return pathcat(baseURL, path, params);\n };\n }\n\n setOptions(options: ClientOptions) {\n this.options = options;\n }\n\n async get<Path extends PathsFor<\"GET\">>(\n path: Path,\n query?: Query<Path>,\n options?: APIRequestOptions,\n ) {\n return this.requester<\n Extract<Endpoints, { path: Path; method: \"GET\" }>[\"res\"]\n >(\"GET\", path, undefined, query, options);\n }\n\n async post<Path extends Extract<Endpoints, { method: \"POST\" }>[\"path\"]>(\n path: Path,\n body: Extract<Endpoints, { path: Path; method: \"POST\" }>[\"body\"],\n query?: Query<Path>,\n options?: APIRequestOptions,\n ) {\n return this.requester<\n Extract<Endpoints, { path: Path; method: \"POST\" }>[\"res\"]\n >(\"POST\", path, body, query, options);\n }\n\n async put<Path extends Extract<Endpoints, { method: \"PUT\" }>[\"path\"]>(\n path: Path,\n body: Extract<Endpoints, { path: Path; method: \"PUT\" }>[\"body\"],\n query?: Query<Path>,\n options?: APIRequestOptions,\n ) {\n return this.requester<\n Extract<Endpoints, { path: Path; method: \"PUT\" }>[\"res\"]\n >(\"PUT\", path, body, query, options);\n }\n\n async patch<Path extends Extract<Endpoints, { method: \"PATCH\" }>[\"path\"]>(\n path: Path,\n body: Extract<Endpoints, { path: Path; method: \"PATCH\" }>[\"body\"],\n query?: Query<Path>,\n options?: APIRequestOptions,\n ) {\n return this.requester<\n Extract<Endpoints, { path: Path; method: \"PATCH\" }>[\"res\"]\n >(\"PATCH\", path, body, query, options);\n }\n\n async delete<Path extends Extract<Endpoints, { method: \"DELETE\" }>[\"path\"]>(\n path: Path,\n query?: Query<Path>,\n options?: APIRequestOptions,\n ) {\n return this.requester<\n Extract<Endpoints, { path: Path; method: \"DELETE\" }>[\"res\"]\n >(\"DELETE\", path, undefined, query, options);\n }\n\n private async requester<T>(\n method: Options[\"method\"],\n path: string,\n body: unknown,\n query: Query<string> = {},\n options: APIRequestOptions = {},\n ) {\n const url = this.url(path, query);\n\n if (body !== undefined) {\n if (method === \"GET\") {\n throw new Error(\"Cannot send a GET request with a body\");\n }\n }\n\n const response: Response<APIResponse<T>> = await request<T>(url, {\n method,\n data: body,\n ...options,\n });\n\n const result = response.data;\n\n if (!result.success) {\n throw new TonightPassAPIError<T>(response, result);\n }\n\n return result.data;\n }\n}\n","import { Client } from \"../rest\";\n\nexport function sdk<T>(builder: (client: Client) => T) {\n return builder;\n}\n","import { sdk } from \"./builder\";\n\nexport const health = sdk((client) => ({\n database: async () => client.get(\"/health/database\"),\n http: async () => client.get(\"/health/http\"),\n}));\n","import { sdk } from \"./builder\";\nimport { UpdateUserDto } from \"../rest\";\n\nexport const users = sdk((client) => ({\n getAll: async () => client.get(\"/users\"),\n get: async (id: string) => client.get(\"/users\", { id }),\n me: async () => client.get(\"/users/me\"),\n check: async (identifier: string, suggestions?: boolean) =>\n client.get(\"/users/check/:identifier\", { identifier, suggestions }),\n update: async (id: string, data: UpdateUserDto) =>\n client.put(\"/users/:id\", data, { id }),\n}));\n","import { Query } from \"pathcat\";\n\nimport { sdk } from \"./builder\";\n\nexport const careers = sdk((client) => ({\n categories: {\n getAll: async (query?: Query<\"/careers/categories\">) =>\n client.get(\"/careers/categories\", query),\n },\n employmentTypes: {\n getAll: async (query?: Query<\"/careers/employmentTypes\">) =>\n client.get(\"/careers/employmentTypes\", query),\n },\n jobs: {\n getAll: async (query?: Query<\"/careers/jobs\">) =>\n client.get(\"/careers/jobs\", query),\n get: async (id: number) => client.get(\"/careers/jobs/:id\", { id }),\n },\n offices: {\n getAll: async (query?: Query<\"/careers/offices\">) =>\n client.get(\"/careers/offices\", query),\n },\n}));\n","import { sdk } from \"./builder\";\n\nexport const profiles = sdk((client) => ({\n get: async (username: string) =>\n client.get(\"/profiles/:username\", { username }),\n}));\n","import { Client, ClientOptions } from \"./rest\";\nimport { careers } from \"./sdk/careers\";\nimport { health } from \"./sdk/health\";\nimport { profiles } from \"./sdk/profiles\";\nimport { users } from \"./sdk/users\";\n\nexport class TonightPass {\n public readonly client: Client;\n\n public readonly careers;\n public readonly health;\n public readonly profiles;\n public readonly users;\n\n constructor(options: ClientOptions) {\n this.client = new Client(options);\n\n this.careers = careers(this.client);\n this.health = health(this.client);\n this.profiles = profiles(this.client);\n this.users = users(this.client);\n }\n}\n"]}
|
package/dist/index.mjs
CHANGED
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import 'reflect-metadata';
|
|
2
2
|
import { Type } from 'class-transformer';
|
|
3
3
|
import { IsOptional, IsObject, ValidateNested, IsString, MinLength, MaxLength, IsEmail, IsPhoneNumber, Length, Matches, IsUrl, IsDateString } from 'class-validator';
|
|
4
|
-
import
|
|
4
|
+
import V from 'redaxios';
|
|
5
5
|
import { pathcat } from 'pathcat';
|
|
6
6
|
|
|
7
|
-
var j=Object.defineProperty;var F=Object.getOwnPropertyDescriptor;var a=(r,e,s,t)=>{for(var
|
|
7
|
+
var j=Object.defineProperty;var F=Object.getOwnPropertyDescriptor;var a=(r,e,s,t)=>{for(var o=t>1?void 0:t?F(e,s):e,i=r.length-1,d;i>=0;i--)(d=r[i])&&(o=(t?d(e,s,o):d(o))||o);return t&&o&&j(e,s,o),o};var I="https://api.tonightpass.com";var ie=/^[a-z0-9._%+-]+@[a-z0-9.-]+\.[a-z]{2,4}$/,ae=/((?=.*\d)|(?=.*\W+))(?![.\n])(?=.*[A-Z])(?=.*[a-z]).*$/,b=/(^[\p{L}\d'\\.\s\\-]*$)/u,pe=/^[a-z\d]+(?:(\.|-|_)[a-z\d]+)*$/,de=/\$2[abxy]?\$\d{1,2}\$[A-Za-z\d\\./]{53}/,me=/^\s*(?:\+?(\d{1,3}))?([-. (]*(\d{3})[-. )]*)?((\d{3})[-. ]*(\d{2,4})(?:[-.x ]*(\d+))?)\s*$/,ce=/(((http:\/\/www)|(http:\/\/)|(www))[-a-zA-Z0-9@:%_\\+.~#?&//=]+)\.(jpg|jpeg|gif|png|bmp|tiff|tga|svg)/i;var U=class{identifier;password;identity;addresses};var C=class{identifier;password};var h=class{identifier;identity;password};a([IsOptional(),IsObject(),ValidateNested(),Type(()=>f)],h.prototype,"identifier",2),a([IsOptional(),IsObject(),ValidateNested(),Type(()=>m)],h.prototype,"identity",2),a([IsOptional(),IsString(),MinLength(6),MaxLength(130)],h.prototype,"password",2);var f=class{email;phoneNumber;username};a([IsOptional(),IsString(),IsEmail()],f.prototype,"email",2),a([IsOptional(),IsString(),IsPhoneNumber()],f.prototype,"phoneNumber",2),a([IsOptional(),IsString(),MinLength(3)],f.prototype,"username",2);var m=class{firstName;lastName;displayName;description;profilePictureUrl;bannerUrl;gender;birthDate};a([IsOptional(),IsString(),Length(2,50),Matches(b,{message:"First name must be composed of letters only"})],m.prototype,"firstName",2),a([IsOptional(),IsString(),Length(2,50),Matches(b,{message:"Last name must be composed of letters only"})],m.prototype,"lastName",2),a([IsOptional(),IsString(),Length(1,32)],m.prototype,"displayName",2),a([IsOptional(),IsString(),Length(15,500)],m.prototype,"description",2),a([IsOptional(),IsUrl()],m.prototype,"profilePictureUrl",2),a([IsOptional(),IsUrl()],m.prototype,"bannerUrl",2),a([IsOptional()],m.prototype,"gender",2),a([IsOptional(),IsDateString()],m.prototype,"birthDate",2);var y=typeof window<"u";var $=V.create({headers:{"Content-Type":"application/json",Accept:"application/json",...!y&&{"User-Agent":"tonightpass-api-client"}},responseType:"json",transformRequest:[function(r){return JSON.stringify(r)}],withCredentials:y}),k=async(r,e)=>$(r,{...e}).then(t=>t).catch(t=>{throw t.data});var B=(c=>(c.ENTRY="entry",c.PACKAGE="package",c.MEAL="meal",c.DRINK="drink",c.PARKING="parking",c.ACCOMMODATION="accommodation",c.CAMPING="camping",c.LOCKER="locker",c.SHUTTLE="shuttle",c.OTHER="other",c))(B||{});var X=(n=>(n.Clubbing="clubbing",n.Concert="concert",n.Afterwork="afterwork",n.DancingLunch="dancing_lunch",n.Diner="diner",n.Garden="garden",n.AfterBeach="after_beach",n.Festival="festival",n.Spectacle="spectacle",n.Cruise="cruise",n.OutsideAnimation="outside_animation",n.Sport="sport",n.Match="match",n.Seminar="seminar",n.Conference="conference",n.WellnessDay="wellness_day",n.Workshop="workshop",n.TradeFair="trade_fair",n.ConsumerShow="consumer_show",n.Membership="membership",n))(X||{}),W=(i=>(i.Music="music",i.Dress="dress",i.Sport="sport",i.Food="food",i.Art="art",i))(W||{});var K=(d=>(d.Facebook="facebook",d.Twitter="twitter",d.Instagram="instagram",d.Linkedin="linkedin",d.Youtube="youtube",d.Website="website",d))(K||{}),Y=(o=>(o[o.EMPLOYEE=0]="EMPLOYEE",o[o.MANAGER=1]="MANAGER",o[o.ADMINISTRATOR=2]="ADMINISTRATOR",o[o.OWNER=3]="OWNER",o))(Y||{});var Z=(i=>(i.Authentication="authentication",i.OrganizationInvite="organization_invite",i.PasswordRecovery="password_recovery",i.EmailValidation="email_validation",i.PhoneValidation="phone_validation",i))(Z||{});var J=(t=>(t[t.USER=0]="USER",t[t.DEVELOPER=8]="DEVELOPER",t[t.ADMINISTRATOR=10]="ADMINISTRATOR",t))(J||{});var ee=(u=>(u.Created="created",u.Cancelled="cancelled",u.Completed="completed",u.Pending="pending",u.Confirmed="confirmed",u.Declined="declined",u.Refunded="refunded",u.PartiallyRefunded="partially_refunded",u.Expired="expired",u))(ee||{});var te=(t=>(t.EUR="EUR",t.USD="USD",t.GBP="GBP",t))(te||{}),re=(s=>(s.FR="fr",s.EN="en",s))(re||{});var A=class extends Error{constructor(s,t){super(t.message);this.response=s;this.data=t;this.status=s.status;}status},x=class{options;url;constructor(e){this.options=e,this.url=(s,t)=>{let o=this.options.baseURL||I;return pathcat(o,s,t)};}setOptions(e){this.options=e;}async get(e,s,t){return this.requester("GET",e,void 0,s,t)}async post(e,s,t,o){return this.requester("POST",e,s,t,o)}async put(e,s,t,o){return this.requester("PUT",e,s,t,o)}async patch(e,s,t,o){return this.requester("PATCH",e,s,t,o)}async delete(e,s,t){return this.requester("DELETE",e,void 0,s,t)}async requester(e,s,t,o={},i={}){let d=this.url(s,o);if(t!==void 0&&e==="GET")throw new Error("Cannot send a GET request with a body");let R=await k(d,{method:e,data:t,...i}),E=R.data;if(!E.success)throw new A(R,E);return E.data}};function P(r){return r}var _=r=>({database:async()=>r.get("/health/database"),http:async()=>r.get("/health/http")});var T=r=>({getAll:async()=>r.get("/users"),get:async e=>r.get("/users",{id:e}),me:async()=>r.get("/users/me"),check:async(e,s)=>r.get("/users/check/:identifier",{identifier:e,suggestions:s}),update:async(e,s)=>r.put("/users/:id",s,{id:e})});var M=r=>({categories:{getAll:async e=>r.get("/careers/categories",e)},employmentTypes:{getAll:async e=>r.get("/careers/employmentTypes",e)},jobs:{getAll:async e=>r.get("/careers/jobs",e),get:async e=>r.get("/careers/jobs/:id",{id:e})},offices:{getAll:async e=>r.get("/careers/offices",e)}});var q=r=>({get:async e=>r.get("/profiles/:username",{username:e})});var Q=class{client;careers;health;profiles;users;constructor(e){this.client=new x(e),this.careers=M(this.client),this.health=_(this.client),this.profiles=q(this.client),this.users=T(this.client);}};
|
|
8
8
|
|
|
9
|
-
export { de as BCRYPT_HASH, x as Client, U as CreateUserDto, te as Currency, I as DEFAULT_API_URL, ie as EMAIL_REGEX, W as EventStyleType, B as EventTicketCategory, X as EventType, ce as IMAGE_URL_REGEX, re as Language,
|
|
9
|
+
export { de as BCRYPT_HASH, x as Client, U as CreateUserDto, te as Currency, I as DEFAULT_API_URL, ie as EMAIL_REGEX, W as EventStyleType, B as EventTicketCategory, X as EventType, ce as IMAGE_URL_REGEX, re as Language, b as NAME_REGEX, ee as OrderStatus, Y as OrganizationMemberRole, K as OrganizationSocialType, ae as PASSWORD_REGEX, me as PHONE_NUMBER_REGEX, pe as SLUG_REGEX, C as SignInUserDto, Q as TonightPass, A as TonightPassAPIError, h as UpdateUserDto, J as UserRole, Z as UserTokenType, _ as health, y as isBrowser, k as request, P as sdk, T as users };
|
|
10
10
|
//# sourceMappingURL=out.js.map
|
|
11
11
|
//# sourceMappingURL=index.mjs.map
|
package/dist/index.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/constants/api.ts","../src/constants/regex.ts","../src/rest/dtos/index.ts","../src/rest/dtos/users/create-user.dto.ts","../src/rest/dtos/users/sign-in-user.dto.ts","../src/rest/dtos/users/update-user.dto.ts","../src/rest/request/request.ts","../src/utils/index.ts","../src/rest/types/event/ticket/index.ts","../src/rest/types/event/index.ts","../src/rest/types/organizations/index.ts","../src/rest/types/token/index.ts","../src/rest/types/users/index.ts","../src/rest/types/order/index.ts","../src/rest/types/index.ts","../src/rest/client.ts","../src/sdk/builder.ts","../src/sdk/health.ts","../src/sdk/users.ts","../src/sdk/careers.ts","../src/sdk/profiles.ts","../src/tonightpass.ts"],"names":["DEFAULT_API_URL","EMAIL_REGEX","PASSWORD_REGEX","NAME_REGEX","SLUG_REGEX","BCRYPT_HASH","PHONE_NUMBER_REGEX","IMAGE_URL_REGEX","CreateUserDto","SignInUserDto","Type","IsDateString","IsEmail","IsObject","IsOptional","IsPhoneNumber","IsString","IsUrl","Length","Matches","MaxLength","MinLength","ValidateNested","UpdateUserDto","__decorateClass","UpdateIdentifierDto","UpdateIdentityDto","axios","isBrowser","instance","data","request","url","options","response","error","EventTicketCategory","EventType","EventStyleType","OrganizationSocialType","OrganizationMemberRole","UserTokenType","UserRole","OrderStatus","Currency","Language","pathcat","TonightPassAPIError","Client","path","params","baseURL","query","body","method","result","sdk","builder","health","client","users","id","identifier","suggestions","careers","profiles","username","TonightPass"],"mappings":"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","sourcesContent":["export const DEFAULT_API_URL = \"https://api.tonightpass.com\";\n","export const EMAIL_REGEX = /^[a-z0-9._%+-]+@[a-z0-9.-]+\\.[a-z]{2,4}$/;\n\n// checks if a password has at least one uppercase letter and a number or special character\nexport const PASSWORD_REGEX =\n /((?=.*\\d)|(?=.*\\W+))(?![.\\n])(?=.*[A-Z])(?=.*[a-z]).*$/;\n\n// checks if a string has only letters, numbers, spaces, apostrophes, dots and dashes\nexport const NAME_REGEX = /(^[\\p{L}\\d'\\\\.\\s\\\\-]*$)/u;\n\n// checks if a string is a valid slug, useful for usernames\nexport const SLUG_REGEX = /^[a-z\\d]+(?:(\\.|-|_)[a-z\\d]+)*$/;\n\n// validates if passwords are valid bcrypt hashes\nexport const BCRYPT_HASH = /\\$2[abxy]?\\$\\d{1,2}\\$[A-Za-z\\d\\\\./]{53}/;\n\nexport const PHONE_NUMBER_REGEX =\n /^\\s*(?:\\+?(\\d{1,3}))?([-. (]*(\\d{3})[-. )]*)?((\\d{3})[-. ]*(\\d{2,4})(?:[-.x ]*(\\d+))?)\\s*$/;\n\nexport const IMAGE_URL_REGEX =\n /(((http:\\/\\/www)|(http:\\/\\/)|(www))[-a-zA-Z0-9@:%_\\\\+.~#?&//=]+)\\.(jpg|jpeg|gif|png|bmp|tiff|tga|svg)/i;\n","import \"reflect-metadata\";\n\nexport * from \"./users\";\n","import { UserIdentifier, UserIdentityGender } from \"../../types\";\n\nexport class CreateUserDto {\n identifier: UserIdentifier;\n password: string;\n identity: CreateUserIdentituDto;\n addresses: Location[];\n}\n\nclass CreateUserIdentituDto {\n firstName: string;\n lastName: string;\n gender: UserIdentityGender;\n profilePictureUrl?: string;\n birthDate: Date;\n}\n","export class SignInUserDto {\n identifier: string;\n password: string;\n}\n","import { Type } from \"class-transformer\";\nimport {\n IsDateString,\n IsEmail,\n IsObject,\n IsOptional,\n IsPhoneNumber,\n IsString,\n IsUrl,\n Length,\n Matches,\n MaxLength,\n MinLength,\n ValidateNested,\n} from \"class-validator\";\n\nimport { NAME_REGEX } from \"../../../constants/regex\";\nimport { UserIdentifier, UserIdentity } from \"../../types\";\n\nexport class UpdateUserDto {\n @IsOptional()\n @IsObject()\n @ValidateNested()\n @Type(() => UpdateIdentifierDto)\n identifier?: UpdateIdentifierDto;\n\n @IsOptional()\n @IsObject()\n @ValidateNested()\n @Type(() => UpdateIdentityDto)\n identity?: UpdateIdentityDto;\n\n @IsOptional()\n @IsString()\n @MinLength(6)\n @MaxLength(130)\n password?: string;\n}\n\nclass UpdateIdentifierDto\n implements\n Partial<Pick<UserIdentifier, \"email\" | \"phoneNumber\" | \"username\">>\n{\n @IsOptional()\n @IsString()\n @IsEmail()\n email?: string;\n\n @IsOptional()\n @IsString()\n @IsPhoneNumber()\n phoneNumber?: string;\n\n @IsOptional()\n @IsString()\n @MinLength(3)\n username?: string;\n}\n\nclass UpdateIdentityDto\n implements\n Partial<\n Pick<\n UserIdentity,\n | \"firstName\"\n | \"lastName\"\n | \"displayName\"\n | \"description\"\n | \"profilePictureUrl\"\n | \"bannerUrl\"\n | \"gender\"\n | \"birthDate\"\n >\n >\n{\n @IsOptional()\n @IsString()\n @Length(2, 50)\n @Matches(NAME_REGEX, {\n message: \"First name must be composed of letters only\",\n })\n firstName?: string;\n\n @IsOptional()\n @IsString()\n @Length(2, 50)\n @Matches(NAME_REGEX, {\n message: \"Last name must be composed of letters only\",\n })\n lastName?: string;\n\n @IsOptional()\n @IsString()\n @Length(1, 32)\n displayName?: string;\n\n @IsOptional()\n @IsString()\n @Length(15, 500)\n description?: string;\n\n @IsOptional()\n @IsUrl()\n profilePictureUrl?: string | undefined;\n\n @IsOptional()\n @IsUrl()\n bannerUrl?: string | undefined;\n\n @IsOptional()\n gender?: string;\n\n @IsOptional()\n @IsDateString()\n birthDate?: Date;\n}\n","import axios, { Options, Response } from \"redaxios\";\n\nimport { isBrowser } from \"../../utils\";\nimport { APIResponse, ErroredAPIResponse } from \"../endpoints\";\n\nconst instance = axios.create({\n headers: {\n \"Content-Type\": \"application/json\",\n Accept: \"application/json\",\n ...(!isBrowser && { \"User-Agent\": \"tonightpass-api-client\" }),\n },\n responseType: \"json\",\n transformRequest: [\n function (data) {\n return JSON.stringify(data);\n },\n ],\n withCredentials: isBrowser,\n});\n\nexport interface APIRequestOptions extends Options {}\n\nexport const request = async <T>(url: string, options?: Options) => {\n const response = instance<APIResponse<T>>(url, { ...options })\n .then((response) => response)\n .catch((error: Response<ErroredAPIResponse>) => {\n throw error.data;\n });\n\n return response;\n};\n","export const isBrowser = typeof window !== \"undefined\";\n","import { Currency } from \"../..\";\n\nexport type EventTicket = {\n id: string;\n name: string;\n description?: string;\n price: number;\n displayPrice: number;\n quantity: number;\n type: EventTicketType;\n category: EventTicketCategory;\n currency: Currency;\n vatRate: number;\n externalId?: string;\n isVisible: boolean;\n isFeesIncluded: boolean;\n startAt: Date;\n endAt: Date;\n updatedAt: Date;\n createdAt: Date;\n};\n\nexport type EventTicketType = \"e-ticket\" | \"other\";\n\nexport enum EventTicketCategory {\n ENTRY = \"entry\",\n PACKAGE = \"package\",\n MEAL = \"meal\",\n DRINK = \"drink\",\n PARKING = \"parking\",\n ACCOMMODATION = \"accommodation\",\n CAMPING = \"camping\",\n LOCKER = \"locker\",\n SHUTTLE = \"shuttle\",\n OTHER = \"other\",\n}\n","import { EventTicket } from \"./ticket\";\nimport { Location } from \"..\";\nimport { Organization } from \"../organizations\";\n\nexport * from \"./ticket\";\n\nexport type Event = {\n title: string;\n description: string;\n slug: string;\n organization: Organization;\n type: EventType;\n public: boolean;\n flyers: string[];\n trailers: string[];\n location: Location;\n tickets: EventTicket[];\n styles: EventStyle[];\n startAt: Date;\n endAt: Date;\n updatedAt: Date;\n createdAt: Date;\n};\n\nexport enum EventType {\n Clubbing = \"clubbing\",\n Concert = \"concert\",\n Afterwork = \"afterwork\",\n DancingLunch = \"dancing_lunch\",\n Diner = \"diner\",\n Garden = \"garden\",\n AfterBeach = \"after_beach\",\n Festival = \"festival\",\n Spectacle = \"spectacle\",\n Cruise = \"cruise\",\n OutsideAnimation = \"outside_animation\",\n Sport = \"sport\",\n Match = \"match\",\n Seminar = \"seminar\",\n Conference = \"conference\",\n WellnessDay = \"wellness_day\",\n Workshop = \"workshop\",\n TradeFair = \"trade_fair\",\n ConsumerShow = \"consumer_show\",\n Membership = \"membership\",\n}\n\nexport type EventStyle = {\n type: EventStyleType;\n emoji: string;\n name: string;\n};\n\nexport enum EventStyleType {\n Music = \"music\",\n Dress = \"dress\",\n Sport = \"sport\",\n Food = \"food\",\n Art = \"art\",\n}\n","import { Location, Profile, ProfileMetadata } from \"..\";\nimport { Event } from \"../event\";\nimport { EventTicket } from \"../event/ticket\";\nimport { User } from \"../users\";\n\nexport type Organization = {\n id: string;\n slug: string;\n identity: OrganizationIdentity;\n members: OrganizationMember[];\n location?: Location;\n events: Event[];\n savedTickets: EventTicket[];\n verified: boolean;\n updatedAt: Date;\n createdAt: Date;\n};\n\nexport type OrganizationIdentity = Profile & {\n socialLinks: OrganizationSocialLink[];\n\n metadata: ProfileMetadata & {\n eventsCount: number;\n viewsCount: number;\n membersCount: number;\n };\n};\n\nexport type OrganizationSocialLink = {\n type: OrganizationSocialType;\n url: string;\n};\n\nexport enum OrganizationSocialType {\n Facebook = \"facebook\",\n Twitter = \"twitter\",\n Instagram = \"instagram\",\n Linkedin = \"linkedin\",\n Youtube = \"youtube\",\n Website = \"website\",\n}\n\nexport type OrganizationMember = {\n user: User;\n role: OrganizationMemberRole;\n createdAt: Date;\n};\n\nexport enum OrganizationMemberRole {\n EMPLOYEE = 0,\n MANAGER = 1,\n ADMINISTRATOR = 2,\n OWNER = 3,\n}\n","export type UserToken = {\n id: string;\n type: UserTokenType;\n value: string;\n createdAt: Date;\n expiresAt: Date;\n};\n\nexport enum UserTokenType {\n Authentication = \"authentication\",\n OrganizationInvite = \"organization_invite\",\n PasswordRecovery = \"password_recovery\",\n EmailValidation = \"email_validation\",\n PhoneValidation = \"phone_validation\",\n}\n","import { Currency, Language, Location, Profile, ProfileMetadata } from \"..\";\nimport { UpdateUserDto } from \"../../dtos\";\nimport { Endpoint } from \"../../endpoints\";\n\nexport type User = {\n id: string;\n identifier: UserIdentifier;\n password: string;\n identity: UserIdentity;\n role: UserRole;\n addresses: Location[];\n preferences: UserPreferences;\n connections: UserConnection[];\n verified: boolean;\n updatedAt: Date;\n createdAt: Date;\n};\n\nexport type UserIdentifier = {\n email?: string;\n phoneNumber?: string;\n username: string;\n\n [key: string]: string | undefined;\n};\n\nexport type UserIdentity = Profile & {\n firstName: string;\n lastName: string;\n fullName: string;\n gender: UserIdentityGender;\n birthDate: Date;\n\n metadata: ProfileMetadata & {\n followingCount: number;\n hasPassPlus: boolean;\n idValid: boolean;\n };\n};\n\nexport enum UserRole {\n USER = 0,\n DEVELOPER = 8,\n ADMINISTRATOR = 10,\n}\n\nexport type UserIdentityGender =\n | \"male\"\n | \"female\"\n | \"non-binary\"\n | \"gender-fluid\"\n | \"neutral\"\n | \"other\"\n | string;\n\nexport type UserPreferences = {\n language: Language;\n currency: Currency;\n notifications: {\n email: {\n newsletter: boolean;\n message: boolean;\n };\n push: {\n message: boolean;\n };\n };\n};\n\nexport type UserConnection = {\n ip: string;\n os: UserConnectionOS;\n device: UserConnectionDevice;\n client: UserConnectionClient;\n updatedAt: Date;\n createdAt: Date;\n};\n\nexport type UserConnectionOS = {\n name: string;\n version: string;\n};\n\nexport type UserConnectionDevice = {\n type: string;\n brand: string;\n};\n\nexport type UserConnectionClient = {\n name: string;\n version: string;\n};\n\nexport type UserEndpoints =\n | Endpoint<\"GET\", \"/users\", User[]>\n | Endpoint<\"GET\", \"/users/:id\", User, { id: string }>\n | Endpoint<\"GET\", \"/users/me\", User>\n | Endpoint<\n \"GET\",\n \"/users/check/:identifier\",\n {\n exists: boolean;\n identifier: UserIdentifier;\n suggestions?: string[];\n },\n { identifier: boolean; suggestions?: boolean }\n >\n | Endpoint<\"PUT\", \"/users/:id\", User, UpdateUserDto>;\n","import { Currency } from \"..\";\nimport { Event, EventTicket } from \"../event\";\nimport { User } from \"../users\";\n\nexport enum OrderStatus {\n Created = \"created\",\n Cancelled = \"cancelled\",\n Completed = \"completed\",\n Pending = \"pending\",\n Confirmed = \"confirmed\",\n Declined = \"declined\",\n Refunded = \"refunded\",\n PartiallyRefunded = \"partially_refunded\",\n Expired = \"expired\",\n}\n\nexport type OrderItem = {\n id: string;\n ticket: EventTicket;\n isUsed: boolean;\n updatedAt: Date;\n createdAt: Date;\n};\n\nexport type Order = {\n id: string;\n owner: User;\n members: User[];\n status: OrderStatus;\n event: Event;\n items: OrderItem[];\n promoCode?: PromoCode;\n total: number;\n currency: Currency;\n createdAt: Date;\n};\n\nexport type PromoCode = {\n id: string;\n code: string;\n used: number;\n discount: number;\n isActive: boolean;\n expirationAt: Date;\n createdAt: Date;\n};\n","export * from \"./careers\";\nexport * from \"./event\";\nexport * from \"./health\";\nexport * from \"./organizations\";\nexport * from \"./token\";\nexport * from \"./users\";\nexport * from \"./order\";\nexport * from \"./profiles\";\n\nexport type Location = {\n name?: string;\n address: string;\n zipCode: string;\n city: string;\n country: string;\n geometry?: {\n latitude: number;\n longitude: number;\n };\n};\n\n// Currency\nexport enum Currency {\n EUR = \"EUR\",\n USD = \"USD\",\n GBP = \"GBP\",\n}\n\n// I18n\nexport enum Language {\n FR = \"fr\",\n EN = \"en\",\n}\n","import { ParamValue, pathcat } from \"pathcat\";\nimport { Options, Response } from \"redaxios\";\n\nimport { APIResponse, Endpoints, ErroredAPIResponse } from \"./endpoints\";\nimport { APIRequestOptions, request } from \"./request\";\nimport { DEFAULT_API_URL } from \"../constants\";\n\nexport type ExtractRouteParams<T extends string> = string extends T\n ? Record<string, string | number | boolean | undefined>\n : T extends `${string}:${infer Param}/${infer Rest}`\n ? {\n [k in Param | keyof ExtractRouteParams<Rest>]:\n | string\n | number\n | boolean;\n }\n : T extends `${string}:${infer Param}`\n ? { [k in Param]: string | number | boolean }\n : object;\n\nexport type ExtractEndpoint<\n Method extends string,\n Path extends string,\n> = Extract<Endpoints, { path: Path; method: Method }>;\n\nexport type PathsFor<M extends Options[\"method\"]> = Extract<\n Endpoints,\n { method: M }\n>[\"path\"];\n\nexport type Query<Path extends string> = ExtractRouteParams<Path> &\n Record<string, string | number | boolean | undefined>;\n\nexport class TonightPassAPIError<T> extends Error {\n public readonly status: number;\n\n constructor(\n public readonly response: Response<APIResponse<T>>,\n public readonly data: ErroredAPIResponse,\n ) {\n super(data.message);\n\n this.status = response.status;\n }\n}\n\nexport interface ClientOptions {\n readonly baseURL: string;\n}\n\nexport class Client {\n private options;\n public readonly url;\n\n constructor(options: ClientOptions) {\n this.options = options;\n this.url = (path: string, params: Record<string, ParamValue>) => {\n const baseURL = this.options.baseURL || DEFAULT_API_URL;\n return pathcat(baseURL, path, params);\n };\n }\n\n setOptions(options: ClientOptions) {\n this.options = options;\n }\n\n async get<Path extends PathsFor<\"GET\">>(\n path: Path,\n query?: Query<Path>,\n options?: APIRequestOptions,\n ) {\n return this.requester<\n Extract<Endpoints, { path: Path; method: \"GET\" }>[\"res\"]\n >(\"GET\", path, undefined, query, options);\n }\n\n async post<Path extends Extract<Endpoints, { method: \"POST\" }>[\"path\"]>(\n path: Path,\n body: Extract<Endpoints, { path: Path; method: \"POST\" }>[\"body\"],\n query?: Query<Path>,\n options?: APIRequestOptions,\n ) {\n return this.requester<\n Extract<Endpoints, { path: Path; method: \"POST\" }>[\"res\"]\n >(\"POST\", path, body, query, options);\n }\n\n async put<Path extends Extract<Endpoints, { method: \"PUT\" }>[\"path\"]>(\n path: Path,\n body: Extract<Endpoints, { path: Path; method: \"PUT\" }>[\"body\"],\n query?: Query<Path>,\n options?: APIRequestOptions,\n ) {\n return this.requester<\n Extract<Endpoints, { path: Path; method: \"PUT\" }>[\"res\"]\n >(\"PUT\", path, body, query, options);\n }\n\n async patch<Path extends Extract<Endpoints, { method: \"PATCH\" }>[\"path\"]>(\n path: Path,\n body: Extract<Endpoints, { path: Path; method: \"PATCH\" }>[\"body\"],\n query?: Query<Path>,\n options?: APIRequestOptions,\n ) {\n return this.requester<\n Extract<Endpoints, { path: Path; method: \"PATCH\" }>[\"res\"]\n >(\"PATCH\", path, body, query, options);\n }\n\n async delete<Path extends Extract<Endpoints, { method: \"DELETE\" }>[\"path\"]>(\n path: Path,\n query?: Query<Path>,\n options?: APIRequestOptions,\n ) {\n return this.requester<\n Extract<Endpoints, { path: Path; method: \"DELETE\" }>[\"res\"]\n >(\"DELETE\", path, undefined, query, options);\n }\n\n private async requester<T>(\n method: Options[\"method\"],\n path: string,\n body: unknown,\n query: Record<string, string | number | boolean | undefined> = {},\n options: APIRequestOptions = {},\n ) {\n const url = this.url(path, query);\n\n if (body !== undefined) {\n if (method === \"GET\") {\n throw new Error(\"Cannot send a GET request with a body\");\n }\n }\n\n const response: Response<APIResponse<T>> = await request<T>(url, {\n method,\n data: body,\n ...options,\n });\n\n const result = response.data;\n\n if (!result.success) {\n throw new TonightPassAPIError<T>(response, result);\n }\n\n return result.data;\n }\n}\n","import { Client } from \"../rest\";\n\nexport function sdk<T>(builder: (client: Client) => T) {\n return builder;\n}\n","import { sdk } from \"./builder\";\n\nexport const health = sdk((client) => ({\n database: async () => client.get(\"/health/database\"),\n http: async () => client.get(\"/health/http\"),\n}));\n","import { sdk } from \"./builder\";\nimport { UpdateUserDto } from \"../rest\";\n\nexport const users = sdk((client) => ({\n getAll: async () => client.get(\"/users\"),\n get: async (id: string) => client.get(\"/users\", { id }),\n me: async () => client.get(\"/users/me\"),\n check: async (identifier: string, suggestions?: boolean) =>\n client.get(\"/users/check/:identifier\", { identifier, suggestions }),\n update: async (id: string, data: UpdateUserDto) =>\n client.put(\"/users/:id\", data, { id }),\n}));\n","import { sdk } from \"./builder\";\nimport { Query } from \"../rest\";\n\nexport const careers = sdk((client) => ({\n categories: {\n getAll: async (query?: Query<\"/careers/categories\">) =>\n client.get(\"/careers/categories\", query),\n },\n employmentTypes: {\n getAll: async (query?: Query<\"/careers/employmentTypes\">) =>\n client.get(\"/careers/employmentTypes\", query),\n },\n jobs: {\n getAll: async (query?: Query<\"/careers/jobs\">) =>\n client.get(\"/careers/jobs\", query),\n get: async (id: number) => client.get(\"/careers/jobs/:id\", { id }),\n },\n offices: {\n getAll: async (query?: Query<\"/careers/offices\">) =>\n client.get(\"/careers/offices\", query),\n },\n}));\n","import { sdk } from \"./builder\";\n\nexport const profiles = sdk((client) => ({\n get: async (username: string) =>\n client.get(\"/profiles/:username\", { username }),\n}));\n","import { Client, ClientOptions } from \"./rest\";\nimport { health, users } from \"./sdk\";\nimport { careers } from \"./sdk/careers\";\nimport { profiles } from \"./sdk/profiles\";\n\nexport class TonightPass {\n public readonly client: Client;\n\n public readonly careers;\n public readonly health;\n public readonly profiles;\n public readonly users;\n\n constructor(options: ClientOptions) {\n this.client = new Client(options);\n\n this.careers = careers(this.client);\n this.health = health(this.client);\n this.profiles = profiles(this.client);\n this.users = users(this.client);\n }\n}\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/constants/api.ts","../src/constants/regex.ts","../src/rest/dtos/index.ts","../src/rest/dtos/users/create-user.dto.ts","../src/rest/dtos/users/sign-in-user.dto.ts","../src/rest/dtos/users/update-user.dto.ts","../src/rest/request/request.ts","../src/utils/index.ts","../src/rest/types/event/ticket/index.ts","../src/rest/types/event/index.ts","../src/rest/types/organizations/index.ts","../src/rest/types/token/index.ts","../src/rest/types/users/index.ts","../src/rest/types/order/index.ts","../src/rest/types/index.ts","../src/rest/client.ts","../src/sdk/builder.ts","../src/sdk/health.ts","../src/sdk/users.ts","../src/sdk/careers.ts","../src/sdk/profiles.ts","../src/tonightpass.ts"],"names":["DEFAULT_API_URL","EMAIL_REGEX","PASSWORD_REGEX","NAME_REGEX","SLUG_REGEX","BCRYPT_HASH","PHONE_NUMBER_REGEX","IMAGE_URL_REGEX","CreateUserDto","SignInUserDto","Type","IsDateString","IsEmail","IsObject","IsOptional","IsPhoneNumber","IsString","IsUrl","Length","Matches","MaxLength","MinLength","ValidateNested","UpdateUserDto","__decorateClass","UpdateIdentifierDto","UpdateIdentityDto","axios","isBrowser","instance","data","request","url","options","response","error","EventTicketCategory","EventType","EventStyleType","OrganizationSocialType","OrganizationMemberRole","UserTokenType","UserRole","OrderStatus","Currency","Language","pathcat","TonightPassAPIError","Client","path","params","baseURL","query","body","method","result","sdk","builder","health","client","users","id","identifier","suggestions","careers","profiles","username","TonightPass"],"mappings":"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","sourcesContent":["export const DEFAULT_API_URL = \"https://api.tonightpass.com\";\n","export const EMAIL_REGEX = /^[a-z0-9._%+-]+@[a-z0-9.-]+\\.[a-z]{2,4}$/;\n\n// checks if a password has at least one uppercase letter and a number or special character\nexport const PASSWORD_REGEX =\n /((?=.*\\d)|(?=.*\\W+))(?![.\\n])(?=.*[A-Z])(?=.*[a-z]).*$/;\n\n// checks if a string has only letters, numbers, spaces, apostrophes, dots and dashes\nexport const NAME_REGEX = /(^[\\p{L}\\d'\\\\.\\s\\\\-]*$)/u;\n\n// checks if a string is a valid slug, useful for usernames\nexport const SLUG_REGEX = /^[a-z\\d]+(?:(\\.|-|_)[a-z\\d]+)*$/;\n\n// validates if passwords are valid bcrypt hashes\nexport const BCRYPT_HASH = /\\$2[abxy]?\\$\\d{1,2}\\$[A-Za-z\\d\\\\./]{53}/;\n\nexport const PHONE_NUMBER_REGEX =\n /^\\s*(?:\\+?(\\d{1,3}))?([-. (]*(\\d{3})[-. )]*)?((\\d{3})[-. ]*(\\d{2,4})(?:[-.x ]*(\\d+))?)\\s*$/;\n\nexport const IMAGE_URL_REGEX =\n /(((http:\\/\\/www)|(http:\\/\\/)|(www))[-a-zA-Z0-9@:%_\\\\+.~#?&//=]+)\\.(jpg|jpeg|gif|png|bmp|tiff|tga|svg)/i;\n","import \"reflect-metadata\";\n\nexport * from \"./users\";\n","import { UserIdentifier, UserIdentityGender } from \"../../types\";\n\nexport class CreateUserDto {\n identifier: UserIdentifier;\n password: string;\n identity: CreateUserIdentituDto;\n addresses: Location[];\n}\n\nclass CreateUserIdentituDto {\n firstName: string;\n lastName: string;\n gender: UserIdentityGender;\n profilePictureUrl?: string;\n birthDate: Date;\n}\n","export class SignInUserDto {\n identifier: string;\n password: string;\n}\n","import { Type } from \"class-transformer\";\nimport {\n IsDateString,\n IsEmail,\n IsObject,\n IsOptional,\n IsPhoneNumber,\n IsString,\n IsUrl,\n Length,\n Matches,\n MaxLength,\n MinLength,\n ValidateNested,\n} from \"class-validator\";\n\nimport { NAME_REGEX } from \"../../../constants/regex\";\nimport { UserIdentifier, UserIdentity } from \"../../types\";\n\nexport class UpdateUserDto {\n @IsOptional()\n @IsObject()\n @ValidateNested()\n @Type(() => UpdateIdentifierDto)\n identifier?: UpdateIdentifierDto;\n\n @IsOptional()\n @IsObject()\n @ValidateNested()\n @Type(() => UpdateIdentityDto)\n identity?: UpdateIdentityDto;\n\n @IsOptional()\n @IsString()\n @MinLength(6)\n @MaxLength(130)\n password?: string;\n}\n\nclass UpdateIdentifierDto\n implements\n Partial<Pick<UserIdentifier, \"email\" | \"phoneNumber\" | \"username\">>\n{\n @IsOptional()\n @IsString()\n @IsEmail()\n email?: string;\n\n @IsOptional()\n @IsString()\n @IsPhoneNumber()\n phoneNumber?: string;\n\n @IsOptional()\n @IsString()\n @MinLength(3)\n username?: string;\n}\n\nclass UpdateIdentityDto\n implements\n Partial<\n Pick<\n UserIdentity,\n | \"firstName\"\n | \"lastName\"\n | \"displayName\"\n | \"description\"\n | \"profilePictureUrl\"\n | \"bannerUrl\"\n | \"gender\"\n | \"birthDate\"\n >\n >\n{\n @IsOptional()\n @IsString()\n @Length(2, 50)\n @Matches(NAME_REGEX, {\n message: \"First name must be composed of letters only\",\n })\n firstName?: string;\n\n @IsOptional()\n @IsString()\n @Length(2, 50)\n @Matches(NAME_REGEX, {\n message: \"Last name must be composed of letters only\",\n })\n lastName?: string;\n\n @IsOptional()\n @IsString()\n @Length(1, 32)\n displayName?: string;\n\n @IsOptional()\n @IsString()\n @Length(15, 500)\n description?: string;\n\n @IsOptional()\n @IsUrl()\n profilePictureUrl?: string | undefined;\n\n @IsOptional()\n @IsUrl()\n bannerUrl?: string | undefined;\n\n @IsOptional()\n gender?: string;\n\n @IsOptional()\n @IsDateString()\n birthDate?: Date;\n}\n","import axios, { Options, Response } from \"redaxios\";\n\nimport { isBrowser } from \"../../utils\";\nimport { APIResponse, ErroredAPIResponse } from \"../endpoints\";\n\nconst instance = axios.create({\n headers: {\n \"Content-Type\": \"application/json\",\n Accept: \"application/json\",\n ...(!isBrowser && { \"User-Agent\": \"tonightpass-api-client\" }),\n },\n responseType: \"json\",\n transformRequest: [\n function (data) {\n return JSON.stringify(data);\n },\n ],\n withCredentials: isBrowser,\n});\n\nexport interface APIRequestOptions extends Options {}\n\nexport const request = async <T>(url: string, options?: Options) => {\n const response = instance<APIResponse<T>>(url, { ...options })\n .then((response) => response)\n .catch((error: Response<ErroredAPIResponse>) => {\n throw error.data;\n });\n\n return response;\n};\n","export const isBrowser = typeof window !== \"undefined\";\n","import { Currency } from \"../..\";\n\nexport type EventTicket = {\n id: string;\n name: string;\n description?: string;\n price: number;\n displayPrice: number;\n quantity: number;\n type: EventTicketType;\n category: EventTicketCategory;\n currency: Currency;\n vatRate: number;\n externalId?: string;\n isVisible: boolean;\n isFeesIncluded: boolean;\n startAt: Date;\n endAt: Date;\n updatedAt: Date;\n createdAt: Date;\n};\n\nexport type EventTicketType = \"e-ticket\" | \"other\";\n\nexport enum EventTicketCategory {\n ENTRY = \"entry\",\n PACKAGE = \"package\",\n MEAL = \"meal\",\n DRINK = \"drink\",\n PARKING = \"parking\",\n ACCOMMODATION = \"accommodation\",\n CAMPING = \"camping\",\n LOCKER = \"locker\",\n SHUTTLE = \"shuttle\",\n OTHER = \"other\",\n}\n","import { EventTicket } from \"./ticket\";\nimport { Location } from \"..\";\nimport { Organization } from \"../organizations\";\n\nexport * from \"./ticket\";\n\nexport type Event = {\n title: string;\n description: string;\n slug: string;\n organization: Organization;\n type: EventType;\n public: boolean;\n flyers: string[];\n trailers: string[];\n location: Location;\n tickets: EventTicket[];\n styles: EventStyle[];\n startAt: Date;\n endAt: Date;\n updatedAt: Date;\n createdAt: Date;\n};\n\nexport enum EventType {\n Clubbing = \"clubbing\",\n Concert = \"concert\",\n Afterwork = \"afterwork\",\n DancingLunch = \"dancing_lunch\",\n Diner = \"diner\",\n Garden = \"garden\",\n AfterBeach = \"after_beach\",\n Festival = \"festival\",\n Spectacle = \"spectacle\",\n Cruise = \"cruise\",\n OutsideAnimation = \"outside_animation\",\n Sport = \"sport\",\n Match = \"match\",\n Seminar = \"seminar\",\n Conference = \"conference\",\n WellnessDay = \"wellness_day\",\n Workshop = \"workshop\",\n TradeFair = \"trade_fair\",\n ConsumerShow = \"consumer_show\",\n Membership = \"membership\",\n}\n\nexport type EventStyle = {\n type: EventStyleType;\n emoji: string;\n name: string;\n};\n\nexport enum EventStyleType {\n Music = \"music\",\n Dress = \"dress\",\n Sport = \"sport\",\n Food = \"food\",\n Art = \"art\",\n}\n","import { Location, Profile, ProfileMetadata } from \"..\";\nimport { Event } from \"../event\";\nimport { EventTicket } from \"../event/ticket\";\nimport { User } from \"../users\";\n\nexport type Organization = {\n id: string;\n slug: string;\n identity: OrganizationIdentity;\n members: OrganizationMember[];\n location?: Location;\n events: Event[];\n savedTickets: EventTicket[];\n verified: boolean;\n updatedAt: Date;\n createdAt: Date;\n};\n\nexport type OrganizationIdentity = Profile & {\n socialLinks: OrganizationSocialLink[];\n\n metadata: ProfileMetadata & {\n eventsCount: number;\n viewsCount: number;\n membersCount: number;\n };\n};\n\nexport type OrganizationSocialLink = {\n type: OrganizationSocialType;\n url: string;\n};\n\nexport enum OrganizationSocialType {\n Facebook = \"facebook\",\n Twitter = \"twitter\",\n Instagram = \"instagram\",\n Linkedin = \"linkedin\",\n Youtube = \"youtube\",\n Website = \"website\",\n}\n\nexport type OrganizationMember = {\n user: User;\n role: OrganizationMemberRole;\n createdAt: Date;\n};\n\nexport enum OrganizationMemberRole {\n EMPLOYEE = 0,\n MANAGER = 1,\n ADMINISTRATOR = 2,\n OWNER = 3,\n}\n","export type UserToken = {\n id: string;\n type: UserTokenType;\n value: string;\n createdAt: Date;\n expiresAt: Date;\n};\n\nexport enum UserTokenType {\n Authentication = \"authentication\",\n OrganizationInvite = \"organization_invite\",\n PasswordRecovery = \"password_recovery\",\n EmailValidation = \"email_validation\",\n PhoneValidation = \"phone_validation\",\n}\n","import { Currency, Language, Location, Profile, ProfileMetadata } from \"..\";\nimport { UpdateUserDto } from \"../../dtos\";\nimport { Endpoint } from \"../../endpoints\";\n\nexport type User = {\n id: string;\n identifier: UserIdentifier;\n password: string;\n identity: UserIdentity;\n role: UserRole;\n addresses: Location[];\n preferences: UserPreferences;\n connections: UserConnection[];\n verified: boolean;\n updatedAt: Date;\n createdAt: Date;\n};\n\nexport type UserIdentifier = {\n email?: string;\n phoneNumber?: string;\n username: string;\n\n [key: string]: string | undefined;\n};\n\nexport type UserIdentity = Profile & {\n firstName: string;\n lastName: string;\n fullName: string;\n gender: UserIdentityGender;\n birthDate: Date;\n\n metadata: ProfileMetadata & {\n followingCount: number;\n hasPassPlus: boolean;\n idValid: boolean;\n };\n};\n\nexport enum UserRole {\n USER = 0,\n DEVELOPER = 8,\n ADMINISTRATOR = 10,\n}\n\nexport type UserIdentityGender =\n | \"male\"\n | \"female\"\n | \"non-binary\"\n | \"gender-fluid\"\n | \"neutral\"\n | \"other\"\n | string;\n\nexport type UserPreferences = {\n language: Language;\n currency: Currency;\n notifications: {\n email: {\n newsletter: boolean;\n message: boolean;\n };\n push: {\n message: boolean;\n };\n };\n};\n\nexport type UserConnection = {\n ip: string;\n os: UserConnectionOS;\n device: UserConnectionDevice;\n client: UserConnectionClient;\n updatedAt: Date;\n createdAt: Date;\n};\n\nexport type UserConnectionOS = {\n name: string;\n version: string;\n};\n\nexport type UserConnectionDevice = {\n type: string;\n brand: string;\n};\n\nexport type UserConnectionClient = {\n name: string;\n version: string;\n};\n\nexport type UserEndpoints =\n | Endpoint<\"GET\", \"/users\", User[]>\n | Endpoint<\"GET\", \"/users/:id\", User, { id: string }>\n | Endpoint<\"GET\", \"/users/me\", User>\n | Endpoint<\n \"GET\",\n \"/users/check/:identifier\",\n {\n exists: boolean;\n identifier: UserIdentifier;\n suggestions?: string[];\n },\n { identifier: boolean; suggestions?: boolean }\n >\n | Endpoint<\"PUT\", \"/users/:id\", User, UpdateUserDto>;\n","import { Currency } from \"..\";\nimport { Event, EventTicket } from \"../event\";\nimport { User } from \"../users\";\n\nexport enum OrderStatus {\n Created = \"created\",\n Cancelled = \"cancelled\",\n Completed = \"completed\",\n Pending = \"pending\",\n Confirmed = \"confirmed\",\n Declined = \"declined\",\n Refunded = \"refunded\",\n PartiallyRefunded = \"partially_refunded\",\n Expired = \"expired\",\n}\n\nexport type OrderItem = {\n id: string;\n ticket: EventTicket;\n isUsed: boolean;\n updatedAt: Date;\n createdAt: Date;\n};\n\nexport type Order = {\n id: string;\n owner: User;\n members: User[];\n status: OrderStatus;\n event: Event;\n items: OrderItem[];\n promoCode?: PromoCode;\n total: number;\n currency: Currency;\n createdAt: Date;\n};\n\nexport type PromoCode = {\n id: string;\n code: string;\n used: number;\n discount: number;\n isActive: boolean;\n expirationAt: Date;\n createdAt: Date;\n};\n","export * from \"./auth\";\nexport * from \"./careers\";\nexport * from \"./event\";\nexport * from \"./health\";\nexport * from \"./organizations\";\nexport * from \"./token\";\nexport * from \"./users\";\nexport * from \"./order\";\nexport * from \"./profiles\";\n\nexport type Location = {\n name?: string;\n address: string;\n zipCode: string;\n city: string;\n country: string;\n geometry?: {\n latitude: number;\n longitude: number;\n };\n};\n\n// Currency\nexport enum Currency {\n EUR = \"EUR\",\n USD = \"USD\",\n GBP = \"GBP\",\n}\n\n// I18n\nexport enum Language {\n FR = \"fr\",\n EN = \"en\",\n}\n","import { ParamValue, Query, pathcat } from \"pathcat\";\nimport { Options, Response } from \"redaxios\";\n\nimport { APIResponse, Endpoints, ErroredAPIResponse } from \"./endpoints\";\nimport { APIRequestOptions, request } from \"./request\";\nimport { DEFAULT_API_URL } from \"../constants\";\n\nexport type PathsFor<M extends Options[\"method\"]> = Extract<\n Endpoints,\n { method: M }\n>[\"path\"];\n\nexport class TonightPassAPIError<T> extends Error {\n public readonly status: number;\n\n constructor(\n public readonly response: Response<APIResponse<T>>,\n public readonly data: ErroredAPIResponse,\n ) {\n super(data.message);\n\n this.status = response.status;\n }\n}\n\nexport interface ClientOptions {\n readonly baseURL: string;\n}\n\nexport class Client {\n private options;\n public readonly url;\n\n constructor(options: ClientOptions) {\n this.options = options;\n this.url = (path: string, params: Record<string, ParamValue>) => {\n const baseURL = this.options.baseURL || DEFAULT_API_URL;\n return pathcat(baseURL, path, params);\n };\n }\n\n setOptions(options: ClientOptions) {\n this.options = options;\n }\n\n async get<Path extends PathsFor<\"GET\">>(\n path: Path,\n query?: Query<Path>,\n options?: APIRequestOptions,\n ) {\n return this.requester<\n Extract<Endpoints, { path: Path; method: \"GET\" }>[\"res\"]\n >(\"GET\", path, undefined, query, options);\n }\n\n async post<Path extends Extract<Endpoints, { method: \"POST\" }>[\"path\"]>(\n path: Path,\n body: Extract<Endpoints, { path: Path; method: \"POST\" }>[\"body\"],\n query?: Query<Path>,\n options?: APIRequestOptions,\n ) {\n return this.requester<\n Extract<Endpoints, { path: Path; method: \"POST\" }>[\"res\"]\n >(\"POST\", path, body, query, options);\n }\n\n async put<Path extends Extract<Endpoints, { method: \"PUT\" }>[\"path\"]>(\n path: Path,\n body: Extract<Endpoints, { path: Path; method: \"PUT\" }>[\"body\"],\n query?: Query<Path>,\n options?: APIRequestOptions,\n ) {\n return this.requester<\n Extract<Endpoints, { path: Path; method: \"PUT\" }>[\"res\"]\n >(\"PUT\", path, body, query, options);\n }\n\n async patch<Path extends Extract<Endpoints, { method: \"PATCH\" }>[\"path\"]>(\n path: Path,\n body: Extract<Endpoints, { path: Path; method: \"PATCH\" }>[\"body\"],\n query?: Query<Path>,\n options?: APIRequestOptions,\n ) {\n return this.requester<\n Extract<Endpoints, { path: Path; method: \"PATCH\" }>[\"res\"]\n >(\"PATCH\", path, body, query, options);\n }\n\n async delete<Path extends Extract<Endpoints, { method: \"DELETE\" }>[\"path\"]>(\n path: Path,\n query?: Query<Path>,\n options?: APIRequestOptions,\n ) {\n return this.requester<\n Extract<Endpoints, { path: Path; method: \"DELETE\" }>[\"res\"]\n >(\"DELETE\", path, undefined, query, options);\n }\n\n private async requester<T>(\n method: Options[\"method\"],\n path: string,\n body: unknown,\n query: Query<string> = {},\n options: APIRequestOptions = {},\n ) {\n const url = this.url(path, query);\n\n if (body !== undefined) {\n if (method === \"GET\") {\n throw new Error(\"Cannot send a GET request with a body\");\n }\n }\n\n const response: Response<APIResponse<T>> = await request<T>(url, {\n method,\n data: body,\n ...options,\n });\n\n const result = response.data;\n\n if (!result.success) {\n throw new TonightPassAPIError<T>(response, result);\n }\n\n return result.data;\n }\n}\n","import { Client } from \"../rest\";\n\nexport function sdk<T>(builder: (client: Client) => T) {\n return builder;\n}\n","import { sdk } from \"./builder\";\n\nexport const health = sdk((client) => ({\n database: async () => client.get(\"/health/database\"),\n http: async () => client.get(\"/health/http\"),\n}));\n","import { sdk } from \"./builder\";\nimport { UpdateUserDto } from \"../rest\";\n\nexport const users = sdk((client) => ({\n getAll: async () => client.get(\"/users\"),\n get: async (id: string) => client.get(\"/users\", { id }),\n me: async () => client.get(\"/users/me\"),\n check: async (identifier: string, suggestions?: boolean) =>\n client.get(\"/users/check/:identifier\", { identifier, suggestions }),\n update: async (id: string, data: UpdateUserDto) =>\n client.put(\"/users/:id\", data, { id }),\n}));\n","import { Query } from \"pathcat\";\n\nimport { sdk } from \"./builder\";\n\nexport const careers = sdk((client) => ({\n categories: {\n getAll: async (query?: Query<\"/careers/categories\">) =>\n client.get(\"/careers/categories\", query),\n },\n employmentTypes: {\n getAll: async (query?: Query<\"/careers/employmentTypes\">) =>\n client.get(\"/careers/employmentTypes\", query),\n },\n jobs: {\n getAll: async (query?: Query<\"/careers/jobs\">) =>\n client.get(\"/careers/jobs\", query),\n get: async (id: number) => client.get(\"/careers/jobs/:id\", { id }),\n },\n offices: {\n getAll: async (query?: Query<\"/careers/offices\">) =>\n client.get(\"/careers/offices\", query),\n },\n}));\n","import { sdk } from \"./builder\";\n\nexport const profiles = sdk((client) => ({\n get: async (username: string) =>\n client.get(\"/profiles/:username\", { username }),\n}));\n","import { Client, ClientOptions } from \"./rest\";\nimport { careers } from \"./sdk/careers\";\nimport { health } from \"./sdk/health\";\nimport { profiles } from \"./sdk/profiles\";\nimport { users } from \"./sdk/users\";\n\nexport class TonightPass {\n public readonly client: Client;\n\n public readonly careers;\n public readonly health;\n public readonly profiles;\n public readonly users;\n\n constructor(options: ClientOptions) {\n this.client = new Client(options);\n\n this.careers = careers(this.client);\n this.health = health(this.client);\n this.profiles = profiles(this.client);\n this.users = users(this.client);\n }\n}\n"]}
|
package/package.json
CHANGED
package/src/index.ts
CHANGED
package/src/rest/client.ts
CHANGED
|
@@ -1,36 +1,15 @@
|
|
|
1
|
-
import { ParamValue, pathcat } from "pathcat";
|
|
1
|
+
import { ParamValue, Query, pathcat } from "pathcat";
|
|
2
2
|
import { Options, Response } from "redaxios";
|
|
3
3
|
|
|
4
4
|
import { APIResponse, Endpoints, ErroredAPIResponse } from "./endpoints";
|
|
5
5
|
import { APIRequestOptions, request } from "./request";
|
|
6
6
|
import { DEFAULT_API_URL } from "../constants";
|
|
7
7
|
|
|
8
|
-
export type ExtractRouteParams<T extends string> = string extends T
|
|
9
|
-
? Record<string, string | number | boolean | undefined>
|
|
10
|
-
: T extends `${string}:${infer Param}/${infer Rest}`
|
|
11
|
-
? {
|
|
12
|
-
[k in Param | keyof ExtractRouteParams<Rest>]:
|
|
13
|
-
| string
|
|
14
|
-
| number
|
|
15
|
-
| boolean;
|
|
16
|
-
}
|
|
17
|
-
: T extends `${string}:${infer Param}`
|
|
18
|
-
? { [k in Param]: string | number | boolean }
|
|
19
|
-
: object;
|
|
20
|
-
|
|
21
|
-
export type ExtractEndpoint<
|
|
22
|
-
Method extends string,
|
|
23
|
-
Path extends string,
|
|
24
|
-
> = Extract<Endpoints, { path: Path; method: Method }>;
|
|
25
|
-
|
|
26
8
|
export type PathsFor<M extends Options["method"]> = Extract<
|
|
27
9
|
Endpoints,
|
|
28
10
|
{ method: M }
|
|
29
11
|
>["path"];
|
|
30
12
|
|
|
31
|
-
export type Query<Path extends string> = ExtractRouteParams<Path> &
|
|
32
|
-
Record<string, string | number | boolean | undefined>;
|
|
33
|
-
|
|
34
13
|
export class TonightPassAPIError<T> extends Error {
|
|
35
14
|
public readonly status: number;
|
|
36
15
|
|
|
@@ -121,7 +100,7 @@ export class Client {
|
|
|
121
100
|
method: Options["method"],
|
|
122
101
|
path: string,
|
|
123
102
|
body: unknown,
|
|
124
|
-
query:
|
|
103
|
+
query: Query<string> = {},
|
|
125
104
|
options: APIRequestOptions = {},
|
|
126
105
|
) {
|
|
127
106
|
const url = this.url(path, query);
|
package/src/rest/endpoints.ts
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { Options } from "redaxios";
|
|
2
2
|
|
|
3
3
|
import {
|
|
4
|
+
AuthEndpoints,
|
|
4
5
|
CareersEndpoints,
|
|
5
6
|
HealthEndpoints,
|
|
6
7
|
ProfileEndpoints,
|
|
@@ -35,6 +36,7 @@ export type Endpoint<
|
|
|
35
36
|
};
|
|
36
37
|
|
|
37
38
|
export type Endpoints =
|
|
39
|
+
| AuthEndpoints
|
|
38
40
|
| CareersEndpoints
|
|
39
41
|
| HealthEndpoints
|
|
40
42
|
| ProfileEndpoints
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { CreateUserDto, SignInUserDto } from "../../dtos";
|
|
2
|
+
import { Endpoint } from "../../endpoints";
|
|
3
|
+
import { User } from "../users";
|
|
4
|
+
|
|
5
|
+
export type AuthEndpoints =
|
|
6
|
+
| Endpoint<"POST", "/auth/sign-up", User, CreateUserDto>
|
|
7
|
+
| Endpoint<"POST", "/auth/sign-in", User, SignInUserDto>
|
|
8
|
+
| Endpoint<"POST", "/auth/sign-out", void>
|
|
9
|
+
| Endpoint<"POST", "/auth/refresh-token", User>;
|
package/src/rest/types/index.ts
CHANGED
package/src/sdk/auth.ts
ADDED
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { sdk } from "./builder";
|
|
2
|
+
import { CreateUserDto, SignInUserDto } from "../rest";
|
|
3
|
+
|
|
4
|
+
export const auth = sdk((client) => ({
|
|
5
|
+
signIn: async (data: SignInUserDto) => client.post("/auth/sign-in", data),
|
|
6
|
+
signUp: async (data: CreateUserDto) => client.post("/auth/sign-up", data),
|
|
7
|
+
signOut: async () => client.post("/auth/sign-out", undefined),
|
|
8
|
+
refreshToken: async () => client.post("/auth/refresh-token", undefined),
|
|
9
|
+
}));
|
package/src/sdk/careers.ts
CHANGED
package/src/tonightpass.ts
CHANGED
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { Client, ClientOptions } from "./rest";
|
|
2
|
-
import { health, users } from "./sdk";
|
|
3
2
|
import { careers } from "./sdk/careers";
|
|
3
|
+
import { health } from "./sdk/health";
|
|
4
4
|
import { profiles } from "./sdk/profiles";
|
|
5
|
+
import { users } from "./sdk/users";
|
|
5
6
|
|
|
6
7
|
export class TonightPass {
|
|
7
8
|
public readonly client: Client;
|
|
File without changes
|