bezeichner

command module
v1.201.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Nov 8, 2024 License: MIT Imports: 3 Imported by: 0

README

CircleCI codecov Go Report Card Go Reference

Bezeichner

Bezeichner takes care of identifiers used in your services.

Background

Identifiers are used everywhere and very important. There are many ways to generate one and we take inspiration from the following design.

We don't have a preferred method. We just want to provide you with the best option.

Why a service?

Lot's of distributed systems need global unique IDs. Since you are more than likely going to use microservices we don't need to reinvent the wheel for every language you use. Just use the service!

Server

The server is defined by the following proto contract. So each version of the service will have a new contract.

Generator

This system allows you to configure an application with a generator.

To configure we just need the have the following configuration:

generator:
  applications:
    - name: uuid
      kind: uuid
      prefix: prefix
      suffix: suffix
      separator: "-"
    - name: ksuid
      kind: ksuid
      prefix: prefix
      suffix: suffix
      separator: "-"
    - name: ulid
      kind: ulid
      prefix: prefix
      suffix: suffix
      separator: "-"
    - name: xid
      kind: xid
      prefix: prefix
      suffix: suffix
      separator: "-"
    - name: snowflake
      kind: snowflake
      prefix: prefix
      suffix: suffix
      separator: "-"
    - name: nanoid
      kind: nanoid
      prefix: prefix
      suffix: suffix
      separator: "-"
    - name: typeid
      kind: typeid
      prefix: prefix
      suffix: suffix
      separator: "-"
    - name: pg
      kind: pg
      prefix: prefix
      suffix: suffix
      separator: "-"
    - name: redis
      kind: redis
      prefix: prefix
      suffix: suffix
      separator: "-"

Each generator has the following properties:

  • A distinct name.
  • The kind of generator (uuid, ksuid, ulid, xid, snowflake, nanoid, typeid, pg, redis).
  • The prefix of the identifier.
  • The suffix of the identifier.
  • The separator used between the prefix and suffix.
Postgres

The postgres kind expects a sequence named after the application. The service does not create one. So you would need to use a migration service.

Redis

The redis kind expects a value named after the application. If it does not exist, the system will create one.

Mapper

The system allows you to map to different identifiers. This allows you to deal with legacy identifiers.

To configure we just need the have the following configuration:

mapper:
  identifiers:
    req1: resp1
    req2: resp2
Health

The system defines a way to monitor all of it's dependencies.

To configure we just need the have the following configuration:

health:
  duration: 1s (how often to check)
  timeout: 1s (when we should timeout the check)
Deployment

Since we are advocating building microservices, you would normally use a container orchestration system and have a global service or shard these services per bounded context.

Design

The service uses the awesome work of others. You can check out:

Dependencies

Dependencies

Client

The client can be used in other projects. This is configured as follows:

client:
  v1:
    host: server_host
    timeout: 1s
Dependencies

Dependencies

Development

If you would like to contribute, here is how you can get started.

Structure

The project follows the structure in golang-standards/project-layout.

Dependencies

Please make sure that you have the following installed:

Style

This project favours the Uber Go Style Guide

Setup

The get yourself setup, please run the following:

make setup
Binaries

To make sure everything compiles for the app, please run the following:

make build-test
Features

To run all the features, please run the following:

make features
Changes

To see what has changed, please have a look at CHANGELOG.md

Documentation

The Go Gopher

There is no documentation for this package.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL