at-shared-types 1.2.7 → 1.2.8
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/dist/auth/auth.runtime.d.ts +6 -0
- package/dist/auth/auth.runtime.d.ts.map +1 -0
- package/dist/auth/domain/authSession.d.ts +21 -0
- package/dist/auth/domain/authSession.d.ts.map +1 -0
- package/dist/auth/index.d.ts +16 -0
- package/dist/auth/index.d.ts.map +1 -0
- package/dist/auth/providers/atplatform/atplatform.login.types.d.ts +9 -0
- package/dist/auth/providers/atplatform/atplatform.login.types.d.ts.map +1 -0
- package/dist/auth/providers/atplatform/atplatform.runtime.d.ts +6 -0
- package/dist/auth/providers/atplatform/atplatform.runtime.d.ts.map +1 -0
- package/dist/auth/providers/atplatform/atplatform.token.types.d.ts +9 -0
- package/dist/auth/providers/atplatform/atplatform.token.types.d.ts.map +1 -0
- package/dist/auth/providers/parto/parto.login.types.d.ts +28 -0
- package/dist/auth/providers/parto/parto.login.types.d.ts.map +1 -0
- package/dist/auth/providers/parto/parto.runtime.d.ts +6 -0
- package/dist/auth/providers/parto/parto.runtime.d.ts.map +1 -0
- package/dist/auth/providers/parto/parto.token.types.d.ts +13 -0
- package/dist/auth/providers/parto/parto.token.types.d.ts.map +1 -0
- package/dist/index.cjs +111 -0
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.ts +1 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.mjs +110 -0
- package/dist/index.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { ATAuthProviderType, ATAuthSessionDTO } from "./domain/authSession";
|
|
2
|
+
export * from "./providers/parto/parto.runtime";
|
|
3
|
+
export * from "./providers/atplatform/atplatform.runtime";
|
|
4
|
+
export declare function mapSessionFromLogin(providerType: ATAuthProviderType, response: unknown): ATAuthSessionDTO;
|
|
5
|
+
export declare function mapSessionFromToken(providerType: ATAuthProviderType, payload: unknown, token: string): ATAuthSessionDTO;
|
|
6
|
+
//# sourceMappingURL=auth.runtime.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth.runtime.d.ts","sourceRoot":"","sources":["../../src/auth/auth.runtime.ts"],"names":[],"mappings":"AAUA,OAAO,EAAE,kBAAkB,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AAE5E,cAAc,iCAAiC,CAAC;AAChD,cAAc,2CAA2C,CAAC;AAkB1D,wBAAgB,mBAAmB,CAC/B,YAAY,EAAE,kBAAkB,EAChC,QAAQ,EAAE,OAAO,GAClB,gBAAgB,CAOlB;AAED,wBAAgB,mBAAmB,CAC/B,YAAY,EAAE,kBAAkB,EAChC,OAAO,EAAE,OAAO,EAChB,KAAK,EAAE,MAAM,GACd,gBAAgB,CAOlB"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
export declare const ATAuthProviderTypes: readonly ["parto", "atplatform"];
|
|
2
|
+
export type ATAuthProviderType = typeof ATAuthProviderTypes[number];
|
|
3
|
+
export interface ATAuthUserDTO {
|
|
4
|
+
userID: string;
|
|
5
|
+
username?: string;
|
|
6
|
+
email?: string;
|
|
7
|
+
firstName?: string;
|
|
8
|
+
lastName?: string;
|
|
9
|
+
avatar?: string;
|
|
10
|
+
permissions?: string[];
|
|
11
|
+
}
|
|
12
|
+
export interface ATAuthSessionDTO {
|
|
13
|
+
token: string;
|
|
14
|
+
refreshToken?: string;
|
|
15
|
+
expiresAt?: number;
|
|
16
|
+
iss?: string;
|
|
17
|
+
providerType: ATAuthProviderType;
|
|
18
|
+
user: ATAuthUserDTO;
|
|
19
|
+
meta?: Record<string, unknown>;
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=authSession.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"authSession.d.ts","sourceRoot":"","sources":["../../../src/auth/domain/authSession.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,mBAAmB,kCAAmC,CAAC;AACpE,MAAM,MAAM,kBAAkB,GAAG,OAAO,mBAAmB,CAAC,MAAM,CAAC,CAAC;AAEpE,MAAM,WAAW,aAAa;IAC1B,MAAM,EAAE,MAAM,CAAC;IAEf,QAAQ,CAAC,EAAE,MAAM,CAAC;IAElB,KAAK,CAAC,EAAE,MAAM,CAAC;IAEf,SAAS,CAAC,EAAE,MAAM,CAAC;IAEnB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAElB,MAAM,CAAC,EAAE,MAAM,CAAC;IAEhB,WAAW,CAAC,EAAE,MAAM,EAAE,CAAC;CAC1B;AAED,MAAM,WAAW,gBAAgB;IAC7B,KAAK,EAAE,MAAM,CAAC;IAEd,YAAY,CAAC,EAAE,MAAM,CAAC;IAEtB,SAAS,CAAC,EAAE,MAAM,CAAC;IAEnB,GAAG,CAAC,EAAE,MAAM,CAAC;IAEb,YAAY,EAAE,kBAAkB,CAAC;IAEjC,IAAI,EAAE,aAAa,CAAC;IAGpB,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CAClC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
export * from "./domain/authSession";
|
|
2
|
+
export * from "./auth.runtime";
|
|
3
|
+
import * as CoreTypes from "./domain/authSession";
|
|
4
|
+
import * as Runtime from "./auth.runtime";
|
|
5
|
+
export declare namespace Types {
|
|
6
|
+
type ATAuthProviderType = CoreTypes.ATAuthProviderType;
|
|
7
|
+
type ATAuthUserDTO = CoreTypes.ATAuthUserDTO;
|
|
8
|
+
type ATAuthSessionDTO = CoreTypes.ATAuthSessionDTO;
|
|
9
|
+
type ATPlatformLoginResponseDTO = import("./providers/atplatform/atplatform.login.types").ATPlatformLoginResponseDTO;
|
|
10
|
+
type ATPlatformAccessTokenPayloadDTO = import("./providers/atplatform/atplatform.token.types").ATPlatformAccessTokenPayloadDTO;
|
|
11
|
+
type PartoUserInfoDTO = import("./providers/parto/parto.login.types").PartoUserInfoDTO;
|
|
12
|
+
type PartoLoginResponseDTO = import("./providers/parto/parto.login.types").PartoLoginResponseDTO;
|
|
13
|
+
type PartoAccessTokenPayloadDTO = import("./providers/parto/parto.token.types").PartoAccessTokenPayloadDTO;
|
|
14
|
+
}
|
|
15
|
+
export { Runtime };
|
|
16
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/auth/index.ts"],"names":[],"mappings":"AACA,cAAc,sBAAsB,CAAC;AACrC,cAAc,gBAAgB,CAAC;AAE/B,OAAO,KAAK,SAAS,MAAM,sBAAsB,CAAC;AAClD,OAAO,KAAK,OAAO,MAAM,gBAAgB,CAAC;AAG1C,yBAAiB,KAAK,CAAC;IAEnB,KAAY,kBAAkB,GAAG,SAAS,CAAC,kBAAkB,CAAC;IAC9D,KAAY,aAAa,GAAG,SAAS,CAAC,aAAa,CAAC;IACpD,KAAY,gBAAgB,GAAG,SAAS,CAAC,gBAAgB,CAAC;IAG1D,KAAY,0BAA0B,GAAG,OAAO,+CAA+C,EAAE,0BAA0B,CAAC;IAC5H,KAAY,+BAA+B,GAAG,OAAO,+CAA+C,EAAE,+BAA+B,CAAC;IAGtI,KAAY,gBAAgB,GAAG,OAAO,qCAAqC,EAAE,gBAAgB,CAAC;IAC9F,KAAY,qBAAqB,GAAG,OAAO,qCAAqC,EAAE,qBAAqB,CAAC;IACxG,KAAY,0BAA0B,GAAG,OAAO,qCAAqC,EAAE,0BAA0B,CAAC;CACrH;AAGD,OAAO,EAAE,OAAO,EAAE,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"atplatform.login.types.d.ts","sourceRoot":"","sources":["../../../../src/auth/providers/atplatform/atplatform.login.types.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,0BAA0B;IACvC,KAAK,EAAE,MAAM,CAAC;IAEd,aAAa,EAAE,MAAM,CAAC;IAEtB,OAAO,EAAE,MAAM,CAAC;IAEhB,QAAQ,EAAE,MAAM,CAAC;IAEjB,UAAU,EAAE,MAAM,CAAC;IAEnB,SAAS,EAAE,MAAM,CAAC;CACrB"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { ATAuthSessionDTO } from "../../domain/authSession";
|
|
2
|
+
import { ATPlatformLoginResponseDTO } from "./atplatform.login.types";
|
|
3
|
+
import { ATPlatformAccessTokenPayloadDTO } from "./atplatform.token.types";
|
|
4
|
+
export declare function mapATPlatformSessionFromLogin(response: ATPlatformLoginResponseDTO): ATAuthSessionDTO;
|
|
5
|
+
export declare function mapATPlatformSessionFromToken(payload: ATPlatformAccessTokenPayloadDTO, token: string): ATAuthSessionDTO;
|
|
6
|
+
//# sourceMappingURL=atplatform.runtime.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"atplatform.runtime.d.ts","sourceRoot":"","sources":["../../../../src/auth/providers/atplatform/atplatform.runtime.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;AAC5D,OAAO,EAAE,0BAA0B,EAAE,MAAM,0BAA0B,CAAC;AACtE,OAAO,EAAE,+BAA+B,EAAE,MAAM,0BAA0B,CAAC;AAE3E,wBAAgB,6BAA6B,CACzC,QAAQ,EAAE,0BAA0B,GACrC,gBAAgB,CAYlB;AAED,wBAAgB,6BAA6B,CACzC,OAAO,EAAE,+BAA+B,EACxC,KAAK,EAAE,MAAM,GACd,gBAAgB,CAUlB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"atplatform.token.types.d.ts","sourceRoot":"","sources":["../../../../src/auth/providers/atplatform/atplatform.token.types.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,+BAA+B;IAE5C,GAAG,EAAE,MAAM,CAAC;IAEZ,GAAG,EAAE,MAAM,CAAC;IAEZ,GAAG,EAAE,MAAM,CAAC;IAEZ,GAAG,EAAE,MAAM,CAAC;IAEZ,GAAG,EAAE,MAAM,CAAC;IACZ,GAAG,EAAE,MAAM,CAAC;CACf"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
export interface PartoUserInfoDTO {
|
|
2
|
+
ID: number;
|
|
3
|
+
userName: string;
|
|
4
|
+
firstName: string;
|
|
5
|
+
lastName: string;
|
|
6
|
+
isAgent: boolean;
|
|
7
|
+
birthdate: string;
|
|
8
|
+
businessTypeID: number;
|
|
9
|
+
companyName: string | null;
|
|
10
|
+
customerID: number | null;
|
|
11
|
+
department: string | null;
|
|
12
|
+
directPhone: string | null;
|
|
13
|
+
enabled: boolean;
|
|
14
|
+
factionsJson: string | null;
|
|
15
|
+
genderId: number;
|
|
16
|
+
internalPhone: string | null;
|
|
17
|
+
loginEnabled: boolean;
|
|
18
|
+
nationalCode: string | null;
|
|
19
|
+
offices: unknown;
|
|
20
|
+
phone: string | null;
|
|
21
|
+
roles: unknown;
|
|
22
|
+
}
|
|
23
|
+
export interface PartoLoginResponseDTO {
|
|
24
|
+
token: string;
|
|
25
|
+
refreshToken: string;
|
|
26
|
+
userInfo: PartoUserInfoDTO;
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=parto.login.types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"parto.login.types.d.ts","sourceRoot":"","sources":["../../../../src/auth/providers/parto/parto.login.types.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,gBAAgB;IAC7B,EAAE,EAAE,MAAM,CAAC;IAEX,QAAQ,EAAE,MAAM,CAAC;IAEjB,SAAS,EAAE,MAAM,CAAC;IAElB,QAAQ,EAAE,MAAM,CAAC;IAEjB,OAAO,EAAE,OAAO,CAAC;IAEjB,SAAS,EAAE,MAAM,CAAC;IAElB,cAAc,EAAE,MAAM,CAAC;IAEvB,WAAW,EAAE,MAAM,GAAG,IAAI,CAAC;IAE3B,UAAU,EAAE,MAAM,GAAG,IAAI,CAAC;IAE1B,UAAU,EAAE,MAAM,GAAG,IAAI,CAAC;IAE1B,WAAW,EAAE,MAAM,GAAG,IAAI,CAAC;IAE3B,OAAO,EAAE,OAAO,CAAC;IAEjB,YAAY,EAAE,MAAM,GAAG,IAAI,CAAC;IAE5B,QAAQ,EAAE,MAAM,CAAC;IAEjB,aAAa,EAAE,MAAM,GAAG,IAAI,CAAC;IAE7B,YAAY,EAAE,OAAO,CAAC;IAEtB,YAAY,EAAE,MAAM,GAAG,IAAI,CAAC;IAE5B,OAAO,EAAE,OAAO,CAAC;IAEjB,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;IAErB,KAAK,EAAE,OAAO,CAAC;CAClB;AAED,MAAM,WAAW,qBAAqB;IAClC,KAAK,EAAE,MAAM,CAAC;IAEd,YAAY,EAAE,MAAM,CAAC;IAErB,QAAQ,EAAE,gBAAgB,CAAC;CAC9B"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { ATAuthSessionDTO } from "../../domain/authSession";
|
|
2
|
+
import { PartoLoginResponseDTO } from "./parto.login.types";
|
|
3
|
+
import { PartoAccessTokenPayloadDTO } from "./parto.token.types";
|
|
4
|
+
export declare function mapPartoSessionFromLogin(response: PartoLoginResponseDTO): ATAuthSessionDTO;
|
|
5
|
+
export declare function mapPartoSessionFromToken(payload: PartoAccessTokenPayloadDTO, token: string): ATAuthSessionDTO;
|
|
6
|
+
//# sourceMappingURL=parto.runtime.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"parto.runtime.d.ts","sourceRoot":"","sources":["../../../../src/auth/providers/parto/parto.runtime.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;AAC5D,OAAO,EAAE,qBAAqB,EAAE,MAAM,qBAAqB,CAAC;AAC5D,OAAO,EAAE,0BAA0B,EAAE,MAAM,qBAAqB,CAAC;AAEjE,wBAAgB,wBAAwB,CACpC,QAAQ,EAAE,qBAAqB,GAChC,gBAAgB,CAmBlB;AAED,wBAAgB,wBAAwB,CACpC,OAAO,EAAE,0BAA0B,EACnC,KAAK,EAAE,MAAM,GACd,gBAAgB,CAYlB"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export interface PartoAccessTokenPayloadDTO {
|
|
2
|
+
aud: string;
|
|
3
|
+
iss: string;
|
|
4
|
+
sub?: string;
|
|
5
|
+
ID: string;
|
|
6
|
+
CUSTOMERID?: string;
|
|
7
|
+
PERMISSIONS?: string;
|
|
8
|
+
unique_name?: string;
|
|
9
|
+
exp: number;
|
|
10
|
+
iat: number;
|
|
11
|
+
nbf?: number;
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=parto.token.types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"parto.token.types.d.ts","sourceRoot":"","sources":["../../../../src/auth/providers/parto/parto.token.types.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,0BAA0B;IACvC,GAAG,EAAE,MAAM,CAAC;IAEZ,GAAG,EAAE,MAAM,CAAC;IAEZ,GAAG,CAAC,EAAE,MAAM,CAAC;IAEb,EAAE,EAAE,MAAM,CAAC;IAEX,UAAU,CAAC,EAAE,MAAM,CAAC;IAEpB,WAAW,CAAC,EAAE,MAAM,CAAC;IAErB,WAAW,CAAC,EAAE,MAAM,CAAC;IAErB,GAAG,EAAE,MAAM,CAAC;IAEZ,GAAG,EAAE,MAAM,CAAC;IAEZ,GAAG,CAAC,EAAE,MAAM,CAAC;CAChB"}
|
package/dist/index.cjs
CHANGED
|
@@ -20,6 +20,7 @@ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: tru
|
|
|
20
20
|
// src/index.ts
|
|
21
21
|
var src_exports = {};
|
|
22
22
|
__export(src_exports, {
|
|
23
|
+
ATAuth: () => auth_exports,
|
|
23
24
|
ATCasing: () => casing_exports
|
|
24
25
|
});
|
|
25
26
|
module.exports = __toCommonJS(src_exports);
|
|
@@ -76,8 +77,118 @@ function toCamelDeep(value) {
|
|
|
76
77
|
}
|
|
77
78
|
return value;
|
|
78
79
|
}
|
|
80
|
+
|
|
81
|
+
// src/auth/index.ts
|
|
82
|
+
var auth_exports = {};
|
|
83
|
+
__export(auth_exports, {
|
|
84
|
+
ATAuthProviderTypes: () => ATAuthProviderTypes,
|
|
85
|
+
Runtime: () => auth_runtime_exports,
|
|
86
|
+
mapATPlatformSessionFromLogin: () => mapATPlatformSessionFromLogin,
|
|
87
|
+
mapATPlatformSessionFromToken: () => mapATPlatformSessionFromToken,
|
|
88
|
+
mapPartoSessionFromLogin: () => mapPartoSessionFromLogin,
|
|
89
|
+
mapPartoSessionFromToken: () => mapPartoSessionFromToken,
|
|
90
|
+
mapSessionFromLogin: () => mapSessionFromLogin,
|
|
91
|
+
mapSessionFromToken: () => mapSessionFromToken
|
|
92
|
+
});
|
|
93
|
+
|
|
94
|
+
// src/auth/domain/authSession.ts
|
|
95
|
+
var ATAuthProviderTypes = ["parto", "atplatform"];
|
|
96
|
+
|
|
97
|
+
// src/auth/auth.runtime.ts
|
|
98
|
+
var auth_runtime_exports = {};
|
|
99
|
+
__export(auth_runtime_exports, {
|
|
100
|
+
mapATPlatformSessionFromLogin: () => mapATPlatformSessionFromLogin,
|
|
101
|
+
mapATPlatformSessionFromToken: () => mapATPlatformSessionFromToken,
|
|
102
|
+
mapPartoSessionFromLogin: () => mapPartoSessionFromLogin,
|
|
103
|
+
mapPartoSessionFromToken: () => mapPartoSessionFromToken,
|
|
104
|
+
mapSessionFromLogin: () => mapSessionFromLogin,
|
|
105
|
+
mapSessionFromToken: () => mapSessionFromToken
|
|
106
|
+
});
|
|
107
|
+
|
|
108
|
+
// src/auth/providers/parto/parto.runtime.ts
|
|
109
|
+
function mapPartoSessionFromLogin(response) {
|
|
110
|
+
const user = response.userInfo;
|
|
111
|
+
return {
|
|
112
|
+
token: response.token,
|
|
113
|
+
refreshToken: response.refreshToken,
|
|
114
|
+
providerType: "parto",
|
|
115
|
+
user: {
|
|
116
|
+
userID: String(user.ID),
|
|
117
|
+
username: user.userName,
|
|
118
|
+
firstName: user.firstName,
|
|
119
|
+
lastName: user.lastName
|
|
120
|
+
},
|
|
121
|
+
meta: {
|
|
122
|
+
department: user.department,
|
|
123
|
+
companyName: user.companyName,
|
|
124
|
+
businessTypeID: user.businessTypeID
|
|
125
|
+
}
|
|
126
|
+
};
|
|
127
|
+
}
|
|
128
|
+
function mapPartoSessionFromToken(payload, token) {
|
|
129
|
+
return {
|
|
130
|
+
token,
|
|
131
|
+
expiresAt: payload.exp,
|
|
132
|
+
providerType: "parto",
|
|
133
|
+
iss: payload.iss,
|
|
134
|
+
user: {
|
|
135
|
+
userID: payload.ID,
|
|
136
|
+
username: payload.unique_name,
|
|
137
|
+
permissions: payload.PERMISSIONS?.split(",")
|
|
138
|
+
}
|
|
139
|
+
};
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
// src/auth/providers/atplatform/atplatform.runtime.ts
|
|
143
|
+
function mapATPlatformSessionFromLogin(response) {
|
|
144
|
+
return {
|
|
145
|
+
token: response.token,
|
|
146
|
+
refreshToken: response.refresh_token,
|
|
147
|
+
providerType: "atplatform",
|
|
148
|
+
user: {
|
|
149
|
+
userID: String(response.user_id),
|
|
150
|
+
username: response.username,
|
|
151
|
+
firstName: response.first_name,
|
|
152
|
+
lastName: response.last_name
|
|
153
|
+
}
|
|
154
|
+
};
|
|
155
|
+
}
|
|
156
|
+
function mapATPlatformSessionFromToken(payload, token) {
|
|
157
|
+
return {
|
|
158
|
+
token,
|
|
159
|
+
expiresAt: payload.exp,
|
|
160
|
+
iss: payload.iss,
|
|
161
|
+
providerType: "atplatform",
|
|
162
|
+
user: {
|
|
163
|
+
userID: payload.sub
|
|
164
|
+
}
|
|
165
|
+
};
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
// src/auth/auth.runtime.ts
|
|
169
|
+
var mapSessionFromLoginByProvider = {
|
|
170
|
+
atplatform: mapATPlatformSessionFromLogin,
|
|
171
|
+
parto: mapPartoSessionFromLogin
|
|
172
|
+
};
|
|
173
|
+
var mapSessionFromTokenByProvider = {
|
|
174
|
+
atplatform: mapATPlatformSessionFromToken,
|
|
175
|
+
parto: mapPartoSessionFromToken
|
|
176
|
+
};
|
|
177
|
+
function mapSessionFromLogin(providerType, response) {
|
|
178
|
+
const mapper = mapSessionFromLoginByProvider[providerType];
|
|
179
|
+
if (!mapper)
|
|
180
|
+
throw new Error(`Unsupported provider type: ${providerType}`);
|
|
181
|
+
return mapper(response);
|
|
182
|
+
}
|
|
183
|
+
function mapSessionFromToken(providerType, payload, token) {
|
|
184
|
+
const mapper = mapSessionFromTokenByProvider[providerType];
|
|
185
|
+
if (!mapper)
|
|
186
|
+
throw new Error(`Unsupported provider type: ${providerType}`);
|
|
187
|
+
return mapper(payload, token);
|
|
188
|
+
}
|
|
79
189
|
// Annotate the CommonJS export names for ESM import in node:
|
|
80
190
|
0 && (module.exports = {
|
|
191
|
+
ATAuth,
|
|
81
192
|
ATCasing
|
|
82
193
|
});
|
|
83
194
|
//# sourceMappingURL=index.cjs.map
|
package/dist/index.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/index.ts","../src/casing/index.ts","../src/casing/case.types.ts","../src/casing/case.runtime.ts"],"sourcesContent":["export * as ATCasing from \"./casing\";\r\n\r\n","// src/casing/index.ts\r\nexport * from \"./case.types\";\r\nexport * from \"./case.runtime\";\r\n\r\n// (optional) if you still like namespaces, keep them too:\r\nimport * as Types from \"./case.types\";\r\nimport * as Runtime from \"./case.runtime\";\r\nexport { Types, Runtime };\r\n","type FixAcronyms<S extends string> =\r\n S extends `${infer A}ID${infer B}` ? FixAcronyms<`${A}Id${B}`> : S;\r\n\r\nexport type SnakeCase<S extends string> =\r\n S extends `${infer H}${infer T}`\r\n ? T extends Uncapitalize<T>\r\n ? `${Lowercase<H>}${SnakeCase<T>}`\r\n : `${Lowercase<H>}_${SnakeCase<Uncapitalize<T>>}`\r\n : S;\r\n\r\nexport type CamelCase<S extends string> =\r\n S extends `${infer A}_${infer B}`\r\n ? `${A}${Capitalize<CamelCase<B>>}`\r\n : S;\r\n\r\ntype Primitive = string | number | boolean | bigint | symbol | null | undefined;\r\ntype Builtin = Primitive | Date | RegExp | Error;\r\n\r\nexport type DeepSnakeKeys<T> =\r\n T extends Builtin ? T :\r\n T extends (...args: any[]) => any ? T :\r\n T extends readonly [any, ...any[]]\r\n ? { [I in keyof T]: DeepSnakeKeys<T[I]> } :\r\n T extends ReadonlyArray<infer U>\r\n ? ReadonlyArray<DeepSnakeKeys<U>> :\r\n T extends Map<infer K, infer V>\r\n ? Map<DeepSnakeKeys<K>, DeepSnakeKeys<V>> :\r\n T extends Set<infer U>\r\n ? Set<DeepSnakeKeys<U>> :\r\n T extends object\r\n ? {\r\n [K in keyof T as K extends string\r\n ? SnakeCase<FixAcronyms<K>>\r\n : K\r\n ]: DeepSnakeKeys<T[K]>\r\n }\r\n : T;\r\n\r\nexport type DeepCamelKeys<T> =\r\n T extends Builtin ? T :\r\n T extends (...args: any[]) => any ? T :\r\n T extends readonly [any, ...any[]]\r\n ? { [I in keyof T]: DeepCamelKeys<T[I]> } :\r\n T extends ReadonlyArray<infer U>\r\n ? ReadonlyArray<DeepCamelKeys<U>> :\r\n T extends Map<infer K, infer V>\r\n ? Map<DeepCamelKeys<K>, DeepCamelKeys<V>> :\r\n T extends Set<infer U>\r\n ? Set<DeepCamelKeys<U>> :\r\n T extends object\r\n ? { [K in keyof T as K extends string ? CamelCase<K> : K]: DeepCamelKeys<T[K]> }\r\n : T;\r\n","const CAMEL_TO_SNAKE = /[A-Z]/g;\r\nconst SNAKE_TO_CAMEL = /_([a-z])/g;\r\n\r\n// Normalize common acronyms before snake conversion\r\nconst normalizeAcronyms = (k: string) => k.replace(/ID/g, \"Id\");\r\n\r\nexport const toSnakeKey = (k: string) =>\r\n normalizeAcronyms(k).replace(CAMEL_TO_SNAKE, m => `_${m.toLowerCase()}`);\r\n\r\nexport const toCamelKey = (k: string) =>\r\n k.replace(SNAKE_TO_CAMEL, (_, c) => c.toUpperCase());\r\n\r\nexport function toSnakeDeep<T>(value: T, exceptions = new Set<string>()): any {\r\n if (Array.isArray(value)) return value.map(v => toSnakeDeep(v, exceptions));\r\n if (value instanceof Date) return value;\r\n if (value && typeof value === \"object\") {\r\n const out: Record<string, any> = {};\r\n for (const [k, v] of Object.entries(value as any)) {\r\n const nk = exceptions.has(k) ? k : toSnakeKey(k);\r\n out[nk] = toSnakeDeep(v, exceptions);\r\n }\r\n return out;\r\n }\r\n return value;\r\n}\r\n\r\nexport function toCamelDeep<T>(value: T): any {\r\n if (Array.isArray(value)) return value.map(toCamelDeep);\r\n if (value instanceof Date) return value;\r\n if (value && typeof value === \"object\") {\r\n const out: Record<string, any> = {};\r\n for (const [k, v] of Object.entries(value as any)) {\r\n out[toCamelKey(k)] = toCamelDeep(v);\r\n }\r\n return out;\r\n }\r\n return value;\r\n}\r\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACAA;;;ACAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAAM,iBAAiB;AACvB,IAAM,iBAAiB;AAGvB,IAAM,oBAAoB,CAAC,MAAc,EAAE,QAAQ,OAAO,IAAI;AAEvD,IAAM,aAAa,CAAC,MACvB,kBAAkB,CAAC,EAAE,QAAQ,gBAAgB,OAAK,IAAI,EAAE,YAAY,CAAC,EAAE;AAEpE,IAAM,aAAa,CAAC,MACvB,EAAE,QAAQ,gBAAgB,CAAC,GAAG,MAAM,EAAE,YAAY,CAAC;AAEhD,SAAS,YAAe,OAAU,aAAa,oBAAI,IAAY,GAAQ;AAC1E,MAAI,MAAM,QAAQ,KAAK,EAAG,QAAO,MAAM,IAAI,OAAK,YAAY,GAAG,UAAU,CAAC;AAC1E,MAAI,iBAAiB,KAAM,QAAO;AAClC,MAAI,SAAS,OAAO,UAAU,UAAU;AACpC,UAAM,MAA2B,CAAC;AAClC,eAAW,CAAC,GAAG,CAAC,KAAK,OAAO,QAAQ,KAAY,GAAG;AAC/C,YAAM,KAAK,WAAW,IAAI,CAAC,IAAI,IAAI,WAAW,CAAC;AAC/C,UAAI,EAAE,IAAI,YAAY,GAAG,UAAU;AAAA,IACvC;AACA,WAAO;AAAA,EACX;AACA,SAAO;AACX;AAEO,SAAS,YAAe,OAAe;AAC1C,MAAI,MAAM,QAAQ,KAAK,EAAG,QAAO,MAAM,IAAI,WAAW;AACtD,MAAI,iBAAiB,KAAM,QAAO;AAClC,MAAI,SAAS,OAAO,UAAU,UAAU;AACpC,UAAM,MAA2B,CAAC;AAClC,eAAW,CAAC,GAAG,CAAC,KAAK,OAAO,QAAQ,KAAY,GAAG;AAC/C,UAAI,WAAW,CAAC,CAAC,IAAI,YAAY,CAAC;AAAA,IACtC;AACA,WAAO;AAAA,EACX;AACA,SAAO;AACX;","names":[]}
|
|
1
|
+
{"version":3,"sources":["../src/index.ts","../src/casing/index.ts","../src/casing/case.types.ts","../src/casing/case.runtime.ts","../src/auth/index.ts","../src/auth/domain/authSession.ts","../src/auth/auth.runtime.ts","../src/auth/providers/parto/parto.runtime.ts","../src/auth/providers/atplatform/atplatform.runtime.ts"],"sourcesContent":["export * as ATCasing from \"./casing\";\r\nexport * as ATAuth from \"./auth\";","// src/casing/index.ts\r\nexport * from \"./case.types\";\r\nexport * from \"./case.runtime\";\r\n\r\n// (optional) if you still like namespaces, keep them too:\r\nimport * as Types from \"./case.types\";\r\nimport * as Runtime from \"./case.runtime\";\r\nexport { Types, Runtime };\r\n","type FixAcronyms<S extends string> =\r\n S extends `${infer A}ID${infer B}` ? FixAcronyms<`${A}Id${B}`> : S;\r\n\r\nexport type SnakeCase<S extends string> =\r\n S extends `${infer H}${infer T}`\r\n ? T extends Uncapitalize<T>\r\n ? `${Lowercase<H>}${SnakeCase<T>}`\r\n : `${Lowercase<H>}_${SnakeCase<Uncapitalize<T>>}`\r\n : S;\r\n\r\nexport type CamelCase<S extends string> =\r\n S extends `${infer A}_${infer B}`\r\n ? `${A}${Capitalize<CamelCase<B>>}`\r\n : S;\r\n\r\ntype Primitive = string | number | boolean | bigint | symbol | null | undefined;\r\ntype Builtin = Primitive | Date | RegExp | Error;\r\n\r\nexport type DeepSnakeKeys<T> =\r\n T extends Builtin ? T :\r\n T extends (...args: any[]) => any ? T :\r\n T extends readonly [any, ...any[]]\r\n ? { [I in keyof T]: DeepSnakeKeys<T[I]> } :\r\n T extends ReadonlyArray<infer U>\r\n ? ReadonlyArray<DeepSnakeKeys<U>> :\r\n T extends Map<infer K, infer V>\r\n ? Map<DeepSnakeKeys<K>, DeepSnakeKeys<V>> :\r\n T extends Set<infer U>\r\n ? Set<DeepSnakeKeys<U>> :\r\n T extends object\r\n ? {\r\n [K in keyof T as K extends string\r\n ? SnakeCase<FixAcronyms<K>>\r\n : K\r\n ]: DeepSnakeKeys<T[K]>\r\n }\r\n : T;\r\n\r\nexport type DeepCamelKeys<T> =\r\n T extends Builtin ? T :\r\n T extends (...args: any[]) => any ? T :\r\n T extends readonly [any, ...any[]]\r\n ? { [I in keyof T]: DeepCamelKeys<T[I]> } :\r\n T extends ReadonlyArray<infer U>\r\n ? ReadonlyArray<DeepCamelKeys<U>> :\r\n T extends Map<infer K, infer V>\r\n ? Map<DeepCamelKeys<K>, DeepCamelKeys<V>> :\r\n T extends Set<infer U>\r\n ? Set<DeepCamelKeys<U>> :\r\n T extends object\r\n ? { [K in keyof T as K extends string ? CamelCase<K> : K]: DeepCamelKeys<T[K]> }\r\n : T;\r\n","const CAMEL_TO_SNAKE = /[A-Z]/g;\r\nconst SNAKE_TO_CAMEL = /_([a-z])/g;\r\n\r\n// Normalize common acronyms before snake conversion\r\nconst normalizeAcronyms = (k: string) => k.replace(/ID/g, \"Id\");\r\n\r\nexport const toSnakeKey = (k: string) =>\r\n normalizeAcronyms(k).replace(CAMEL_TO_SNAKE, m => `_${m.toLowerCase()}`);\r\n\r\nexport const toCamelKey = (k: string) =>\r\n k.replace(SNAKE_TO_CAMEL, (_, c) => c.toUpperCase());\r\n\r\nexport function toSnakeDeep<T>(value: T, exceptions = new Set<string>()): any {\r\n if (Array.isArray(value)) return value.map(v => toSnakeDeep(v, exceptions));\r\n if (value instanceof Date) return value;\r\n if (value && typeof value === \"object\") {\r\n const out: Record<string, any> = {};\r\n for (const [k, v] of Object.entries(value as any)) {\r\n const nk = exceptions.has(k) ? k : toSnakeKey(k);\r\n out[nk] = toSnakeDeep(v, exceptions);\r\n }\r\n return out;\r\n }\r\n return value;\r\n}\r\n\r\nexport function toCamelDeep<T>(value: T): any {\r\n if (Array.isArray(value)) return value.map(toCamelDeep);\r\n if (value instanceof Date) return value;\r\n if (value && typeof value === \"object\") {\r\n const out: Record<string, any> = {};\r\n for (const [k, v] of Object.entries(value as any)) {\r\n out[toCamelKey(k)] = toCamelDeep(v);\r\n }\r\n return out;\r\n }\r\n return value;\r\n}\r\n","// Export core auth models & runtime functions\r\nexport * from \"./domain/authSession\";\r\nexport * from \"./auth.runtime\";\r\n\r\nimport * as CoreTypes from \"./domain/authSession\";\r\nimport * as Runtime from \"./auth.runtime\";\r\n\r\n// Exported namespace grouping all domain, session, and provider-specific types\r\nexport namespace Types {\r\n // Core session types\r\n export type ATAuthProviderType = CoreTypes.ATAuthProviderType;\r\n export type ATAuthUserDTO = CoreTypes.ATAuthUserDTO;\r\n export type ATAuthSessionDTO = CoreTypes.ATAuthSessionDTO;\r\n\r\n // ATPlatform Types\r\n export type ATPlatformLoginResponseDTO = import(\"./providers/atplatform/atplatform.login.types\").ATPlatformLoginResponseDTO;\r\n export type ATPlatformAccessTokenPayloadDTO = import(\"./providers/atplatform/atplatform.token.types\").ATPlatformAccessTokenPayloadDTO;\r\n\r\n // Parto Types\r\n export type PartoUserInfoDTO = import(\"./providers/parto/parto.login.types\").PartoUserInfoDTO;\r\n export type PartoLoginResponseDTO = import(\"./providers/parto/parto.login.types\").PartoLoginResponseDTO;\r\n export type PartoAccessTokenPayloadDTO = import(\"./providers/parto/parto.token.types\").PartoAccessTokenPayloadDTO;\r\n}\r\n\r\n// Export runtime under a clean namespace\r\nexport { Runtime };\r\n","export const ATAuthProviderTypes = [\"parto\", \"atplatform\"] as const;\r\nexport type ATAuthProviderType = typeof ATAuthProviderTypes[number];\r\n\r\nexport interface ATAuthUserDTO {\r\n userID: string;\r\n\r\n username?: string;\r\n\r\n email?: string;\r\n\r\n firstName?: string;\r\n\r\n lastName?: string;\r\n\r\n avatar?: string;\r\n\r\n permissions?: string[];\r\n}\r\n\r\nexport interface ATAuthSessionDTO {\r\n token: string;\r\n\r\n refreshToken?: string;\r\n\r\n expiresAt?: number;\r\n\r\n iss?: string;\r\n\r\n providerType: ATAuthProviderType;\r\n\r\n user: ATAuthUserDTO;\r\n\r\n //issuer junks \r\n meta?: Record<string, unknown>;\r\n}\r\n","import {\r\n mapPartoSessionFromLogin,\r\n mapPartoSessionFromToken,\r\n} from \"./providers/parto/parto.runtime\";\r\n\r\nimport {\r\n mapATPlatformSessionFromLogin,\r\n mapATPlatformSessionFromToken,\r\n} from \"./providers/atplatform/atplatform.runtime\";\r\n\r\nimport { ATAuthProviderType, ATAuthSessionDTO } from \"./domain/authSession\";\r\n\r\nexport * from \"./providers/parto/parto.runtime\";\r\nexport * from \"./providers/atplatform/atplatform.runtime\";\r\n\r\nconst mapSessionFromLoginByProvider: Record<\r\n ATAuthProviderType,\r\n (response: any) => ATAuthSessionDTO\r\n> = {\r\n atplatform: mapATPlatformSessionFromLogin,\r\n parto: mapPartoSessionFromLogin,\r\n};\r\n\r\nconst mapSessionFromTokenByProvider: Record<\r\n ATAuthProviderType,\r\n (payload: any, token: string) => ATAuthSessionDTO\r\n> = {\r\n atplatform: mapATPlatformSessionFromToken,\r\n parto: mapPartoSessionFromToken,\r\n};\r\n\r\nexport function mapSessionFromLogin(\r\n providerType: ATAuthProviderType,\r\n response: unknown,\r\n): ATAuthSessionDTO {\r\n const mapper = mapSessionFromLoginByProvider[providerType];\r\n\r\n if (!mapper)\r\n throw new Error(`Unsupported provider type: ${providerType}`);\r\n\r\n return mapper(response);\r\n}\r\n\r\nexport function mapSessionFromToken(\r\n providerType: ATAuthProviderType,\r\n payload: unknown,\r\n token: string\r\n): ATAuthSessionDTO {\r\n const mapper = mapSessionFromTokenByProvider[providerType];\r\n\r\n if (!mapper)\r\n throw new Error(`Unsupported provider type: ${providerType}`);\r\n\r\n return mapper(payload, token);\r\n}\r\n\r\n","import { ATAuthSessionDTO } from \"../../domain/authSession\";\r\nimport { PartoLoginResponseDTO } from \"./parto.login.types\";\r\nimport { PartoAccessTokenPayloadDTO } from \"./parto.token.types\";\r\n\r\nexport function mapPartoSessionFromLogin(\r\n response: PartoLoginResponseDTO\r\n): ATAuthSessionDTO {\r\n const user = response.userInfo;\r\n\r\n return {\r\n token: response.token,\r\n refreshToken: response.refreshToken,\r\n providerType: 'parto',\r\n user: {\r\n userID: String(user.ID),\r\n username: user.userName,\r\n firstName: user.firstName,\r\n lastName: user.lastName\r\n },\r\n meta: {\r\n department: user.department,\r\n companyName: user.companyName,\r\n businessTypeID: user.businessTypeID\r\n }\r\n };\r\n}\r\n\r\nexport function mapPartoSessionFromToken(\r\n payload: PartoAccessTokenPayloadDTO,\r\n token: string\r\n): ATAuthSessionDTO {\r\n return {\r\n token,\r\n expiresAt: payload.exp,\r\n providerType: 'parto',\r\n iss: payload.iss,\r\n user: {\r\n userID: payload.ID,\r\n username: payload.unique_name,\r\n permissions: payload.PERMISSIONS?.split(\",\")\r\n }\r\n };\r\n}\r\n","import { ATAuthSessionDTO } from \"../../domain/authSession\";\r\nimport { ATPlatformLoginResponseDTO } from \"./atplatform.login.types\";\r\nimport { ATPlatformAccessTokenPayloadDTO } from \"./atplatform.token.types\";\r\n\r\nexport function mapATPlatformSessionFromLogin(\r\n response: ATPlatformLoginResponseDTO\r\n): ATAuthSessionDTO {\r\n return {\r\n token: response.token,\r\n refreshToken: response.refresh_token,\r\n providerType: 'atplatform',\r\n user: {\r\n userID: String(response.user_id),\r\n username: response.username,\r\n firstName: response.first_name,\r\n lastName: response.last_name\r\n }\r\n };\r\n}\r\n\r\nexport function mapATPlatformSessionFromToken(\r\n payload: ATPlatformAccessTokenPayloadDTO,\r\n token: string\r\n): ATAuthSessionDTO {\r\n return {\r\n token,\r\n expiresAt: payload.exp,\r\n iss: payload.iss,\r\n providerType: 'atplatform',\r\n user: {\r\n userID: payload.sub\r\n }\r\n };\r\n}\r\n"],"mappings":"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","names":[]}
|
package/dist/index.d.ts
CHANGED
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,QAAQ,MAAM,UAAU,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,QAAQ,MAAM,UAAU,CAAC;AACrC,OAAO,KAAK,MAAM,MAAM,QAAQ,CAAC"}
|
package/dist/index.mjs
CHANGED
|
@@ -54,7 +54,117 @@ function toCamelDeep(value) {
|
|
|
54
54
|
}
|
|
55
55
|
return value;
|
|
56
56
|
}
|
|
57
|
+
|
|
58
|
+
// src/auth/index.ts
|
|
59
|
+
var auth_exports = {};
|
|
60
|
+
__export(auth_exports, {
|
|
61
|
+
ATAuthProviderTypes: () => ATAuthProviderTypes,
|
|
62
|
+
Runtime: () => auth_runtime_exports,
|
|
63
|
+
mapATPlatformSessionFromLogin: () => mapATPlatformSessionFromLogin,
|
|
64
|
+
mapATPlatformSessionFromToken: () => mapATPlatformSessionFromToken,
|
|
65
|
+
mapPartoSessionFromLogin: () => mapPartoSessionFromLogin,
|
|
66
|
+
mapPartoSessionFromToken: () => mapPartoSessionFromToken,
|
|
67
|
+
mapSessionFromLogin: () => mapSessionFromLogin,
|
|
68
|
+
mapSessionFromToken: () => mapSessionFromToken
|
|
69
|
+
});
|
|
70
|
+
|
|
71
|
+
// src/auth/domain/authSession.ts
|
|
72
|
+
var ATAuthProviderTypes = ["parto", "atplatform"];
|
|
73
|
+
|
|
74
|
+
// src/auth/auth.runtime.ts
|
|
75
|
+
var auth_runtime_exports = {};
|
|
76
|
+
__export(auth_runtime_exports, {
|
|
77
|
+
mapATPlatformSessionFromLogin: () => mapATPlatformSessionFromLogin,
|
|
78
|
+
mapATPlatformSessionFromToken: () => mapATPlatformSessionFromToken,
|
|
79
|
+
mapPartoSessionFromLogin: () => mapPartoSessionFromLogin,
|
|
80
|
+
mapPartoSessionFromToken: () => mapPartoSessionFromToken,
|
|
81
|
+
mapSessionFromLogin: () => mapSessionFromLogin,
|
|
82
|
+
mapSessionFromToken: () => mapSessionFromToken
|
|
83
|
+
});
|
|
84
|
+
|
|
85
|
+
// src/auth/providers/parto/parto.runtime.ts
|
|
86
|
+
function mapPartoSessionFromLogin(response) {
|
|
87
|
+
const user = response.userInfo;
|
|
88
|
+
return {
|
|
89
|
+
token: response.token,
|
|
90
|
+
refreshToken: response.refreshToken,
|
|
91
|
+
providerType: "parto",
|
|
92
|
+
user: {
|
|
93
|
+
userID: String(user.ID),
|
|
94
|
+
username: user.userName,
|
|
95
|
+
firstName: user.firstName,
|
|
96
|
+
lastName: user.lastName
|
|
97
|
+
},
|
|
98
|
+
meta: {
|
|
99
|
+
department: user.department,
|
|
100
|
+
companyName: user.companyName,
|
|
101
|
+
businessTypeID: user.businessTypeID
|
|
102
|
+
}
|
|
103
|
+
};
|
|
104
|
+
}
|
|
105
|
+
function mapPartoSessionFromToken(payload, token) {
|
|
106
|
+
return {
|
|
107
|
+
token,
|
|
108
|
+
expiresAt: payload.exp,
|
|
109
|
+
providerType: "parto",
|
|
110
|
+
iss: payload.iss,
|
|
111
|
+
user: {
|
|
112
|
+
userID: payload.ID,
|
|
113
|
+
username: payload.unique_name,
|
|
114
|
+
permissions: payload.PERMISSIONS?.split(",")
|
|
115
|
+
}
|
|
116
|
+
};
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
// src/auth/providers/atplatform/atplatform.runtime.ts
|
|
120
|
+
function mapATPlatformSessionFromLogin(response) {
|
|
121
|
+
return {
|
|
122
|
+
token: response.token,
|
|
123
|
+
refreshToken: response.refresh_token,
|
|
124
|
+
providerType: "atplatform",
|
|
125
|
+
user: {
|
|
126
|
+
userID: String(response.user_id),
|
|
127
|
+
username: response.username,
|
|
128
|
+
firstName: response.first_name,
|
|
129
|
+
lastName: response.last_name
|
|
130
|
+
}
|
|
131
|
+
};
|
|
132
|
+
}
|
|
133
|
+
function mapATPlatformSessionFromToken(payload, token) {
|
|
134
|
+
return {
|
|
135
|
+
token,
|
|
136
|
+
expiresAt: payload.exp,
|
|
137
|
+
iss: payload.iss,
|
|
138
|
+
providerType: "atplatform",
|
|
139
|
+
user: {
|
|
140
|
+
userID: payload.sub
|
|
141
|
+
}
|
|
142
|
+
};
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
// src/auth/auth.runtime.ts
|
|
146
|
+
var mapSessionFromLoginByProvider = {
|
|
147
|
+
atplatform: mapATPlatformSessionFromLogin,
|
|
148
|
+
parto: mapPartoSessionFromLogin
|
|
149
|
+
};
|
|
150
|
+
var mapSessionFromTokenByProvider = {
|
|
151
|
+
atplatform: mapATPlatformSessionFromToken,
|
|
152
|
+
parto: mapPartoSessionFromToken
|
|
153
|
+
};
|
|
154
|
+
function mapSessionFromLogin(providerType, response) {
|
|
155
|
+
const mapper = mapSessionFromLoginByProvider[providerType];
|
|
156
|
+
if (!mapper)
|
|
157
|
+
throw new Error(`Unsupported provider type: ${providerType}`);
|
|
158
|
+
return mapper(response);
|
|
159
|
+
}
|
|
160
|
+
function mapSessionFromToken(providerType, payload, token) {
|
|
161
|
+
const mapper = mapSessionFromTokenByProvider[providerType];
|
|
162
|
+
if (!mapper)
|
|
163
|
+
throw new Error(`Unsupported provider type: ${providerType}`);
|
|
164
|
+
return mapper(payload, token);
|
|
165
|
+
}
|
|
57
166
|
export {
|
|
167
|
+
auth_exports as ATAuth,
|
|
58
168
|
casing_exports as ATCasing
|
|
59
169
|
};
|
|
60
170
|
//# sourceMappingURL=index.mjs.map
|
package/dist/index.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/casing/index.ts","../src/casing/case.types.ts","../src/casing/case.runtime.ts"],"sourcesContent":["// src/casing/index.ts\r\nexport * from \"./case.types\";\r\nexport * from \"./case.runtime\";\r\n\r\n// (optional) if you still like namespaces, keep them too:\r\nimport * as Types from \"./case.types\";\r\nimport * as Runtime from \"./case.runtime\";\r\nexport { Types, Runtime };\r\n","type FixAcronyms<S extends string> =\r\n S extends `${infer A}ID${infer B}` ? FixAcronyms<`${A}Id${B}`> : S;\r\n\r\nexport type SnakeCase<S extends string> =\r\n S extends `${infer H}${infer T}`\r\n ? T extends Uncapitalize<T>\r\n ? `${Lowercase<H>}${SnakeCase<T>}`\r\n : `${Lowercase<H>}_${SnakeCase<Uncapitalize<T>>}`\r\n : S;\r\n\r\nexport type CamelCase<S extends string> =\r\n S extends `${infer A}_${infer B}`\r\n ? `${A}${Capitalize<CamelCase<B>>}`\r\n : S;\r\n\r\ntype Primitive = string | number | boolean | bigint | symbol | null | undefined;\r\ntype Builtin = Primitive | Date | RegExp | Error;\r\n\r\nexport type DeepSnakeKeys<T> =\r\n T extends Builtin ? T :\r\n T extends (...args: any[]) => any ? T :\r\n T extends readonly [any, ...any[]]\r\n ? { [I in keyof T]: DeepSnakeKeys<T[I]> } :\r\n T extends ReadonlyArray<infer U>\r\n ? ReadonlyArray<DeepSnakeKeys<U>> :\r\n T extends Map<infer K, infer V>\r\n ? Map<DeepSnakeKeys<K>, DeepSnakeKeys<V>> :\r\n T extends Set<infer U>\r\n ? Set<DeepSnakeKeys<U>> :\r\n T extends object\r\n ? {\r\n [K in keyof T as K extends string\r\n ? SnakeCase<FixAcronyms<K>>\r\n : K\r\n ]: DeepSnakeKeys<T[K]>\r\n }\r\n : T;\r\n\r\nexport type DeepCamelKeys<T> =\r\n T extends Builtin ? T :\r\n T extends (...args: any[]) => any ? T :\r\n T extends readonly [any, ...any[]]\r\n ? { [I in keyof T]: DeepCamelKeys<T[I]> } :\r\n T extends ReadonlyArray<infer U>\r\n ? ReadonlyArray<DeepCamelKeys<U>> :\r\n T extends Map<infer K, infer V>\r\n ? Map<DeepCamelKeys<K>, DeepCamelKeys<V>> :\r\n T extends Set<infer U>\r\n ? Set<DeepCamelKeys<U>> :\r\n T extends object\r\n ? { [K in keyof T as K extends string ? CamelCase<K> : K]: DeepCamelKeys<T[K]> }\r\n : T;\r\n","const CAMEL_TO_SNAKE = /[A-Z]/g;\r\nconst SNAKE_TO_CAMEL = /_([a-z])/g;\r\n\r\n// Normalize common acronyms before snake conversion\r\nconst normalizeAcronyms = (k: string) => k.replace(/ID/g, \"Id\");\r\n\r\nexport const toSnakeKey = (k: string) =>\r\n normalizeAcronyms(k).replace(CAMEL_TO_SNAKE, m => `_${m.toLowerCase()}`);\r\n\r\nexport const toCamelKey = (k: string) =>\r\n k.replace(SNAKE_TO_CAMEL, (_, c) => c.toUpperCase());\r\n\r\nexport function toSnakeDeep<T>(value: T, exceptions = new Set<string>()): any {\r\n if (Array.isArray(value)) return value.map(v => toSnakeDeep(v, exceptions));\r\n if (value instanceof Date) return value;\r\n if (value && typeof value === \"object\") {\r\n const out: Record<string, any> = {};\r\n for (const [k, v] of Object.entries(value as any)) {\r\n const nk = exceptions.has(k) ? k : toSnakeKey(k);\r\n out[nk] = toSnakeDeep(v, exceptions);\r\n }\r\n return out;\r\n }\r\n return value;\r\n}\r\n\r\nexport function toCamelDeep<T>(value: T): any {\r\n if (Array.isArray(value)) return value.map(toCamelDeep);\r\n if (value instanceof Date) return value;\r\n if (value && typeof value === \"object\") {\r\n const out: Record<string, any> = {};\r\n for (const [k, v] of Object.entries(value as any)) {\r\n out[toCamelKey(k)] = toCamelDeep(v);\r\n }\r\n return out;\r\n }\r\n return value;\r\n}\r\n"],"mappings":";;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACAA;;;ACAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAAM,iBAAiB;AACvB,IAAM,iBAAiB;AAGvB,IAAM,oBAAoB,CAAC,MAAc,EAAE,QAAQ,OAAO,IAAI;AAEvD,IAAM,aAAa,CAAC,MACvB,kBAAkB,CAAC,EAAE,QAAQ,gBAAgB,OAAK,IAAI,EAAE,YAAY,CAAC,EAAE;AAEpE,IAAM,aAAa,CAAC,MACvB,EAAE,QAAQ,gBAAgB,CAAC,GAAG,MAAM,EAAE,YAAY,CAAC;AAEhD,SAAS,YAAe,OAAU,aAAa,oBAAI,IAAY,GAAQ;AAC1E,MAAI,MAAM,QAAQ,KAAK,EAAG,QAAO,MAAM,IAAI,OAAK,YAAY,GAAG,UAAU,CAAC;AAC1E,MAAI,iBAAiB,KAAM,QAAO;AAClC,MAAI,SAAS,OAAO,UAAU,UAAU;AACpC,UAAM,MAA2B,CAAC;AAClC,eAAW,CAAC,GAAG,CAAC,KAAK,OAAO,QAAQ,KAAY,GAAG;AAC/C,YAAM,KAAK,WAAW,IAAI,CAAC,IAAI,IAAI,WAAW,CAAC;AAC/C,UAAI,EAAE,IAAI,YAAY,GAAG,UAAU;AAAA,IACvC;AACA,WAAO;AAAA,EACX;AACA,SAAO;AACX;AAEO,SAAS,YAAe,OAAe;AAC1C,MAAI,MAAM,QAAQ,KAAK,EAAG,QAAO,MAAM,IAAI,WAAW;AACtD,MAAI,iBAAiB,KAAM,QAAO;AAClC,MAAI,SAAS,OAAO,UAAU,UAAU;AACpC,UAAM,MAA2B,CAAC;AAClC,eAAW,CAAC,GAAG,CAAC,KAAK,OAAO,QAAQ,KAAY,GAAG;AAC/C,UAAI,WAAW,CAAC,CAAC,IAAI,YAAY,CAAC;AAAA,IACtC;AACA,WAAO;AAAA,EACX;AACA,SAAO;AACX;","names":[]}
|
|
1
|
+
{"version":3,"sources":["../src/casing/index.ts","../src/casing/case.types.ts","../src/casing/case.runtime.ts","../src/auth/index.ts","../src/auth/domain/authSession.ts","../src/auth/auth.runtime.ts","../src/auth/providers/parto/parto.runtime.ts","../src/auth/providers/atplatform/atplatform.runtime.ts"],"sourcesContent":["// src/casing/index.ts\r\nexport * from \"./case.types\";\r\nexport * from \"./case.runtime\";\r\n\r\n// (optional) if you still like namespaces, keep them too:\r\nimport * as Types from \"./case.types\";\r\nimport * as Runtime from \"./case.runtime\";\r\nexport { Types, Runtime };\r\n","type FixAcronyms<S extends string> =\r\n S extends `${infer A}ID${infer B}` ? FixAcronyms<`${A}Id${B}`> : S;\r\n\r\nexport type SnakeCase<S extends string> =\r\n S extends `${infer H}${infer T}`\r\n ? T extends Uncapitalize<T>\r\n ? `${Lowercase<H>}${SnakeCase<T>}`\r\n : `${Lowercase<H>}_${SnakeCase<Uncapitalize<T>>}`\r\n : S;\r\n\r\nexport type CamelCase<S extends string> =\r\n S extends `${infer A}_${infer B}`\r\n ? `${A}${Capitalize<CamelCase<B>>}`\r\n : S;\r\n\r\ntype Primitive = string | number | boolean | bigint | symbol | null | undefined;\r\ntype Builtin = Primitive | Date | RegExp | Error;\r\n\r\nexport type DeepSnakeKeys<T> =\r\n T extends Builtin ? T :\r\n T extends (...args: any[]) => any ? T :\r\n T extends readonly [any, ...any[]]\r\n ? { [I in keyof T]: DeepSnakeKeys<T[I]> } :\r\n T extends ReadonlyArray<infer U>\r\n ? ReadonlyArray<DeepSnakeKeys<U>> :\r\n T extends Map<infer K, infer V>\r\n ? Map<DeepSnakeKeys<K>, DeepSnakeKeys<V>> :\r\n T extends Set<infer U>\r\n ? Set<DeepSnakeKeys<U>> :\r\n T extends object\r\n ? {\r\n [K in keyof T as K extends string\r\n ? SnakeCase<FixAcronyms<K>>\r\n : K\r\n ]: DeepSnakeKeys<T[K]>\r\n }\r\n : T;\r\n\r\nexport type DeepCamelKeys<T> =\r\n T extends Builtin ? T :\r\n T extends (...args: any[]) => any ? T :\r\n T extends readonly [any, ...any[]]\r\n ? { [I in keyof T]: DeepCamelKeys<T[I]> } :\r\n T extends ReadonlyArray<infer U>\r\n ? ReadonlyArray<DeepCamelKeys<U>> :\r\n T extends Map<infer K, infer V>\r\n ? Map<DeepCamelKeys<K>, DeepCamelKeys<V>> :\r\n T extends Set<infer U>\r\n ? Set<DeepCamelKeys<U>> :\r\n T extends object\r\n ? { [K in keyof T as K extends string ? CamelCase<K> : K]: DeepCamelKeys<T[K]> }\r\n : T;\r\n","const CAMEL_TO_SNAKE = /[A-Z]/g;\r\nconst SNAKE_TO_CAMEL = /_([a-z])/g;\r\n\r\n// Normalize common acronyms before snake conversion\r\nconst normalizeAcronyms = (k: string) => k.replace(/ID/g, \"Id\");\r\n\r\nexport const toSnakeKey = (k: string) =>\r\n normalizeAcronyms(k).replace(CAMEL_TO_SNAKE, m => `_${m.toLowerCase()}`);\r\n\r\nexport const toCamelKey = (k: string) =>\r\n k.replace(SNAKE_TO_CAMEL, (_, c) => c.toUpperCase());\r\n\r\nexport function toSnakeDeep<T>(value: T, exceptions = new Set<string>()): any {\r\n if (Array.isArray(value)) return value.map(v => toSnakeDeep(v, exceptions));\r\n if (value instanceof Date) return value;\r\n if (value && typeof value === \"object\") {\r\n const out: Record<string, any> = {};\r\n for (const [k, v] of Object.entries(value as any)) {\r\n const nk = exceptions.has(k) ? k : toSnakeKey(k);\r\n out[nk] = toSnakeDeep(v, exceptions);\r\n }\r\n return out;\r\n }\r\n return value;\r\n}\r\n\r\nexport function toCamelDeep<T>(value: T): any {\r\n if (Array.isArray(value)) return value.map(toCamelDeep);\r\n if (value instanceof Date) return value;\r\n if (value && typeof value === \"object\") {\r\n const out: Record<string, any> = {};\r\n for (const [k, v] of Object.entries(value as any)) {\r\n out[toCamelKey(k)] = toCamelDeep(v);\r\n }\r\n return out;\r\n }\r\n return value;\r\n}\r\n","// Export core auth models & runtime functions\r\nexport * from \"./domain/authSession\";\r\nexport * from \"./auth.runtime\";\r\n\r\nimport * as CoreTypes from \"./domain/authSession\";\r\nimport * as Runtime from \"./auth.runtime\";\r\n\r\n// Exported namespace grouping all domain, session, and provider-specific types\r\nexport namespace Types {\r\n // Core session types\r\n export type ATAuthProviderType = CoreTypes.ATAuthProviderType;\r\n export type ATAuthUserDTO = CoreTypes.ATAuthUserDTO;\r\n export type ATAuthSessionDTO = CoreTypes.ATAuthSessionDTO;\r\n\r\n // ATPlatform Types\r\n export type ATPlatformLoginResponseDTO = import(\"./providers/atplatform/atplatform.login.types\").ATPlatformLoginResponseDTO;\r\n export type ATPlatformAccessTokenPayloadDTO = import(\"./providers/atplatform/atplatform.token.types\").ATPlatformAccessTokenPayloadDTO;\r\n\r\n // Parto Types\r\n export type PartoUserInfoDTO = import(\"./providers/parto/parto.login.types\").PartoUserInfoDTO;\r\n export type PartoLoginResponseDTO = import(\"./providers/parto/parto.login.types\").PartoLoginResponseDTO;\r\n export type PartoAccessTokenPayloadDTO = import(\"./providers/parto/parto.token.types\").PartoAccessTokenPayloadDTO;\r\n}\r\n\r\n// Export runtime under a clean namespace\r\nexport { Runtime };\r\n","export const ATAuthProviderTypes = [\"parto\", \"atplatform\"] as const;\r\nexport type ATAuthProviderType = typeof ATAuthProviderTypes[number];\r\n\r\nexport interface ATAuthUserDTO {\r\n userID: string;\r\n\r\n username?: string;\r\n\r\n email?: string;\r\n\r\n firstName?: string;\r\n\r\n lastName?: string;\r\n\r\n avatar?: string;\r\n\r\n permissions?: string[];\r\n}\r\n\r\nexport interface ATAuthSessionDTO {\r\n token: string;\r\n\r\n refreshToken?: string;\r\n\r\n expiresAt?: number;\r\n\r\n iss?: string;\r\n\r\n providerType: ATAuthProviderType;\r\n\r\n user: ATAuthUserDTO;\r\n\r\n //issuer junks \r\n meta?: Record<string, unknown>;\r\n}\r\n","import {\r\n mapPartoSessionFromLogin,\r\n mapPartoSessionFromToken,\r\n} from \"./providers/parto/parto.runtime\";\r\n\r\nimport {\r\n mapATPlatformSessionFromLogin,\r\n mapATPlatformSessionFromToken,\r\n} from \"./providers/atplatform/atplatform.runtime\";\r\n\r\nimport { ATAuthProviderType, ATAuthSessionDTO } from \"./domain/authSession\";\r\n\r\nexport * from \"./providers/parto/parto.runtime\";\r\nexport * from \"./providers/atplatform/atplatform.runtime\";\r\n\r\nconst mapSessionFromLoginByProvider: Record<\r\n ATAuthProviderType,\r\n (response: any) => ATAuthSessionDTO\r\n> = {\r\n atplatform: mapATPlatformSessionFromLogin,\r\n parto: mapPartoSessionFromLogin,\r\n};\r\n\r\nconst mapSessionFromTokenByProvider: Record<\r\n ATAuthProviderType,\r\n (payload: any, token: string) => ATAuthSessionDTO\r\n> = {\r\n atplatform: mapATPlatformSessionFromToken,\r\n parto: mapPartoSessionFromToken,\r\n};\r\n\r\nexport function mapSessionFromLogin(\r\n providerType: ATAuthProviderType,\r\n response: unknown,\r\n): ATAuthSessionDTO {\r\n const mapper = mapSessionFromLoginByProvider[providerType];\r\n\r\n if (!mapper)\r\n throw new Error(`Unsupported provider type: ${providerType}`);\r\n\r\n return mapper(response);\r\n}\r\n\r\nexport function mapSessionFromToken(\r\n providerType: ATAuthProviderType,\r\n payload: unknown,\r\n token: string\r\n): ATAuthSessionDTO {\r\n const mapper = mapSessionFromTokenByProvider[providerType];\r\n\r\n if (!mapper)\r\n throw new Error(`Unsupported provider type: ${providerType}`);\r\n\r\n return mapper(payload, token);\r\n}\r\n\r\n","import { ATAuthSessionDTO } from \"../../domain/authSession\";\r\nimport { PartoLoginResponseDTO } from \"./parto.login.types\";\r\nimport { PartoAccessTokenPayloadDTO } from \"./parto.token.types\";\r\n\r\nexport function mapPartoSessionFromLogin(\r\n response: PartoLoginResponseDTO\r\n): ATAuthSessionDTO {\r\n const user = response.userInfo;\r\n\r\n return {\r\n token: response.token,\r\n refreshToken: response.refreshToken,\r\n providerType: 'parto',\r\n user: {\r\n userID: String(user.ID),\r\n username: user.userName,\r\n firstName: user.firstName,\r\n lastName: user.lastName\r\n },\r\n meta: {\r\n department: user.department,\r\n companyName: user.companyName,\r\n businessTypeID: user.businessTypeID\r\n }\r\n };\r\n}\r\n\r\nexport function mapPartoSessionFromToken(\r\n payload: PartoAccessTokenPayloadDTO,\r\n token: string\r\n): ATAuthSessionDTO {\r\n return {\r\n token,\r\n expiresAt: payload.exp,\r\n providerType: 'parto',\r\n iss: payload.iss,\r\n user: {\r\n userID: payload.ID,\r\n username: payload.unique_name,\r\n permissions: payload.PERMISSIONS?.split(\",\")\r\n }\r\n };\r\n}\r\n","import { ATAuthSessionDTO } from \"../../domain/authSession\";\r\nimport { ATPlatformLoginResponseDTO } from \"./atplatform.login.types\";\r\nimport { ATPlatformAccessTokenPayloadDTO } from \"./atplatform.token.types\";\r\n\r\nexport function mapATPlatformSessionFromLogin(\r\n response: ATPlatformLoginResponseDTO\r\n): ATAuthSessionDTO {\r\n return {\r\n token: response.token,\r\n refreshToken: response.refresh_token,\r\n providerType: 'atplatform',\r\n user: {\r\n userID: String(response.user_id),\r\n username: response.username,\r\n firstName: response.first_name,\r\n lastName: response.last_name\r\n }\r\n };\r\n}\r\n\r\nexport function mapATPlatformSessionFromToken(\r\n payload: ATPlatformAccessTokenPayloadDTO,\r\n token: string\r\n): ATAuthSessionDTO {\r\n return {\r\n token,\r\n expiresAt: payload.exp,\r\n iss: payload.iss,\r\n providerType: 'atplatform',\r\n user: {\r\n userID: payload.sub\r\n }\r\n };\r\n}\r\n"],"mappings":"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","names":[]}
|