--- eleventyNavigation: key: RepositoryPermissions title: Repository Permissions parent: Collaborating order: 50 --- When you invite collaborators to join your repository (see [Invite Collaborators](/collaborating/invite-collaborators)) or when you create teams for your organization (see [Create and Manage an Organization](/collaborating/create-organization)), you have to decide what each collaborator/team is allowed to do. You can assign teams different levels of permission for each unit (e.g. issues, PRs, wiki). ## Profile and Visibility The visibility of your repositories will depend on the visibility of your profile, as well as whether you have marked a repository as private. Let's break down what this means: - If your profile's visibility is set to "Limited", _all_ of your non-private repositories will only be visible to logged in users. - If your profile's visibility is set to "Public", _all_ of your non-private repositories will be shown to everyone. - If you do not want anyone (apart from [your fellow collaborators](https://docs.codeberg.org/collaborating/invite-collaborators/)) to see your repositories, mark your repository as "Private". The visibility of your profile can be changed in the [Privacy settings](https://codeberg.org/user/settings). Be careful when you set your profile's visibility to "Limited"; Even if a repository is public, users that are _not logged in_ will get a [404 error](https://en.wikipedia.org/wiki/HTTP_404) if they try to access your repository — it will seem as if it does not exist at all! Privacy Settings in Codeberg's User Settings ## Collaborators There are four permission levels: **Read**, **Write**, **Administrator** and **Owner**. By default, the person who creates a repository is an **_Owner_**. The table below gives an overview of what collaborators are allowed to do when granted each of these permission levels:
Task Read Write Admin Owner
View, clone and pull repository {% fas_icon "check" %} {% fas_icon "check" %} {% fas_icon "check" %} {% fas_icon "check" %}
Contribute pull requests {% fas_icon "check" %} {% fas_icon "check" %} {% fas_icon "check" %} {% fas_icon "check" %}
Push to/update contributed pull requests {% fas_icon "check" %} {% fas_icon "check" %} {% fas_icon "check" %} {% fas_icon "check" %}
Push directly to repository {% fas_icon "times" %} {% fas_icon "check" %} {% fas_icon "check" %} {% fas_icon "check" %}
Merge pull requests {% fas_icon "times" %} {% fas_icon "check" %} {% fas_icon "check" %} {% fas_icon "check" %}
Moderate/delete issues and comments {% fas_icon "times" %} {% fas_icon "check" %} {% fas_icon "check" %} {% fas_icon "check" %}
Force-push/rewrite history (if enabled) {% fas_icon "times" %} {% fas_icon "check" %} {% fas_icon "check" %} {% fas_icon "check" %}
Add/remove collaborators to repository {% fas_icon "times" %} {% fas_icon "times" %} {% fas_icon "check" %} {% fas_icon "check" %}
Configure branch settings (protect/unprotect, enable force-push) {% fas_icon "times" %} {% fas_icon "times" %} {% fas_icon "check" %} {% fas_icon "check" %}
Configure repository settings (enable wiki, issues, PRs, update profile) {% fas_icon "times" %} {% fas_icon "times" %} {% fas_icon "check" %} {% fas_icon "check" %}
Configure repository settings in the danger zone (transfer ownership, delete wiki data / repository, archive repository) {% fas_icon "times" %} {% fas_icon "times" %} {% fas_icon "times" %} {% fas_icon "check" %}
## Teams The permissions for teams are quite configurable. You can specify which repositories a team has access to; therefore, you can specify for each unit (Code Access, Issues, Releases) a different permission level. Each unit is configured to have one of these 3 permission levels: - No Access: Members cannot view or take any other action on this unit. - Read: Members can view the unit, and do standard actions for that unit (See the Read column under [Collaborators](#collaborators)). - Write: Members can view the unit, and execute write actions that unit (See the Write column under [Collaborators](#collaborators)). When a team is configured to have administrator access, when this is specified, you cannot change units. The team will have admin permissions (See the Admin column under [Collaborators](#collaborators)). Currently, there are six units that can be configured: - Code: access source code, files, commits, and branches. - Issues: organize bug reports, tasks, and milestones. - Pull Requests: access pull requests, and code reviews. - Releases: track the project versions and downloads. - Wiki: access and write documentation. - Projects: access and manage issues and pull requests in project boards. There are also two units which can be toggled: - External Wiki: access to external wiki. - External Issues: access to the external issue tracker. A team can be given the permission to create new repositories. When a member of such team creates a new repository, they will get administrator access to the repository.