@appconda/nextjs 1.0.386 → 1.0.388

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.
@@ -28,8 +28,6 @@ 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);
33
31
  return () => {
34
32
  if (options == null) {
35
33
  options = {
@@ -57,6 +55,8 @@ export const authOptions = (() => {
57
55
  backupCode: { label: "Backup Code", type: "input", placeholder: "Two-factor backup code" },
58
56
  },
59
57
  async authorize(credentials, _req) {
58
+ const adminClient = getAppcondaClientSync();
59
+ const accountService = new AccountService(adminClient);
60
60
  const session = await accountService.CredentialLogin(credentials);
61
61
  return session;
62
62
  },
@@ -76,6 +76,8 @@ export const authOptions = (() => {
76
76
  },
77
77
  },
78
78
  async authorize(credentials, _req) {
79
+ const adminClient = getAppcondaClientSync();
80
+ const accountService = new AccountService(adminClient);
79
81
  const token = credentials?.token;
80
82
  const user = await accountService.TokenLogin({ token: token });
81
83
  return user;
@@ -86,6 +88,8 @@ export const authOptions = (() => {
86
88
  ],
87
89
  callbacks: {
88
90
  async jwt({ token }) {
91
+ const adminClient = getAppcondaClientSync();
92
+ const accountService = new AccountService(adminClient);
89
93
  const existingUser = await accountService.GetUserByEmail({ email: token?.email });
90
94
  if (!existingUser) {
91
95
  return token;
@@ -126,4 +130,4 @@ export const authOptions = (() => {
126
130
  return options;
127
131
  };
128
132
  })();
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"]}
133
+ //# 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\n\n  return () => {\n   \n\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 adminClient =  getAppcondaClientSync();\n              const accountService = new AccountService(adminClient);\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              const adminClient =  getAppcondaClientSync();\n              const accountService = new AccountService(adminClient);\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 adminClient =  getAppcondaClientSync();\n            const accountService = new AccountService(adminClient);\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"]}
package/package.json CHANGED
@@ -2,7 +2,7 @@
2
2
  "name": "@appconda/nextjs",
3
3
  "homepage": "https://appconda.io/support",
4
4
  "description": "Appconda is an open-source self-hosted backend server that abstract and simplify complex and repetitive development tasks behind a very simple REST API",
5
- "version": "1.0.386",
5
+ "version": "1.0.388",
6
6
  "license": "BSD-3-Clause",
7
7
  "main": "dist/index.js",
8
8
  "types": "dist/index.d.ts",
@@ -45,10 +45,11 @@ export async function signIn({ userName, password }: { userName: string, passwor
45
45
 
46
46
  export const authOptions = (() => {
47
47
  let options : any= null;
48
- const adminClient = getAppcondaClientSync();
49
- const accountService = new AccountService(adminClient);
48
+
50
49
 
51
50
  return () => {
51
+
52
+
52
53
  if (options == null) {
53
54
  options = {
54
55
  providers: [
@@ -75,6 +76,8 @@ export const authOptions = (() => {
75
76
  backupCode: { label: "Backup Code", type: "input", placeholder: "Two-factor backup code" },
76
77
  },
77
78
  async authorize(credentials, _req) {
79
+ const adminClient = getAppcondaClientSync();
80
+ const accountService = new AccountService(adminClient);
78
81
  const session = await accountService.CredentialLogin(credentials as any);
79
82
 
80
83
  return session;
@@ -95,6 +98,8 @@ export const authOptions = (() => {
95
98
  },
96
99
  },
97
100
  async authorize(credentials, _req) {
101
+ const adminClient = getAppcondaClientSync();
102
+ const accountService = new AccountService(adminClient);
98
103
 
99
104
  const token = credentials?.token;
100
105
  const user = await accountService.TokenLogin({token: token!});
@@ -107,6 +112,8 @@ export const authOptions = (() => {
107
112
  ],
108
113
  callbacks: {
109
114
  async jwt({ token }) {
115
+ const adminClient = getAppcondaClientSync();
116
+ const accountService = new AccountService(adminClient);
110
117
  const existingUser = await accountService.GetUserByEmail({email: token?.email!});
111
118
 
112
119
  if (!existingUser) {