Security News
Node.js EOL Versions CVE Dubbed the "Worst CVE of the Year" by Security Experts
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
High-precision state management using MongoDB query language.
npm i adaka
createStore
function to get started.import { createStore } from "adaka";
type Person = { name: string; age: number; children?: string[] };
const store = createStore<Person>({
name: "John",
age: 30,
children: ["Luke"]
});
// create a selector
const selector = store.select<{ name: string }>({ name: 1 });
// subcriber runs whenever name changes.
const unsubscribe = selector.subscribe(view => {
console.log("->", view);
});
// first update
store.update({ $set: { name: "Amoah" } }); //output: '-> {name:"Amoah"}'
// can also use selector.getState() to obtain the value directly.
console.log(selector.getState()); // {name: "Amoah"}
// second update
store.update({ $set: { name: "Donkor" } }); //output: '-> {name:"Donkor"}'
// third update on different part of the state. subscriber is not notified.
store.update({ $push: { children: "Ama" } }); // no output
// remove subscriber by calling return method.
unsubscribe();
// subscriber no longer runs
store.update({ $set: { name: "Odame" } }); // no output
A selector may use a condition to restrict when listeners are notified. When a condition is used listeners are notified
only once for when the condition is false with a return value of undefined
. Further updates that do not meet the condition
do not trigger anymore notifications. On the other hand, any update that meets the condition triggers a notification.
// store object.
// ------------
// {
// name: "John",
// age: 30,
// children: ["Luke"]
// }
// second child if person under 30.
const selector = store.select<{ secondChild: string }>({
secondChild: "$children.1"
}, {age: {$lt: 30}});
selector.subscribe(data => {
console.log("->", data);
});
selector.getState() // undefined
store.update({$set: {age: 25}})
// no second child yet.
selector.getState() // {}
store.update({ $push: { children: "Adrian"} })
selector.getState() // { secondChild: 'Adrian' }. listeners notified.
store.update({ $set: { age: 35 } })
selector.getState() // undefined. listeners notified.
store.update({ $set: { age: 40 } })
selector.getState() // undefined. no notifications because condition is false.
The react-adaka and React >=18.2.0
libraries are required to use this integration.
import { createStore, createSelectorHook } from "react-adaka"
// first create your store
const store = createStore({
status: "error",
errors: [
{ type:"api", message: "unknown error" }
],
});
// create a selector hook some where in global scope. need one per store.
const useSelector = createSelectorHook(store)
// use the hook inside your React component.
function ShowErrorTypes() {
// select the types of errors only when the status is in "error".
const { errorTypes } = useSelector({ errorTypes: "$errors.type" }, { status: "error"})
return errorTypes ? <div>Issues found: {errorTypes.join("\n")} </div> : <div/>
}
This package uses the mingo library for MongoDB query language support and loads only the basic supported query
, projection
, expression
, and all update
operators by default. Refer to the readme page for more information.
The mingo
libray is added as a peer dependency to enable users to select only required operators using the context
option so that tree-shaking can work effectively. Basic mingo
operators are loaded into the global context by default.
MIT
FAQs
High-precision state management using MongoDB query language.
The npm package adaka receives a total of 4 weekly downloads. As such, adaka popularity was classified as not popular.
We found that adaka demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.