libpg-query
Version:
The real PostgreSQL query parser
48 lines (40 loc) • 1.17 kB
JavaScript
import { getDefaultContext } from '@emnapi/runtime';
import PgQueryModule from './libpg-query.js';
let PgQuery;
const initPromise = PgQueryModule().then((module) => {
const binding = module.emnapiInit({
context: getDefaultContext(),
});
PgQuery = binding;
});
/**
* Function wrapper that waits for the WASM module to initialize
* before executing the function.
*/
function awaitInit(fn) {
return async (...args) => {
await initPromise;
return fn(...args);
};
}
export const parseQuery = awaitInit((query) => {
return new Promise(async (resolve, reject) => {
PgQuery.parseQueryAsync(query, (err, result) => {
err ? reject(err) : resolve(JSON.parse(result));
});
});
});
export const parsePlPgSQL = awaitInit((query) => {
return new Promise(async (resolve, reject) => {
PgQuery.parsePlPgSQLAsync(query, (err, result) => {
err ? reject(err) : resolve(JSON.parse(result));
});
});
});
export const fingerprint = awaitInit((query) => {
return new Promise(async (resolve, reject) => {
PgQuery.fingerprintAsync(query, (err, result) => {
err ? reject(err) : resolve(result);
});
});
});