0.0.23 • Published 7 years ago

isotropy-ast-analyzer-db v0.0.23

Weekly downloads
6
License
MIT
Repository
-
Last release
7 years ago

Isotropy AST Analyzer for DB

This module abstracts AST analysis for common database operations so that they don't have to be repeated in every database plugin. This is part of the isotropy framework (www.isotropy.org).

This README is not complete. However, parsing the following examples is supported.

Create a module "db.js" containing an array that mocks the database. The filename can be changed in configuration.

//In db.js
export default [
  {
    { title: "buy tickets", assignee: "you", priority: 1 },
    { title: "search for extra-terrestrials", assignee: "you", priority: 2 }
  }
]

Perform a database insert

import myDb from "./my-db.js";

//Insert a single item
async function addTodo(title, assignee) {
  myDb.todos = myDb.todos.concat({ title, assignee });
}

//Insert a list of new items
async function addManyTodos(title, assignee) {
  const todosList = [
    { title: "get milk", assignee: "you", priority: 1 },
    { title: "buy eggs", assignee: "you", priority: 2 }
  ];
  myDb.todos = myDb.todos.concat(todosList)
}

Get all records

import myDb from "./my-db.js";

async function getAllTodos(who) {
  return myDb.todos;
}

Query a table

import myDb from "./my-db.js";

async function getTodos(who) {
  return myDb.todos.filter(todo => todo.assignee === who);
}

Query and return specific fields

import myDb from "./my-db.js";

async function getTodos(who) {
  return myDb.todos
    .filter(todo => todo.assignee === who)
    .map(todo => ({ assignee: todo.assignee }));
}

Limit the number of results

//Returns rows 10-20
import myDb from "./my-db.js";

async function getTodos(who) {
  return myDb.todos
    .filter(todo => todo.assignee === who)
    .slice(10, 20);
}

Order by a specific field

import myDb from "./my-db.js";

async function getTodos(who) {
  return myDb.todos
    .filter(todo => todo.assignee === who)
    .sort((x, y) => x.assignee > y.assignee);
}

Update a record

import myDb from "./my-db.js";

async function updateTodo(assignee, newAssignee) {
  myDb.todos = myDb.todos.map(todo => todo.assignee === assignee ? { ...todo, assignee: newAssignee } : todo);
}

Delete a record

import myDb from "./my-db.js";

async function deleteTodo(title, assignee) {
  myDb.todos = myDb.todos.filter(todo => !(todo.assignee == assignee && todo.title === title));
}

Count the number of items

import myDb from "./my-db.js";

async function countTodos(who) {
  return myDb.todos.filter(todo => todo.assignee === who).length;
}

Multiple databases

import todosDbModule from "./todos-db.js";
import authDb from "./auth-db.js";

async function getTodos(who) {
  return todosDbModule.todos.filter(todo => todo.assignee === who);
  return authDb.users.filter(u => u.name === "jack");
}

Plugin Configuration (Advanced)

"isotropy-mongo-db": {
  "dbModulePaths": { "todosDbModule": "./db.js" },
}
0.0.23

7 years ago

0.0.22

7 years ago

0.0.21

7 years ago

0.0.20

7 years ago

0.0.17

7 years ago

0.0.16

7 years ago

0.0.15

7 years ago

0.0.14

7 years ago

0.0.13

7 years ago

0.0.12

7 years ago

0.0.11

7 years ago

0.0.10

7 years ago

0.0.9

7 years ago