Skip to content

Commit 025bd60

Browse files
sophiethekinggithub-actionsisaacmbrown
authored
Ruleset management [Public Beta] (#42101)
Co-authored-by: github-actions <[email protected]> Co-authored-by: Isaac Brown <[email protected]>
1 parent 6ff61c7 commit 025bd60

13 files changed

+86
-0
lines changed
Loading
Loading
Loading

content/organizations/managing-organization-settings/creating-rulesets-for-repositories-in-your-organization.md

+6
Original file line numberDiff line numberDiff line change
@@ -17,6 +17,12 @@ When you create a ruleset for an organization, you use `fnmatch` syntax to defin
1717

1818
Forks do not inherit rulesets from their upstream repositories. However, forks owned by your organization are subject to the rulesets you create, like any other repository.
1919

20+
{% ifversion repo-rules-management %}
21+
22+
{% data reusables.repositories.import-a-ruleset-conceptual %} For more information, see "[AUTOTITLE](/organizations/managing-organization-settings/managing-rulesets-for-repositories-in-your-organization#using-ruleset-history)."
23+
24+
{% endif %}
25+
2026
To create a ruleset, complete the following procedures:
2127

2228
- [Creating a branch or tag ruleset](#creating-a-branch-or-tag-ruleset)

content/organizations/managing-organization-settings/managing-rulesets-for-repositories-in-your-organization.md

+25
Original file line numberDiff line numberDiff line change
@@ -35,6 +35,30 @@ You can use the REST and GraphQL APIs to manage rulesets. For more information,
3535
{% data reusables.organizations.access-ruleset-settings %}
3636
{% data reusables.repositories.delete-ruleset-steps %}
3737

38+
{% ifversion repo-rules-management %}
39+
40+
## Using ruleset history
41+
42+
{% data reusables.repositories.ruleset-beta-note %}
43+
44+
{% data reusables.repositories.ruleset-history-conceptual %}
45+
46+
{% data reusables.profile.access_org %}
47+
{% data reusables.profile.org_settings %}
48+
{% data reusables.organizations.access-ruleset-settings %}
49+
{% data reusables.repositories.ruleset-history %}
50+
51+
### Importing a ruleset
52+
53+
You can import a ruleset from another repository or organization using the exported JSON file from the previous section. This can be useful if you want to apply the same ruleset to multiple repositories or organizations.
54+
55+
{% data reusables.profile.access_org %}
56+
{% data reusables.profile.org_settings %}
57+
{% data reusables.organizations.access-ruleset-settings %}
58+
{% data reusables.repositories.import-a-ruleset %}
59+
60+
{% endif %}
61+
3862
## Viewing insights for rulesets
3963

4064
You can view insights for rulesets to see how rulesets are affecting the repositories in your organization. {% data reusables.repositories.about-ruleset-insights %}
@@ -44,5 +68,6 @@ You can view insights for rulesets to see how rulesets are affecting the reposit
4468
1. In the left sidebar, in the "Code, planning, and automation" section, click **{% octicon "repo" aria-hidden="true" %} Repository**, then click **Repository rule insights**.
4569

4670
![Screenshot of an organization's settings page. In the sidebar, a link labeled "Repository rule insights" is outlined in orange.](/assets/images/help/organizations/repository-rule-insights.png)
71+
4772
1. On the "Rule Insights" page, use the dropdown menus at the top of the page to filter the actions by ruleset, repository, actor, and time period.
4873
{% data reusables.repositories.rulesets-view-rule-runs %}

content/repositories/configuring-branches-and-merges-in-your-repository/managing-rulesets/creating-rulesets-for-a-repository.md

+3
Original file line numberDiff line numberDiff line change
@@ -14,6 +14,9 @@ shortTitle: Create a ruleset
1414

1515
You can create rulesets to control how users can interact with selected branches and tags in a repository. When you create a ruleset, you can allow certain users to bypass the rules in the ruleset. This can be users with certain permissions, specific teams, or {% data variables.product.prodname_github_apps %}. For more information on rulesets, see "[AUTOTITLE](/repositories/configuring-branches-and-merges-in-your-repository/managing-rulesets/about-rulesets)."
1616

17+
{% ifversion repo-rules-management %}
18+
{% data reusables.repositories.import-a-ruleset-conceptual %} For more information, see "[AUTOTITLE](/organizations/managing-organization-settings/managing-rulesets-for-repositories-in-your-organization#using-ruleset-history)."{% endif %}
19+
1720
{% ifversion repo-rules-enterprise %}
1821
You can also create rulesets for all repositories in an organization. For more information, see "[AUTOTITLE](/organizations/managing-organization-settings/creating-rulesets-for-repositories-in-your-organization)."{% endif %}
1922

content/repositories/configuring-branches-and-merges-in-your-repository/managing-rulesets/managing-rulesets-for-a-repository.md

+24
Original file line numberDiff line numberDiff line change
@@ -62,6 +62,30 @@ Anyone with read access to a repository can view the rulesets targeting the repo
6262
{% data reusables.repositories.repo-rulesets-settings %}
6363
{% data reusables.repositories.delete-ruleset-steps %}
6464

65+
{% ifversion repo-rules-management %}
66+
67+
## Using ruleset history
68+
69+
{% data reusables.repositories.ruleset-beta-note %}
70+
71+
{% data reusables.repositories.ruleset-history-conceptual %}
72+
73+
{% data reusables.repositories.navigate-to-repo %}
74+
{% data reusables.repositories.sidebar-settings %}
75+
{% data reusables.repositories.repo-rulesets-settings %}
76+
{% data reusables.repositories.ruleset-history %}
77+
78+
### Importing a ruleset
79+
80+
{% data reusables.repositories.import-a-ruleset-conceptual %}
81+
82+
{% data reusables.repositories.navigate-to-repo %}
83+
{% data reusables.repositories.sidebar-settings %}
84+
{% data reusables.repositories.repo-rulesets-settings %}
85+
{% data reusables.repositories.import-a-ruleset %}
86+
87+
{% endif %}
88+
6589
{% ifversion repo-rules-enterprise %}
6690

6791
## Viewing insights for rulesets
+5
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,5 @@
1+
# Reference: #11915
2+
# Ruleset management public beta
3+
versions:
4+
ghec: '*'
5+
ghes: '>=3.12'
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
You can import a ruleset from another repository or organization using a JSON file. This can be useful if you want to apply the same ruleset to multiple repositories or organizations.
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,6 @@
1+
1. Select the **New ruleset** dropdown, then click **Import a ruleset**.
2+
3+
![Screenshot of the page for repository rulesets. A dropdown menu labeled "New ruleset" is expanded and the "Import a ruleset" option is highlighted with an orange outline.](/assets/images/help/repository/import-a-ruleset.png)
4+
5+
1. Open the exported JSON file.
6+
1. Review the imported ruleset and click **Create**.
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,8 @@
1+
{% note %}
2+
3+
**Notes:**
4+
5+
- Ruleset history is currently in public beta and subject to change.
6+
- Only changes made to a ruleset after the public beta release, on October 11, 2023, are included in the ruleset history.
7+
8+
{% endnote %}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
You can view all the changes to a ruleset and revert back to a specific iteration. You can also download a JSON file containing the ruleset's configuration at a specific iteration. The bypass list of a ruleset is excluded from the exported JSON file.
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,7 @@
1+
1. To view the history of changes to the ruleset, select {% octicon "kebab-horizontal" aria-label="Open additional options" %} to the right of the ruleset's name, then click **{% octicon "history" aria-hidden="true" %} History**.
2+
3+
![Screenshot of the page for repository rulesets. Below a button labeled with three dots, an option labeled "History" is outlined in orange.](/assets/images/help/repository/ruleset-history.png)
4+
5+
1. To the right of the specific iteration, select {% octicon "kebab-horizontal" aria-label="Open additional options" %}, then click **Compare changes**, **Restore**, or **Download**.
6+
7+
![Screenshot of the page for repository rulesets history. A dropdown menu labeled with three dots is expanded and highlighted with an orange outline.](/assets/images/help/repository/ruleset-history-options.png)

0 commit comments

Comments
 (0)