7.3.0 • Published 7 years ago
google-cloud-datastore-toolkit v7.3.0
Deprecated
Turns out this implementation has lots of data consistency holes. Refactored with breaking changes: @ https://github.com/xemasiv/datastore2 @ https://www.npmjs.com/package/datastore2
Google Cloud Datastore Toolkit
- Goals- Entities as variables on steroids.
- Strict consistency with Datastore records for predictability.
- Methods as Promises for readability.
 
Changelog
- v7.2- Added Transaction support, see below.
 
- v7.1- Fixed Entity.fromKeyName If passes UUIDv4 regex test, keep keyName as string. Otherwise, apply parseInt * If no entity was found, load as String.
 
- v6.1- Fixed Entity.fromUUID bug: Auto-assigned Key ID's are Integer. Across browser-server, these keys might be interpreted as String, which results in unpredictability The fix is to use RegExUUIDv4 on keyName argument. If regex passed, keep it. Otherwise, parseInt it. This way non-uuidv4 keynames are transformed into Integers and not Strings.
 
- v5.1- Rewrite of Queue, now allows resolve and reject.
 
- v4.1- Woops typo
 
- v4.0- Moved helpers to Toolkit.Helpers
 
- v3.2- New helpers: AssocPromise, AssocIterate
 
- v3.1- Fixed handling for Reader when cache is not present.
 
- v3.0- Entity now has strict consistency with Datastore
- New helpers: RedisCache, Queue, IterablePromise
 
- v2- Everything's a mess, don't use.
 
Unrelated Notes
- Lol I'm too lazy to write docs.
Classes, Methods, Arguments & Properties
Added @ v7.2
- Transaction- constructor(...keyPairs)- Creates a Transaction instance.
- Accepts multiple key pairs, label are mapped to entity data.
- Accepted Arguments- keyPair/ args0 to n / Array : label, key Array Values
 
 
- start(executorFunction)
- commit(mappedResults)- Receives the Updated mappedResults.
- Saves and commits the the transaction.
- Executes a rollback on commit error.
- Accepted Arguments- mappedResults/ args0 / object
 
 
 
    let transactionAmount = 10;
    return new Transaction(
      ['alice', alice.key],
      ['bob', bob.key]
    ).start((R, T) => {
      R.alice.current -= transactionAmount;
      R.bob.current += transactionAmount;
      /*
        Validations:
        - No NaN / undefined / null value found.
        - Final values didn't equate below zero.
      */
      if (R.alice.current < 0) {
        return Promise.reject("Invalid transaction.")
      } else {
        return T.commit(R);
      }
    });- Entity - constructor(kind)Function- kindis our Entity's kind.
- Arguments:- kind / args0 / String
 
 
- .fromUUID()Function, returns Promise- Generates a random UUIDv4 string for the entity's key name.
- Availability of UUIDv4 string as key name is verified.
- Upserts an empty data to reserve entry, for consistency.
- Sets Entity.keyandEntity.dataproperties before resolving.
 
- .fromKeyName(keyName, autoUpsert)Function, returns Promise
- .fromFilters()Function, returns Promise- We uses the key of the first entity that matches supplied filters.
- Sets Entity.keyandEntity.dataproperties before resolving.
- Arguments:- filters/ args0 / Array of Filters
- Example format of a filteris 'column', 'operator', 'value'
 
 
- .upsert()Function, returns Promise- Upserts supplied data.
- Also fetches data afterwards to re-assign Entity.dataproperty, for consistency.
- Arguments:- data / args0 / Object
 
 
- .merge()Function, returns Promise- Same like upsert, except we merge new data with existing data.
- Also fetches data afterwards to re-assign Entity.dataproperty, for consistency.
- Arguments:- data / args0 / Object
 
 
- .delete()Function, returns Promise- Deletes the entity from Datastore.
- Then sets .key, and.dataproperties of Entity to undefined.
 
- .kindProperty
- .keyProperty
- .dataProperty
- .ErrorTypesstatic Property- ENTITY_NOT_FOUND
- DATASTORE_ERROR
 
- .exists(kind, keyName)static Function, returns Promise
 
- Reader 
- Batch 
- AssocPromise 
- AssocIterate 
- IterablePromise - constructor(iterableArray)Function- iterableArrayis the iterable to be iterated.
- Arguments:- iterableArray / args0 / Array
 
 
- .all(promiseExecutorFunction)Function, returns Promise- promiseExecutorFunctionis the function to execute on all iterated values.
- promiseExecutorFunctionshould takes- item,- index,- resolveand- reject, in order, and should call- resolveor- reject.
- Returns a promise, which means this can be chained.
- Arguments:- promiseExecutorFunction / args0 / Function
 
 
 
- Queue- constructor(concurrency)Function- concurrencyis the concurrency of this Queue instance.
- Arguments:- concurrency / args0 / Integer
 
 
- .push(executableFunction)Function, returns Promise- Pushes an executableFunctionto the queue.
- Returns a promise, which means this can be chained.
- executableFunctionshould take the argument- callbackthen execute it once done, as shown in examples.
- Arguments:- executableFunction / args0 / Function
 
 
- Pushes an 
 
Setup:
// Set path for JSON, optional if already set in your environment
process.env["GOOGLE_APPLICATION_CREDENTIALS"] = __dirname.concat('/test.json');
// Set datastore constructor opts
const constructorOpts = {
  projectId: 'projectNameGoesHere'
};
// Destructure
const DatastoreToolkit = require('google-cloud-datastore-toolkit');
const { Reader, Entity, Batch } = DatastoreToolkit(constructorOpts);Preloading entities:
let alice = new Entity('Person');
let bob = new Entity('Person');
Promise.all([
    alice.fromKeyName('alice_key_name'),
    bob.fromKeyName('bob_key_name')
  ])
  .then(() => {
    console.log(alice.data, bob.data);
  })
  .catch()Queue
let x = new Queue();
Promise.resolve()
	.then(() => x.push((resolve, reject) => {
   	resolve(123);
  }))
  .then(console.log)
  .then(() => x.push((resolve, reject) => {
   	resolve(456);
   }))
  .then(console.log)
	.then(() => x.push((resolve, reject) => {
   	resolve(123);
  }))
  .then(console.log)
  .catch(console.error)IterablePromise
new IterablePromise([1,2,3,4,5])
  .all((item, index, resolve, reject) => {
    setTimeout(() => {
      console.log(item, index);
      resolve();
    }, 5500)
  })
  .then()
  .catch()