@appconda/nextjs 1.0.384 → 1.0.386

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.
@@ -0,0 +1,5 @@
1
+ export declare function signIn({ userName, password }: {
2
+ userName: string;
3
+ password: string;
4
+ }): Promise<import("../modules/account/types").Session>;
5
+ export declare const authOptions: () => any;
@@ -0,0 +1,235 @@
1
+ import CredentialsProvider from "next-auth/providers/credentials";
2
+ import { cookies } from "next/headers";
3
+ import { getAppcondaClient } from "../getAppcondaClient";
4
+ import { Account } from "../modules/account/service";
5
+ import { getEnv } from "../lib/env";
6
+ import { getSDKForCurrentUser } from "../getSDKForCurrentUser";
7
+ import { Query } from "../query";
8
+ /* const getEnv = () => {
9
+ return {
10
+ APPCONDA_ENDPOINT: 'process.env.APPCONDA_ENDPOINT',
11
+ APPCONDA_CLIENT_ENDPOINT: 'process.env.APPCONDA_CLIENT_ENDPOINT',
12
+ _SERVICE_TOKEN: 'process.env._SERVICE_TOKEN',
13
+ ENTERPRISE_LICENSE_KEY: 'process.env.ENTERPRISE_LICENSE_KEY',
14
+ };
15
+ }; */
16
+ export async function signIn({ userName, password }) {
17
+ const adminClient = await getAppcondaClient();
18
+ const account = new Account(adminClient);
19
+ const session = await account.createEmailPasswordSession(userName, password);
20
+ const c = await cookies();
21
+ c.set('a_session', session.secret, {
22
+ path: "/",
23
+ httpOnly: true,
24
+ sameSite: "strict",
25
+ secure: true,
26
+ });
27
+ return session;
28
+ }
29
+ export const authOptions = (() => {
30
+ let options = null;
31
+ return () => {
32
+ if (options == null) {
33
+ options = {
34
+ providers: [
35
+ CredentialsProvider({
36
+ id: "credentials",
37
+ // The name to display on the sign in form (e.g. "Sign in with...")
38
+ name: "Credentials",
39
+ // The credentials is used to generate a suitable form on the sign in page.
40
+ // You can specify whatever fields you are expecting to be submitted.
41
+ // e.g. domain, username, password, 2FA token, etc.
42
+ // You can pass any HTML attribute to the <input> tag through the object.
43
+ credentials: {
44
+ email: {
45
+ label: "Email Address",
46
+ type: "email",
47
+ placeholder: "Your email address",
48
+ },
49
+ password: {
50
+ label: "Password",
51
+ type: "password",
52
+ placeholder: "Your password",
53
+ },
54
+ totpCode: { label: "Two-factor Code", type: "input", placeholder: "Code from authenticator app" },
55
+ backupCode: { label: "Backup Code", type: "input", placeholder: "Two-factor backup code" },
56
+ },
57
+ async authorize(credentials, _req) {
58
+ debugger;
59
+ let user;
60
+ const appcondaSession = await signIn({ userName: credentials?.email, password: credentials?.password });
61
+ console.log(credentials);
62
+ /* try {
63
+ user = await prisma.user.findUnique({
64
+ where: {
65
+ email: credentials?.email,
66
+ },
67
+ });
68
+ } catch (e) {
69
+ console.error(e);
70
+ throw Error("Internal server error. Please try again later");
71
+ }
72
+ if (!user || !credentials) {
73
+ throw new Error("Invalid credentials");
74
+ }
75
+ if (!user.password) {
76
+ throw new Error("Invalid credentials");
77
+ }
78
+
79
+ const isValid = await verifyPassword(credentials.password, user.password);
80
+
81
+ if (!isValid) {
82
+ throw new Error("Invalid credentials");
83
+ }
84
+
85
+ if (user.twoFactorEnabled && credentials.backupCode) {
86
+ if (!ENCRYPTION_KEY) {
87
+ console.error("Missing encryption key; cannot proceed with backup code login.");
88
+ throw new Error("Internal Server Error");
89
+ }
90
+
91
+ if (!user.backupCodes) throw new Error("No backup codes found");
92
+
93
+ const backupCodes = JSON.parse(symmetricDecrypt(user.backupCodes, ENCRYPTION_KEY));
94
+
95
+ // check if user-supplied code matches one
96
+ const index = backupCodes.indexOf(credentials.backupCode.replaceAll("-", ""));
97
+ if (index === -1) throw new Error("Invalid backup code");
98
+
99
+ // delete verified backup code and re-encrypt remaining
100
+ backupCodes[index] = null;
101
+ await prisma.user.update({
102
+ where: {
103
+ id: user.id,
104
+ },
105
+ data: {
106
+ backupCodes: symmetricEncrypt(JSON.stringify(backupCodes), ENCRYPTION_KEY),
107
+ },
108
+ });
109
+ } else if (user.twoFactorEnabled) {
110
+ if (!credentials.totpCode) {
111
+ throw new Error("second factor required");
112
+ }
113
+
114
+ if (!user.twoFactorSecret) {
115
+ throw new Error("Internal Server Error");
116
+ }
117
+
118
+ if (!ENCRYPTION_KEY) {
119
+ throw new Error("Internal Server Error");
120
+ }
121
+
122
+ const secret = symmetricDecrypt(user.twoFactorSecret, ENCRYPTION_KEY);
123
+ if (secret.length !== 32) {
124
+ throw new Error("Internal Server Error");
125
+ }
126
+
127
+ const isValidToken = (await import("./totp")).totpAuthenticatorCheck(credentials.totpCode, secret);
128
+ if (!isValidToken) {
129
+ throw new Error("Invalid second factor code");
130
+ }
131
+ } */
132
+ console.log("asafdf");
133
+ return {
134
+ id: appcondaSession.userId,
135
+ email: appcondaSession.providerUid,
136
+ emailVerified: true,
137
+ imageUrl: "",
138
+ };
139
+ },
140
+ }),
141
+ CredentialsProvider({
142
+ id: "token",
143
+ // The name to display on the sign in form (e.g. "Sign in with...")
144
+ name: "Token",
145
+ // The credentials is used to generate a suitable form on the sign in page.
146
+ // You can specify whatever fields you are expecting to be submitted.
147
+ // e.g. domain, username, password, 2FA token, etc.
148
+ // You can pass any HTML attribute to the <input> tag through the object.
149
+ credentials: {
150
+ token: {
151
+ label: "Verification Token",
152
+ type: "string",
153
+ },
154
+ },
155
+ async authorize(credentials, _req) {
156
+ let user;
157
+ /* try {
158
+ if (!credentials?.token) {
159
+ throw new Error("Token not found");
160
+ }
161
+ const { id } = await verifyToken(credentials?.token);
162
+ user = await prisma.user.findUnique({
163
+ where: {
164
+ id: id,
165
+ },
166
+ });
167
+ } catch (e) {
168
+ console.error(e);
169
+ throw new Error("Either a user does not match the provided token or the token is invalid");
170
+ }
171
+
172
+ if (!user) {
173
+ throw new Error("Either a user does not match the provided token or the token is invalid");
174
+ }
175
+
176
+ if (user.emailVerified) {
177
+ throw new Error("Email already verified");
178
+ }
179
+
180
+ user = await updateUser(user.id, { emailVerified: new Date() }); */
181
+ return user || null;
182
+ },
183
+ }),
184
+ // Conditionally add enterprise SSO providers
185
+ ...(getEnv().ENTERPRISE_LICENSE_KEY ? [] : []),
186
+ ],
187
+ callbacks: {
188
+ async jwt({ token }) {
189
+ const { users } = await getSDKForCurrentUser();
190
+ const userList = await users.list([Query.equal("email", token.email)]);
191
+ const user = userList.users[0] ?? {};
192
+ /* const existingUser = await getUserByEmail(token?.email!);
193
+
194
+ if (!existingUser) {
195
+ return token;
196
+ } */
197
+ return {
198
+ ...token,
199
+ //@ts-ignore
200
+ profile: { id: user.$id, ...user },
201
+ };
202
+ },
203
+ async session({ session, token }) {
204
+ //@ts-ignore
205
+ session.user.id = token?.id;
206
+ //@ts-ignore
207
+ session.user = token.profile;
208
+ return session;
209
+ },
210
+ //@ts-ignore
211
+ async signIn({ user, account }) {
212
+ /* if (account?.provider === "credentials" || account?.provider === "token") {
213
+ // check if user's email is verified or not
214
+ if (!user.emailVerified && !EMAIL_VERIFICATION_DISABLED) {
215
+ throw new Error("Email Verification is Pending");
216
+ }
217
+ return true;
218
+ }
219
+ if (ENTERPRISE_LICENSE_KEY) {
220
+ return handleSSOCallback({ user, account });
221
+ } */
222
+ return true;
223
+ },
224
+ },
225
+ pages: {
226
+ signIn: "/auth/login",
227
+ signOut: "/auth/logout",
228
+ error: "/auth/login", // Error code passed in query string as ?error=
229
+ },
230
+ };
231
+ }
232
+ return options;
233
+ };
234
+ })();
235
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"_authOptions.js","sourceRoot":"","sources":["../../src/actions/_authOptions.ts"],"names":[],"mappings":"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","sourcesContent":["import type { NextAuthOptions } from \"next-auth\";\nimport CredentialsProvider from \"next-auth/providers/credentials\";\nimport { cookies } from \"next/headers\";\nimport { getAppcondaClient } from \"../getAppcondaClient\";\nimport { Account } from \"../modules/account/service\";\nimport { getEnv } from \"../lib/env\";\nimport { getSDKForCurrentUser } from \"../getSDKForCurrentUser\";\nimport { Query } from \"../query\";\n\n/* const getEnv = () => {\n  return {\n    APPCONDA_ENDPOINT: 'process.env.APPCONDA_ENDPOINT',\n    APPCONDA_CLIENT_ENDPOINT: 'process.env.APPCONDA_CLIENT_ENDPOINT',\n    _SERVICE_TOKEN: 'process.env._SERVICE_TOKEN',\n    ENTERPRISE_LICENSE_KEY: 'process.env.ENTERPRISE_LICENSE_KEY',\n  };\n}; */\n\nexport async function signIn({ userName, password }: { userName: string, password: string }) {\n  const adminClient = await getAppcondaClient();\n\n  const account = new Account(adminClient);\n\n  const session = await account.createEmailPasswordSession(userName, password);\n\n  const c = await cookies();\n\n  c.set('a_session', session.secret, {\n    path: \"/\",\n    httpOnly: true,\n    sameSite: \"strict\",\n    secure: true,\n  });\n\n  return session;\n\n}\n\nexport const authOptions = (() => {\n  let options : any= null;\n\n  return () => {\n    if (options == null) {\n      options = {\n        providers: [\n          CredentialsProvider({\n            id: \"credentials\",\n            // The name to display on the sign in form (e.g. \"Sign in with...\")\n            name: \"Credentials\",\n            // The credentials is used to generate a suitable form on the sign in page.\n            // You can specify whatever fields you are expecting to be submitted.\n            // e.g. domain, username, password, 2FA token, etc.\n            // You can pass any HTML attribute to the <input> tag through the object.\n            credentials: {\n              email: {\n                label: \"Email Address\",\n                type: \"email\",\n                placeholder: \"Your email address\",\n              },\n              password: {\n                label: \"Password\",\n                type: \"password\",\n                placeholder: \"Your password\",\n              },\n              totpCode: { label: \"Two-factor Code\", type: \"input\", placeholder: \"Code from authenticator app\" },\n              backupCode: { label: \"Backup Code\", type: \"input\", placeholder: \"Two-factor backup code\" },\n            },\n            async authorize(credentials, _req) {\n              debugger;\n              let user;\n              const appcondaSession = await signIn({ userName: credentials?.email as string, password: credentials?.password as string });\n\n              console.log(credentials);\n              /*  try {\n                 user = await prisma.user.findUnique({\n                   where: {\n                     email: credentials?.email,\n                   },\n                 });\n               } catch (e) {\n                 console.error(e);\n                 throw Error(\"Internal server error. Please try again later\");\n               }\n               if (!user || !credentials) {\n                 throw new Error(\"Invalid credentials\");\n               }\n               if (!user.password) {\n                 throw new Error(\"Invalid credentials\");\n               }\n       \n               const isValid = await verifyPassword(credentials.password, user.password);\n       \n               if (!isValid) {\n                 throw new Error(\"Invalid credentials\");\n               }\n       \n               if (user.twoFactorEnabled && credentials.backupCode) {\n                 if (!ENCRYPTION_KEY) {\n                   console.error(\"Missing encryption key; cannot proceed with backup code login.\");\n                   throw new Error(\"Internal Server Error\");\n                 }\n       \n                 if (!user.backupCodes) throw new Error(\"No backup codes found\");\n       \n                 const backupCodes = JSON.parse(symmetricDecrypt(user.backupCodes, ENCRYPTION_KEY));\n       \n                 // check if user-supplied code matches one\n                 const index = backupCodes.indexOf(credentials.backupCode.replaceAll(\"-\", \"\"));\n                 if (index === -1) throw new Error(\"Invalid backup code\");\n       \n                 // delete verified backup code and re-encrypt remaining\n                 backupCodes[index] = null;\n                 await prisma.user.update({\n                   where: {\n                     id: user.id,\n                   },\n                   data: {\n                     backupCodes: symmetricEncrypt(JSON.stringify(backupCodes), ENCRYPTION_KEY),\n                   },\n                 });\n               } else if (user.twoFactorEnabled) {\n                 if (!credentials.totpCode) {\n                   throw new Error(\"second factor required\");\n                 }\n       \n                 if (!user.twoFactorSecret) {\n                   throw new Error(\"Internal Server Error\");\n                 }\n       \n                 if (!ENCRYPTION_KEY) {\n                   throw new Error(\"Internal Server Error\");\n                 }\n       \n                 const secret = symmetricDecrypt(user.twoFactorSecret, ENCRYPTION_KEY);\n                 if (secret.length !== 32) {\n                   throw new Error(\"Internal Server Error\");\n                 }\n       \n                 const isValidToken = (await import(\"./totp\")).totpAuthenticatorCheck(credentials.totpCode, secret);\n                 if (!isValidToken) {\n                   throw new Error(\"Invalid second factor code\");\n                 }\n               } */\n\n              console.log(\"asafdf\")\n\n              return {\n                id: appcondaSession.userId,\n                email: appcondaSession.providerUid,\n                emailVerified: true,\n                imageUrl: \"\",\n              };\n            },\n          }),\n          CredentialsProvider({\n            id: \"token\",\n            // The name to display on the sign in form (e.g. \"Sign in with...\")\n            name: \"Token\",\n            // The credentials is used to generate a suitable form on the sign in page.\n            // You can specify whatever fields you are expecting to be submitted.\n            // e.g. domain, username, password, 2FA token, etc.\n            // You can pass any HTML attribute to the <input> tag through the object.\n            credentials: {\n              token: {\n                label: \"Verification Token\",\n                type: \"string\",\n              },\n            },\n            async authorize(credentials, _req) {\n\n              let user;\n              /*  try {\n                 if (!credentials?.token) {\n                   throw new Error(\"Token not found\");\n                 }\n                 const { id } = await verifyToken(credentials?.token);\n                 user = await prisma.user.findUnique({\n                   where: {\n                     id: id,\n                   },\n                 });\n               } catch (e) {\n                 console.error(e);\n                 throw new Error(\"Either a user does not match the provided token or the token is invalid\");\n               }\n       \n               if (!user) {\n                 throw new Error(\"Either a user does not match the provided token or the token is invalid\");\n               }\n       \n               if (user.emailVerified) {\n                 throw new Error(\"Email already verified\");\n               }\n       \n               user = await updateUser(user.id, { emailVerified: new Date() }); */\n\n              return user || null;\n            },\n          }),\n          // Conditionally add enterprise SSO providers\n          ...(getEnv().ENTERPRISE_LICENSE_KEY ? [] : []),\n        ],\n        callbacks: {\n          async jwt({ token }) {\n\n            const { users } = await getSDKForCurrentUser();\n            const userList = await users.list([Query.equal(\"email\", token.email!)])\n\n            const user = userList.users[0] ?? {};\n\n            /*  const existingUser = await getUserByEmail(token?.email!);\n       \n             if (!existingUser) {\n               return token;\n             } */\n\n            return {\n              ...token,\n              //@ts-ignore\n              profile: { id: user.$id, ...user },\n            };\n          },\n          async session({ session, token }) {\n            //@ts-ignore\n            session.user.id = token?.id;\n            //@ts-ignore\n            session.user = token.profile;\n\n            return session;\n          },\n          //@ts-ignore\n          async signIn({ user, account }: { user: any; account: Account | null }) {\n            /*   if (account?.provider === \"credentials\" || account?.provider === \"token\") {\n                // check if user's email is verified or not\n                if (!user.emailVerified && !EMAIL_VERIFICATION_DISABLED) {\n                  throw new Error(\"Email Verification is Pending\");\n                }\n                return true;\n              }\n              if (ENTERPRISE_LICENSE_KEY) {\n                return handleSSOCallback({ user, account });\n              } */\n            return true;\n          },\n        },\n        pages: {\n          signIn: \"/auth/login\",\n          signOut: \"/auth/logout\",\n          error: \"/auth/login\", // Error code passed in query string as ?error=\n        },\n      }\n    }\n    return options;\n  }\n})();\n"]}
@@ -1,5 +1,5 @@
1
1
  export declare function signIn({ userName, password }: {
2
2
  userName: string;
3
3
  password: string;
4
- }): Promise<import("../modules/account/types").Session>;
4
+ }): Promise<any>;
5
5
  export declare const authOptions: () => any;
@@ -1,10 +1,7 @@
1
1
  import CredentialsProvider from "next-auth/providers/credentials";
2
2
  import { cookies } from "next/headers";
3
- import { getAppcondaClient } from "../getAppcondaClient";
4
- import { Account } from "../modules/account/service";
5
- import { getEnv } from "../lib/env";
6
- import { getSDKForCurrentUser } from "../getSDKForCurrentUser";
7
- import { Query } from "../query";
3
+ import { getAppcondaClient, getAppcondaClientSync } from "../getAppcondaClient";
4
+ import { AccountService } from "../modules";
8
5
  /* const getEnv = () => {
9
6
  return {
10
7
  APPCONDA_ENDPOINT: 'process.env.APPCONDA_ENDPOINT',
@@ -13,6 +10,9 @@ import { Query } from "../query";
13
10
  ENTERPRISE_LICENSE_KEY: 'process.env.ENTERPRISE_LICENSE_KEY',
14
11
  };
15
12
  }; */
13
+ const ENCRYPTION_KEY = '51570cb4caa6c1f5f80e6e57a32efb397e9220434532697c94c8f821a7dd1951';
14
+ const ENTERPRISE_LICENSE_KEY = '';
15
+ const EMAIL_VERIFICATION_DISABLED = false;
16
16
  export async function signIn({ userName, password }) {
17
17
  const adminClient = await getAppcondaClient();
18
18
  const account = new Account(adminClient);
@@ -28,6 +28,8 @@ export async function signIn({ userName, password }) {
28
28
  }
29
29
  export const authOptions = (() => {
30
30
  let options = null;
31
+ const adminClient = getAppcondaClientSync();
32
+ const accountService = new AccountService(adminClient);
31
33
  return () => {
32
34
  if (options == null) {
33
35
  options = {
@@ -55,87 +57,8 @@ export const authOptions = (() => {
55
57
  backupCode: { label: "Backup Code", type: "input", placeholder: "Two-factor backup code" },
56
58
  },
57
59
  async authorize(credentials, _req) {
58
- debugger;
59
- let user;
60
- const appcondaSession = await signIn({ userName: credentials?.email, password: credentials?.password });
61
- console.log(credentials);
62
- /* try {
63
- user = await prisma.user.findUnique({
64
- where: {
65
- email: credentials?.email,
66
- },
67
- });
68
- } catch (e) {
69
- console.error(e);
70
- throw Error("Internal server error. Please try again later");
71
- }
72
- if (!user || !credentials) {
73
- throw new Error("Invalid credentials");
74
- }
75
- if (!user.password) {
76
- throw new Error("Invalid credentials");
77
- }
78
-
79
- const isValid = await verifyPassword(credentials.password, user.password);
80
-
81
- if (!isValid) {
82
- throw new Error("Invalid credentials");
83
- }
84
-
85
- if (user.twoFactorEnabled && credentials.backupCode) {
86
- if (!ENCRYPTION_KEY) {
87
- console.error("Missing encryption key; cannot proceed with backup code login.");
88
- throw new Error("Internal Server Error");
89
- }
90
-
91
- if (!user.backupCodes) throw new Error("No backup codes found");
92
-
93
- const backupCodes = JSON.parse(symmetricDecrypt(user.backupCodes, ENCRYPTION_KEY));
94
-
95
- // check if user-supplied code matches one
96
- const index = backupCodes.indexOf(credentials.backupCode.replaceAll("-", ""));
97
- if (index === -1) throw new Error("Invalid backup code");
98
-
99
- // delete verified backup code and re-encrypt remaining
100
- backupCodes[index] = null;
101
- await prisma.user.update({
102
- where: {
103
- id: user.id,
104
- },
105
- data: {
106
- backupCodes: symmetricEncrypt(JSON.stringify(backupCodes), ENCRYPTION_KEY),
107
- },
108
- });
109
- } else if (user.twoFactorEnabled) {
110
- if (!credentials.totpCode) {
111
- throw new Error("second factor required");
112
- }
113
-
114
- if (!user.twoFactorSecret) {
115
- throw new Error("Internal Server Error");
116
- }
117
-
118
- if (!ENCRYPTION_KEY) {
119
- throw new Error("Internal Server Error");
120
- }
121
-
122
- const secret = symmetricDecrypt(user.twoFactorSecret, ENCRYPTION_KEY);
123
- if (secret.length !== 32) {
124
- throw new Error("Internal Server Error");
125
- }
126
-
127
- const isValidToken = (await import("./totp")).totpAuthenticatorCheck(credentials.totpCode, secret);
128
- if (!isValidToken) {
129
- throw new Error("Invalid second factor code");
130
- }
131
- } */
132
- console.log("asafdf");
133
- return {
134
- id: appcondaSession.userId,
135
- email: appcondaSession.providerUid,
136
- emailVerified: true,
137
- imageUrl: "",
138
- };
60
+ const session = await accountService.CredentialLogin(credentials);
61
+ return session;
139
62
  },
140
63
  }),
141
64
  CredentialsProvider({
@@ -153,72 +76,43 @@ export const authOptions = (() => {
153
76
  },
154
77
  },
155
78
  async authorize(credentials, _req) {
156
- let user;
157
- /* try {
158
- if (!credentials?.token) {
159
- throw new Error("Token not found");
160
- }
161
- const { id } = await verifyToken(credentials?.token);
162
- user = await prisma.user.findUnique({
163
- where: {
164
- id: id,
165
- },
166
- });
167
- } catch (e) {
168
- console.error(e);
169
- throw new Error("Either a user does not match the provided token or the token is invalid");
170
- }
171
-
172
- if (!user) {
173
- throw new Error("Either a user does not match the provided token or the token is invalid");
174
- }
175
-
176
- if (user.emailVerified) {
177
- throw new Error("Email already verified");
178
- }
179
-
180
- user = await updateUser(user.id, { emailVerified: new Date() }); */
181
- return user || null;
79
+ const token = credentials?.token;
80
+ const user = await accountService.TokenLogin({ token: token });
81
+ return user;
182
82
  },
183
83
  }),
184
84
  // Conditionally add enterprise SSO providers
185
- ...(getEnv().ENTERPRISE_LICENSE_KEY ? [] : []),
85
+ // ...(ENTERPRISE_LICENSE_KEY ? getSSOProviders() : []),
186
86
  ],
187
87
  callbacks: {
188
88
  async jwt({ token }) {
189
- const { users } = await getSDKForCurrentUser();
190
- const userList = await users.list([Query.equal("email", token.email)]);
191
- const user = userList.users[0] ?? {};
192
- /* const existingUser = await getUserByEmail(token?.email!);
193
-
194
- if (!existingUser) {
195
- return token;
196
- } */
89
+ const existingUser = await accountService.GetUserByEmail({ email: token?.email });
90
+ if (!existingUser) {
91
+ return token;
92
+ }
197
93
  return {
198
94
  ...token,
199
- //@ts-ignore
200
- profile: { id: user.$id, ...user },
95
+ profile: { id: existingUser.id },
201
96
  };
202
97
  },
203
98
  async session({ session, token }) {
204
- //@ts-ignore
99
+ // @ts-expect-error
205
100
  session.user.id = token?.id;
206
- //@ts-ignore
101
+ // @ts-expect-error
207
102
  session.user = token.profile;
208
103
  return session;
209
104
  },
210
- //@ts-ignore
211
105
  async signIn({ user, account }) {
212
- /* if (account?.provider === "credentials" || account?.provider === "token") {
106
+ if (account?.provider === "credentials" || account?.provider === "token") {
213
107
  // check if user's email is verified or not
214
108
  if (!user.emailVerified && !EMAIL_VERIFICATION_DISABLED) {
215
- throw new Error("Email Verification is Pending");
109
+ throw new Error("Email Verification is Pending");
216
110
  }
217
111
  return true;
218
- }
219
- if (ENTERPRISE_LICENSE_KEY) {
220
- return handleSSOCallback({ user, account });
221
- } */
112
+ }
113
+ /* if (ENTERPRISE_LICENSE_KEY) {
114
+ return handleSSOCallback({ user, account });
115
+ } */
222
116
  return true;
223
117
  },
224
118
  },
@@ -232,4 +126,4 @@ export const authOptions = (() => {
232
126
  return options;
233
127
  };
234
128
  })();
235
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"authOptions.js","sourceRoot":"","sources":["../../src/actions/authOptions.ts"],"names":[],"mappings":"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","sourcesContent":["import type { NextAuthOptions } from \"next-auth\";\nimport CredentialsProvider from \"next-auth/providers/credentials\";\nimport { cookies } from \"next/headers\";\nimport { getAppcondaClient } from \"../getAppcondaClient\";\nimport { Account } from \"../modules/account/service\";\nimport { getEnv } from \"../lib/env\";\nimport { getSDKForCurrentUser } from \"../getSDKForCurrentUser\";\nimport { Query } from \"../query\";\n\n/* const getEnv = () => {\n  return {\n    APPCONDA_ENDPOINT: 'process.env.APPCONDA_ENDPOINT',\n    APPCONDA_CLIENT_ENDPOINT: 'process.env.APPCONDA_CLIENT_ENDPOINT',\n    _SERVICE_TOKEN: 'process.env._SERVICE_TOKEN',\n    ENTERPRISE_LICENSE_KEY: 'process.env.ENTERPRISE_LICENSE_KEY',\n  };\n}; */\n\nexport async function signIn({ userName, password }: { userName: string, password: string }) {\n  const adminClient = await getAppcondaClient();\n\n  const account = new Account(adminClient);\n\n  const session = await account.createEmailPasswordSession(userName, password);\n\n  const c = await cookies();\n\n  c.set('a_session', session.secret, {\n    path: \"/\",\n    httpOnly: true,\n    sameSite: \"strict\",\n    secure: true,\n  });\n\n  return session;\n\n}\n\nexport const authOptions = (() => {\n  let options : any= null;\n\n  return () => {\n    if (options == null) {\n      options = {\n        providers: [\n          CredentialsProvider({\n            id: \"credentials\",\n            // The name to display on the sign in form (e.g. \"Sign in with...\")\n            name: \"Credentials\",\n            // The credentials is used to generate a suitable form on the sign in page.\n            // You can specify whatever fields you are expecting to be submitted.\n            // e.g. domain, username, password, 2FA token, etc.\n            // You can pass any HTML attribute to the <input> tag through the object.\n            credentials: {\n              email: {\n                label: \"Email Address\",\n                type: \"email\",\n                placeholder: \"Your email address\",\n              },\n              password: {\n                label: \"Password\",\n                type: \"password\",\n                placeholder: \"Your password\",\n              },\n              totpCode: { label: \"Two-factor Code\", type: \"input\", placeholder: \"Code from authenticator app\" },\n              backupCode: { label: \"Backup Code\", type: \"input\", placeholder: \"Two-factor backup code\" },\n            },\n            async authorize(credentials, _req) {\n              debugger;\n              let user;\n              const appcondaSession = await signIn({ userName: credentials?.email as string, password: credentials?.password as string });\n\n              console.log(credentials);\n              /*  try {\n                 user = await prisma.user.findUnique({\n                   where: {\n                     email: credentials?.email,\n                   },\n                 });\n               } catch (e) {\n                 console.error(e);\n                 throw Error(\"Internal server error. Please try again later\");\n               }\n               if (!user || !credentials) {\n                 throw new Error(\"Invalid credentials\");\n               }\n               if (!user.password) {\n                 throw new Error(\"Invalid credentials\");\n               }\n       \n               const isValid = await verifyPassword(credentials.password, user.password);\n       \n               if (!isValid) {\n                 throw new Error(\"Invalid credentials\");\n               }\n       \n               if (user.twoFactorEnabled && credentials.backupCode) {\n                 if (!ENCRYPTION_KEY) {\n                   console.error(\"Missing encryption key; cannot proceed with backup code login.\");\n                   throw new Error(\"Internal Server Error\");\n                 }\n       \n                 if (!user.backupCodes) throw new Error(\"No backup codes found\");\n       \n                 const backupCodes = JSON.parse(symmetricDecrypt(user.backupCodes, ENCRYPTION_KEY));\n       \n                 // check if user-supplied code matches one\n                 const index = backupCodes.indexOf(credentials.backupCode.replaceAll(\"-\", \"\"));\n                 if (index === -1) throw new Error(\"Invalid backup code\");\n       \n                 // delete verified backup code and re-encrypt remaining\n                 backupCodes[index] = null;\n                 await prisma.user.update({\n                   where: {\n                     id: user.id,\n                   },\n                   data: {\n                     backupCodes: symmetricEncrypt(JSON.stringify(backupCodes), ENCRYPTION_KEY),\n                   },\n                 });\n               } else if (user.twoFactorEnabled) {\n                 if (!credentials.totpCode) {\n                   throw new Error(\"second factor required\");\n                 }\n       \n                 if (!user.twoFactorSecret) {\n                   throw new Error(\"Internal Server Error\");\n                 }\n       \n                 if (!ENCRYPTION_KEY) {\n                   throw new Error(\"Internal Server Error\");\n                 }\n       \n                 const secret = symmetricDecrypt(user.twoFactorSecret, ENCRYPTION_KEY);\n                 if (secret.length !== 32) {\n                   throw new Error(\"Internal Server Error\");\n                 }\n       \n                 const isValidToken = (await import(\"./totp\")).totpAuthenticatorCheck(credentials.totpCode, secret);\n                 if (!isValidToken) {\n                   throw new Error(\"Invalid second factor code\");\n                 }\n               } */\n\n              console.log(\"asafdf\")\n\n              return {\n                id: appcondaSession.userId,\n                email: appcondaSession.providerUid,\n                emailVerified: true,\n                imageUrl: \"\",\n              };\n            },\n          }),\n          CredentialsProvider({\n            id: \"token\",\n            // The name to display on the sign in form (e.g. \"Sign in with...\")\n            name: \"Token\",\n            // The credentials is used to generate a suitable form on the sign in page.\n            // You can specify whatever fields you are expecting to be submitted.\n            // e.g. domain, username, password, 2FA token, etc.\n            // You can pass any HTML attribute to the <input> tag through the object.\n            credentials: {\n              token: {\n                label: \"Verification Token\",\n                type: \"string\",\n              },\n            },\n            async authorize(credentials, _req) {\n\n              let user;\n              /*  try {\n                 if (!credentials?.token) {\n                   throw new Error(\"Token not found\");\n                 }\n                 const { id } = await verifyToken(credentials?.token);\n                 user = await prisma.user.findUnique({\n                   where: {\n                     id: id,\n                   },\n                 });\n               } catch (e) {\n                 console.error(e);\n                 throw new Error(\"Either a user does not match the provided token or the token is invalid\");\n               }\n       \n               if (!user) {\n                 throw new Error(\"Either a user does not match the provided token or the token is invalid\");\n               }\n       \n               if (user.emailVerified) {\n                 throw new Error(\"Email already verified\");\n               }\n       \n               user = await updateUser(user.id, { emailVerified: new Date() }); */\n\n              return user || null;\n            },\n          }),\n          // Conditionally add enterprise SSO providers\n          ...(getEnv().ENTERPRISE_LICENSE_KEY ? [] : []),\n        ],\n        callbacks: {\n          async jwt({ token }) {\n\n            const { users } = await getSDKForCurrentUser();\n            const userList = await users.list([Query.equal(\"email\", token.email!)])\n\n            const user = userList.users[0] ?? {};\n\n            /*  const existingUser = await getUserByEmail(token?.email!);\n       \n             if (!existingUser) {\n               return token;\n             } */\n\n            return {\n              ...token,\n              //@ts-ignore\n              profile: { id: user.$id, ...user },\n            };\n          },\n          async session({ session, token }) {\n            //@ts-ignore\n            session.user.id = token?.id;\n            //@ts-ignore\n            session.user = token.profile;\n\n            return session;\n          },\n          //@ts-ignore\n          async signIn({ user, account }: { user: any; account: Account | null }) {\n            /*   if (account?.provider === \"credentials\" || account?.provider === \"token\") {\n                // check if user's email is verified or not\n                if (!user.emailVerified && !EMAIL_VERIFICATION_DISABLED) {\n                  throw new Error(\"Email Verification is Pending\");\n                }\n                return true;\n              }\n              if (ENTERPRISE_LICENSE_KEY) {\n                return handleSSOCallback({ user, account });\n              } */\n            return true;\n          },\n        },\n        pages: {\n          signIn: \"/auth/login\",\n          signOut: \"/auth/logout\",\n          error: \"/auth/login\", // Error code passed in query string as ?error=\n        },\n      }\n    }\n    return options;\n  }\n})();\n"]}
129
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"authOptions.js","sourceRoot":"","sources":["../../src/actions/authOptions.ts"],"names":[],"mappings":"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","sourcesContent":["import type { Account, NextAuthOptions } from \"next-auth\";\nimport CredentialsProvider from \"next-auth/providers/credentials\";\nimport { cookies } from \"next/headers\";\nimport { getAppcondaClient, getAppcondaClientSync } from \"../getAppcondaClient\";\n\nimport { getEnv } from \"../lib/env\";\nimport { getSDKForCurrentUser } from \"../getSDKForCurrentUser\";\nimport { Query } from \"../query\";\nimport { AccountService, TUser } from \"../modules\";\n\n/* const getEnv = () => {\n  return {\n    APPCONDA_ENDPOINT: 'process.env.APPCONDA_ENDPOINT',\n    APPCONDA_CLIENT_ENDPOINT: 'process.env.APPCONDA_CLIENT_ENDPOINT',\n    _SERVICE_TOKEN: 'process.env._SERVICE_TOKEN',\n    ENTERPRISE_LICENSE_KEY: 'process.env.ENTERPRISE_LICENSE_KEY',\n  };\n}; */\n\nconst ENCRYPTION_KEY='51570cb4caa6c1f5f80e6e57a32efb397e9220434532697c94c8f821a7dd1951';\nconst ENTERPRISE_LICENSE_KEY = '';\nconst EMAIL_VERIFICATION_DISABLED = false;\n\nexport async function signIn({ userName, password }: { userName: string, password: string }) {\n  const adminClient = await getAppcondaClient();\n\n  const account = new Account(adminClient);\n\n  const session = await account.createEmailPasswordSession(userName, password);\n\n  const c = await cookies();\n\n  c.set('a_session', session.secret, {\n    path: \"/\",\n    httpOnly: true,\n    sameSite: \"strict\",\n    secure: true,\n  });\n\n  return session;\n\n}\n\n\n\nexport const authOptions = (() => {\n  let options : any= null;\n  const adminClient =  getAppcondaClientSync();\n  const accountService = new AccountService(adminClient);\n\n  return () => {\n    if (options == null) {\n      options = {\n        providers: [\n          CredentialsProvider({\n            id: \"credentials\",\n            // The name to display on the sign in form (e.g. \"Sign in with...\")\n            name: \"Credentials\",\n            // The credentials is used to generate a suitable form on the sign in page.\n            // You can specify whatever fields you are expecting to be submitted.\n            // e.g. domain, username, password, 2FA token, etc.\n            // You can pass any HTML attribute to the <input> tag through the object.\n            credentials: {\n              email: {\n                label: \"Email Address\",\n                type: \"email\",\n                placeholder: \"Your email address\",\n              },\n              password: {\n                label: \"Password\",\n                type: \"password\",\n                placeholder: \"Your password\",\n              },\n              totpCode: { label: \"Two-factor Code\", type: \"input\", placeholder: \"Code from authenticator app\" },\n              backupCode: { label: \"Backup Code\", type: \"input\", placeholder: \"Two-factor backup code\" },\n            },\n            async authorize(credentials, _req) {\n              const session = await accountService.CredentialLogin(credentials as any);\n            \n              return session;\n            },\n          }),\n          CredentialsProvider({\n            id: \"token\",\n            // The name to display on the sign in form (e.g. \"Sign in with...\")\n            name: \"Token\",\n            // The credentials is used to generate a suitable form on the sign in page.\n            // You can specify whatever fields you are expecting to be submitted.\n            // e.g. domain, username, password, 2FA token, etc.\n            // You can pass any HTML attribute to the <input> tag through the object.\n            credentials: {\n              token: {\n                label: \"Verification Token\",\n                type: \"string\",\n              },\n            },\n            async authorize(credentials, _req) {\n             \n              const token = credentials?.token;\n              const user = await accountService.TokenLogin({token: token!});\n      \n              return user;\n            },\n          }),\n          // Conditionally add enterprise SSO providers\n         // ...(ENTERPRISE_LICENSE_KEY ? getSSOProviders() : []),\n        ],\n        callbacks: {\n          async jwt({ token }) {\n            const existingUser = await accountService.GetUserByEmail({email: token?.email!});\n      \n            if (!existingUser) {\n              return token;\n            }\n      \n            return {\n              ...token,\n              profile: { id: existingUser.id },\n            };\n          },\n          async session({ session, token }) {\n            // @ts-expect-error\n            session.user.id = token?.id;\n            // @ts-expect-error\n            session.user = token.profile;\n      \n            return session;\n          },\n          async signIn({ user, account }: { user: TUser; account: Account }) {\n            if (account?.provider === \"credentials\" || account?.provider === \"token\") {\n              // check if user's email is verified or not\n              if (!user.emailVerified && !EMAIL_VERIFICATION_DISABLED) {\n                throw new Error(\"Email Verification is Pending\");\n              }\n              return true;\n            }\n            /* if (ENTERPRISE_LICENSE_KEY) {\n              return handleSSOCallback({ user, account });\n            } */\n            return true;\n          },\n        },\n        pages: {\n          signIn: \"/auth/login\",\n          signOut: \"/auth/logout\",\n          error: \"/auth/login\", // Error code passed in query string as ?error=\n        },\n      }\n    }\n    return options;\n  }\n})();\n"]}
@@ -1,2 +1,3 @@
1
1
  import { Client } from "./client";
2
2
  export declare function getAppcondaClient(): Promise<Client>;
3
+ export declare function getAppcondaClientSync(): Client;
@@ -41,4 +41,31 @@ export async function getAppcondaClient() {
41
41
  .setProject('console');
42
42
  return adminClient;
43
43
  }
44
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0QXBwY29uZGFDbGllbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvZ2V0QXBwY29uZGFDbGllbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUNsQyxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sV0FBVyxDQUFDO0FBRW5DLFNBQVMsa0JBQWtCLENBQUMsU0FBaUI7SUFDekMsSUFBSSxDQUFDO1FBQ0QsTUFBTSxHQUFHLEdBQUcsSUFBSSxHQUFHLENBQUMsU0FBUyxDQUFDLENBQUM7UUFDL0IsT0FBTztZQUNILFFBQVEsRUFBRSxHQUFHLENBQUMsUUFBUTtZQUN0QixJQUFJLEVBQUUsR0FBRyxDQUFDLElBQUksSUFBSSxDQUFDLEdBQUcsQ0FBQyxRQUFRLEtBQUssUUFBUSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxFQUFFLGlDQUFpQztZQUMvRixRQUFRLEVBQUUsR0FBRyxDQUFDLFFBQVE7U0FDekIsQ0FBQztJQUNOLENBQUM7SUFBQyxPQUFPLEtBQUssRUFBRSxDQUFDO1FBQ2IsT0FBTyxDQUFDLEtBQUssQ0FBQyxjQUFjLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFDckMsT0FBTyxFQUFFLFFBQVEsRUFBRSxFQUFFLEVBQUUsSUFBSSxFQUFFLEVBQUUsRUFBRSxRQUFRLEVBQUUsRUFBRSxFQUFFLENBQUM7SUFDcEQsQ0FBQztBQUNMLENBQUM7QUFFRCxNQUFNLENBQUMsS0FBSyxVQUFVLGlCQUFpQjtJQUVuQyxJQUFJLEdBQUcsQ0FBQztJQUNSLElBQUksTUFBTSxFQUFFLENBQUMsaUJBQWlCLEVBQUUsQ0FBQztRQUM3QixHQUFHLEdBQUcsTUFBTSxFQUFFLENBQUMsaUJBQWlCLENBQUM7SUFDckMsQ0FBQztTQUFNLElBQUksT0FBTyxNQUFNLEtBQUssV0FBVyxFQUFFLENBQUM7UUFDdkMsTUFBTSxRQUFRLEdBQUcsa0JBQWtCLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUMxRCxJQUFJLFFBQVEsQ0FBQyxJQUFJLEVBQUUsQ0FBQztZQUNoQixHQUFHLEdBQUcsR0FBRyxRQUFRLENBQUMsUUFBUSxLQUFLLFFBQVEsQ0FBQyxRQUFRLElBQUksUUFBUSxDQUFDLElBQUksS0FBSyxDQUFBO1FBQzFFLENBQUM7YUFBTSxDQUFDO1lBQ0osR0FBRyxHQUFHLEdBQUcsUUFBUSxDQUFDLFFBQVEsS0FBSyxRQUFRLENBQUMsUUFBUSxLQUFLLENBQUE7UUFDekQsQ0FBQztJQUNMLENBQUM7U0FBTSxDQUFDO1FBQ0osR0FBRyxHQUFHLE1BQU0sRUFBRSxDQUFDLGlCQUFpQixJQUFJLG9CQUFvQixDQUFBO0lBQzVELENBQUM7SUFFRDs7OztVQUlNO0lBQ04sTUFBTSxXQUFXLEdBQUcsSUFBSSxNQUFNLEVBQUU7U0FDM0IsV0FBVyxDQUFDLEdBQUcsQ0FBQyxDQUFDLG9CQUFvQjtTQUNyQyxVQUFVLENBQUMsU0FBUyxDQUFDLENBQUM7SUFFM0IsT0FBTyxXQUFXLENBQUE7QUFFdEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENsaWVudCB9IGZyb20gXCIuL2NsaWVudFwiO1xuaW1wb3J0IHsgZ2V0RW52IH0gZnJvbSBcIi4vbGliL2VudlwiO1xuXG5mdW5jdGlvbiBnZXRQb3J0QW5kSG9zdG5hbWUodXJsU3RyaW5nOiBzdHJpbmcpOiB7IGhvc3RuYW1lOiBzdHJpbmc7IHBvcnQ6IHN0cmluZzsgcHJvdG9jb2w6IHN0cmluZyB9IHtcbiAgICB0cnkge1xuICAgICAgICBjb25zdCB1cmwgPSBuZXcgVVJMKHVybFN0cmluZyk7XG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICBob3N0bmFtZTogdXJsLmhvc3RuYW1lLFxuICAgICAgICAgICAgcG9ydDogdXJsLnBvcnQgfHwgKHVybC5wcm90b2NvbCA9PT0gJ2h0dHBzOicgPyAnNDQzJyA6ICc4MCcpLCAvLyBEZWZhdWx0IHBvcnRzIGlmIG5vdCBzcGVjaWZpZWRcbiAgICAgICAgICAgIHByb3RvY29sOiB1cmwucHJvdG9jb2xcbiAgICAgICAgfTtcbiAgICB9IGNhdGNoIChlcnJvcikge1xuICAgICAgICBjb25zb2xlLmVycm9yKCdJbnZhbGlkIFVSTDonLCBlcnJvcik7XG4gICAgICAgIHJldHVybiB7IGhvc3RuYW1lOiAnJywgcG9ydDogJycsIHByb3RvY29sOiAnJyB9O1xuICAgIH1cbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGdldEFwcGNvbmRhQ2xpZW50KCkge1xuXG4gICAgbGV0IHVybDtcbiAgICBpZiAoZ2V0RW52KCkuQVBQQ09OREFfRU5EUE9JTlQpIHtcbiAgICAgICAgdXJsID0gZ2V0RW52KCkuQVBQQ09OREFfRU5EUE9JTlQ7XG4gICAgfSBlbHNlIGlmICh0eXBlb2Ygd2luZG93ICE9PSAndW5kZWZpbmVkJykge1xuICAgICAgICBjb25zdCBob3N0SW5mbyA9IGdldFBvcnRBbmRIb3N0bmFtZSh3aW5kb3cubG9jYXRpb24uaHJlZik7XG4gICAgICAgIGlmIChob3N0SW5mby5wb3J0KSB7XG4gICAgICAgICAgICB1cmwgPSBgJHtob3N0SW5mby5wcm90b2NvbH0vLyR7aG9zdEluZm8uaG9zdG5hbWV9OiR7aG9zdEluZm8ucG9ydH0vdjFgXG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICB1cmwgPSBgJHtob3N0SW5mby5wcm90b2NvbH0vLyR7aG9zdEluZm8uaG9zdG5hbWV9L3YxYFxuICAgICAgICB9XG4gICAgfSBlbHNlIHtcbiAgICAgICAgdXJsID0gZ2V0RW52KCkuQVBQQ09OREFfRU5EUE9JTlQgfHwgJ2h0dHA6Ly9hcHBjb25kYS92MSdcbiAgICB9XG5cbiAgICAvKiAgaWYgKEFwcGxpY2F0aW9uQ29uZmlnLlBvcnQgPT0gbnVsbCkge1xuICAgICAgICAgdXJsID0gYCR7QXBwbGljYXRpb25Db25maWcuUHJvdG9jb2x9Oi8vJHtBcHBsaWNhdGlvbkNvbmZpZy5Eb21haW59OiR7QXBwbGljYXRpb25Db25maWcuUG9ydH0vdjFgXG4gICAgIH0gZWxzZSB7XG4gICAgICAgICAgIHVybCA9IGAke0FwcGxpY2F0aW9uQ29uZmlnLlByb3RvY29sfTovLyR7QXBwbGljYXRpb25Db25maWcuRG9tYWlufS92MWBcbiAgICAgfSAgKi9cbiAgICBjb25zdCBhZG1pbkNsaWVudCA9IG5ldyBDbGllbnQoKVxuICAgICAgICAuc2V0RW5kcG9pbnQodXJsKSAvLyBZb3VyIEFQSSBFbmRwb2ludFxuICAgICAgICAuc2V0UHJvamVjdCgnY29uc29sZScpO1xuXG4gICAgcmV0dXJuIGFkbWluQ2xpZW50XG5cbn0iXX0=
44
+ export function getAppcondaClientSync() {
45
+ let url;
46
+ if (getEnv().APPCONDA_ENDPOINT) {
47
+ url = getEnv().APPCONDA_ENDPOINT;
48
+ }
49
+ else if (typeof window !== 'undefined') {
50
+ const hostInfo = getPortAndHostname(window.location.href);
51
+ if (hostInfo.port) {
52
+ url = `${hostInfo.protocol}//${hostInfo.hostname}:${hostInfo.port}/v1`;
53
+ }
54
+ else {
55
+ url = `${hostInfo.protocol}//${hostInfo.hostname}/v1`;
56
+ }
57
+ }
58
+ else {
59
+ url = getEnv().APPCONDA_ENDPOINT || 'http://appconda/v1';
60
+ }
61
+ /* if (ApplicationConfig.Port == null) {
62
+ url = `${ApplicationConfig.Protocol}://${ApplicationConfig.Domain}:${ApplicationConfig.Port}/v1`
63
+ } else {
64
+ url = `${ApplicationConfig.Protocol}://${ApplicationConfig.Domain}/v1`
65
+ } */
66
+ const adminClient = new Client()
67
+ .setEndpoint(url) // Your API Endpoint
68
+ .setProject('console');
69
+ return adminClient;
70
+ }
71
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0QXBwY29uZGFDbGllbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvZ2V0QXBwY29uZGFDbGllbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUNsQyxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sV0FBVyxDQUFDO0FBRW5DLFNBQVMsa0JBQWtCLENBQUMsU0FBaUI7SUFDekMsSUFBSSxDQUFDO1FBQ0QsTUFBTSxHQUFHLEdBQUcsSUFBSSxHQUFHLENBQUMsU0FBUyxDQUFDLENBQUM7UUFDL0IsT0FBTztZQUNILFFBQVEsRUFBRSxHQUFHLENBQUMsUUFBUTtZQUN0QixJQUFJLEVBQUUsR0FBRyxDQUFDLElBQUksSUFBSSxDQUFDLEdBQUcsQ0FBQyxRQUFRLEtBQUssUUFBUSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxFQUFFLGlDQUFpQztZQUMvRixRQUFRLEVBQUUsR0FBRyxDQUFDLFFBQVE7U0FDekIsQ0FBQztJQUNOLENBQUM7SUFBQyxPQUFPLEtBQUssRUFBRSxDQUFDO1FBQ2IsT0FBTyxDQUFDLEtBQUssQ0FBQyxjQUFjLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFDckMsT0FBTyxFQUFFLFFBQVEsRUFBRSxFQUFFLEVBQUUsSUFBSSxFQUFFLEVBQUUsRUFBRSxRQUFRLEVBQUUsRUFBRSxFQUFFLENBQUM7SUFDcEQsQ0FBQztBQUNMLENBQUM7QUFFRCxNQUFNLENBQUMsS0FBSyxVQUFVLGlCQUFpQjtJQUVuQyxJQUFJLEdBQUcsQ0FBQztJQUNSLElBQUksTUFBTSxFQUFFLENBQUMsaUJBQWlCLEVBQUUsQ0FBQztRQUM3QixHQUFHLEdBQUcsTUFBTSxFQUFFLENBQUMsaUJBQWlCLENBQUM7SUFDckMsQ0FBQztTQUFNLElBQUksT0FBTyxNQUFNLEtBQUssV0FBVyxFQUFFLENBQUM7UUFDdkMsTUFBTSxRQUFRLEdBQUcsa0JBQWtCLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUMxRCxJQUFJLFFBQVEsQ0FBQyxJQUFJLEVBQUUsQ0FBQztZQUNoQixHQUFHLEdBQUcsR0FBRyxRQUFRLENBQUMsUUFBUSxLQUFLLFFBQVEsQ0FBQyxRQUFRLElBQUksUUFBUSxDQUFDLElBQUksS0FBSyxDQUFBO1FBQzFFLENBQUM7YUFBTSxDQUFDO1lBQ0osR0FBRyxHQUFHLEdBQUcsUUFBUSxDQUFDLFFBQVEsS0FBSyxRQUFRLENBQUMsUUFBUSxLQUFLLENBQUE7UUFDekQsQ0FBQztJQUNMLENBQUM7U0FBTSxDQUFDO1FBQ0osR0FBRyxHQUFHLE1BQU0sRUFBRSxDQUFDLGlCQUFpQixJQUFJLG9CQUFvQixDQUFBO0lBQzVELENBQUM7SUFFRDs7OztVQUlNO0lBQ04sTUFBTSxXQUFXLEdBQUcsSUFBSSxNQUFNLEVBQUU7U0FDM0IsV0FBVyxDQUFDLEdBQUcsQ0FBQyxDQUFDLG9CQUFvQjtTQUNyQyxVQUFVLENBQUMsU0FBUyxDQUFDLENBQUM7SUFFM0IsT0FBTyxXQUFXLENBQUE7QUFFdEIsQ0FBQztBQUVELE1BQU0sVUFBVyxxQkFBcUI7SUFFbEMsSUFBSSxHQUFHLENBQUM7SUFDUixJQUFJLE1BQU0sRUFBRSxDQUFDLGlCQUFpQixFQUFFLENBQUM7UUFDN0IsR0FBRyxHQUFHLE1BQU0sRUFBRSxDQUFDLGlCQUFpQixDQUFDO0lBQ3JDLENBQUM7U0FBTSxJQUFJLE9BQU8sTUFBTSxLQUFLLFdBQVcsRUFBRSxDQUFDO1FBQ3ZDLE1BQU0sUUFBUSxHQUFHLGtCQUFrQixDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDMUQsSUFBSSxRQUFRLENBQUMsSUFBSSxFQUFFLENBQUM7WUFDaEIsR0FBRyxHQUFHLEdBQUcsUUFBUSxDQUFDLFFBQVEsS0FBSyxRQUFRLENBQUMsUUFBUSxJQUFJLFFBQVEsQ0FBQyxJQUFJLEtBQUssQ0FBQTtRQUMxRSxDQUFDO2FBQU0sQ0FBQztZQUNKLEdBQUcsR0FBRyxHQUFHLFFBQVEsQ0FBQyxRQUFRLEtBQUssUUFBUSxDQUFDLFFBQVEsS0FBSyxDQUFBO1FBQ3pELENBQUM7SUFDTCxDQUFDO1NBQU0sQ0FBQztRQUNKLEdBQUcsR0FBRyxNQUFNLEVBQUUsQ0FBQyxpQkFBaUIsSUFBSSxvQkFBb0IsQ0FBQTtJQUM1RCxDQUFDO0lBRUQ7Ozs7VUFJTTtJQUNOLE1BQU0sV0FBVyxHQUFHLElBQUksTUFBTSxFQUFFO1NBQzNCLFdBQVcsQ0FBQyxHQUFHLENBQUMsQ0FBQyxvQkFBb0I7U0FDckMsVUFBVSxDQUFDLFNBQVMsQ0FBQyxDQUFDO0lBRTNCLE9BQU8sV0FBVyxDQUFBO0FBRXRCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDbGllbnQgfSBmcm9tIFwiLi9jbGllbnRcIjtcbmltcG9ydCB7IGdldEVudiB9IGZyb20gXCIuL2xpYi9lbnZcIjtcblxuZnVuY3Rpb24gZ2V0UG9ydEFuZEhvc3RuYW1lKHVybFN0cmluZzogc3RyaW5nKTogeyBob3N0bmFtZTogc3RyaW5nOyBwb3J0OiBzdHJpbmc7IHByb3RvY29sOiBzdHJpbmcgfSB7XG4gICAgdHJ5IHtcbiAgICAgICAgY29uc3QgdXJsID0gbmV3IFVSTCh1cmxTdHJpbmcpO1xuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgaG9zdG5hbWU6IHVybC5ob3N0bmFtZSxcbiAgICAgICAgICAgIHBvcnQ6IHVybC5wb3J0IHx8ICh1cmwucHJvdG9jb2wgPT09ICdodHRwczonID8gJzQ0MycgOiAnODAnKSwgLy8gRGVmYXVsdCBwb3J0cyBpZiBub3Qgc3BlY2lmaWVkXG4gICAgICAgICAgICBwcm90b2NvbDogdXJsLnByb3RvY29sXG4gICAgICAgIH07XG4gICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgICAgY29uc29sZS5lcnJvcignSW52YWxpZCBVUkw6JywgZXJyb3IpO1xuICAgICAgICByZXR1cm4geyBob3N0bmFtZTogJycsIHBvcnQ6ICcnLCBwcm90b2NvbDogJycgfTtcbiAgICB9XG59XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBnZXRBcHBjb25kYUNsaWVudCgpIHtcblxuICAgIGxldCB1cmw7XG4gICAgaWYgKGdldEVudigpLkFQUENPTkRBX0VORFBPSU5UKSB7XG4gICAgICAgIHVybCA9IGdldEVudigpLkFQUENPTkRBX0VORFBPSU5UO1xuICAgIH0gZWxzZSBpZiAodHlwZW9mIHdpbmRvdyAhPT0gJ3VuZGVmaW5lZCcpIHtcbiAgICAgICAgY29uc3QgaG9zdEluZm8gPSBnZXRQb3J0QW5kSG9zdG5hbWUod2luZG93LmxvY2F0aW9uLmhyZWYpO1xuICAgICAgICBpZiAoaG9zdEluZm8ucG9ydCkge1xuICAgICAgICAgICAgdXJsID0gYCR7aG9zdEluZm8ucHJvdG9jb2x9Ly8ke2hvc3RJbmZvLmhvc3RuYW1lfToke2hvc3RJbmZvLnBvcnR9L3YxYFxuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgdXJsID0gYCR7aG9zdEluZm8ucHJvdG9jb2x9Ly8ke2hvc3RJbmZvLmhvc3RuYW1lfS92MWBcbiAgICAgICAgfVxuICAgIH0gZWxzZSB7XG4gICAgICAgIHVybCA9IGdldEVudigpLkFQUENPTkRBX0VORFBPSU5UIHx8ICdodHRwOi8vYXBwY29uZGEvdjEnXG4gICAgfVxuXG4gICAgLyogIGlmIChBcHBsaWNhdGlvbkNvbmZpZy5Qb3J0ID09IG51bGwpIHtcbiAgICAgICAgIHVybCA9IGAke0FwcGxpY2F0aW9uQ29uZmlnLlByb3RvY29sfTovLyR7QXBwbGljYXRpb25Db25maWcuRG9tYWlufToke0FwcGxpY2F0aW9uQ29uZmlnLlBvcnR9L3YxYFxuICAgICB9IGVsc2Uge1xuICAgICAgICAgICB1cmwgPSBgJHtBcHBsaWNhdGlvbkNvbmZpZy5Qcm90b2NvbH06Ly8ke0FwcGxpY2F0aW9uQ29uZmlnLkRvbWFpbn0vdjFgXG4gICAgIH0gICovXG4gICAgY29uc3QgYWRtaW5DbGllbnQgPSBuZXcgQ2xpZW50KClcbiAgICAgICAgLnNldEVuZHBvaW50KHVybCkgLy8gWW91ciBBUEkgRW5kcG9pbnRcbiAgICAgICAgLnNldFByb2plY3QoJ2NvbnNvbGUnKTtcblxuICAgIHJldHVybiBhZG1pbkNsaWVudFxuXG59XG5cbmV4cG9ydCAgZnVuY3Rpb24gZ2V0QXBwY29uZGFDbGllbnRTeW5jKCkge1xuXG4gICAgbGV0IHVybDtcbiAgICBpZiAoZ2V0RW52KCkuQVBQQ09OREFfRU5EUE9JTlQpIHtcbiAgICAgICAgdXJsID0gZ2V0RW52KCkuQVBQQ09OREFfRU5EUE9JTlQ7XG4gICAgfSBlbHNlIGlmICh0eXBlb2Ygd2luZG93ICE9PSAndW5kZWZpbmVkJykge1xuICAgICAgICBjb25zdCBob3N0SW5mbyA9IGdldFBvcnRBbmRIb3N0bmFtZSh3aW5kb3cubG9jYXRpb24uaHJlZik7XG4gICAgICAgIGlmIChob3N0SW5mby5wb3J0KSB7XG4gICAgICAgICAgICB1cmwgPSBgJHtob3N0SW5mby5wcm90b2NvbH0vLyR7aG9zdEluZm8uaG9zdG5hbWV9OiR7aG9zdEluZm8ucG9ydH0vdjFgXG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICB1cmwgPSBgJHtob3N0SW5mby5wcm90b2NvbH0vLyR7aG9zdEluZm8uaG9zdG5hbWV9L3YxYFxuICAgICAgICB9XG4gICAgfSBlbHNlIHtcbiAgICAgICAgdXJsID0gZ2V0RW52KCkuQVBQQ09OREFfRU5EUE9JTlQgfHwgJ2h0dHA6Ly9hcHBjb25kYS92MSdcbiAgICB9XG5cbiAgICAvKiAgaWYgKEFwcGxpY2F0aW9uQ29uZmlnLlBvcnQgPT0gbnVsbCkge1xuICAgICAgICAgdXJsID0gYCR7QXBwbGljYXRpb25Db25maWcuUHJvdG9jb2x9Oi8vJHtBcHBsaWNhdGlvbkNvbmZpZy5Eb21haW59OiR7QXBwbGljYXRpb25Db25maWcuUG9ydH0vdjFgXG4gICAgIH0gZWxzZSB7XG4gICAgICAgICAgIHVybCA9IGAke0FwcGxpY2F0aW9uQ29uZmlnLlByb3RvY29sfTovLyR7QXBwbGljYXRpb25Db25maWcuRG9tYWlufS92MWBcbiAgICAgfSAgKi9cbiAgICBjb25zdCBhZG1pbkNsaWVudCA9IG5ldyBDbGllbnQoKVxuICAgICAgICAuc2V0RW5kcG9pbnQodXJsKSAvLyBZb3VyIEFQSSBFbmRwb2ludFxuICAgICAgICAuc2V0UHJvamVjdCgnY29uc29sZScpO1xuXG4gICAgcmV0dXJuIGFkbWluQ2xpZW50XG5cbn0iXX0=
@@ -1,7 +1,9 @@
1
1
  import { z } from 'zod';
2
- import { _CreateUserSchema, GetUserByIdSchema, RegisterUserSchema, UpdateUserVerifyTokenSchema } from './schema';
2
+ import { _CreateUserSchema, CredentialLoginSchema, GetUserByIdSchema, RegisterUserSchema, TokenLoginSchema, UpdateUserVerifyTokenSchema } from './schema';
3
3
  import { TUser } from './types';
4
4
  export declare function CreateUser(parsedInput: z.infer<typeof _CreateUserSchema>): Promise<TUser>;
5
5
  export declare function RegisterUser(parsedInput: z.infer<typeof RegisterUserSchema>): Promise<TUser>;
6
6
  export declare function GetUserById(parsedInput: z.infer<typeof GetUserByIdSchema>): Promise<TUser>;
7
7
  export declare function UpdateUserVerifyToken(parsedInput: z.infer<typeof UpdateUserVerifyTokenSchema>): Promise<TUser>;
8
+ export declare function CredentialLogin(parsedInput: z.infer<typeof CredentialLoginSchema>): Promise<TUser>;
9
+ export declare function TokenLogin(parsedInput: z.infer<typeof TokenLoginSchema>): Promise<TUser>;