GitXplorerGitXplorer
e

autoserver

public
205 stars
12 forks
0 issues

Commits

List of commits on branch main.
Unverified
82ed7890e0fff06cd72a3aefe20b96729c9dbfe8

Upgrade @ehmicky/eslint-config 20.0.21 -> 20.0.22

eehmicky committed 7 days ago
Unverified
b424c760e84e74a09b9914f496b2f9fdc3e21c60

Upgrade qs 6.13.1 -> 6.14.0

eehmicky committed 7 days ago
Unverified
c3190b1de1b486f42c822bec42248752628f5b12

Upgrade @ehmicky/eslint-config 20.0.20 -> 20.0.21

eehmicky committed 13 days ago
Unverified
908970cde83fbcff3c39de261c348de1d3ae317b

Upgrade @ehmicky/eslint-config 20.0.19 -> 20.0.20

eehmicky committed 13 days ago
Unverified
ee04eb83f37c1e80a645877d48d2022fb05d8f9d

Upgrade @ehmicky/dev-tasks 3.0.27 -> 3.0.28

eehmicky committed 13 days ago
Unverified
4381a1a6316c794a160143fcaef7d4cfb83360af

Upgrade nodemon 3.1.7 -> 3.1.9

eehmicky committed 13 days ago

README

The README file for this repository.

autoserver logo

Node Mastodon Medium

Create a full-featured REST/GraphQL API from a configuration file.

Hire me

Please reach out if you're looking for a Node.js API or CLI engineer (11 years of experience). Most recently I have been Netlify Build's and Netlify Plugins' technical lead for 2.5 years. I am available for full-time remote positions.

Development status

This project is still in active development, and is not ready for production. Key features are currently missing.

If you want to follow our progress in the meantime, you are welcome to star this repository.

Overview

Create a simple configuration file describing your data model:

engine: 0
collections:
  users:
    description: User of the API
    attributes:
      id:
        type: string
      age:
        type: integer
      score:
        type: number
        alias: high_score
        default: 10
        validate:
          minimum: 20
      reports:
        type: reports[]
  reports:
    attributes:
      id:
        type: string
      content:
        type: string
  default:
    database: mongodb
databases:
  mongodb:
    hostname: localhost
    password: secret_mongodb_password
    dbname: my_database_name
protocols:
  http:
    port: 5001

Then start a full-featured web API.

$ autoserver

Clients will now be able to perform GraphQL requests:

{
  find_users(
    filter: { score: { _gt: 100 } }
    order: "score"
  ) {
    id
    age
    score
    reports: { content }
  }
}

Or REST requests:

GET /rest/users/?filter.score._gt=100&order=score&populate=reports
{
  "data": [
    {
      "id": "15",
      "age": 32,
      "score": 150,
      "reports": { "id": "65", "content": "..." }
    },
    {
      "id": "251",
      "age": 24,
      "score": 168,
      "reports": { "id": "67", "content": "..." }
    },
    {
      "id": "7",
      "age": 51,
      "score": 192,
      "reports": { "id": "10", "content": "..." }
    }
  ]
}

Features

Documentation

The documentation is here.

Badge

The following badge can be added to your project: autoserver

[![autoserver](https://img.shields.io/badge/auto-server-406890.svg?logo=)](https://github.com/ehmicky/autoserver)

Contribute

See the developer's documentation.

Contributors