Skip to content

An interface definition tool that follows the single source of truth (SSOT) principle.

License

Notifications You must be signed in to change notification settings

March-mitsuki/selien

Repository files navigation

selien, a ssot interface specification

简体中文

selien = connective(English) + 連携(日本語) + lien(français) + 连接(中文)

ssot, Single source of truth.

A tool for automatically generating type definitions from a single source file. Your great companion for cross-language development.

Inspire by openAPI.

  • What selien does
    • Helps you generate type definitions across languages by writing YAML files according to conventions.
    • Improves the quality of your cross-language code by following the rules of a single trusted source.
  • What selien is not
    • Selien is not a replacement for openAPI or similar tools like gRPC.
    • Selien doesn't handle as many things as openAPI does. It only focuses on generating type definitions, and you are responsible for the other logic.
  • Currently supported languages
    • typescript
    • go

How to use

To explain the syntax, we first need to explain our file structure. Before you start writing your first selien file, you need to specify a directory as the selien-root directory. All type definitions start from here.

For example, if you have an my_project directory as your project root directory, you can create a directory called selien-spec inside it and create YAML files inside that directory. Alternatively, you can continue creating directorys below.

For example:

.
└── my_project # project root
    ├── src/
    │   └── ...your_other_file
    ├── selien-spec/ # selien root
    │   ├── shared.yaml # Type definitions to be directly shared
    │   ├── rest/  # Type definition files for REST API
    │   │   └── api.yaml
    │   └── websocket/ # Type definition files for WebSocket
    │       └── common.yaml
    └── ...your_other_file

Then, you need to create a file named selien.config.yaml in your <project-root> directory and write your settings inside it. If we continue with the directory structure mentioned above:

For more information about selien.config.yaml, see here

spec:
  root: selien-spec
output:
  go:
    mod_name: github.com/March-mitsuki/selien
    mod_root: pckages/go
    output: packages/go/selien_spec
  ts:
    output: packages/ts/selien_spec
  • selien will automatically interpret the paths specified in the directory and keep their structure.
    • For example, when generating TypeScript code with selien, all the types defined in <selien-root>/rest/api.yamlwill be generated into <ts-output>/rest/api.ts.

Now, let's finally look at the syntax. We'll start with a simple example.

# For example, this file exists in <selien-root>/shared.yaml

selien-version: 0.1.0 # First, we need to define the version of selien.
definition: # Each selien file must start with a definition.
  customString: # This is the name of the type. You can define it freely. Selien will automatically capitalize the first letter.
    declaration: type-alias # Currently supports two declarations: type-alias and enum.
    body: # A declaration must have a sibling body.
      type: string # Defines the type of the type. See examples and the supported types below.

Then run the CLI command:

selien gen

Selien will generate the code for the language(s) you defined in selien.config.yaml into the specified directory. For example, based on the settings we defined above, we will get:

// <working-directory>/packages/ts/selien_spec/shared.ts

export type CustomString = string;

and

// <working-directory>/packages/go/selien_spec/shared.go

// Since it's directly under selien_spec, the package is selien_spec.
package selien_spec

type CustomString string

That's it! It's quite simple, isn't it? If you want to learn more about the syntax, you can take a look at the expamle directory

Currently supported types

  • type-alias
    • number
      • go -> int
      • ts -> number
    • string
      • go -> string
      • ts -> string
    • boolean
      • go -> bool
      • ts -> boolean
    • any
      • go -> interface{}
      • ts -> any
    • object
      • go -> struct
      • ts -> type alias object
    • array
      • go -> slice
      • ts -> array
    • number literal
      • go -> int
      • ts -> number literal
    • string literal
      • go -> string
      • ts -> string literal
    • $ref
      • Supports reusing previously defined types. See example
    • $dyn
      • Supports dynamic import. See example
    • union
      • go -> interface{}
      • ts -> union type
    • split
      • Supports separating type definitions for different languages. See example
  • enum
    • go -> a special type and const block, see example
    • ts -> enum

install

As of now (v0.1.x), there are two ways to install Selien onto your host.

  1. (Recommended) Build from the source code.
  2. Download the binary file from GitHub release and add the path yourself. (Not recommended as there may be some codesign issues that could cause errors.)

This guide will only cover how to build from the source code.

Building from the source code:

First, you need to have rust installed. If you haven't done so, please follow the official installation steps, see here

You can check if you've already installed rust by running the command below:

rustup --version

Next, you need to clone this repository and enter the directory:

git clone https://github.com/March-mitsuki/selien.git && cd selien

If you are using Unix-like

Then run the following command to build Selien from the source code. The binary file will be located in the ~/.selien/bin directory after that.

cd packages/core && cargo build --bin selien --release && rm -rf ~/.selien && mkdir -p ~/.selien/bin && mv target/release/selien ~/.selien/bin && echo 'Selien is installed to ~/.selien/bin'

And you can choose to add the 'selien' command to the path, or you can choose not to add it and use it from ~/.selien/bin/selien every time. However, we highly recommend adding it permanently.

If you choose to add it to the path, you may need to use different commands depending on the shell you are using.

  • bash
    • { echo -e "\n# selien"; echo 'export SELIEN_HOME="$HOME/.selien/bin"'; echo 'export PATH="$SELIEN_HOME:$PATH"'; echo -e "# selien end\n" } >> ~/.bashrc && source ~/.bashrc
  • zsh
    • { echo -e "\n# selien"; echo 'export SELIEN_HOME="$HOME/.selien/bin"'; echo 'export PATH="$SELIEN_HOME:$PATH"'; echo -e "# selien end\n" } >> ~/.zshrc && source ~/.zshrc

To test the installation, you can run the following cmd:

selien --version

If you are using Windows

Please run the command below in powershell to build Selien. The binary file will be in the ~/.selien/bin directory thereafter.

cd packages/core; if ($?) { cargo build --bin selien --release }; Remove-Item -Path ~/.selien -Recurse -ErrorAction Ignore; mkdir ~/.selien/bin; if ($?) { mv target/release/selien.exe ~/.selien/bin }; if ($?) { echo 'Selien is installed to ~/.selien/bin' }

And you can choose to add the 'selien' command to the path, or you can choose not to add it and use it from ~/.selien/bin/selien every time. However, we highly recommend adding it permanently.

If you're using Windows, you may need to manually modify your 'Path' variable in a GUI editor. Here's an example of the steps:

  1. Click the Windows button and type 'path' in the search box.
  2. You should see an option called 'Control Panel - Edit the system environment variables.' Click on it.
  3. In the panel that appears, there should be an option at the bottom right called 'Environment Variables.' Click on it.
  4. After clicking, you should see a new panel divided into two sections: the top section is for 'User variables.' Let's modify that section.
  5. In the 'User variables' section, find 'Path' and double-click on it.
  6. Once opened, you should see a series of buttons on the right side. Click on 'Add' and enter %USERPROFILE%\.selien\bin.
  7. Finally, click 'OK' at the bottom right.

Reopen your powershell to test the installation.

selien --version

update

If you build selien from source, update will be very simple.

One, enter your cloned selien git repo, and pull a new version.

cd /path/to/selien && git pull

Two, run the commands used in the install again.

  • Unix-like
    • cd packages/core && cargo build --bin selien --release && rm -rf ~/.selien && mkdir -p ~/.selien/bin && mv target/release/selien ~/.selien/bin && echo 'Selien is installed to ~/.selien/bin'
  • Windows
    • cd packages/core; if ($?) { cargo build --bin selien --release }; Remove-Item -Path ~/.selien -Recurse -ErrorAction Ignore; mkdir ~/.selien/bin; if ($?) { mv target/release/selien.exe ~/.selien/bin }; if ($?) { echo 'Selien is installed to ~/.selien/bin' }

That's it. Now you have a updated selien.

contribution

see contribution

About

An interface definition tool that follows the single source of truth (SSOT) principle.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published