New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

@tikkhun/utils-core

Package Overview
Dependencies
Maintainers
0
Versions
12
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@tikkhun/utils-core - npm Package Compare versions

Comparing version 0.0.3 to 0.0.4

dist/consts/delimiter.d.mts

2

dist/consts/index.d.ts

@@ -0,3 +1,5 @@

export { DotDelimiter, DoubleUnderlineDelimiter, UnderlineDelimiter } from './delimiter.js';
declare const ROLES: readonly ["user", "admin"];
export { ROLES };

9

dist/consts/index.js

@@ -5,6 +5,9 @@ 'use strict';

@tikkhun/utils-core
0.0.3
0.0.4
*/
var s="user",n="admin",o=[s,n];
var o="_",n="__",r=".";var e="user",t="admin",s=[e,t];
exports.ROLES = o;
exports.DotDelimiter = r;
exports.DoubleUnderlineDelimiter = n;
exports.ROLES = s;
exports.UnderlineDelimiter = o;

@@ -5,3 +5,3 @@ 'use strict';

@tikkhun/utils-core
0.0.3
0.0.4
*/

@@ -8,0 +8,0 @@ function s(n,e){return Object.values(e).includes(n)}

export { ROLES } from './consts/index.js';
export { isStringInEnum } from './enum.js';
export { getError, getResult, getSuccess } from './result.js';
export { JsonToListOptions, ListItem, ListToJsonOptions, defaultJsonToListOptions, defaultListToJsonOptions, jsonToList, listToJson } from './json.js';
export { FlatJsonOptions, defaultFlatJsonOptions, flatJson } from './json/flatJson.js';
export { ListItem } from './json/json.interface.js';
export { JsonToListOptions, defaultJsonToListOptions, jsonToList } from './json/jsonToList.js';
export { ListToJsonOptions, defaultListToJsonOptions, listToJson } from './json/listToJson.js';
export { defaultunflatJsonOptions, unflatJson, unflatJsonOptions } from './json/unflatJson.js';
export { DEFAULT_JSON_BIGINT_OPTIONS, JsonBigInt, JsonBigIntOptions, isBigInt } from './JsonBigInt.js';
export { clone, getByPath, isEmptyObj, isPlainObject, killUndefined } from './object.js';
export { toBeList } from './list.js';
export { clone, getByPath, isEmptyObj, isPlainObject, killUndefined, sortKey } from './object.js';
export { limitOffsetToPage } from './pagination.js';
export { color16, getRandomNumber } from './random.js';
export { getError, getResult, getSuccess } from './result.js';
export { formatSizeUnits } from './size.js';

@@ -13,1 +19,2 @@ export { capitalize, toBigCamelCase, toCamelCase, toConstCase } from './text.js';

export { getMajorVersion } from './version.js';
export { DotDelimiter, DoubleUnderlineDelimiter, UnderlineDelimiter } from './consts/delimiter.js';
'use strict';
var j = require('lodash');
var P = require('lodash');
function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
var j__default = /*#__PURE__*/_interopDefault(j);
var P__default = /*#__PURE__*/_interopDefault(P);
/**
@tikkhun/utils-core
0.0.3
0.0.4
*/
var O=Object.defineProperty,y=Object.defineProperties;var T=Object.getOwnPropertyDescriptors;var g=Object.getOwnPropertySymbols;var h=Object.prototype.hasOwnProperty,I=Object.prototype.propertyIsEnumerable;var l=(t,r,e)=>r in t?O(t,r,{enumerable:!0,configurable:!0,writable:!0,value:e}):t[r]=e,a=(t,r)=>{for(var e in r||(r={}))h.call(r,e)&&l(t,e,r[e]);if(g)for(var e of g(r))I.call(r,e)&&l(t,e,r[e]);return t},f=(t,r)=>y(t,T(r));var m=(t,r,e)=>new Promise((n,i)=>{var o=c=>{try{s(e.next(c));}catch(u){i(u);}},p=c=>{try{s(e.throw(c));}catch(u){i(u);}},s=c=>c.done?n(c.value):Promise.resolve(c.value).then(o,p);s((e=e.apply(t,r)).next());});var L="user",S="admin",v=[L,S];function A(t,r){return Object.values(r).includes(t)}function M(t,r){return r==="error"?b(t):J(t)}function b(t){return {status:"success",code:void 0,error:"",data:t}}function J(t){return {status:"error",code:void 0,error:t.message,data:null}}var {set:N}=j__default.default,P={delimiter:".",list:[],isKeyInclude:()=>!0,keyItemTransformer:function(t){return t}};function G(t){let{delimiter:r,keyItemTransformer:e,list:n,isKeyInclude:i}=Object.assign(P,t),o={};return n.forEach(({key:p,value:s})=>{i(p)&&N(o,p.split(r).map(e).join("."),s);}),o}var B={delimiter:".",json:{}};function C(t){let{delimiter:r,json:e,prefix:n}=Object.assign(B,t);return Object.keys(e).reduce((i,o)=>{let p=n?`${n}${r}${o}`:o;if(typeof e[o]=="object"&&e[o]!==null){let s=C(f(a({},t),{json:e[o],prefix:p}));if(s&&s.length)return i.concat(s)}else return i.concat({key:p,value:e[o]});return i},[])}var E={magicString:"tikkhun-json-bigint"},x=class{constructor(r){this.options=Object.assign(E,r);}reviver(r,e){if(typeof e=="string"&&e.includes(this.options.magicString)){let n=e.replace(new RegExp(this.options.magicString,"g"),"");return BigInt(n)}return e}parse(r){return JSON.parse(r,this.reviver.bind(this))}replacer(r,e){return w(e)?`${this.options.magicString}${e}${this.options.magicString}`:e}stringify(r){return JSON.stringify(r,this.replacer.bind(this))}};function w(t){return typeof t=="bigint"}var{get:U}=j__default.default;function H(t,r=""){return r?U(t,r):t}function Q(t){return JSON.parse(JSON.stringify(t))}function W(t){for(let r in t)if(t.hasOwnProperty(r))return !1;return !0}function X(t){return t?t.constructor===Object:!1}function Y(t){return JSON.parse(JSON.stringify(t))}var R={limit:0,offset:0};function rt(t){let{limit:r,offset:e}=Object.assign({},R,t),n=r>0?r:0,i=e>=0?Math.floor(e/n)+1:0;return {pageSize:n,pageNo:i}}var d=["B","KB","MB","GB","TB","PB"];function nt(t){let r=0;for(;t>=1024&&r<d.length-1;)t/=1024,r++;return `${t.toFixed(2)} ${d[r]}`}function ot(t=""){if(typeof t!="string")throw new Error("str is not string");let[r,...e]=t;return r?r.toUpperCase()+e.join(""):""}function st(t=""){return t.replace(/[-\s]/g,"_").replace(/[A-Z]/g,r=>`_${r}`).toUpperCase()}function pt(t){return t=t.replace(/[-_](\w)/g,(r,e)=>e.toUpperCase()),t.replace(/^\w/,r=>r.toUpperCase())}function ct(t){return t=t.replace(/[-_](\w)/g,(r,e)=>e.toUpperCase()),t.charAt(0).toLowerCase()+t.slice(1)}function ft(t){return m(this,null,function*(){return yield new Promise(r=>{setTimeout(r,t);})})}function lt(t){let r=[],e={};return t.forEach(n=>{e[n.id]=f(a({},n),{children:[]});}),t.forEach(n=>{if(!n.parentId)return;let i=e[n.parentId];i?(i.children||(i.children=[]),i.children.push(e[n.id])):r.push(e[n.id]);}),r}function dt(t){return t.match(/^(\d)\./)}
var T=Object.defineProperty,J=Object.defineProperties;var b=Object.getOwnPropertyDescriptors;var l=Object.getOwnPropertySymbols;var h=Object.prototype.hasOwnProperty,j=Object.prototype.propertyIsEnumerable;var g=(t,r,e)=>r in t?T(t,r,{enumerable:!0,configurable:!0,writable:!0,value:e}):t[r]=e,a=(t,r)=>{for(var e in r||(r={}))h.call(r,e)&&g(t,e,r[e]);if(l)for(var e of l(r))j.call(r,e)&&g(t,e,r[e]);return t},f=(t,r)=>J(t,b(r));var m=(t,r,e)=>new Promise((n,o)=>{var i=c=>{try{p(e.next(c));}catch(u){o(u);}},s=c=>{try{p(e.throw(c));}catch(u){o(u);}},p=c=>c.done?n(c.value):Promise.resolve(c.value).then(i,s);p((e=e.apply(t,r)).next());});var k="_",v="__",G=".";var I="user",L="admin",V=[I,L];function H(t,r){return Object.values(r).includes(t)}var d={delimiter:".",data:{},prefix:""};function x(t){let{data:r,delimiter:e,prefix:n}=Object.assign(d,t);return Object.entries(r).reduce((o={},[i,s])=>{let p=n?`${n}${e}${i}`:i;return typeof s=="object"&&s!==null?a(a({},o),x({prefix:p,data:s,delimiter:e})):f(a({},o),{[p]:s})},{})}x.prototype.defaultFlatJsonOptions=d;var S={delimiter:".",json:{}};function N(t){let{delimiter:r,json:e,prefix:n}=Object.assign(S,t);return Object.keys(e).reduce((o,i)=>{let s=n?`${n}${r}${i}`:i;if(typeof e[i]=="object"&&e[i]!==null){let p=N(f(a({},t),{json:e[i],prefix:s}));if(p&&p.length)return o.concat(p)}else return o.concat({key:s,value:e[i]});return o},[])}var {set:_}=P__default.default,R={delimiter:".",list:[],isKeyInclude:()=>!0,keyItemTransformer:function(t){return t}};function et(t){let{delimiter:r,keyItemTransformer:e,list:n,isKeyInclude:o}=Object.assign(R,t),i={};return n.forEach(({key:s,value:p})=>{o(s)&&_(i,s.split(r).map(e).join("."),p);}),i}var {set:E}=P__default.default,w={delimiter:".",data:{}};function it(t={}){let{data:r,delimiter:e}=Object.assign(w,t),n={};return Object.entries(r).forEach(([o,i])=>{E(n,o.split(e).join("."),i);}),n}var C={magicString:"tikkhun-json-bigint"},O=class{constructor(r){this.options=Object.assign(C,r);}reviver(r,e){if(typeof e=="string"&&e.includes(this.options.magicString)){let n=e.replace(new RegExp(this.options.magicString,"g"),"");return BigInt(n)}return e}parse(r){return JSON.parse(r,this.reviver.bind(this))}replacer(r,e){return U(e)?`${this.options.magicString}${e}${this.options.magicString}`:e}stringify(r){return JSON.stringify(r,this.replacer.bind(this))}};function U(t){return typeof t=="bigint"}function mt(t){return Array.isArray(t)?t:[t]}var{get:A}=P__default.default;function Ot(t,r=""){return r?A(t,r):t}function yt(t){return JSON.parse(JSON.stringify(t))}function Tt(t){for(let r in t)if(t.hasOwnProperty(r))return !1;return !0}function Jt(t){return t?t.constructor===Object:!1}function bt(t){return JSON.parse(JSON.stringify(t))}function ht(t){return Object.keys(t).sort().reduce((e,n)=>(e[n]=t[n],e),{})}var D={limit:0,offset:0};function It(t){let{limit:r,offset:e}=Object.assign({},D,t),n=r>0?r:0,o=e>=0?Math.floor(e/n)+1:0;return {pageSize:n,pageNo:o}}function St(){return (Math.random()*16777216<<0).toString(16)}function Nt(t,r){return Math.round(Math.random()*r+t)}function _t(t,r){return r==="error"?F(t):M(t)}function F(t){return {status:"success",code:void 0,error:"",data:t}}function M(t){return {status:"error",code:void 0,error:t.message,data:null}}var y=["B","KB","MB","GB","TB","PB"];function Bt(t){let r=0;for(;t>=1024&&r<y.length-1;)t/=1024,r++;return `${t.toFixed(2)} ${y[r]}`}function wt(t=""){if(typeof t!="string")throw new Error("str is not string");let[r,...e]=t;return r?r.toUpperCase()+e.join(""):""}function Ct(t=""){return t.replace(/[-\s]/g,"_").replace(/[A-Z]/g,r=>`_${r}`).toUpperCase()}function Ut(t){return t=t.replace(/[-_](\w)/g,(r,e)=>e.toUpperCase()),t.replace(/^\w/,r=>r.toUpperCase())}function $t(t){return t=t.replace(/[-_](\w)/g,(r,e)=>e.toUpperCase()),t.charAt(0).toLowerCase()+t.slice(1)}function Dt(t){return m(this,null,function*(){return yield new Promise(r=>{setTimeout(r,t);})})}function Kt(t){let r=[],e={};return t.forEach(n=>{e[n.id]=f(a({},n),{children:[]});}),t.forEach(n=>{if(!n.parentId)return;let o=e[n.parentId];o?(o.children||(o.children=[]),o.children.push(e[n.id])):r.push(e[n.id]);}),r}function Gt(t){return t.match(/^(\d)\./)}
exports.DEFAULT_JSON_BIGINT_OPTIONS = E;
exports.JsonBigInt = x;
exports.ROLES = v;
exports.buildTree = lt;
exports.capitalize = ot;
exports.clone = Y;
exports.defaultJsonToListOptions = B;
exports.defaultListToJsonOptions = P;
exports.formatSizeUnits = nt;
exports.getByPath = H;
exports.getError = J;
exports.getMajorVersion = dt;
exports.getResult = M;
exports.getSuccess = b;
exports.isBigInt = w;
exports.isEmptyObj = W;
exports.isPlainObject = X;
exports.isStringInEnum = A;
exports.jsonToList = C;
exports.killUndefined = Q;
exports.limitOffsetToPage = rt;
exports.listToJson = G;
exports.sleep = ft;
exports.toBigCamelCase = pt;
exports.toCamelCase = ct;
exports.toConstCase = st;
exports.DEFAULT_JSON_BIGINT_OPTIONS = C;
exports.DotDelimiter = G;
exports.DoubleUnderlineDelimiter = v;
exports.JsonBigInt = O;
exports.ROLES = V;
exports.UnderlineDelimiter = k;
exports.buildTree = Kt;
exports.capitalize = wt;
exports.clone = bt;
exports.color16 = St;
exports.defaultFlatJsonOptions = d;
exports.defaultJsonToListOptions = S;
exports.defaultListToJsonOptions = R;
exports.defaultunflatJsonOptions = w;
exports.flatJson = x;
exports.formatSizeUnits = Bt;
exports.getByPath = Ot;
exports.getError = M;
exports.getMajorVersion = Gt;
exports.getRandomNumber = Nt;
exports.getResult = _t;
exports.getSuccess = F;
exports.isBigInt = U;
exports.isEmptyObj = Tt;
exports.isPlainObject = Jt;
exports.isStringInEnum = H;
exports.jsonToList = N;
exports.killUndefined = yt;
exports.limitOffsetToPage = It;
exports.listToJson = et;
exports.sleep = Dt;
exports.sortKey = ht;
exports.toBeList = mt;
exports.toBigCamelCase = Ut;
exports.toCamelCase = $t;
exports.toConstCase = Ct;
exports.unflatJson = it;

@@ -5,3 +5,3 @@ 'use strict';

@tikkhun/utils-core
0.0.3
0.0.4
*/

@@ -8,0 +8,0 @@ var n=/^[0-9]*$/;function e(t){return Number.isInteger(t)}function i(t){return e(t)&&t>0}function s(t){return t>-1}function u(t){return n.test(t)}

@@ -5,3 +5,3 @@ 'use strict';

@tikkhun/utils-core
0.0.3
0.0.4
*/

@@ -8,0 +8,0 @@ var e={magicString:"tikkhun-json-bigint"},r=class{constructor(t){this.options=Object.assign(e,t);}reviver(t,i){if(typeof i=="string"&&i.includes(this.options.magicString)){let s=i.replace(new RegExp(this.options.magicString,"g"),"");return BigInt(s)}return i}parse(t){return JSON.parse(t,this.reviver.bind(this))}replacer(t,i){return o(i)?`${this.options.magicString}${i}${this.options.magicString}`:i}stringify(t){return JSON.stringify(t,this.replacer.bind(this))}};function o(n){return typeof n=="bigint"}

@@ -0,2 +1,3 @@

declare function toBeList(sth: any): any[];
export { }
export { toBeList };
'use strict';
/**
@tikkhun/utils-core
0.0.4
*/
function n(r){return Array.isArray(r)?r:[r]}
exports.toBeList = n;

@@ -6,3 +6,9 @@ declare function getByPath(config: Record<string, any>, path?: string): any;

declare function clone(obj: any): any;
/**
* 调整key顺序
* @param obj
* @returns
*/
declare function sortKey(obj: Record<string, any>): any;
export { clone, getByPath, isEmptyObj, isPlainObject, killUndefined };
export { clone, getByPath, isEmptyObj, isPlainObject, killUndefined, sortKey };
'use strict';
var t = require('lodash');
var i = require('lodash');
function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
var t__default = /*#__PURE__*/_interopDefault(t);
var i__default = /*#__PURE__*/_interopDefault(i);
/**
@tikkhun/utils-core
0.0.3
0.0.4
*/
var{get:e}=t__default.default;function o(r,n=""){return n?e(r,n):r}function u(r){return JSON.parse(JSON.stringify(r))}function f(r){for(let n in r)if(r.hasOwnProperty(n))return !1;return !0}function s(r){return r?r.constructor===Object:!1}function a(r){return JSON.parse(JSON.stringify(r))}
var{get:o}=i__default.default;function u(r,t=""){return t?o(r,t):r}function c(r){return JSON.parse(JSON.stringify(r))}function f(r){for(let t in r)if(r.hasOwnProperty(t))return !1;return !0}function y(r){return r?r.constructor===Object:!1}function a(r){return JSON.parse(JSON.stringify(r))}function O(r){return Object.keys(r).sort().reduce((n,e)=>(n[e]=r[e],n),{})}
exports.clone = a;
exports.getByPath = o;
exports.getByPath = u;
exports.isEmptyObj = f;
exports.isPlainObject = s;
exports.killUndefined = u;
exports.isPlainObject = y;
exports.killUndefined = c;
exports.sortKey = O;

@@ -5,3 +5,3 @@ 'use strict';

@tikkhun/utils-core
0.0.3
0.0.4
*/

@@ -8,0 +8,0 @@ var s={limit:0,offset:0};function n(o){let{limit:t,offset:e}=Object.assign({},s,o),i=t>0?t:0,f=e>=0?Math.floor(e/i)+1:0;return {pageSize:i,pageNo:f}}

@@ -5,3 +5,3 @@ 'use strict';

@tikkhun/utils-core
0.0.3
0.0.4
*/

@@ -8,0 +8,0 @@ var o=/^(?:(?:\+|00)86)?1\d{10}$/,t=/^[0-9]*$/,e=/^[a-zA-Z0-9]*$/,n=/^(?=.*[A-Za-z])(?=.*\d)[A-Za-z\d]{8,}$/;

@@ -5,3 +5,3 @@ 'use strict';

@tikkhun/utils-core
0.0.3
0.0.4
*/

@@ -8,0 +8,0 @@ function t(r,e){return e==="error"?n(r):s(r)}function n(r){return {status:"success",code:void 0,error:"",data:r}}function s(r){return {status:"error",code:void 0,error:r.message,data:null}}

@@ -5,3 +5,3 @@ 'use strict';

@tikkhun/utils-core
0.0.3
0.0.4
*/

@@ -8,0 +8,0 @@ var e=["B","KB","MB","GB","TB","PB"];function B(t){let n=0;for(;t>=1024&&n<e.length-1;)t/=1024,n++;return `${t.toFixed(2)} ${e[n]}`}

@@ -5,3 +5,3 @@ 'use strict';

@tikkhun/utils-core
0.0.3
0.0.4
*/

@@ -8,0 +8,0 @@ function o(e=""){if(typeof e!="string")throw new Error("str is not string");let[r,...t]=e;return r?r.toUpperCase()+t.join(""):""}function n(e=""){return e.replace(/[-\s]/g,"_").replace(/[A-Z]/g,r=>`_${r}`).toUpperCase()}function p(e){return e=e.replace(/[-_](\w)/g,(r,t)=>t.toUpperCase()),e.replace(/^\w/,r=>r.toUpperCase())}function a(e){return e=e.replace(/[-_](\w)/g,(r,t)=>t.toUpperCase()),e.charAt(0).toLowerCase()+e.slice(1)}

@@ -5,3 +5,3 @@ 'use strict';

@tikkhun/utils-core
0.0.3
0.0.4
*/

@@ -8,0 +8,0 @@ var u=(t,r,n)=>new Promise((a,s)=>{var m=e=>{try{i(n.next(e));}catch(o){s(o);}},c=e=>{try{i(n.throw(e));}catch(o){s(o);}},i=e=>e.done?a(e.value):Promise.resolve(e.value).then(m,c);i((n=n.apply(t,r)).next());});function w(t){return u(this,null,function*(){return yield new Promise(r=>{setTimeout(r,t);})})}

@@ -5,3 +5,3 @@ 'use strict';

@tikkhun/utils-core
0.0.3
0.0.4
*/

@@ -8,0 +8,0 @@ var o=Object.defineProperty,h=Object.defineProperties;var l=Object.getOwnPropertyDescriptors;var d=Object.getOwnPropertySymbols;var a=Object.prototype.hasOwnProperty,f=Object.prototype.propertyIsEnumerable;var c=(i,e,r)=>e in i?o(i,e,{enumerable:!0,configurable:!0,writable:!0,value:r}):i[e]=r,p=(i,e)=>{for(var r in e||(e={}))a.call(e,r)&&c(i,r,e[r]);if(d)for(var r of d(e))f.call(e,r)&&c(i,r,e[r]);return i},s=(i,e)=>h(i,l(e));function T(i){let e=[],r={};return i.forEach(n=>{r[n.id]=s(p({},n),{children:[]});}),i.forEach(n=>{if(!n.parentId)return;let t=r[n.parentId];t?(t.children||(t.children=[]),t.children.push(r[n.id])):e.push(r[n.id]);}),e}

@@ -5,3 +5,3 @@ 'use strict';

@tikkhun/utils-core
0.0.3
0.0.4
*/

@@ -8,0 +8,0 @@ function t(n){return typeof n=="number"}function e(n){return typeof n=="bigint"}

@@ -5,3 +5,3 @@ 'use strict';

@tikkhun/utils-core
0.0.3
0.0.4
*/

@@ -8,0 +8,0 @@ function t(r){return r.match(/^(\d)\./)}

@@ -5,3 +5,3 @@ 'use strict';

@tikkhun/utils-core
0.0.3
0.0.4
*/

@@ -8,0 +8,0 @@ function e(n,t=""){return a=>n(a)||t}

{
"name": "@tikkhun/utils-core",
"version": "0.0.3",
"version": "0.0.4",
"description": "",

@@ -33,7 +33,9 @@ "main": "dist/index.js",

"devDependencies": {
"@linjiajian999/esbuild-plugin-import": "^1.0.2",
"@types/lodash": "^4.17.6",
"@types/node": "^20.3.1",
"esbuild-plugin-lodash": "^1.2.0",
"ts-node": "^10.9.1",
"tsup": "^8.0.2",
"vitest": "^1.3.1"
"vitest": "^1.6.0"
},

@@ -40,0 +42,0 @@ "scripts": {

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc