Branch policies are rules and restrictions that apply to specific branches and tags in a repository. With policies, you can manage changes, implement code reviews, enforce proper naming and conditions for creating branches and tags, and protect branches from accidental commits or direct pushes.
You specify the policy configuration for a particular repository and store it in the .sourcecraft/branches.yaml file. A configuration stored in the main branch, e.g., master or main, applies to the entire repository.
The general policy configuration format in .sourcecraft/branches.yaml is as follows:
target: Protected resource type. This is a required parameter. The possible values are:
default_branch: Main branch, such as master or main.
branch: Branch.
tag: Tag.
matches: Filter or list of filters by protected resource name. This is a required parameter for target: branch and target: tag.
message: Message the user will get when the policy is triggered. This is a required parameter.
rules: Rule or list of rules to apply to the protected resource. This is a required parameter. The possible values are:
prevent_force_push: Prevent rewriting the branch commit history (force push operations).
prevent_non_pr_changes: Prevent direct changes to the branch (push operations); changes must be submitted through pull requests.
prevent_all_changes: Prevent any actions with the branch or tag.
prevent_deletion: Prevent deletion of a branch or tag.
prevent_creation: Prevent creating a branch or tag.
Warning
Support for storing configurations for CI/CD, approval rules, and branch policies in a single .src.ci.yaml file at the repository root will soon be discontinued. Use the separate .sourcecraft/ci.yaml, .sourcecraft/review.yaml, and .sourcecraft/branches.yaml files.
On the Home tab, navigate to Repositories and select a repository.
In the top-right corner, click Clone.
Depending on your connection method, copy the link for cloning the repository.
In the terminal, run this command:
git clone <link_for_cloning_repository>
Go to your cloned repository:
cd <repository_name>
Generate a branch policy configuration file named .sourcecraft/branches.yaml, for example:
branch_protection:policies:## Preventing commit history rewrites, no-PR changes, ## and deletion of the main branch-target:default_branchmessage:"Direct push into main branch is forbidden, create PR first"rules:-prevent_force_push-prevent_non_pr_changes-prevent_deletion## Preventing the creation of branches with names that match filters-target:branchmatches: ["*", "!OO-*/**", "!hotfix/**", "!chore/**", "!release/**"]
message:"Please use proper branch naming"rules:-prevent_creation## Preventing the creation of tags with names that match filters-target:tagmatches:"gitcore-*"message:"Manual tag creation is forbidden, please use Releaser"rules:-prevent_creation
See also the branch policy example in the test-serverless-cube SourceCraft repository.
Add the branch policy configuration file to the git index, commit, and push the changes to the remote branch named main: