A build tool with transparent logs and metadata tied to each build.
The only build tool that allows you to pass in a repo and build your project, while getting extensive metadata tied to your shippable product. There's no need to frantically track down build info if something goes wrong. Know who built it, in what directory, on what machine, at what time. Never not know again.
Run builder init [repo url]
on a project (must be a compatible language). This creates a new project with a hidden, logs, workspace, and artifact dir.
For compatible compiled languages (C#, Golang, Java) a builder.yaml file gets created (see below for more info) in the workspace dir. For interpreted languages (Javascript, Python, Ruby) it's created in the temp dir.
For compiled, the artifact dir contains an executable file, both json and yaml metadata, and a zip of those contents. That zip can be sent off wherever by specifing the "--output" path flag.
You can then cd into the path of your builder.yaml and run the builder
command. This will pull any changes from the repo and create a new artifact (meaning a shippable product, either zip or executable) with new metadata.
IF you know your project has a specific buildFile name or you would like to use your own buildCommand, etc, you can attach a builder.yaml to your project and run builder config [repo url]
instead of init. This config command allows for an extra layer of custom parameters and will use your builder.yaml instead of creating one.
Important to note: at this time, if you create your own builder.yaml and initialize a project with config, you should include all of the builder parameters (even if they are empty) in order for the builder
command to work properly. This will be address in the next version.
Builder is great at guessing what to do with most repos it's given, for the other case, you need to initialize your project by placing a user defined builder.yaml in your repo and running the config
command.
builder init
: auto default build a project (creates packaged artifact) with metadata and logs, creates default builder.yaml- only necessary argument is a github repo url
builder config
: user defined (user created builder.yaml) project build that creates artifact with metadata and logs- only necessary argument is a github repo url
builder
: user cds into a project path with a builder.yaml, it then pulls changes, creates new artifact and new metadata- no arguments accepted at this time
- if you would like the new artifact sent to a specified dir, make sure your output path is specified in the builder.yaml
- '--help' or '-h': provide info for Builder
- '--output' or '-o': user defined output path for artifact
- '--name' or '-n': user defined project name
- '--yes' or '-y': bypass prompts
- '--branch' or '-b': specify repo branch
You must have the language or package manager previously installed in order to build specified project.
- Golang
- Uses
go build main.go
as default command. - Uses
main.go
as entry point to project by default. - If your main package has a different name than main.go you need to create a builder.yaml within your repo, specify the buildfile, and run the
config
command.
- Uses
- Node
- Uses
npm install
as default command - Must have package.json in order to install dependencies by default.
- Uses
- Java
- Uses
mvn clean install
as default command. - Must have pom.xml as default buildfile.
- Uses
- C#
- Uses
dotnet build [file path]
as default command.
- Uses
- Python
- Uses
pip3 install -r requirements.txt -t [path/requirements]
as default command. - As of now, a requirements.txt is necessary to build default python projects.
- Uses
- Ruby
- Uses
bundle install --path vendor/bundle
as default command.
- Uses
To use other buildtools, buildcommands, or custome buildfiles you must create builder.yaml and run config
.
If you are specifying a buildfile, buildtool, or buildcmd within the builder.yaml, you MUST include the projectType.
At this point in time, please include ALL builder.yaml parameters (all keys must be lowercase), even if they are empty. (This will be addressed in the next update)
- projectpath: provide path for project to be built
- ("C:/Users/Name/Projects", etc)
- projecttype: provide language/framework being used
- (Node, Java, Go, Ruby, Python, C#, Ruby)
- buildtool: provide tool used to install dependencies/build project
- (maven, npm, bundler, pipenv, etc)
- buildfile: provide file name needed to install dep/build project
- Can be any user specified file. (myCoolProject.go, package.json etc)
- buildcmd: provide full command to build/compile project
- ("npm install --silent", "mvn -o package", anything not provided by the Builder as a default)
- outputpath: provide path for artifact to be sent
- ("C:/Users/Name/Artifacts", etc)
- "BUILDER_PARENT_DIR": parent dir path
- "BUILDER_HIDDEN_DIR": hidden dir path
- "BUILDER_LOGS_DIR": logs dir path
- "BUILDER_COMMAND": bool if builder cmd is running
- "BUILDER_DIR_PATH": user defined parent dir path for specific build
- "BUILDER_PROJECT_TYPE": user defined project type (go, java, etc)
- "BUILDER_BUILD_TOOL": user defined build tool (maven, gradle, npm, yarn, etc)
- "BUILDER_BUILD_FILE": user defined build file (myCoolProject.go)
- "BUILDER_BUILD_COMMAND": user defined build commmand (yarn install)
- "BUILDER_OUTPUT_PATH": user defined output path for artifact
- check for either 'init' or 'config' command
- checks arguments passed into the cli exec call
- call GetRepoURL
- check for '--help or -h' flag
- if no repo, exit
- if repo exists, check to ls-remote to see if it's a real git repo
- check for '--output or -o' flag (artifact/output path)
- set 'BUILDER_OUTPUT_PATH' (either "" or user defined path)
- call GetName (checks for '-n' flag, assigns dir name to name var)
- create 'configPath'var based on 'BUILDER_PATH_DIR' env var (established in a builder.yaml)
- create 'path' var either locally or with configPath + name + timestamp
- call MakeParentDir:
- check if path already exists
- check for '-y' flag to bypassPrompt
- make entire parentDir path
- set 'BUILDER_PARENT_DIR' env var
- call MakeHiddenDir:
- create hiddenPath var (parentDir + './hidden')
- check if path already exists
- make entire hiddenDir path
- set 'BUILDER_HIDDEN_DIR' env var
- call MakeLogDir:
- create logPath var (parentDir + '/logs')
- check if path already exists
- make entire logDir path
- set 'BUILDER_LOGS_DIR' env var
- call CreateLogs:
- grab parentDir to create logs.txt name
- create logs.txt in logs dir
- create InfoLogger, WarningLogger, ErrorLogger vars to be used throughout
- Logs.txt created HERE
- call MakeWorkspaceDir:
- create workPath var (parentDir + '/workspace')
- check if path already exists
- make entire wokspaceDir path
- set 'BUILDER_WORKSPACE_DIR' env var
- call GetRepoURL:
- check for repo after 'init' or 'config'
- return repo string
- check "BUILDER_HIDDEN_DIR', if "", clone into tempRepo dir (used for 'config')
- clone repo into hiddenDir
- check "BUILDER_PROJECT_TYPE", if exists call ConfigDerive:
- check "BUILDER_BUILD_FILE", if exists, return user specified build file/files
- checks env var, returns []string containing languages default build file/files
- set files []string to builder.yaml val or default
- cycle through hidden dir to find the project type
- if file path for one of the project types exists, compile project
- GO -->
- copy contents of hidden into workspace dir
- compile.Go:
- check "BUILDER_BUILD_TOOL" if exists, run that build tool, else run default
- run 'go build' (default) in workspace path
- if "BUILDER_OUTPUT_PATH" exists, copy artifact to that path
- JAVA -->
- copy contents of hidden into workspace dir
- compile.Java:
- check "BUILDER_BUILD_TOOL" if exists, run that build tool, else run default
- run 'mvn clean install' (default) in workspace path
- if "BUILDER_OUTPUT_PATH" exists, copy artifact to that path
- NPM -->
- compile.Npm:
- create temp directory inside workspace dir
- copy hidden dir contents (repo) into temp dir
- check "BUILDER_BUILD_TOOL" if exists, run that build tool, else run default
- run 'npm install' (default) in temp dir path
- create temp.zip dir
- recursively add files from temp dir to temp.zip
- if "BUILDER_OUTPUT_PATH" exists, copy artifact (zip file in this case) to that path
- compile.Npm:
- create a yaml & json inside parent dir with:
- UserName
- HomeDir
- IP
- Timestamp
- GitHash
6. MakeHidden:
- give hidden dir the hidden attrib
- make hidden dir read-only
- create globalLogs dir and .txt if it doesn't exists
- copy current builds logs.txt contents into globalLogs.txt
- checks arguments passed into the cli exec call
- call GetRepoURL
- check for '--help or -h' flag
- if no repo, exit
- if repo exists, check to ls-remote to see if it's a real git repo
- check for '--output or -o' flag (artifact/output path)
- set 'BUILDER_OUTPUT_PATH' (either "" or user defined path)
This instance is to clone the repo in tempRepo dir to get builder.yaml info
- call GetRepoURL:
- check for repo after 'init' or 'config'
- return repo string
- check "BUILDER_HIDDEN_DIR', if "", clone into tempRepo dir (used for 'config')
- clone repo into hiddenDir
- create a map[string] interface{} to dump yaml info into
- read builder.yaml in the tempRepo dir
- unpack the yaml file into the map int{}
- pass the map int{} into ConfigEvens:
- check for specific keys in map and create env vars based on value
- check "projectType" and create 'BUILDER_PROJECT_TYPE' env var
- check "buildTool" and create 'BUILDER_BUILD_TOOL' env var
- check "buildFile" and create 'BUILDER_BUILD_FILE' env var
- check "path" (this is parent dir path) and create 'BUILDER_DIR_PATH' env var
- delete tempRepo dir