GoLiGen
Simple license file generator written in GO
Table of Contents
Installation
Download a compiled binary
You can download the current stable version of the project from
https://artifacts.maczukin.pl/goligen/${RELEASE}/index.html
, where
${RELEASE}
is one of:
Release | Description |
---|---|
release_stable |
The current stable version of the project |
release_unstable |
The current unstable version of the project |
vX.Y.Z |
The vX.Y.Z version of the project, eg. v0.1.0 |
branch/name |
Version from the branch/name branch in git tree |
Examples:
-
If you want to install the latest stable version - whichever it will be at the moment - you can find the download page at: https://artifacts.maczukin.pl/goligen/release_stable/index.html.
To install the binary for Linux OS and amd64 platform:
$ sudo wget -O /usr/local/bin/goligen https://artifacts.maczukin.pl/goligen/release_stable/binaries/goligen-linux-amd64 $ sudo chmod +x /usr/local/bin/goligen
-
If you want to install the
v0.1.0
version, you can find the download pave at: https://artifacts.maczukin.pl/goligen/v0.1.0/index.html.To install the binary for Linux OS and amd64 platform:
$ sudo wget -O /usr/local/bin/goligen https://artifacts.maczukin.pl/goligen/v0.1.0/binaries/goligen-linux-amd64 $ sudo chmod +x /usr/local/bin/goligen
Install from source
Notice: You need to have a configured GO environment for this
To install GoLiGen from sourcec simply execute command:
$ go install gitlab.com/tmaczukin/goligen
This will download current sources and install the binary in your $GOPATH/bin
.
Usage
GoLiGen is a quite simple command line tool. It has two main commands:
list
- to list the available license templatesgenerate
- to generate the license itself
The global options' description you can find by using the help
command:
$ out/binaries/goligen help
(...)
GLOBAL OPTIONS:
--debug Set debug mode [$DEBUG]
--log-level "info" Set log level (options: debug, info, warn, error, fatal, panic) [$LOG_LEVEL]
--help, -h show help
--version, -v print the version
List available license templates
goligen list
To list an available license templates you need to use the list
command. It will output the list of template's IDs on
the standard output:
$ ./goligen list
INFO[0000] Available internal license templates:
INFO[0000] GPL-2.0
INFO[0000] MIT
If you are using user templates then you will see also all available templates from the user's configuration directory:
$ goligen list
INFO[0000] Available internal license templates:
INFO[0000] MIT
INFO[0000] GPL-2.0
INFO[0000] Available user license templates:
INFO[0000] GPL-3.0
Generate the license
goligen generate [command options] [ID]
To generate the license you need to use the generate
command. It will generate the license text and return it on the
standard output.
generate
command requires the ID
argument and at least one date
/name
pair for the copyright:
$ goligen generate -d 2016 -n "Example Inc." MIT
INFO[0000] Generating license: MIT
INFO[0000] Generating to standard output
The MIT License (MIT)
Copyright (c) 2016 Example Inc.
(...)
If you will not provide the ID
and the copyrights
values, then GoLiGen will return an error. Also remember, that
providing copyright
data you need to add a date
/name
pair. If you omit one date
or one name
then an error
will be raised.
$ goligen generate
FATA[0000] You must provide 'license ID' as a first command argument
$ goligen generate MIT
FATA[0000] There must be at least one copyright-date/copyright-name pair
$ goligen generate -d 2016 MIT
FATA[0000] Copyright-date and copyright-name must be added in pairs
If you are using those values often, then consider creating the configuration file.
If you want to save the license into file (instead of standard output) than you can use -o
option. However remember
that GoLiGen will refuse to rewrite the existing file. To force this you should use -f
flag.
Options -d
(for date
) and -n
(for name
) you can use multiple times but always in pairs.
If you want to use a user template then you must also provide the -u
flag.
Full generate
command options list:
$ goligen help generate
NAME:
goligen generate - Generate license
USAGE:
goligen generate [command options] [ID]
OPTIONS:
--copyright-date, -d [--copyright-date option --copyright-date option] Date of copyright owner
--copyright-name, -n [--copyright-name option --copyright-name option] Name of the copyright owner
-o, --output Output file
-f, --force-output Rewrite file if exists
-u, --use-user-template Use user template instead of internal
Default configuration
If you are creating new projects often, and you are using similar data each time, then you may want to not repeat yourself in command line. Instead, you can create a configuration file with default values for the generator.
File needs to be located in your home directory: ~/.goligen/config.toml
. In the configuration file you can set
a default license ID
and as more default copyrights
as you want.
An example of config.toml
file:
default_license_id = "MIT"
[[default_copyrights]]
date = "2016"
name = "Example Inc."
Own license templates
If you want to use some Free/OpenSource license that is not included in GoLiGen, then it is highly recommended to create a Merge Request with a new license template. I would like this software to be usable for the whole FOSS community. But there is a plenty of FOSS-like licenses. I will be adding templates in my free time, but this process may take some time. So help is welcome.
If you want to use a license template that is not present in internal templates list (for example some not added FOSS license, but also your own proprietary license) you may add your own user license template.
For this you need to create a templates directory in the configuration directory: ~/.goligen/templates/
. Inside of the
directory you can add the license template files. Each file must have a name same as the license ID
that you would
like to use. The name must match the regular expression: [A-Za-z0-9\\-\\.+]+$
.
After adding your own license template you will see it on the list:
$ goligen list
INFO[0000] Available internal license templates:
INFO[0000] GPL-2.0
INFO[0000] MIT
INFO[0000] Available user license templates:
INFO[0000] GPL-3.0
You can use the template by adding the -u
flag to the generate
command.
License
This is a free software licensed under MIT license. See LICENSE file.