/space-api-js

Primary LanguageJavaScriptApache License 2.0Apache-2.0

Client API for Space Cloud

Installation

Install via. npm

$ npm install space-api --save

or import as a stand alone library

<script src="https://spaceuptech.com/downloads/libraries/space-api.js"></script>

Documentation

The complete documentation can be found here.

Documentation for specific databases is given below:

Documentation for real time feature is given below:

Quick Start

Create Client Instance

import { API, and, or, cond } from 'space-api';

const api = new API('demo-project', 'http://localhost:8080');

// For MongoDB
const db = api.Mongo();

// For PostgresQL
const db = api.Postgres();

// For MySQL
const db = api.MySQL();

Note: Multiple databases may be used simultaneously.

Insert a document into the database

const doc = {_id: 1, title: "Title 1", content: "My first record"};
db.insert('COLLECTION_NAME').one(doc).then(res => {
  if (res.status === 200) {
    // Document inserted successfully
    return;
  }
}).catch(ex => {
  // Exception occured while processing request
});

Note: Always insert documents with a id in order to use the realtime feature.

Query documents in database

const find = and(cond('title', '==', 'Title1'), cond('author', '==', 'Jon'));
db.get('COLLECTION_NAME').where(find)
  .skip(10).limit(10)
  .all()
  .then(res => {
    if (res.status === 200) {
      // res.data contains the documents returned by the database
      console.log('Response:', res.data);
      return;
    }
  }).catch(ex => {
    // Exception occured while processing request
  });

Update documents in database

const find = and(cond('author', '==', 'Jon'));
db.update('COLLECTION_NAME').where(find)
  .set({ author: 'John' })
  .all()
  .then(res => {
    if (res.status === 200) {
      // Document updated successfully
      return;
    }
  }).catch(ex => {
    // Exception occured while processing request
  });

Delete documents in database

const find = and(cond('author', '==', 'John'));
db.delete('COLLECTION_NAME').where(find)
  .many()
  .then(res => {
    if (res.status === 200) {
      // Document deleted successfully
      return;
    }
  }).catch(ex => {
    // Exception occured while processing request
  });

Get real time updates

const onSnapshot  = (docs, type) => {
  if (type === 'initial') {
    console.log('Initial docs ', docs)
      return
    }
    console.log(docs, type)
   }
 
const onError = (err) => {
  console.log('Monitor error', err)
}
 
let unsubscribe = db.liveQuery('posts').where().subscribe(onSnapshot, onError) 
 
unsubscribe()

Upload file

const fileInput = document.querySelector('#your-file-input');
api.FileStore().uploadFile("/some-path", fileInput.files[0])
  .then(res => {
    if (res.status === 200) {
        console.log("File uploaded successfully");
    }
  }).catch(ex => {
    // Exception occured while uploading file
  })

Call functions directly (Function as a Service)

api.call('my-engine', 'my-func', { msg: 'Function as a Service is awesome!' }, 1000)
  .then(res => {
    if (res.status === 200) {
      console.log('Response: ', res.data)
    }
  }).catch(ex => {
    // Exception occured while processing request
  })

License

Copyright 2018 Noorain Panjwani

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.