2020-06-23 00:09:42 +05:30
---
type: reference, howto
stage: Manage
group: Import
2021-02-22 17:27:13 +05:30
info: To determine the technical writer assigned to the Stage/Group associated with this page, see https://about.gitlab.com/handbook/engineering/ux/technical-writing/#assignments
2020-06-23 00:09:42 +05:30
---
2022-04-04 11:22:00 +05:30
# Import your project from Bitbucket Server **(FREE)**
2018-11-18 11:00:15 +05:30
2020-04-22 19:07:51 +05:30
> [Introduced](https://gitlab.com/gitlab-org/gitlab-foss/-/merge_requests/20164) in GitLab 11.2.
2018-11-18 11:00:15 +05:30
2021-02-22 17:27:13 +05:30
NOTE:
2022-04-04 11:22:00 +05:30
This process is different than [importing from Bitbucket Cloud ](bitbucket.md ).
2018-11-18 11:00:15 +05:30
2022-04-04 11:22:00 +05:30
From Bitbucket Server, you can import:
2018-11-18 11:00:15 +05:30
2022-04-04 11:22:00 +05:30
- Repository description
- Git repository data
- Pull requests
- Pull request comments
2021-06-08 01:23:25 +05:30
When importing, repository public access is retained. If a repository is private in Bitbucket, it's
created as private in GitLab as well.
2018-11-18 11:00:15 +05:30
2022-04-04 11:22:00 +05:30
## Import your Bitbucket repositories
2018-11-18 11:00:15 +05:30
2022-04-04 11:22:00 +05:30
Prerequisites:
2018-11-18 11:00:15 +05:30
2022-04-04 11:22:00 +05:30
- An administrator must have enabled the **Bitbucket Server** in
**Admin > Settings > General > Visibility and access controls > Import sources** .
- Review the importer's [limitations ](#limitations ).
2018-11-18 11:00:15 +05:30
2022-04-04 11:22:00 +05:30
To import your Bitbucket repositories:
2018-11-18 11:00:15 +05:30
2022-04-04 11:22:00 +05:30
1. Sign in to GitLab.
1. On the top bar, select **New** (**{plus}**).
1. Select **New project/repository** .
1. Select **Import project** .
1. Select **Bitbucket Server** .
1. Log in to Bitbucket and grant GitLab access to your Bitbucket account.
1. Select the projects to import, or import all projects. You can filter projects by name and select
the namespace for which to import each project.
2018-11-18 11:00:15 +05:30
2022-04-04 11:22:00 +05:30
## Limitations
2018-11-18 11:00:15 +05:30
2022-04-04 11:22:00 +05:30
- GitLab doesn't allow comments on arbitrary lines of code. Any out-of-bounds Bitbucket comments are
inserted as comments in the merge request.
- Bitbucket Server allows multiple threading levels. The importer collapses this into one thread and
quotes part of the original comment.
- Declined pull requests have unreachable commits. This prevents the importer from generating a
proper diff. These pull requests show up as empty changes.
- Project filtering doesn't support fuzzy search. Only starts with or full match strings are
supported.
2018-11-18 11:00:15 +05:30
2022-04-04 11:22:00 +05:30
The following aren't imported:
2018-11-18 11:00:15 +05:30
2022-04-04 11:22:00 +05:30
- Pull request approvals
- Attachments in Markdown
- Task lists
- Emoji reactions
2020-11-24 15:15:51 +05:30
2022-04-04 11:22:00 +05:30
## User assignment
2021-01-03 14:25:43 +05:30
2022-04-04 11:22:00 +05:30
When issues and pull requests are importing, the importer tries to find the author's email address
with a confirmed email address in the GitLab user database. If no such user is available, the
project creator is set as the author. The importer appends a note in the comment to mark the
original creator.
2021-01-03 14:25:43 +05:30
2022-04-04 11:22:00 +05:30
The importer creates any new namespaces (groups) if they don't exist. If the namespace is taken, the
repository imports under the namespace of the user who started the import process.
2021-01-03 14:25:43 +05:30
2022-04-04 11:22:00 +05:30
### User assignment by username
2021-01-03 14:25:43 +05:30
2022-04-04 11:22:00 +05:30
> - [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/218609) in GitLab 13.4 [with a flag](../../../administration/feature_flags.md) named `bitbucket_server_user_mapping_by_username`. Disabled by default.
> - Not recommended for production use.
2020-11-24 15:15:51 +05:30
2022-04-04 11:22:00 +05:30
FLAG:
On self-managed GitLab and GitLab.com, by default this feature is not available. To make it
available, ask an administrator to [enable the feature flag ](../../../administration/feature_flags.md )
named `bitbucket_server_user_mapping_by_username` . This feature is not ready for production use.
2021-01-03 14:25:43 +05:30
2022-04-04 11:22:00 +05:30
With this feature enabled, the importer tries to find a user in the GitLab user database with the
author's:
2021-01-03 14:25:43 +05:30
2022-04-04 11:22:00 +05:30
- `username`
- `slug`
- `displayName`
2020-11-24 15:15:51 +05:30
2022-04-04 11:22:00 +05:30
If no user matches these properties, the project creator is set as the author.
2020-11-24 15:15:51 +05:30
2022-04-04 11:22:00 +05:30
## Troubleshooting
2021-01-03 14:25:43 +05:30
2022-04-04 11:22:00 +05:30
### General
2020-11-24 15:15:51 +05:30
2022-04-04 11:22:00 +05:30
If the GUI-based import tool does not work, you can try to:
2018-11-18 11:00:15 +05:30
2022-04-04 11:22:00 +05:30
- Use the [GitLab Import API ](../../../api/import.md#import-repository-from-bitbucket-server )
Bitbucket Server endpoint.
- Set up [repository mirroring ](../repository/mirror/index.md ).
It provides verbose error output.
2018-11-18 11:00:15 +05:30
2022-04-04 11:22:00 +05:30
See the [troubleshooting section ](bitbucket.md#troubleshooting )
for Bitbucket Cloud.
2018-11-18 11:00:15 +05:30
2022-04-04 11:22:00 +05:30
### LFS objects not imported
2018-11-18 11:00:15 +05:30
2022-04-04 11:22:00 +05:30
If the project import completes but LFS objects can't be downloaded or cloned, you may be using a
password or personal access token containing special characters. For more information, see
[this issue ](https://gitlab.com/gitlab-org/gitlab/-/issues/337769 ).
2018-11-18 11:00:15 +05:30
2022-04-04 11:22:00 +05:30
## Related topics
2018-11-18 11:00:15 +05:30
2021-12-11 22:18:48 +05:30
For information on automating user, group, and project import API calls, see
[Automate group and project import ](index.md#automate-group-and-project-import ).