Skip to content
/ servedata Public template

File-system-based database (in the git repo), with a server attached with users and access control for serving this data. See an example in production:

License

Notifications You must be signed in to change notification settings

o0101/servedata

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Dec 28, 2021
66918bb Â· Dec 28, 2021

History

9 Commits
Feb 22, 2021
Feb 22, 2021
Feb 22, 2021
Feb 22, 2021
Feb 22, 2021
Feb 22, 2021
Feb 22, 2021
Feb 22, 2021
Feb 22, 2021
Feb 22, 2021
Feb 22, 2021
Feb 22, 2021
Feb 22, 2021
Feb 22, 2021
Feb 22, 2021
Feb 22, 2021
Feb 22, 2021
Feb 22, 2021
Feb 22, 2021
Feb 22, 2021
Feb 22, 2021
Feb 22, 2021
Feb 22, 2021
Feb 22, 2021
Feb 22, 2021
Feb 22, 2021
Feb 22, 2021
Feb 22, 2021
Feb 22, 2021
Feb 22, 2021
Dec 28, 2021
Dec 28, 2021
Feb 22, 2021
Feb 22, 2021
Feb 22, 2021
Feb 22, 2021
Feb 22, 2021
Feb 22, 2021
Feb 22, 2021
Feb 22, 2021
Feb 22, 2021
Feb 22, 2021
Feb 22, 2021
Feb 22, 2021
Feb 22, 2021

Repository files navigation

🔮 Dosyago downloads version

Around 3000 source lines of code (see stats folder)

What is Dosyago / Capi.click?

A simple server based on SirDB with a schema-driven API, for serving all types of data, while attempting to meet ROCA guidelines.

Already includes schemas, users, groups, authentication, authorization, permissions and payments.

Using this template

You need to populate the secrets directory, with a G Suite/GMail API key with sender permissions, and (if you want fun error pages), a Giphy API key.

Also right now there's some places in the templates where I used my email ([email protected]), so you probably want to replace that.

Also to use payments, you need Stripe keys.

Use cases

This uses the SirDB as a database. This would be acceptable for user account related use cases for a moderate number of users (up to 100k), or for user content and data related use cases for a smaller number of less frequent users (up to 5k). Mitigations such as vertical scaling, and using a ramdisk (with scheduled saves to hard disk) can increase performance.

For apps with a large number of users performing many operations on data and content, a separate database for content and data (separate to user account data) will be good.

Features

  • Automatic CRUD for tables
  • Permissions for users and groups
  • Custom actions for updating multiple tables or using 3rd party APIs
  • Views for showing result of simple operations
  • Custom selections to grab data from multiple tables or 3rd party APIs and display

Examples of all the above can be found in the code.

You can use whatever view framework you like. For convenience here I use bepis.

About

File-system-based database (in the git repo), with a server attached with users and access control for serving this data. See an example in production:

Resources

License

Security policy

Stars

Watchers

Forks

Sponsor this project

Packages

No packages published

Languages