UNPKG

sq3-kv-data-store

Version:

Node.js key/value store for SQLITE3 that includes data search features

222 lines 28.6 kB
import util from 'node:util'; import { default as SqlString } from 'sqlstring'; const isComparable = (v) => { return typeof v === 'boolean' || typeof v === 'string' || typeof v === 'number'; }; const $eq = (sel, tosel) => { return SqlString.format([ '( ', // 'EXISTS json_extract(value, ?) ', // 'AND json_extract(value, ?) == ?', 'json_extract(value, ?) == ?', ' )' ].join(''), [/* sel, */ sel, tosel]); }; const $lt = (sel, tosel) => { return SqlString.format([ '( ', // 'EXISTS json_extract(value, ?) ', // 'AND json_extract(value, ?) < ?', 'json_extract(value, ?) < ?', ' )' ].join(''), [/* sel, */ sel, tosel]); }; const $lte = (sel, tosel) => { return SqlString.format([ '( ', // 'EXISTS json_extract(value, ?) ', // 'AND json_extract(value, ?) <= ?', 'json_extract(value, ?) <= ?', ' )' ].join(''), [/* sel, */ sel, tosel]); }; const $gt = (sel, tosel) => { return SqlString.format([ '( ', // 'EXISTS json_extract(value, ?) ', // 'AND json_extract(value, ?) > ?', 'json_extract(value, ?) > ?', ' )' ].join(''), [/* sel, */ sel, tosel]); }; const $gte = (sel, tosel) => { return SqlString.format([ '( ', // 'EXISTS json_extract(value, ?) ', // 'AND json_extract(value, ?) >= ?', 'json_extract(value, ?) >= ?', ' )' ].join(''), [/* sel, */ sel, tosel]); }; const $ne = (sel, tosel) => { return SqlString.format([ '( ', // 'EXISTS json_extract(value, ?) ', // 'AND json_extract(value, ?) <> ?', 'json_extract(value, ?) <> ?', ' )' ].join(''), [/* sel, */ sel, tosel]); }; const $exists = (sel) => { return SqlString.format([ '( ', 'EXISTS(json_extract(value, ?)) ', ' )' ].join(''), [sel]); }; const $null = (sel) => { return SqlString.format([ '( ', 'json_extract(value, ?) IS NULL ', ' )' ].join(''), [sel]); }; const $notnull = (sel) => { return SqlString.format([ '( ', 'json_extract(value, ?) IS NOT NULL ', ' )' ].join(''), [sel]); }; const $like = (sel, tosel) => { return SqlString.format([ '( ', // 'EXISTS json_extract(value, ?) ', // 'AND json_extract(value, ?) LIKE ?', 'json_extract(value, ?) LIKE ?', ' )' ].join(''), [/* sel, */ sel, tosel]); }; const $glob = (sel, tosel) => { return SqlString.format([ '( ', // 'EXISTS json_extract(value, ?) ', // 'AND json_extract(value, ?) GLOB ?', 'json_extract(value, ?) GLOB ?', ' )' ].join(''), [/* sel, */ sel, tosel]); }; const $regexp = (sel, tosel) => { return SqlString.format([ '( ', // 'EXISTS json_extract(value, ?) ', // 'AND json_extract(value, ?) regexp ?', 'json_extract(value, ?) regexp ?', ' )' ].join(''), [/* sel, */ sel, tosel]); }; function handleArraySelector(selectors) { const queries = new Array(); for (const sel of selectors) { if (Array.isArray(sel)) { throw new Error(`Found array in array selectors ${util.inspect(sel)}`); } if (typeof sel !== 'object') { throw new Error(`Found non-object selector ${util.inspect(sel)}`); } const sels = handleObjectSelector(sel); queries.push('( ' + sels.join(' AND ') + ' )'); } return queries; } function handleObjectSelector(selectors) { const queries = new Array(); for (const sel in selectors) { if (!(typeof sel === 'string')) { throw new Error(`handleObjectSelector got invalid selector ${util.inspect(sel)}`); } const tosel = selectors[sel]; if (sel === '$or' && !(Array.isArray(tosel))) { throw new Error(`selectors2where got $or without array ${util.inspect(tosel)}`); } if (sel === '$or') { queries.push('( ' + handleArraySelector(tosel).join(' OR ') + ' )'); continue; } if (sel === '$and' && !(Array.isArray(tosel))) { throw new Error(`selectors2where got $and without array ${util.inspect(tosel)}`); } if (sel === '$and') { queries.push('( ' + handleArraySelector(tosel).join(' AND ') + ' )'); continue; } if (sel === '$exists') { if (typeof tosel !== 'string') { throw new Error(`Incorrect operand ${util.inspect(tosel)} for $exists`); } queries.push('( ' + $exists(tosel) + ' )'); continue; } if (sel === '$null') { if (typeof tosel !== 'string') { throw new Error(`Incorrect operand ${util.inspect(tosel)} for $null`); } queries.push('( ' + $null(tosel) + ' )'); continue; } if (sel === '$notnull') { if (typeof tosel !== 'string') { throw new Error(`Incorrect operand ${util.inspect(tosel)} for $notnull`); } queries.push('( ' + $notnull(tosel) + ' )'); continue; } // THe default action is equality if (isComparable(tosel)) { queries.push($eq(sel, tosel)); continue; } if (typeof tosel === 'object') { const keys = Object.keys(tosel); if (keys.length < 1 || keys.length > 1) { throw new Error(`selectors2where got incorrect comparison operand for ${util.inspect(sel)} with ${util.inspect(tosel)}`); } const op = keys[0]; const orsel = tosel[op]; if (op === '$eq') { queries.push($eq(sel, orsel)); } else if (op === '$lt') { queries.push($lt(sel, orsel)); } else if (op === '$lte') { queries.push($lte(sel, orsel)); } else if (op === '$gt') { queries.push($gt(sel, orsel)); } else if (op === '$gte') { queries.push($gte(sel, orsel)); } else if (op === '$ne') { queries.push($ne(sel, orsel)); } else if (op === '$exists') { queries.push($exists(sel)); } else if (op === '$like') { queries.push($like(sel, orsel)); } else if (op === '$glob') { queries.push($glob(sel, orsel)); } else if (op === '$regexp') { queries.push($regexp(sel, orsel)); } else { throw new Error(`selectors2where got invalid operator ${util.inspect(op)} in ${util.inspect(tosel)}`); } } } return queries; } export function selectors2where(selectors) { if (typeof selectors !== 'object') { throw new Error(`Incorrect type for selector ${util.inspect(selectors)}`); } const queries = handleObjectSelector(selectors); return /* '( ' + */ queries.join(' AND ') /* + ' )' */; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"finder.js","sourceRoot":"","sources":["../src/finder.ts"],"names":[],"mappings":"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","sourcesContent":["\nimport util from 'node:util';\nimport { default as SqlString } from 'sqlstring';\n\n\ntype ComparableValue = boolean | string | number;\n\ntype $eqOperation  = { $eq:  ComparableValue };\ntype $ltOperation  = { $lt:  ComparableValue };\ntype $lteOperation = { $lte: ComparableValue };\ntype $gtOperation  = { $gt:  ComparableValue };\ntype $gteOperation = { $gte: ComparableValue };\ntype $neOperation  = { $ne:  ComparableValue };\ntype $existsOperation = { $exists: ComparableValue };\n\nconst isComparable = (v: any): boolean => {\n    return typeof v === 'boolean'\n        || typeof v === 'string'\n        || typeof v === 'number';\n}\n\n\nconst $eq = (sel: string, tosel: ComparableValue) => {\n    return SqlString.format([\n        '( ',\n        // 'EXISTS json_extract(value, ?) ',\n        // 'AND json_extract(value, ?) == ?',\n        'json_extract(value, ?) == ?',\n        ' )'\n    ].join(''),\n        [ /* sel, */ sel, tosel ]\n    );\n}\n\nconst $lt = (sel: string, tosel: ComparableValue) => {\n    return SqlString.format([\n        '( ',\n        // 'EXISTS json_extract(value, ?) ',\n        // 'AND json_extract(value, ?) < ?',\n        'json_extract(value, ?) < ?',\n        ' )'\n    ].join(''),\n        [ /* sel, */ sel, tosel ]\n    );\n}\n\nconst $lte = (sel: string, tosel: ComparableValue) => {\n    return SqlString.format([\n        '( ',\n        // 'EXISTS json_extract(value, ?) ',\n        // 'AND json_extract(value, ?) <= ?',\n        'json_extract(value, ?) <= ?',\n        ' )'\n    ].join(''),\n        [ /* sel, */ sel, tosel ]\n    );\n}\n\nconst $gt = (sel: string, tosel: ComparableValue) => {\n    return SqlString.format([\n        '( ',\n        // 'EXISTS json_extract(value, ?) ',\n        // 'AND json_extract(value, ?) > ?',\n        'json_extract(value, ?) > ?',\n        ' )'\n    ].join(''),\n        [ /* sel, */ sel, tosel ]\n    );\n}\n\nconst $gte = (sel: string, tosel: ComparableValue) => {\n    return SqlString.format([\n        '( ',\n        // 'EXISTS json_extract(value, ?) ',\n        // 'AND json_extract(value, ?) >= ?',\n        'json_extract(value, ?) >= ?',\n        ' )'\n    ].join(''),\n        [ /* sel, */ sel, tosel ]\n    );\n}\n\nconst $ne = (sel: string, tosel: ComparableValue) => {\n    return SqlString.format([\n        '( ',\n        // 'EXISTS json_extract(value, ?) ',\n        // 'AND json_extract(value, ?) <> ?',\n        'json_extract(value, ?) <> ?',\n        ' )'\n    ].join(''),\n        [ /* sel, */ sel, tosel ]\n    );\n}\n\nconst $exists = (sel: string) => {\n    return SqlString.format([\n        '( ',\n        'EXISTS(json_extract(value, ?)) ',\n        ' )'\n    ].join(''),\n        [ sel ]\n    );\n}\n\nconst $null = (sel: string) => {\n    return SqlString.format([\n        '( ',\n        'json_extract(value, ?) IS NULL ',\n        ' )'\n    ].join(''),\n        [ sel ]\n    );\n}\n\nconst $notnull = (sel: string) => {\n    return SqlString.format([\n        '( ',\n        'json_extract(value, ?) IS NOT NULL ',\n        ' )'\n    ].join(''),\n        [ sel ]\n    );\n}\n\nconst $like = (sel: string, tosel: ComparableValue) => {\n    return SqlString.format([\n        '( ',\n        // 'EXISTS json_extract(value, ?) ',\n        // 'AND json_extract(value, ?) LIKE ?',\n        'json_extract(value, ?) LIKE ?',\n        ' )'\n    ].join(''),\n        [ /* sel, */ sel, tosel ]\n    );\n}\n\nconst $glob = (sel: string, tosel: ComparableValue) => {\n    return SqlString.format([\n        '( ',\n        // 'EXISTS json_extract(value, ?) ',\n        // 'AND json_extract(value, ?) GLOB ?',\n        'json_extract(value, ?) GLOB ?',\n        ' )'\n    ].join(''),\n        [ /* sel, */ sel, tosel ]\n    );\n}\n\nconst $regexp = (sel: string, tosel: ComparableValue) => {\n    return SqlString.format([\n        '( ',\n        // 'EXISTS json_extract(value, ?) ',\n        // 'AND json_extract(value, ?) regexp ?',\n        'json_extract(value, ?) regexp ?',\n        ' )'\n    ].join(''),\n        [ /* sel, */ sel, tosel ]\n    );\n}\n\nfunction handleArraySelector(selectors: Array<any>)\n    : Array<string>\n{\n\n    const queries = new Array<string>();\n\n    for (const sel of selectors) {\n        if (Array.isArray(sel)) {\n            throw new Error(`Found array in array selectors ${util.inspect(sel)}`);\n        }\n        if (typeof sel !== 'object') {\n            throw new Error(`Found non-object selector ${util.inspect(sel)}`);\n        }\n\n        const sels = handleObjectSelector(sel);\n        queries.push(\n            '( ' + sels.join(' AND ') + ' )'\n        );\n    }\n\n    return queries;\n}\n\nfunction handleObjectSelector(selectors: any)\n    : Array<string>\n{\n\n    const queries = new Array<string>();\n\n    for (const sel in selectors) {\n        if (!(typeof sel === 'string')) {\n            throw new Error(`handleObjectSelector got invalid selector ${util.inspect(sel)}`);\n        }\n\n        const tosel = selectors[sel];\n\n        if (sel === '$or' && !(Array.isArray(tosel))) {\n            throw new Error(`selectors2where got $or without array ${util.inspect(tosel)}`);\n        }\n        if (sel === '$or') {\n            queries.push(\n                '( ' + handleArraySelector(tosel).join(' OR ') + ' )'\n            );\n            continue;\n        }\n        if (sel === '$and' && !(Array.isArray(tosel))) {\n            throw new Error(`selectors2where got $and without array ${util.inspect(tosel)}`);\n        }\n        if (sel === '$and') {\n            queries.push(\n                '( ' + handleArraySelector(tosel).join(' AND ') + ' )'\n            );\n            continue;\n        }\n\n        if (sel === '$exists') {\n            if (typeof tosel !== 'string') {\n                throw new Error(`Incorrect operand ${util.inspect(tosel)} for $exists`);\n            }\n            queries.push(\n                '( ' + $exists(tosel) + ' )'\n            );\n            continue;\n        }\n\n        if (sel === '$null') {\n            if (typeof tosel !== 'string') {\n                throw new Error(`Incorrect operand ${util.inspect(tosel)} for $null`);\n            }\n            queries.push(\n                '( ' + $null(tosel) + ' )'\n            );\n            continue;\n        }\n\n        if (sel === '$notnull') {\n            if (typeof tosel !== 'string') {\n                throw new Error(`Incorrect operand ${util.inspect(tosel)} for $notnull`);\n            }\n            queries.push(\n                '( ' + $notnull(tosel) + ' )'\n            );\n            continue;\n        }\n\n        // THe default action is equality\n        if (isComparable(tosel)) {\n            queries.push($eq(sel, tosel));\n            continue;\n        }\n\n        if (typeof tosel === 'object') {\n            const keys = Object.keys(tosel);\n            if (keys.length < 1 || keys.length > 1) {\n                throw new Error(`selectors2where got incorrect comparison operand for ${util.inspect(sel)} with ${util.inspect(tosel)}`);\n            }\n            const op = keys[0];\n            const orsel = tosel[op];\n            if (op === '$eq') {\n                queries.push($eq(sel, orsel));\n            } else if (op === '$lt') {\n                queries.push($lt(sel, orsel));\n            } else if (op === '$lte') {\n                queries.push($lte(sel, orsel));\n            } else if (op === '$gt') {\n                queries.push($gt(sel, orsel));\n            } else if (op === '$gte') {\n                queries.push($gte(sel, orsel));\n            } else if (op === '$ne') {\n                queries.push($ne(sel, orsel));\n            } else if (op === '$exists') {\n                queries.push($exists(sel));\n            } else if (op === '$like') {\n                queries.push($like(sel, orsel));\n            } else if (op === '$glob') {\n                queries.push($glob(sel, orsel));\n            } else if (op === '$regexp') {\n                queries.push($regexp(sel, orsel));\n            } else {\n                throw new Error(`selectors2where got invalid operator ${util.inspect(op)} in ${util.inspect(tosel)}`);\n            }\n        }\n    }\n    return queries;\n}\n\nexport function selectors2where(selectors: any) {\n\n    if (typeof selectors !== 'object') {\n        throw new Error(`Incorrect type for selector ${util.inspect(selectors)}`);\n    }\n\n    const queries = handleObjectSelector(selectors);\n    return /* '( ' + */ queries.join(' AND ') /* + ' )' */;\n}"]}