Skip to main content

BC Government organizations in GitHub

BC Gov Private Cloud PaaS product teams use GitHub to host open code and repositories. Using GitHub you can:

  • Share and control code versions
  • Use tools for team and project management
  • Track issues
  • Collaborate with the open-source community
  • Integrate automation tools

The main organization the B.C. government owns in GitHub is bcgov where we store all open-source code developed by B.C. government teams. The bcgov organization includes close to 1000 repositories maintained by the B.C. government developer community.

On this page

Working in the open

The Digital Principles for the Government of B.C. urge product teams to work in the open as outlined in principle five. GitHub is the leading platform for open-source projects. It allows the Province to collaborate with the open-source community to build software, support innovation and save time and money.

Organizations in GitHub

The Province owns several GitHub organizations, which are described below.

bcgov

The bcgov organization contains all public code repositories that hold open-source code or public documents for all B.C. government teams working on the platform, including Platform Services. This organization is public.

  • Most product teams working in the BC Gov Private Cloud PaaS OpenShift platform should use this organization.
  • Any member of the bcgov organization can create repositories and any existing member can invite other users to join the organization.

bcgov-c

The bcgov-c organization stores temporary (up to 12 months), private repositories with closed-source code and private documents. Closed-source projects must be moved to the bcgov organization at the end of the 12 months. This repository is private.

  • Use this repository if you need a temporary location for code while you collect approvals to make the code public. You must commit to making the code public in the future in order to use this repository.
  • Only the Platform Services team can create repositories in this organization. You can ask them to create a repository by submitting a request to Platform Services Team.

Your product team can only have a permanent, private repository in bcgov-c if it is a GitOps repository with ArgoCD manifests. We strongly discourage creating permanent, private repositories in this organization.

bcgov-platform-services

  • Only the Platform Services team can create repositories in this organization.
  • GitHub application integration (for example, SonarCloud testing) needs to be individually enabled for each repository. The Platform Services team approves all third-party application integration in all B.C. government organizations.

Ministry-specific private organizations in GitHub Enterprise

Ministry-specific private organizations must be linked to the B.C. government's Enterprise account (user licenses are required for the members of these organizations).

These organizations permanently store teams' private repositories with closed-sourced code that can't be transitioned to a public repository within 12 months. For more information on creating a private organization linked to the GitHub enterprise account, see GitHub Enterprise user licences in the B.C. government.

  • Product teams that need a permanent location for their closed-source code should use this repository.
  • Each ministry team must purchase their own user licenses to use the organization.
  • Only ministry GitHub administrators can create repositories in this organization. Consult with your ministry's Information Management Branch (IMB) to get in touch with the GitHub administrators.

Diagram of the BC Government GitHub organizations

Security Insights for GitHub Enterprise-linked organizations

The Security Insight feature is available for all organizations linked to the corporate GitHub Enterprise account, as well as branch protection and code owners for private repositories. Branch protection only allows specific people to push to the protected branch. The code owners feature allows automated reviews. For example, if a specific user is a code owner of certain files they are automatically added as PR reviewers and their approval is required before the code can be merged.


Related links: