This commit is contained in:
Benjamin Toby 2025-07-10 12:13:03 +01:00
parent 5ab079f687
commit f9725a1d6f
22 changed files with 262 additions and 177 deletions

2
dist/index.d.ts vendored
View File

@ -52,6 +52,7 @@ declare const datasquirel: {
sendEmailCode: (_: import("./package-shared/types").SendEmailCodeParams) => Promise<import("./package-shared/types").APIResponseObject>; sendEmailCode: (_: import("./package-shared/types").SendEmailCodeParams) => Promise<import("./package-shared/types").APIResponseObject>;
update: (_: import("./package-shared/types").UpdateUserParams) => Promise<import("./package-shared/types").UpdateUserFunctionReturn>; update: (_: import("./package-shared/types").UpdateUserParams) => Promise<import("./package-shared/types").UpdateUserFunctionReturn>;
resetPassword: (_: import("./package-shared/types").ResetPasswordParams) => Promise<import("./package-shared/types").UpdateUserFunctionReturn>; resetPassword: (_: import("./package-shared/types").ResetPasswordParams) => Promise<import("./package-shared/types").UpdateUserFunctionReturn>;
googleLogin: (_: import("./package-shared/types").GoogleAuthParams) => Promise<import("./package-shared/types").APIResponseObject>;
logout: typeof import("./package-shared/actions/users/logout-user").default; logout: typeof import("./package-shared/actions/users/logout-user").default;
auth: typeof import("./package-shared/actions/users/user-auth").default; auth: typeof import("./package-shared/actions/users/user-auth").default;
}; };
@ -73,6 +74,7 @@ declare const datasquirel: {
sendEmailCode: (_: import("./package-shared/types").SendEmailCodeParams) => Promise<import("./package-shared/types").APIResponseObject>; sendEmailCode: (_: import("./package-shared/types").SendEmailCodeParams) => Promise<import("./package-shared/types").APIResponseObject>;
update: (_: import("./package-shared/types").UpdateUserParams) => Promise<import("./package-shared/types").UpdateUserFunctionReturn>; update: (_: import("./package-shared/types").UpdateUserParams) => Promise<import("./package-shared/types").UpdateUserFunctionReturn>;
resetPassword: (_: import("./package-shared/types").ResetPasswordParams) => Promise<import("./package-shared/types").UpdateUserFunctionReturn>; resetPassword: (_: import("./package-shared/types").ResetPasswordParams) => Promise<import("./package-shared/types").UpdateUserFunctionReturn>;
googleLogin: (_: import("./package-shared/types").GoogleAuthParams) => Promise<import("./package-shared/types").APIResponseObject>;
logout: typeof import("./package-shared/actions/users/logout-user").default; logout: typeof import("./package-shared/actions/users/logout-user").default;
auth: typeof import("./package-shared/actions/users/user-auth").default; auth: typeof import("./package-shared/actions/users/user-auth").default;
}; };

View File

@ -118,7 +118,7 @@ function loginUser(_a) {
} }
const cookieNames = (0, get_auth_cookie_names_1.default)({ const cookieNames = (0, get_auth_cookie_names_1.default)({
database, database,
userId: apiUserID, userId: apiUserID || process.env.DSQL_API_USER_ID,
}); });
if (httpResponse.csrf && !skipWriteAuthFile) { if (httpResponse.csrf && !skipWriteAuthFile) {
(0, write_auth_files_1.writeAuthFile)(httpResponse.csrf, JSON.stringify(httpResponse.payload), cleanupTokens && ((_b = httpResponse.payload) === null || _b === void 0 ? void 0 : _b.id) (0, write_auth_files_1.writeAuthFile)(httpResponse.csrf, JSON.stringify(httpResponse.payload), cleanupTokens && ((_b = httpResponse.payload) === null || _b === void 0 ? void 0 : _b.id)

View File

@ -1,27 +1,5 @@
import http from "http"; import { APIResponseObject, GoogleAuthParams } from "../../../types";
import { APILoginFunctionReturn } from "../../../types";
type Param = {
key?: string;
token: string;
database?: string;
response?: http.ServerResponse;
encryptionKey?: string;
encryptionSalt?: string;
additionalFields?: string[];
additionalData?: {
[s: string]: string | number;
};
apiUserID?: string | number;
debug?: boolean;
secureCookie?: boolean;
loginOnly?: boolean;
/**
* Login without calling external API
*/
forceLocal?: boolean;
};
/** /**
* # SERVER FUNCTION: Login with google Function * # SERVER FUNCTION: Login with google Function
*/ */
export default function googleAuth({ key, token, database, response, encryptionKey, encryptionSalt, additionalFields, additionalData, apiUserID, debug, secureCookie, loginOnly, forceLocal, }: Param): Promise<APILoginFunctionReturn>; export default function googleAuth({ apiKey, token, database, response, encryptionKey, encryptionSalt, additionalFields, additionalData, apiUserID, debug, secureCookie, loginOnly, useLocal, apiVersion, }: GoogleAuthParams): Promise<APIResponseObject>;
export {};

View File

@ -14,21 +14,18 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
Object.defineProperty(exports, "__esModule", { value: true }); Object.defineProperty(exports, "__esModule", { value: true });
exports.default = googleAuth; exports.default = googleAuth;
const encrypt_1 = __importDefault(require("../../../functions/dsql/encrypt")); const encrypt_1 = __importDefault(require("../../../functions/dsql/encrypt"));
const grab_host_names_1 = __importDefault(require("../../../utils/grab-host-names"));
const api_google_login_1 = __importDefault(require("../../../functions/api/users/social/api-google-login")); const api_google_login_1 = __importDefault(require("../../../functions/api/users/social/api-google-login"));
const get_auth_cookie_names_1 = __importDefault(require("../../../functions/backend/cookies/get-auth-cookie-names")); const get_auth_cookie_names_1 = __importDefault(require("../../../functions/backend/cookies/get-auth-cookie-names"));
const write_auth_files_1 = require("../../../functions/backend/auth/write-auth-files"); const write_auth_files_1 = require("../../../functions/backend/auth/write-auth-files");
const grab_cookie_expirt_date_1 = __importDefault(require("../../../utils/grab-cookie-expirt-date")); const grab_cookie_expirt_date_1 = __importDefault(require("../../../utils/grab-cookie-expirt-date"));
const query_dsql_api_1 = __importDefault(require("../../../functions/api/query-dsql-api"));
const grab_api_path_1 = __importDefault(require("../../../utils/backend/users/grab-api-path"));
/** /**
* # SERVER FUNCTION: Login with google Function * # SERVER FUNCTION: Login with google Function
*/ */
function googleAuth(_a) { function googleAuth(_a) {
return __awaiter(this, arguments, void 0, function* ({ key, token, database, response, encryptionKey, encryptionSalt, additionalFields, additionalData, apiUserID, debug, secureCookie, loginOnly, forceLocal, }) { return __awaiter(this, arguments, void 0, function* ({ apiKey, token, database, response, encryptionKey, encryptionSalt, additionalFields, additionalData, apiUserID, debug, secureCookie, loginOnly, useLocal, apiVersion, }) {
var _b; var _b;
const grabedHostNames = (0, grab_host_names_1.default)({
userId: apiUserID || process.env.DSQL_API_USER_ID,
});
const { host, port, scheme, user_id } = grabedHostNames;
const COOKIE_EXPIRY_DATE = (0, grab_cookie_expirt_date_1.default)(); const COOKIE_EXPIRY_DATE = (0, grab_cookie_expirt_date_1.default)();
const finalEncryptionKey = encryptionKey || process.env.DSQL_ENCRYPTION_PASSWORD; const finalEncryptionKey = encryptionKey || process.env.DSQL_ENCRYPTION_PASSWORD;
const finalEncryptionSalt = encryptionSalt || process.env.DSQL_ENCRYPTION_SALT; const finalEncryptionSalt = encryptionSalt || process.env.DSQL_ENCRYPTION_SALT;
@ -66,58 +63,32 @@ function googleAuth(_a) {
let httpResponse = { let httpResponse = {
success: false, success: false,
}; };
if (forceLocal) { const googleAuthParams = {
token,
additionalFields,
additionalData,
debug,
loginOnly,
database,
apiUserId: apiUserID || process.env.DSQL_API_USER_ID,
};
if (useLocal) {
if (debug) { if (debug) {
console.log(`Google login with Local Paradigm ...`); console.log(`Google login with Local Paradigm ...`);
} }
httpResponse = yield (0, api_google_login_1.default)({ httpResponse = yield (0, api_google_login_1.default)(googleAuthParams);
token,
additionalFields,
additionalData,
debug,
loginOnly,
});
} }
else { else {
httpResponse = yield new Promise((resolve, reject) => { httpResponse = yield (0, query_dsql_api_1.default)({
const reqPayload = JSON.stringify({ path: (0, grab_api_path_1.default)({
token, paradigm: "auth",
action: "google-login",
database, database,
additionalFields, apiVersion,
additionalData, }),
}); apiKey,
const httpsRequest = scheme.request({ body: googleAuthParams,
method: "POST", method: "POST",
headers: {
"Content-Type": "application/json",
"Content-Length": Buffer.from(reqPayload).length,
Authorization: key ||
process.env.DSQL_FULL_ACCESS_API_KEY ||
process.env.DSQL_API_KEY,
},
port,
hostname: host,
path: `/api/user/${apiUserID || grabedHostNames.user_id}/google-login`,
},
/**
* Callback Function
*
* @description https request callback
*/
(response) => {
var str = "";
response.on("data", function (chunk) {
str += chunk;
});
response.on("end", function () {
resolve(JSON.parse(str));
});
response.on("error", (err) => {
reject(err);
});
});
httpsRequest.write(reqPayload);
httpsRequest.end();
}); });
} }
/** /**
@ -133,7 +104,7 @@ function googleAuth(_a) {
}); });
const cookieNames = (0, get_auth_cookie_names_1.default)({ const cookieNames = (0, get_auth_cookie_names_1.default)({
database, database,
userId: user_id, userId: apiUserID || process.env.DSQL_API_USER_ID,
}); });
if (httpResponse.csrf) { if (httpResponse.csrf) {
(0, write_auth_files_1.writeAuthFile)(httpResponse.csrf, JSON.stringify(httpResponse.payload)); (0, write_auth_files_1.writeAuthFile)(httpResponse.csrf, JSON.stringify(httpResponse.payload));

View File

@ -0,0 +1,15 @@
import http from "http";
import { SendOneTimeCodeEmailResponse } from "../../types";
type Param = {
request?: http.IncomingMessage & {
[s: string]: any;
};
cookieString?: string;
email?: string;
code?: string;
};
/**
* # Verify the temp email code sent to the user's email address
*/
export default function validateTempEmailCode({ request, email, cookieString, code, }: Param): Promise<SendOneTimeCodeEmailResponse | null>;
export {};

View File

@ -0,0 +1,47 @@
"use strict";
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.default = validateTempEmailCode;
const get_auth_cookie_names_1 = __importDefault(require("../../functions/backend/cookies/get-auth-cookie-names"));
const parseCookies_1 = __importDefault(require("../../utils/backend/parseCookies"));
const decrypt_1 = __importDefault(require("../../functions/dsql/decrypt"));
const ejson_1 = __importDefault(require("../../utils/ejson"));
/**
* # Verify the temp email code sent to the user's email address
*/
function validateTempEmailCode(_a) {
return __awaiter(this, arguments, void 0, function* ({ request, email, cookieString, code, }) {
try {
const keyNames = (0, get_auth_cookie_names_1.default)();
const oneTimeCodeCookieName = keyNames.oneTimeCodeName;
const cookies = (0, parseCookies_1.default)({ request, cookieString });
const encryptedOneTimeCode = cookies[oneTimeCodeCookieName];
const encryptedPayload = (0, decrypt_1.default)({
encryptedString: encryptedOneTimeCode,
});
const payload = ejson_1.default.parse(encryptedPayload);
if ((payload === null || payload === void 0 ? void 0 : payload.email) && !email) {
return payload;
}
if ((payload === null || payload === void 0 ? void 0 : payload.email) && payload.email === email) {
return payload;
}
return null;
}
catch (error) {
console.log("validateTempEmailCode error:", error.message);
return null;
}
});
}

View File

@ -1,6 +1,6 @@
import logoutUser from "../../actions/users/logout-user"; import logoutUser from "../../actions/users/logout-user";
import userAuth from "../../actions/users/user-auth"; import userAuth from "../../actions/users/user-auth";
import { AddUserParams, GetUserParams, LoginUserParam, ResetPasswordParams, SendEmailCodeParams, UpdateUserParams } from "../../types"; import { AddUserParams, GetUserParams, GoogleAuthParams, LoginUserParam, ResetPasswordParams, SendEmailCodeParams, UpdateUserParams } from "../../types";
type Params = { type Params = {
local?: boolean; local?: boolean;
}; };
@ -12,6 +12,7 @@ export default function user(params?: Params): {
sendEmailCode: (_: SendEmailCodeParams) => Promise<import("../../types").APIResponseObject>; sendEmailCode: (_: SendEmailCodeParams) => Promise<import("../../types").APIResponseObject>;
update: (_: UpdateUserParams) => Promise<import("../../types").UpdateUserFunctionReturn>; update: (_: UpdateUserParams) => Promise<import("../../types").UpdateUserFunctionReturn>;
resetPassword: (_: ResetPasswordParams) => Promise<import("../../types").UpdateUserFunctionReturn>; resetPassword: (_: ResetPasswordParams) => Promise<import("../../types").UpdateUserFunctionReturn>;
googleLogin: (_: GoogleAuthParams) => Promise<import("../../types").APIResponseObject>;
logout: typeof logoutUser; logout: typeof logoutUser;
auth: typeof userAuth; auth: typeof userAuth;
}; };

View File

@ -19,6 +19,7 @@ const login_user_1 = __importDefault(require("../../actions/users/login-user"));
const logout_user_1 = __importDefault(require("../../actions/users/logout-user")); const logout_user_1 = __importDefault(require("../../actions/users/logout-user"));
const reset_password_1 = __importDefault(require("../../actions/users/reset-password")); const reset_password_1 = __importDefault(require("../../actions/users/reset-password"));
const send_email_code_1 = __importDefault(require("../../actions/users/send-email-code")); const send_email_code_1 = __importDefault(require("../../actions/users/send-email-code"));
const google_auth_1 = __importDefault(require("../../actions/users/social/google-auth"));
const update_user_1 = __importDefault(require("../../actions/users/update-user")); const update_user_1 = __importDefault(require("../../actions/users/update-user"));
const user_auth_1 = __importDefault(require("../../actions/users/user-auth")); const user_auth_1 = __importDefault(require("../../actions/users/user-auth"));
function user(params) { function user(params) {
@ -54,6 +55,11 @@ function user(params) {
return yield (0, reset_password_1.default)(Object.assign(Object.assign({}, _), { useLocal: true })); return yield (0, reset_password_1.default)(Object.assign(Object.assign({}, _), { useLocal: true }));
}) })
: reset_password_1.default, : reset_password_1.default,
googleLogin: (params === null || params === void 0 ? void 0 : params.local)
? (_) => __awaiter(this, void 0, void 0, function* () {
return yield (0, google_auth_1.default)(Object.assign(Object.assign({}, _), { useLocal: true }));
})
: google_auth_1.default,
logout: logout_user_1.default, logout: logout_user_1.default,
auth: user_auth_1.default, auth: user_auth_1.default,
}, },

View File

@ -2,4 +2,4 @@ import { APILoginFunctionReturn, HandleSocialDbFunctionParams } from "../../../t
/** /**
* # Handle Social DB * # Handle Social DB
*/ */
export default function handleSocialDb({ database, email, social_platform, payload, invitation, supEmail, additionalFields, debug, loginOnly, }: HandleSocialDbFunctionParams): Promise<APILoginFunctionReturn>; export default function handleSocialDb({ database, email, social_platform, payload, invitation, supEmail, additionalFields, debug, loginOnly, apiUserId, }: HandleSocialDbFunctionParams): Promise<APILoginFunctionReturn>;

View File

@ -22,14 +22,18 @@ const encrypt_1 = __importDefault(require("../../dsql/encrypt"));
const addDbEntry_1 = __importDefault(require("../../backend/db/addDbEntry")); const addDbEntry_1 = __importDefault(require("../../backend/db/addDbEntry"));
const loginSocialUser_1 = __importDefault(require("./loginSocialUser")); const loginSocialUser_1 = __importDefault(require("./loginSocialUser"));
const grab_dir_names_1 = __importDefault(require("../../../utils/backend/names/grab-dir-names")); const grab_dir_names_1 = __importDefault(require("../../../utils/backend/names/grab-dir-names"));
const grab_db_full_name_1 = __importDefault(require("../../../utils/grab-db-full-name"));
/** /**
* # Handle Social DB * # Handle Social DB
*/ */
function handleSocialDb(_a) { function handleSocialDb(_a) {
return __awaiter(this, arguments, void 0, function* ({ database, email, social_platform, payload, invitation, supEmail, additionalFields, debug, loginOnly, }) { return __awaiter(this, arguments, void 0, function* ({ database, email, social_platform, payload, invitation, supEmail, additionalFields, debug, loginOnly, apiUserId, }) {
var _b; var _b;
try { try {
const finalDbName = database ? database : "datasquirel"; const finalDbName = (0, grab_db_full_name_1.default)({
dbName: database,
userId: apiUserId,
});
const existingSocialUserQUery = `SELECT * FROM users WHERE email = ? AND social_login='1' AND social_platform = ? `; const existingSocialUserQUery = `SELECT * FROM users WHERE email = ? AND social_login='1' AND social_platform = ? `;
const existingSocialUserValues = [email, social_platform]; const existingSocialUserValues = [email, social_platform];
if (debug) { if (debug) {

View File

@ -2,4 +2,4 @@ import { APIGoogleLoginFunctionParams, APILoginFunctionReturn } from "../../../.
/** /**
* # API google login * # API google login
*/ */
export default function apiGoogleLogin({ token, database, additionalFields, additionalData, debug, loginOnly, }: APIGoogleLoginFunctionParams): Promise<APILoginFunctionReturn>; export default function apiGoogleLogin({ token, database, additionalFields, additionalData, debug, loginOnly, apiUserId, }: APIGoogleLoginFunctionParams): Promise<APILoginFunctionReturn>;

View File

@ -20,7 +20,7 @@ const ejson_1 = __importDefault(require("../../../../utils/ejson"));
* # API google login * # API google login
*/ */
function apiGoogleLogin(_a) { function apiGoogleLogin(_a) {
return __awaiter(this, arguments, void 0, function* ({ token, database, additionalFields, additionalData, debug, loginOnly, }) { return __awaiter(this, arguments, void 0, function* ({ token, database, additionalFields, additionalData, debug, loginOnly, apiUserId, }) {
try { try {
const gUser = yield new Promise((resolve, reject) => { const gUser = yield new Promise((resolve, reject) => {
https_1.default https_1.default
@ -71,13 +71,14 @@ function apiGoogleLogin(_a) {
additionalFields, additionalFields,
debug, debug,
loginOnly, loginOnly,
apiUserId,
}); });
//////////////////////////////////////// ////////////////////////////////////////
//////////////////////////////////////// ////////////////////////////////////////
//////////////////////////////////////// ////////////////////////////////////////
return Object.assign({}, loggedInGoogleUser); return Object.assign({}, loggedInGoogleUser);
} }
catch ( /** @type {any} */error) { catch (error) {
console.log(`api-google-login.ts ERROR: ${error.message}`); console.log(`api-google-login.ts ERROR: ${error.message}`);
return { return {
success: false, success: false,

View File

@ -965,6 +965,7 @@ export type APIGoogleLoginFunctionParams = {
}; };
debug?: boolean; debug?: boolean;
loginOnly?: boolean; loginOnly?: boolean;
apiUserId?: string | number;
}; };
export type APIGoogleLoginFunction = (params: APIGoogleLoginFunctionParams) => Promise<APILoginFunctionReturn>; export type APIGoogleLoginFunction = (params: APIGoogleLoginFunctionParams) => Promise<APILoginFunctionReturn>;
/** /**
@ -981,6 +982,7 @@ export type HandleSocialDbFunctionParams = {
debug?: boolean; debug?: boolean;
loginOnly?: boolean; loginOnly?: boolean;
social_id?: string | number; social_id?: string | number;
apiUserId?: string | number;
}; };
export type HandleSocialDbFunctionReturn = { export type HandleSocialDbFunctionReturn = {
success: boolean; success: boolean;
@ -1808,7 +1810,7 @@ export type GrabUserResourceParams<T extends {
targetID?: string | number; targetID?: string | number;
}; };
export declare const UserAPIParadigms: readonly ["auth", "crud"]; export declare const UserAPIParadigms: readonly ["auth", "crud"];
export declare const UserAPIAuthActions: readonly ["login", "get", "signup", "update", "logout", "refresh", "verify", "send-verification", "delete", "send-email-code", "reset-password"]; export declare const UserAPIAuthActions: readonly ["login", "get", "signup", "update", "logout", "refresh", "verify", "send-verification", "delete", "send-email-code", "reset-password", "google-login"];
export type GrabUserAPIPathParams = { export type GrabUserAPIPathParams = {
apiVersion?: string; apiVersion?: string;
paradigm?: (typeof UserAPIParadigms)[number]; paradigm?: (typeof UserAPIParadigms)[number];
@ -1903,4 +1905,25 @@ export type ApiUpdateUserParams<T extends DSQL_DATASQUIREL_USERS = DSQL_DATASQUI
dbSchema?: DSQL_DatabaseSchemaType; dbSchema?: DSQL_DatabaseSchemaType;
dbUserId?: string | number; dbUserId?: string | number;
}; };
export type GoogleAuthParams = {
apiKey?: string;
token: string;
database?: string;
response?: ServerResponse;
encryptionKey?: string;
encryptionSalt?: string;
additionalFields?: string[];
additionalData?: {
[s: string]: string | number;
};
apiUserID?: string | number;
debug?: boolean;
secureCookie?: boolean;
loginOnly?: boolean;
/**
* Login without calling external API
*/
useLocal?: boolean;
apiVersion?: string;
};
export {}; export {};

View File

@ -405,4 +405,5 @@ exports.UserAPIAuthActions = [
"delete", "delete",
"send-email-code", "send-email-code",
"reset-password", "reset-password",
"google-login",
]; ];

View File

@ -145,7 +145,7 @@ export default async function loginUser<
const cookieNames = getAuthCookieNames({ const cookieNames = getAuthCookieNames({
database, database,
userId: apiUserID, userId: apiUserID || process.env.DSQL_API_USER_ID,
}); });
if (httpResponse.csrf && !skipWriteAuthFile) { if (httpResponse.csrf && !skipWriteAuthFile) {

View File

@ -1,36 +1,21 @@
import http from "http";
import encrypt from "../../../functions/dsql/encrypt"; import encrypt from "../../../functions/dsql/encrypt";
import grabHostNames from "../../../utils/grab-host-names";
import apiGoogleLogin from "../../../functions/api/users/social/api-google-login"; import apiGoogleLogin from "../../../functions/api/users/social/api-google-login";
import getAuthCookieNames from "../../../functions/backend/cookies/get-auth-cookie-names"; import getAuthCookieNames from "../../../functions/backend/cookies/get-auth-cookie-names";
import { writeAuthFile } from "../../../functions/backend/auth/write-auth-files"; import { writeAuthFile } from "../../../functions/backend/auth/write-auth-files";
import { APILoginFunctionReturn } from "../../../types"; import {
APIGoogleLoginFunctionParams,
APIResponseObject,
GoogleAuthParams,
} from "../../../types";
import grabCookieExpiryDate from "../../../utils/grab-cookie-expirt-date"; import grabCookieExpiryDate from "../../../utils/grab-cookie-expirt-date";
import queryDSQLAPI from "../../../functions/api/query-dsql-api";
type Param = { import grabUserDSQLAPIPath from "../../../utils/backend/users/grab-api-path";
key?: string;
token: string;
database?: string;
response?: http.ServerResponse;
encryptionKey?: string;
encryptionSalt?: string;
additionalFields?: string[];
additionalData?: { [s: string]: string | number };
apiUserID?: string | number;
debug?: boolean;
secureCookie?: boolean;
loginOnly?: boolean;
/**
* Login without calling external API
*/
forceLocal?: boolean;
};
/** /**
* # SERVER FUNCTION: Login with google Function * # SERVER FUNCTION: Login with google Function
*/ */
export default async function googleAuth({ export default async function googleAuth({
key, apiKey,
token, token,
database, database,
response, response,
@ -42,12 +27,9 @@ export default async function googleAuth({
debug, debug,
secureCookie, secureCookie,
loginOnly, loginOnly,
forceLocal, useLocal,
}: Param): Promise<APILoginFunctionReturn> { apiVersion,
const grabedHostNames = grabHostNames({ }: GoogleAuthParams): Promise<APIResponseObject> {
userId: apiUserID || process.env.DSQL_API_USER_ID,
});
const { host, port, scheme, user_id } = grabedHostNames;
const COOKIE_EXPIRY_DATE = grabCookieExpiryDate(); const COOKIE_EXPIRY_DATE = grabCookieExpiryDate();
const finalEncryptionKey = const finalEncryptionKey =
@ -90,72 +72,37 @@ export default async function googleAuth({
* Initialize HTTP response variable * Initialize HTTP response variable
*/ */
let httpResponse: APILoginFunctionReturn = { let httpResponse: APIResponseObject = {
success: false, success: false,
}; };
if (forceLocal) { const googleAuthParams: APIGoogleLoginFunctionParams = {
token,
additionalFields,
additionalData,
debug,
loginOnly,
database,
apiUserId: apiUserID || process.env.DSQL_API_USER_ID,
};
if (useLocal) {
if (debug) { if (debug) {
console.log(`Google login with Local Paradigm ...`); console.log(`Google login with Local Paradigm ...`);
} }
httpResponse = await apiGoogleLogin({ httpResponse = await apiGoogleLogin(googleAuthParams);
token,
additionalFields,
additionalData,
debug,
loginOnly,
});
} else { } else {
httpResponse = await new Promise((resolve, reject) => { httpResponse = await queryDSQLAPI({
const reqPayload = JSON.stringify({ path: grabUserDSQLAPIPath({
token, paradigm: "auth",
action: "google-login",
database, database,
additionalFields, apiVersion,
additionalData, }),
}); apiKey,
body: googleAuthParams,
const httpsRequest = scheme.request( method: "POST",
{
method: "POST",
headers: {
"Content-Type": "application/json",
"Content-Length": Buffer.from(reqPayload).length,
Authorization:
key ||
process.env.DSQL_FULL_ACCESS_API_KEY ||
process.env.DSQL_API_KEY,
},
port,
hostname: host,
path: `/api/user/${
apiUserID || grabedHostNames.user_id
}/google-login`,
},
/**
* Callback Function
*
* @description https request callback
*/
(response) => {
var str = "";
response.on("data", function (chunk) {
str += chunk;
});
response.on("end", function () {
resolve(JSON.parse(str));
});
response.on("error", (err) => {
reject(err);
});
}
);
httpsRequest.write(reqPayload);
httpsRequest.end();
}); });
} }
@ -173,7 +120,7 @@ export default async function googleAuth({
const cookieNames = getAuthCookieNames({ const cookieNames = getAuthCookieNames({
database, database,
userId: user_id, userId: apiUserID || process.env.DSQL_API_USER_ID,
}); });
if (httpResponse.csrf) { if (httpResponse.csrf) {

View File

@ -0,0 +1,52 @@
import http from "http";
import getAuthCookieNames from "../../functions/backend/cookies/get-auth-cookie-names";
import parseCookies from "../../utils/backend/parseCookies";
import decrypt from "../../functions/dsql/decrypt";
import EJSON from "../../utils/ejson";
import { SendOneTimeCodeEmailResponse } from "../../types";
type Param = {
request?: http.IncomingMessage & { [s: string]: any };
cookieString?: string;
email?: string;
code?: string;
};
/**
* # Verify the temp email code sent to the user's email address
*/
export default async function validateTempEmailCode({
request,
email,
cookieString,
code,
}: Param): Promise<SendOneTimeCodeEmailResponse | null> {
try {
const keyNames = getAuthCookieNames();
const oneTimeCodeCookieName = keyNames.oneTimeCodeName;
const cookies = parseCookies({ request, cookieString });
const encryptedOneTimeCode = cookies[oneTimeCodeCookieName];
const encryptedPayload = decrypt({
encryptedString: encryptedOneTimeCode,
});
const payload = EJSON.parse(encryptedPayload) as
| SendOneTimeCodeEmailResponse
| undefined;
if (payload?.email && !email) {
return payload;
}
if (payload?.email && payload.email === email) {
return payload;
}
return null;
} catch (error: any) {
console.log("validateTempEmailCode error:", error.message);
return null;
}
}

View File

@ -4,12 +4,14 @@ import loginUser from "../../actions/users/login-user";
import logoutUser from "../../actions/users/logout-user"; import logoutUser from "../../actions/users/logout-user";
import resetPassword from "../../actions/users/reset-password"; import resetPassword from "../../actions/users/reset-password";
import sendEmailCode from "../../actions/users/send-email-code"; import sendEmailCode from "../../actions/users/send-email-code";
import googleAuth from "../../actions/users/social/google-auth";
import updateUser from "../../actions/users/update-user"; import updateUser from "../../actions/users/update-user";
import userAuth from "../../actions/users/user-auth"; import userAuth from "../../actions/users/user-auth";
import { import {
AddUserParams, AddUserParams,
GetUserParams, GetUserParams,
GoogleAuthParams,
LoginUserParam, LoginUserParam,
ResetPasswordParams, ResetPasswordParams,
SendEmailCodeParams, SendEmailCodeParams,
@ -53,6 +55,11 @@ export default function user(params?: Params) {
return await resetPassword({ ..._, useLocal: true }); return await resetPassword({ ..._, useLocal: true });
} }
: resetPassword, : resetPassword,
googleLogin: params?.local
? async (_: GoogleAuthParams) => {
return await googleAuth({ ..._, useLocal: true });
}
: googleAuth,
logout: logoutUser, logout: logoutUser,
auth: userAuth, auth: userAuth,
}, },

View File

@ -11,6 +11,7 @@ import {
HandleSocialDbFunctionParams, HandleSocialDbFunctionParams,
} from "../../../types"; } from "../../../types";
import grabDirNames from "../../../utils/backend/names/grab-dir-names"; import grabDirNames from "../../../utils/backend/names/grab-dir-names";
import grabDbFullName from "../../../utils/grab-db-full-name";
/** /**
* # Handle Social DB * # Handle Social DB
@ -25,9 +26,13 @@ export default async function handleSocialDb({
additionalFields, additionalFields,
debug, debug,
loginOnly, loginOnly,
apiUserId,
}: HandleSocialDbFunctionParams): Promise<APILoginFunctionReturn> { }: HandleSocialDbFunctionParams): Promise<APILoginFunctionReturn> {
try { try {
const finalDbName = database ? database : "datasquirel"; const finalDbName = grabDbFullName({
dbName: database,
userId: apiUserId,
});
const existingSocialUserQUery = `SELECT * FROM users WHERE email = ? AND social_login='1' AND social_platform = ? `; const existingSocialUserQUery = `SELECT * FROM users WHERE email = ? AND social_login='1' AND social_platform = ? `;
const existingSocialUserValues = [email, social_platform]; const existingSocialUserValues = [email, social_platform];

View File

@ -17,6 +17,7 @@ export default async function apiGoogleLogin({
additionalData, additionalData,
debug, debug,
loginOnly, loginOnly,
apiUserId,
}: APIGoogleLoginFunctionParams): Promise<APILoginFunctionReturn> { }: APIGoogleLoginFunctionParams): Promise<APILoginFunctionReturn> {
try { try {
const gUser: GoogleOauth2User | undefined = await new Promise( const gUser: GoogleOauth2User | undefined = await new Promise(
@ -78,6 +79,7 @@ export default async function apiGoogleLogin({
additionalFields, additionalFields,
debug, debug,
loginOnly, loginOnly,
apiUserId,
}); });
//////////////////////////////////////// ////////////////////////////////////////
@ -85,7 +87,7 @@ export default async function apiGoogleLogin({
//////////////////////////////////////// ////////////////////////////////////////
return { ...loggedInGoogleUser }; return { ...loggedInGoogleUser };
} catch (/** @type {any} */ error: any) { } catch (error: any) {
console.log(`api-google-login.ts ERROR: ${error.message}`); console.log(`api-google-login.ts ERROR: ${error.message}`);
return { return {

View File

@ -1167,6 +1167,7 @@ export type APIGoogleLoginFunctionParams = {
additionalData?: { [key: string]: string | number }; additionalData?: { [key: string]: string | number };
debug?: boolean; debug?: boolean;
loginOnly?: boolean; loginOnly?: boolean;
apiUserId?: string | number;
}; };
export type APIGoogleLoginFunction = ( export type APIGoogleLoginFunction = (
@ -1187,6 +1188,7 @@ export type HandleSocialDbFunctionParams = {
debug?: boolean; debug?: boolean;
loginOnly?: boolean; loginOnly?: boolean;
social_id?: string | number; social_id?: string | number;
apiUserId?: string | number;
}; };
export type HandleSocialDbFunctionReturn = { export type HandleSocialDbFunctionReturn = {
@ -2348,6 +2350,7 @@ export const UserAPIAuthActions = [
"delete", "delete",
"send-email-code", "send-email-code",
"reset-password", "reset-password",
"google-login",
] as const; ] as const;
export type GrabUserAPIPathParams = { export type GrabUserAPIPathParams = {
@ -2451,3 +2454,23 @@ export type ApiUpdateUserParams<
dbSchema?: DSQL_DatabaseSchemaType; dbSchema?: DSQL_DatabaseSchemaType;
dbUserId?: string | number; dbUserId?: string | number;
}; };
export type GoogleAuthParams = {
apiKey?: string;
token: string;
database?: string;
response?: ServerResponse;
encryptionKey?: string;
encryptionSalt?: string;
additionalFields?: string[];
additionalData?: { [s: string]: string | number };
apiUserID?: string | number;
debug?: boolean;
secureCookie?: boolean;
loginOnly?: boolean;
/**
* Login without calling external API
*/
useLocal?: boolean;
apiVersion?: string;
};

View File

@ -1,6 +1,6 @@
{ {
"name": "@moduletrace/datasquirel", "name": "@moduletrace/datasquirel",
"version": "4.9.7", "version": "4.9.8",
"description": "Cloud-based SQL data management tool", "description": "Cloud-based SQL data management tool",
"main": "dist/index.js", "main": "dist/index.js",
"bin": { "bin": {