Skip to content

Latest commit

 

History

History
264 lines (211 loc) · 5.54 KB

README.md

File metadata and controls

264 lines (211 loc) · 5.54 KB

db2jsonschema

test golangci shellcheck

A utility for generating JSON Schema definitions from database tables.

Installation

Head to the releases page to download binaries for your system.

Check the DockerHub page to make use of db2jsonschema as a docker image.

Usage

db2jsonschema can be used as a standalone command line application or imported as a library in another golang package.

Command Line

By default the db2jsonschema command will return a single document containing all of the table definitions.

db2jsonschema --driver sqlite3 --dburl ./exotic_birds.db
{
  "$schema": "https://json-schema.org/draft/2020-12/schema",
  "$id": "definitions.json",
  "title": "Definitions",
  "definitions": {
    "birds": {
      "created_at": {
        "name": "created_at",
        "type": "string",
        "format": "date-time"
      },
      "deleted_at": {
        "name": "deleted_at",
        "type": "string",
        "format": "date-time"
      },
      "id": {
        "name": "id",
        "type": "number"
      },
      "genus": {
        "name": "genus",
        "type": "string"
      },
      "species": {
        "name": "species",
        "type": "string"
      },
      "updated_at": {
        "name": "updated_at",
        "type": "string",
        "format": "date-time"
      }
    }
  }
}

You can save the schema to a file by piping standard out to the desired location.

db2jsonschema --driver sqlite3 --dburl ./exotic_birds.db > birds.json

The output format can be changed to yaml by passing the --format option.

db2jsonschema --driver sqlite3 --dburl ./exotic_birds.db --format yaml
$schema: https://json-schema.org/draft/2020-12/schema
$id: birds.yaml
title: Definitions
definitions:
  birds:
    created_at:
      name: created_at
      type: string
      format: date-time
    deleted_at:
      name: deleted_at
      type: string
      format: date-time
    id:
      name: id
      type: number
    genus:
      name: genus
      type: string
    species:
      name: species
      type: string
    updated_at:
      name: updated_at
      type: string
      format: date-time

Instead of outputting a single document to standard out it is also possible to write each schema file to a directory by passing the --outdir option.

db2jsonschema --driver sqlite3 --dburl ./exotic_birds.db --outdir ./schemas

This can also be combined with the --format option.

db2jsonschema \
  --driver sqlite3 \
  --dburl ./exotic_birds.db \
  --format yaml \
  --outdir ./schemas

There are also --include and --exclude flags available to control which tables will be used for schema generation.

db2jsonschema \
  --driver sqlite3 \
  --dburl ./exotic_birds.db \
  --include birds
  --format yaml \
  --outdir ./schemas

To pass in multiple --include or --exclude values either provide a comma separated list or use multiple flags, one for each value.

db2jsonschema \
  --driver sqlite3 \
  --dburl ./exotic_birds.db \
  --exclude locations,bird_watchers \
  --format yaml \
  --outdir ./schemas
db2jsonschema \
  --driver sqlite3 \
  --dburl ./exotic_birds.db \
  --exclude locations \
  --exclude bird_watchers \
  --format yaml \
  --outdir ./schemas

The --schematype and --idtemplate options are available to modify the $schema and $id values added to each schema.

--idtemplate is a template string which passes in values for Name and Format. These values can be used or ignored as necessary.

db2jsonschema \
  --driver sqlite3 \
  --dburl ./exotic_birds.db \
  --schematype https://json-schema.org/draft/2020-12/schema \
  --idtemplate https://example.com/schemas/{{ .Name }}.{{ .Format }} \
  --format yaml \
  --outdir ./schemas

Library

Here is an example of importing db2jsonschema as a library and its basic usage.

package main

import (
    "fmt"
	"github.com/tgallant/db2jsonschema"
)

func main() {
  request := &db2jsonschema.Request{
      Driver:     "sqlite3",
      DataSource: "./test.db",
      Format:     "yaml",
      Outdir:     "./schemas",
  }
  err := request.Perform()
  if err != nil {
      fmt.Println(err)
  }
}

Drivers

There are drivers for connecting to different database backends.

  • SQLite
  • MySQL
  • PostgreSQL(WIP)

Contributing

Build

To build a binary do the following.

make build

To build and run a command do the following.

./run.sh --driver sqlite3 --dburl ./test.db --format yaml

Test

To run the tests do the following.

make test

To run all of the checks do the following.

make test_all

To run all of the checks inside of a containerized linux environment do the following.

make ci

To run all of the github actions locally do the following (requires https://github.com/nektos/act).

make actions

To start a local MySQL server run the following.

make mysql

To make a new release perform the following (requires https://docs.npmjs.com/cli/v6/using-npm/semver).

# possible options for SEMVER are:
# major, minor, patch, premajor, preminor, prepatch, or prerelease
make release SEMVER=patch