space-cloud

command module
v0.12.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Sep 29, 2019 License: Apache-2.0 Imports: 8 Imported by: 0

README

Space Cloud

Instant Realtime APIs on any database

WebsiteDocsSupport


Go Report Card Apache License

Space Cloud is a cloud native backend server that provides instant, realtime APIs on any database, with event triggers and space functions for custom business logic.

Space Cloud helps you build modern applications without having to write any backend code in most cases.

It provides GraphQL and REST APIs which can be consumed directly by your frontend in a secure manner.

Features

View complete feature set here.

  • Powerful CRUD: Flexible queries, transactions and cross database joins
  • Realtime: Make live queries to your database
  • File storage: Upload/download files to scalable file stores (eg: Amazon S3, Google Cloud Storage)
  • Extensible: Write custom business logic in form of simple functions
  • Event driven: Trigger webhooks or serverless functions on database or file storage events
  • Fine-grained access control: Dynamic access control that integrates with your auth system (eg: auth0, firebase-auth)
  • Scalable: Written in golang, it follows cloud native practices and scales horizontally

Supported databases❤:

  • MongoDB
  • PostgreSQL and PostgreSQL compatible databases (For eg. CockroachDB, Yugabyte, etc.)
  • MySQL and MySQL compatible databases (For eg. TiDB, MariaDB, etc.)

Table of Contents

Quick start

Using Docker Compose

Docker compose is the easiest way to get started with Space Cloud. Let's see how to quickly get started with MongoDB and Space Cloud using Docker Compose.

Note: MongoDB is not a dependency of Space Cloud. Space Cloud can run with any of it's supported databases.

Prerequisites:

  1. Get the docker-compose file.
wget https://raw.githubusercontent.com/spaceuptech/space-cloud/master/install-manifests/quick-start/docker-compose/mongo/docker-compose.yaml
  1. Run Space Cloud & MongoDB.
docker-compose up -d
  1. Head over to http://localhost:4122/mission-control to open Mission Control and configure Space Cloud.

  2. Create a project.

  3. Head over to the Database section in Mission Control and copy paste mongodb://mongo:27017 in the connection string.

  4. Head over to the Explorer section and follow this guide to insert and read data via Space Cloud using GraphQL.

To get started with Space Cloud without Docker compose, check out the manual guide. For production settings, checkout the deployments guide.

Client-side tooling

Space Cloud exposes GraphQL, HTTP, websockets and gRPC endpoints. See setting up project guide to choose a client and set it up.

GraphQL APIs

Space Cloud works with any GraphQL client. We recommend using Apollo Client. See awesome-graphql for a list of clients.

Client SDKs

If you don't want to use graphql, we have made following client SDKs for you:

How it works

Space Cloud is meant to replace any backend php, nodejs, java code you may write to create your endpoints. Instead, it exposes your database over an external API that can be consumed directly from the frontend. In other words, it allows clients to fire database queries directly.

However, it's important to note that the client does not send database (SQL) queries to Space Cloud. Instead, it sends an object describing the query to be executed. This object is first validated by Space Cloud (using security rules). Once the client is authorized to make the request, a database query is dynamically generated and executed. The results are sent directly to the concerned client.

We understand that not every app can be built using only CRUD operations. Sometimes it's necessary to write business logic. For such cases, Space Cloud offers you APIs to write functions (which runs as microservices alongside Space Cloud). These functions can be invoked from the frontend or by other functions. In this scenario, Space Cloud acts merely as an api gateway between your functions and the client.

Detailed Space Cloud architecture

Apart from these, Space Cloud also integrates with tons of cloud technologies to give you several other features like realtime database (changes in the database are synced with all concerned clients in realtime), file storage, etc.

Support & Troubleshooting

The documentation and community will help you troubleshoot most issues. If you have encountered a bug or need to get in touch with us, you can contact us using one of the following channels:

Contributing

Space Cloud is a young project. We'd love to have you on board if you wish to contribute. To help you get started, here are a few areas you can help us with:

  • Writing the documentation
  • Making sample apps in React, Angular, Android, and any other frontend tech you can think of
  • Deciding the road map of the project
  • Creating issues for any bugs you find
  • And of course, with code for bug fixes and new enhancements

License

Space Cloud is Apache 2.0 licensed.

Documentation

The Go Gopher

There is no documentation for this package.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL