Use PostgreSQL
Add PostgreSQL as a database with the @primate/postgresql module. Configure
it in config/db; Primate connects to it and provides a unified API.
Ensure PostgreSQL is running and accessible.
$ npm install @primate/postgresql
TypeScriptconfig/db/index.ts
import postgresql from "@primate/postgresql";
export default postgresql({
host: "localhost",
port: 3306,
database: "app",
// username: "user",
// password: "pass",
});
TypeScriptstores/User.ts
import p from "pema";
import key from "primate/orm/key";
import store from "primate/orm/store";
import db from "../config/db/index.ts";
export default store({
name: "user",
db,
schema: {
id: key.primary(p.uuid),
name: p.string,
email: p.string.email(),
},
});
TypeScriptroutes/users.ts
import User from "#store/User";
import route from "primate/route";
route.get(async () => {
const users = await User.find({});
return users;
});
route.post(async request => {
const user = await User.insert(request.body);
return user;
});