How Open Integrity uses Gitlab?

Gitlab is an open source version of Github. (It's easy to forget that Github is not itself open source, given how much it has done to support the development of open source software). Gitlab has some useful collaboration features, and we're excited about leveraging them in new ways. We've started using it internally to manage our documentation, for example, and even some aspects of project management. In line with the early work we've done with Open Integrity (and the wiki) we're excited to use open source tools to manage our project transparently and collaboratively.

Collaborate only by email if you want!

The key feature in our eyes is the ability to interact with Gitlab using only email. That's a very low barrier to participate in conversations. In fact each and every issue in Gitlab is a small mailing list to which you can subscribe and un-subscribe simply using email back and forth. We can also invite other users to participate in threads with @mention tags in the way Twitter made popular, which makes it a pretty good alternative to traditional mailing lists.

Freely subscribe and unsubscribe to threads that you want to participate in

In addition, issues are fairly flexible so if conversations start going in several different directions, rather than unsubscribing, we can just create a new issue and allow interested participant to choose which topic to continue to follow. We think that the key to fluid collaboration (and collective intelligence) is to properly allow participants to manage their own signal to noise ratio and have focused conversations where everyone is participating and engaged.

Even better, we're using labels extensively to categorise our work and you can subscribe to labels in order to be sure to get alerted when new information is posted about a topic that interests you.

Collaborate on documents

Even fancier, when aiming to work jointly towards a more formal statement, document or specification, Gitlab allows to discuss edits to a document in a way (called pull requests or merge requests) that is in our opinion better than wikis and only missing more real-time features which in our case are less of a priority. As respected others put it:

Pull requests are much easier to work with than most wiki systems. They make it clear that people are notified about changes and contributions are discussed (with line comments) before being committed.

We've also supported the development of a port of Prose to Gitlab and the addition of collaborative features in order to make participation even more noise free (Gitlab is after all a tool for developers and its interface contains a lot of options that are not needed simply to engage in conversations or collaborate on documents and specifications).

Privacy and encryption

If you have any concerns about the privacy of our email-based exchanges, you can login directly to the Gitlab platform via HTTPS. And, of course, if you want to learn more about any of this and how we host this server, please feel free to ask. If you're interested in supporting PGP support for Gitlab get in touch with us.


GitLab Community Edition

GitLab is open source software to collaborate on code.
Manage git repositories with fine-grained access controls that keep your code secure.
Perform code reviews and enhance collaboration with merge requests.
Each project can also have an issue tracker and a wiki.
Used by more than 100,000 organizations, GitLab is the most popular solution to manage git repositories on-premises.
Read more about GitLab at about.gitlab.com.


GitLab Documentation

Welcome to GitLab, a Git-based fully featured platform for software development!

We offer four different products for you and your company:

  • GitLab Community Edition (CE) is an opensource product, self-hosted, free to use. Every feature available in GitLab CE is also available on GitLab Enterprise Edition (Starter and Premium) and GitLab.com.
  • GitLab Enterprise Edition (EE) is an opencore product, self-hosted, fully featured solution of GitLab, available under distinct subscriptions: GitLab Enterprise Edition Starter (EES) and GitLab Enterprise Edition Premium (EEP).
  • GitLab.com: SaaS GitLab solution, with free and paid subscriptions. GitLab.com is hosted by GitLab, Inc., and administrated by GitLab (users don't have access to admin settings).

GitLab EE contains all features available in GitLab CE, plus premium features available in each version: Enterprise Edition Starter (EES) and Enterprise Edition Premium (EEP). Everything available in EES is also available in EEP.


Shortcuts to GitLab's most visited docs:

GitLab CI Other
Quick start guide API
Configuring .gitlab-ci.yml SSH authentication
Using Docker images GitLab Pages

Getting started with GitLab

User account

  • User documentation: Learn how to use GitLab and explore its features
  • User account: Manage your account
    • Authentication: Account security with two-factor authentication, setup your ssh keys and deploy keys for secure access to your projects.
    • Profile settings: Manage your profile settings, two factor authentication and more.
  • User permissions: Learn what each role in a project (external/guest/reporter/developer/master/owner) can do.

Projects and groups

Repository

Manage your repositories from the UI (user interface):

Issues and Merge Requests (MRs)

Git and GitLab

  • Git: Getting started with Git, branching strategies, Git LFS, advanced use.
  • Git cheatsheet: Download a PDF describing the most used Git operations.
  • GitLab Flow: explore the best of Git with the GitLab Flow strategy.
  • Signing commits: use GPG to sign your commits.

Migrate and import your projects from other platforms

Continuous Integration, Delivery, and Deployment

  • GitLab CI: Explore the features and capabilities of Continuous Integration, Continuous Delivery, and Continuous Deployment with GitLab.
    • Auto Deploy: Configure GitLab CI for the deployment of your application.
    • Review Apps: Preview changes to your app right from a merge request.
  • GitLab Cycle Analytics: Cycle Analytics measures the time it takes to go from an idea to production for each project you have.
  • GitLab Container Registry: Learn how to use GitLab's built-in Container Registry.

Automation

  • API: Automate GitLab via a simple and powerful API.
  • GitLab Webhooks: Let GitLab notify you when new code has been pushed to your project.

Integrations

  • Project Services: Integrate a project with external services, such as CI and chat.
  • GitLab Integration: Integrate with multiple third-party services with GitLab to allow external issue trackers and external authentication.
  • Trello Power-Up: Integrate with GitLab's Trello Power-Up

Administrator documentation

Learn how to administer your GitLab instance. Regular users don't have access to GitLab administration tools and settings.

Install, update, upgrade, migrate

  • Install: Requirements, directory structures and installation from source.
  • Mattermost: Integrate Mattermost with your GitLab installation.
  • Migrate GitLab CI to CE/EE: If you have an old GitLab installation (older than 8.0), follow this guide to migrate your existing GitLab CI data to GitLab CE/EE.
  • Restart GitLab: Learn how to restart GitLab and its components.
  • Update: Update guides to upgrade your installation.

User permissions

Features

Integrations

  • Integrations: How to integrate with systems such as JIRA, Redmine, Twitter.
  • Koding: Set up Koding to use with GitLab.
  • Mattermost: Set up GitLab with Mattermost.

Monitoring

Performance

Customization

Admin tools

  • Gitaly: Configuring Gitaly, GitLab's Git repository storage service
  • Raketasks: Backups, maintenance, automatic webhook setup and the importing of projects.
  • Reply by email: Allow users to comment on issues and merge requests by replying to notification emails.
  • Repository checks: Periodic Git repository checks.
  • Repository storage paths: Manage the paths used to store repositories.
  • Security: Learn what you can do to further secure your GitLab instance.
  • System hooks: Notifications when users, projects and keys are changed.

Troubleshooting

Contributor documentation