Phabricator
Supported on Enterprise plans.
Available via the Web app.
Site admins can associate Git repositories on Phabricator with Sourcegraph so that users can jump to the Phabricator repository from Sourcegraph and use the Phabricator extension and browser extension with Phabricator.
⚠️ NOTE: Sourcegraph support of Phabricator is limited (learn more), and not expected to evolve due to the announced cease of support for Phabricator.
To connect Phabricator to Sourcegraph:
- Go to Site admin > Manage code hosts > Add repositories
- Select Phabricator.
- Configure the connection to Phabricator using the action buttons above the text field, and additional fields can be added using Cmd/Ctrl+Spacefor auto-completion. See the configuration documentation below.
- Press Add repositories.
Repository association
Sourcegraph can provide users with links to various Phabricator pages (for files, commits, branches, etc.) if you add Phabricator as a connection (in Site admin > Manage code hosts).
A Phabricator configuration consists of the following fields:
- urlfield that maps to the url of the Phabricator host
- tokenan optional Conduit API token, which you may generate from the Phabricator web interface. The token is used to fetch the list of repos available on the Phabricator installation
- reposif your Phabricator installation mirrors repositories from a different origin than Sourcegraph, you must specify a list of repository- paths (as displayed on Sourcegraph) and their corresponding Phabricator- callsigns. For example:- [{ path: 'gitolite.example.org/foobar', callsign: 'FOO'}]. Note that the- callsignis case sensitive.
At least one of token and repos should be provided.
For example:
JSON{ // ... "phabricator": [ { "url": "https://phabricator.example.com", "token": "api-abcdefghijklmnop", "repos": [{ "path": "gitolite.example.com/mux", "callsign": "MUX" }] } ] // ... }
See configuration documentation below for more information.
Troubleshooting
If your outbound links to Phabricator are not present or not working, verify your Sourcegraph repository path matches the "normalized" URI output by Phabricator's diffusion.repository.search conduit API.
For example, if you have a repository on Sourcegraph whose URL is https://sourcegraph.example.com/path/to/repo then you should see a URI returned from diffusion.repository.search whose normalized field is path/to/repo. Check this by navigating to $PHABRICATOR_URL/conduit/method/diffusion.repository.search/ and use the "Call Method" form with attachments field set to { "uris": true } and constraints field set to { "callsigns": ["$CALLSIGN_FOR_REPO_ON_SOURCEGRAPH"]}. In the generated output, verify that the first URI has a normalized path equal to path/to/repo.
Native extension
For production usage, we recommend installing the Sourcegraph Phabricator extension for all users (so that each user doesn't need to install the browser extension individually). This involves adding a new extension to the extension directory of your Phabricator instance.
See the phabricator-extension repository for installation instructions and configuration settings.
The Sourcegraph instance's site admin must update the corsOrigin site config property to allow the Phabricator extension to communicate with the Sourcegraph instance. For example:
JSON{ // ... "corsOrigin": "https://my-phabricator.example.com" // ... }
Configuration
admin/code_hosts/phabricator.schema.json
JSON{ "$id": "phabricator.schema.json#", "$schema": "http://json-schema.org/draft-07/schema#", "additionalProperties": false, "allowComments": true, "anyOf": [ { "required": [ "token" ] }, { "required": [ "repos" ] } ], "description": "Configuration for a connection to Phabricator.", "properties": { "gitSSHCipher": { "$ref": "git.schema.json#/definitions/gitSSHCipher", "description": "SSH cipher to use when cloning via SSH. Must be a valid choice from `ssh -Q cipher`." }, "gitSSHCredential": { "$ref": "git.schema.json#/definitions/gitSSHCredential", "description": "SSH keys to use when cloning Git repo." }, "gitURLType": { "default": "http", "description": "The type of Git URLs to use for cloning and fetching Git repositories.", "enum": [ "http", "ssh" ], "type": "string" }, "repos": { "description": "The list of repositories available on Phabricator.", "items": { "additionalProperties": false, "properties": { "callsign": { "description": "The unique Phabricator identifier for the repository, like 'MUX'.", "type": "string" }, "path": { "description": "Display path for the url e.g. gitolite/my/repo", "type": "string" } }, "required": [ "path", "callsign" ], "type": "object" }, "minItems": 1, "type": "array" }, "token": { "description": "API token for the Phabricator instance.", "minLength": 1, "type": "string" }, "url": { "description": "URL of a Phabricator instance, such as https://phabricator.example.com", "examples": [ "https://phabricator.example.com" ], "type": "string" } }, "title": "PhabricatorConnection", "type": "object" }
Configuration Notes
- Limited Support: Phabricator support is limited and not expected to evolve due to Phabricator's end-of-life announcement.
- Token vs Repos: At least one of tokenorreposmust be provided. Usetokenfor automatic discovery orreposfor manual mapping.
- Case-Sensitive Callsigns: Repository callsigns are case-sensitive and must match exactly as configured in Phabricator.
- Repository Association: Sourcegraph creates links to Phabricator pages but doesn't sync the actual repository content from Phabricator.
Security Considerations
- API Token Management: Store Conduit API tokens securely and limit their scope to necessary operations.
- CORS Configuration: Update Sourcegraph's corsOriginsetting to allow the Phabricator extension to communicate with your instance.
- Network Access: Ensure Sourcegraph can reach your Phabricator instance over HTTPS.
- Token Rotation: Regularly rotate API tokens and update configurations accordingly.
Common Examples
Basic Configuration with Token
JSON{ "url": "https://phabricator.example.com", "token": "api-abcdefghijklmnop" }
Manual Repository Mapping
JSON{ "url": "https://phabricator.example.com", "repos": [ { "path": "github.com/myorg/frontend", "callsign": "FRONT" }, { "path": "github.com/myorg/backend", "callsign": "BACK" } ] }
Mixed Configuration
JSON{ "url": "https://phabricator.example.com", "token": "api-abcdefghijklmnop", "repos": [ { "path": "gitolite.example.com/special-repo", "callsign": "SPEC" } ] }
Best Practices
- Verify Repository Paths: Use Phabricator's diffusion.repository.searchAPI to verify that Sourcegraph repository paths match normalized URIs.
- Test Native Extension: Install the native Phabricator extension for better user experience compared to browser extensions.
- Monitor Deprecation: Plan migration away from Phabricator due to its announced end-of-life status.
- Troubleshooting: Use the Conduit API testing interface to verify token permissions and repository accessibility.