Skip to content

Build a serverless REST API on top of of your MySQL database

License

Notifications You must be signed in to change notification settings

zuplo-samples/mysql-postgrest

Repository files navigation

MySQL PostgREST

Do you wish you could interact with your MySQL database via API/SDK like Supabase? Look no further! This project shows you exactly how to recreate the Supabase/PostgREST API and developer experience. Try the demo. You can also read the walkthrough to get a better sense of how this works.

Installation

This is just a template so you can clone this repository directly and run it yourself.

  1. Create a hosted MySQL database (ex. using Aiven's free tier) and grab the connection parameters.

Aiven connection params

  1. Create a table following planetscale's quickstart
CREATE TABLE products (
  id int NOT NULL AUTO_INCREMENT PRIMARY KEY,
  name varchar(255) NOT NULL,
  image_url varchar(255),
  category_id INT,
  KEY category_id_idx (category_id)
);
  1. Create an admin role and grant it full access
CREATE ROLE 'admin'
GRANT ALL on app_db.* to 'admin'
  1. Grant your user the admin role. For example:
GRANT 'admin' to 'avnadmin';

Alternatively you can use the included permissions.json file to determine access and roles.

  1. Create a .env file at the root and set env vars from step 1
NEXT_PUBLIC_API_URL=# ex. "http://localhost:3000"
DATABASE_HOST=# ex. "aws.connect.psdb.cloud"
DATABASE_USERNAME=
DATABASE_PASSWORD=
DATABASE_PORT=
DATABASE_CA_CERTIFICATE=
DATABASE_NAME=# ex. defaultdb
  1. Install and run
npm install
npm run dev

How It Works

img

PostgREST requests are sent from the front-end to a catch-all route which invokes a serverless function. That function translates the request into a SQL query and executes it against your Neon database. The results are returned as a JSON.

NOTE: Be careful performing SQL queries from your front-end - I bundled this together for demonstration purposes. I would host the PostgREST API in a separate project (and protected behind a gateway), and call it from CRUD RESTful serverless functions on this project. Alternatively, I think you can implement stuff like row-level security and anon keys to make this method more secure, which is what Supabase does.

Tools

I used the following tools:

  1. NextJS Serverless Functions for easy Typescript setup + fast runtime (Cloudflare Workers will also work, but you won't be able to read files using node libs).
  2. Vercel to simplify deployment (you can use Cloudflare pages too).
  3. @supabase/postgrest-js to construct queries using a Supabase-like SDK. This sends PostgREST requests to your serverless function.
  4. @subzerocloud/rest to translate the PostgREST requests into Postgres queries.
  5. mariadb for querying your MySQL database.
  6. (optional) Zuplo API Gateway to proxy your serverless function. Good place to add caching, rate limiting, DDOS/bot protection, etc so this doesn't blow up in production. You can find the gateway code here.

Created with ❤️ by Zuplo.

About

Build a serverless REST API on top of of your MySQL database

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published