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.
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 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:
gpg -a --export-secret-keys <fingerprint> | cat -e | sed 's/\$/\\n/g' | pbcopy
ops run gitlab, gives you a list of available commands to get you started.
To develop and run ops locally:
git clone <git URL>
cdinto the directory and install dependancies with
ops build path/to/op
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.