0.6.6 • Published 2 years ago
pgfx v0.6.6
pgfx
A simple effect wrapper around postgres.js
https://tim-smart.github.io/pgfx/modules/index.ts.html
Basic example
import { pipe } from "@effect/data/Function"
import * as Config from "@effect/io/Config"
import * as Effect from "@effect/io/Effect"
import * as Pg from "pgfx"
const PgLive = Pg.makeLayer({
  database: Config.succeed("effect_pg_dev"),
})
const program = Effect.gen(function* (_) {
  const sql = yield* _(Pg.tag)
  const people = yield* _(
    sql<{
      readonly id: number
      readonly name: string
    }>`SELECT id, name FROM people`,
  )
  yield* _(Effect.log(`Got ${people.length} results!`))
})
pipe(program, Effect.provideLayer(PgLive), Effect.runPromise)INSERT resolver
import { pipe } from "@effect/data/Function"
import * as Effect from "@effect/io/Effect"
import * as Schema from "@effect/schema/Schema"
import { SchemaClass } from "effect-schema-class"
import * as Pg from "pgfx"
class Person extends SchemaClass({
  id: Schema.number,
  name: Schema.string,
  createdAt: Schema.DateFromSelf,
  updatedAt: Schema.DateFromSelf,
}) {}
const InsertPersonSchema = pipe(
  Person.structSchema(),
  Schema.omit("id", "createdAt", "updatedAt"),
)
export const makePersonService = Effect.gen(function* (_) {
  const sql = yield* _(Pg.tag)
  const insert = sql.resolver(
    "InsertPerson",
    InsertPersonSchema,
    Person.schema(),
    requests =>
      sql<{
        readonly id: number
        readonly name: string
        readonly createdAt: Date
        readonly updatedAt: Date
      }>`
        INSERT INTO people
        ${sql(requests)}
        RETURNING people.*
      `,
  ).execute
  return { insert }
})SELECT resolver
import * as Effect from "@effect/io/Effect"
import * as Schema from "@effect/schema/Schema"
import { SchemaClass } from "effect-schema-class"
import * as Pg from "pgfx"
class Person extends SchemaClass({
  id: Schema.number,
  name: Schema.string,
  createdAt: Schema.DateFromSelf,
  updatedAt: Schema.DateFromSelf,
}) {}
export const makePersonService = Effect.gen(function* (_) {
  const sql = yield* _(Pg.tag)
  const getByIdResolver = sql.idResolver(
    "GetPersonById",
    Schema.number,
    Person.schema(),
    _ => _.id,
    ids =>
      sql<{
        readonly id: number
        readonly name: string
        readonly createdAt: Date
        readonly updatedAt: Date
      }>`SELECT * FROM people WHERE id IN ${sql(ids)}`,
  )
  const getById = (id: number) =>
    Effect.withRequestCaching("on")(getByIdResolver.execute(id))
  return { getById }
})Migrations
A Migrator module is provided, for running migrations.
Migrations are forward-only, and are written in Typescript as Effect's.
Here is an example migration:
// src/migrations/0001_add_users.ts
import * as Effect from "@effect/io/Effect"
import * as Pg from "pgfx"
export default Effect.flatMap(
  Pg.tag,
  sql => sql`
    CREATE TABLE users (
      id serial PRIMARY KEY,
      name varchar(255) NOT NULL,
      created_at TIMESTAMP NOT NULL DEFAULT NOW(),
      updated_at TIMESTAMP NOT NULL DEFAULT NOW()
    )
  `,
)To run your migrations:
// src/main.ts
import * as Effect from "@effect/io/Effect"
import * as Pg from "pgfx"
import * as Migrator from "pgfx/Migrator"
import * as Config from "@effect/io/Config"
import { fileURLToPath } from "node:url"
import * as Layer from "@effect/io/Layer"
import { pipe } from "@effect/data/Function"
const program = Effect.gen(function* (_) {
  // ...
})
const PgLive = Pg.makeLayer({
  database: Config.succeed("example_database"),
})
const MigratorLive = Layer.provide(
  PgLive,
  Migrator.makeLayer({
    directory: fileURLToPath(new URL("migrations", import.meta.url)),
  }),
)
const EnvLive = Layer.mergeAll(PgLive, MigratorLive)
pipe(
  program,
  Effect.provideLayer(EnvLive),
  Effect.tapErrorCause(Effect.logErrorCause),
  Effect.runFork,
)0.6.6
2 years ago
0.6.5
2 years ago
0.6.4
2 years ago
0.6.3
2 years ago
0.6.2
2 years ago
0.6.1
2 years ago
0.6.0
2 years ago
0.5.8
2 years ago
0.5.7
2 years ago
0.5.6
2 years ago
0.5.5
2 years ago
0.5.4
2 years ago
0.5.3
2 years ago
0.5.2
2 years ago
0.5.1
2 years ago
0.5.0
2 years ago
0.4.5
2 years ago
0.4.4
2 years ago
0.4.3
2 years ago
0.4.2
2 years ago
0.4.1
2 years ago
0.4.0
2 years ago
0.3.7
2 years ago
0.3.6
2 years ago
0.3.5
2 years ago
0.3.4
2 years ago
0.3.3
2 years ago
0.3.2
2 years ago
0.3.1
2 years ago
0.3.0
2 years ago
0.2.2
2 years ago
0.2.1
2 years ago
0.2.0
2 years ago
0.1.7
2 years ago
0.1.6
2 years ago
0.1.5
2 years ago
0.1.4
2 years ago
0.1.3
2 years ago
0.1.2
2 years ago
0.1.1
2 years ago
0.1.0
2 years ago
0.0.1
4 years ago