An Op to simplify an opinionated GitLab workflow.
Please note that this Op was built with SDK 1 and therefore is currently limited to CLI compatibility.
If you would like to interact with GitLab in Slack, please contact us in our community and we can help you.
To run this or any other Op, install the Ops Platform.
Find information about how to run and build Ops via the Ops Platform Documentation
This Op also requires an access token to interact with GitLab. Find the steps to create the access token at https://docs.gitlab.com/ee/user/profile/personal_access_tokens.html. Be sure to grant all scopes so the Op has it's full capability.
- Copy the access token and provide it when prompted the first time the Op runs.
The Op's default API URL is configured to
gitlab.com. If you have a self-hosted instance of GitLab and wish to change the API URL, you can do so by setting the environment variable
GPG Key Signing
GPG signing for your commits can also be enabled. Provided that you already have a valid key added and configured be used with GitLab. Setup GPG signing with the following steps:
- Run this command in a bash terminal. Input your passphrase when prompted to copy your GPG key to your clipboard.
gpg -a --export-secret-keys <fingerprint> | cat -e | sed 's/\$/\\n/g' | pbcopy
- Add the GPG key as an environment variable
- Add the GPG key's corresponding passphrase as an environment variable
ops run gitlab, gives you a list of available commands to get you started.
To develop and run ops locally:
- Clone the repo
git clone <git URL>
cdinto the directory and install dependancies with
- Build the Op
ops build path/to/op
- Run the Op from your local source code with
ops run path/to/op
All the commands start with
ops run gitlab. From there, you would use the following commands to manage your GitLab flow.
Initializes a new git repository in the current working directory and pushes to the user's selected Group or personal GitLab namespace.
Clones a remote project that you are a member of on to your current working directory.
Creates a new issue in GitLab. Current working directory must be a project either cloned or created using the project:create or project:clone commands.
Lists all the issues the user has access to. If the current working directory is a project in GitLab then the issues are scope by the project otherwise it displays all issues that you are assigned to or created by you etc.
Searches all issues in GitLab for your current working directory by selected filters.
Lists all issues in GitLab for your current working directory. Selecting a issue will checkout a branch for that issue and set the upstream in GitLab.
Adds all unstaged changes, commits and pushes to GitLab for the current working branch.
Converts the current working issue into a merge-request and allows you to assign reviewers.
Lists all the open merge requests for a given project. The current working directory has to be a project.
Allows you to create a new project or group label.
Allows you to edit an existing project or group label.
Allows you to remove a project or group label.
Allows you to sync up labels from one base project to any other project(s) that you have access to. The Op will check for any missing labels in the targeted project(s) and add in as necessary.
Allows you to update your GitLab access token.