Updates
This commit is contained in:
parent
5ab079f687
commit
f9725a1d6f
2
dist/index.d.ts
vendored
2
dist/index.d.ts
vendored
@ -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;
|
||||||
};
|
};
|
||||||
|
@ -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)
|
||||||
|
@ -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 {};
|
|
||||||
|
@ -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));
|
||||||
|
15
dist/package-shared/actions/users/validate-temp-email-code.d.ts
vendored
Normal file
15
dist/package-shared/actions/users/validate-temp-email-code.d.ts
vendored
Normal 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 {};
|
47
dist/package-shared/actions/users/validate-temp-email-code.js
vendored
Normal file
47
dist/package-shared/actions/users/validate-temp-email-code.js
vendored
Normal 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;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
3
dist/package-shared/api/user/index.d.ts
vendored
3
dist/package-shared/api/user/index.d.ts
vendored
@ -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;
|
||||||
};
|
};
|
||||||
|
6
dist/package-shared/api/user/index.js
vendored
6
dist/package-shared/api/user/index.js
vendored
@ -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,
|
||||||
},
|
},
|
||||||
|
@ -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>;
|
||||||
|
@ -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) {
|
||||||
|
@ -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>;
|
||||||
|
@ -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,
|
||||||
|
25
dist/package-shared/types/index.d.ts
vendored
25
dist/package-shared/types/index.d.ts
vendored
@ -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 {};
|
||||||
|
1
dist/package-shared/types/index.js
vendored
1
dist/package-shared/types/index.js
vendored
@ -405,4 +405,5 @@ exports.UserAPIAuthActions = [
|
|||||||
"delete",
|
"delete",
|
||||||
"send-email-code",
|
"send-email-code",
|
||||||
"reset-password",
|
"reset-password",
|
||||||
|
"google-login",
|
||||||
];
|
];
|
||||||
|
@ -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) {
|
||||||
|
@ -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) {
|
||||||
|
52
package-shared/actions/users/validate-temp-email-code.ts
Normal file
52
package-shared/actions/users/validate-temp-email-code.ts
Normal 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;
|
||||||
|
}
|
||||||
|
}
|
@ -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,
|
||||||
},
|
},
|
||||||
|
@ -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];
|
||||||
|
@ -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 {
|
||||||
|
@ -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;
|
||||||
|
};
|
||||||
|
@ -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": {
|
||||||
|
Loading…
Reference in New Issue
Block a user