easy-db-client
v3.0.0
Published
Lite&easy client for `easy-db-server` or other full REST server.
Downloads
11
Maintainers
Readme
Easy DB client
Lite&easy client for easy-db-server
or other full REST server.
The same API as using the easy-db
directly.
The same package for browser
, node
and react-native
.
Not create any database structure, just use it.
MongoDB like query and projection operators for GET collection.
Include types for TypeScript.
API
import easyDB from "easy-db-client";
const { insert, select, update, remove, file } = easyDB({
server: "https://example.com/",
token: "secretToken",
});
// INSERT
const idOfRow = await insert("collection1", { myRow: 1 });
const idOfRow = await insert("collection1", id => ({ id, myRow: 1 }));
// SELECT
const allCollection1 = await select("collection1");
const myRow1 = await select("collection1", idOfRow);
const userRows = await select("user", {
query: { age: { $gt : 18 },
projection: { name: 1, age: 1 },
sort: { name: 1, age: -1 },
skip: 20,
limit: 10,
});
// UPDATE
await update("collection1", idOfRow, { ...myRow1, update: 1 });
// REMOVE
await remove("collection1", idOfRow); // only one row
// INSERT FILE
const idOfRow = await insert("collection1", { photo: file("data:base64...") });
// saved { photo: { url: "http://example.com/files/....png" } }
Example of use
import easyDB from "easy-db-client";
const { select, update } = easyDB({});
// Save nickname
await update("myAppName", "nickname", nickname);
// Load nickname
const nickname = await select("myAppName", "nickname");
Support
Browser
Support for all browsers supported fetch
.
IE <= 11
Use any fetch polyfill
, for example whatwg-fetch.
react-native
Full support without condition.
node
Supported with node-fetch
.
import fetch from "node-fetch";
global.fetch = fetch;