Settings

Settings provide the ability to customize and control the Sourcegraph UI and user-specific features. They do not configure operational aspects of the instance (which are set in the site configuration).

Settings can be set at the global level (by site admins), the organization level (by organization members), and at the individual user level.

Settings-Cascade

Editing global settings (for site admins)

Global settings are found in Site admin > Global settings while links to organization and user settings are found in the user dropdown menu.

After setting or changing certain values in Site admin > Global settings the frontend will restart automatically or you might be asked to restart the frontend for the changes to take effect. In case of a Kubernetes deployment this can be done as follows:

SHELL
bash kubectl delete pods -l app=sourcegraph-frontend

Reference

Settings options and their default values are shown below.

admin/config/settings.schema.json

JSON
{ // Disables observability-related site alert banners. "alerts.hideObservabilitySiteAlerts": true, // Whether to show alerts for major and minor version updates. Alerts for patch version updates will be shown if `alerts.showPatchUpdates` is true. "alerts.showMajorMinorUpdates": true, // Whether to show alerts for patch version updates. Alerts for major and minor version updates will be shown if `alerts.showMajorMinorUpdatess` is true. "alerts.showPatchUpdates": true, // Whether to run global searches over all repositories. On instances with many repositories, this can lead to issues such as: low quality results, slow response times, or significant load on the Sourcegraph instance. Defaults to true. "basicCodeIntel.globalSearchesEnabled": null, // Whether to include archived repositories in search results. "basicCodeIntel.includeArchives": null, // Whether to include forked repositories in search results. "basicCodeIntel.includeForks": null, // Whether to use only indexed requests to the search API. "basicCodeIntel.indexOnly": null, // The timeout (in milliseconds) for un-indexed search requests. "basicCodeIntel.unindexedSearchTimeout": null, // Whether to fetch multiple precise definitions and references on hover. "codeIntel.disableRangeQueries": null, // Never fall back to search-based code intelligence. "codeIntel.disableSearchBased": null, // Whether to supplement precise references with search-based results. "codeIntel.mixPreciseAndSearchBasedReferences": null, // Whether to enable trace logging on the extension. "codeIntel.traceExtension": null, // Whether the sidebar on the repo view should be open by default. "fileSidebarVisibleByDefault": true, // Custom page size for the history tab. If set, the history tab will populate that number of commits the first time the history tab is opened and then double the number of commits progressively. "history.defaultPageSize": null, // Show absolute timestamps in the history panel and only show relative timestamps (e.g.: "5 days ago") in tooltip when hovering. "history.preferAbsoluteTimestamps": false, // DEPRECATED: Use `notices` instead. // // An array (often with just one element) of messages to display at the top of all pages, including for unauthenticated users. Users may dismiss a message (and any message with the same string value will remain dismissed for the user). // // Markdown formatting is supported. // // Usually this setting is used in global and organization settings. If set in user settings, the message will only be displayed to that user. (This is useful for testing the correctness of the message's Markdown formatting.) // // MOTD stands for "message of the day" (which is the conventional Unix name for this type of message). "motd": null, // Custom informational messages to display to users at specific locations in the Sourcegraph user interface. // // Usually this setting is used in global and organization settings. If set in user settings, the message will only be displayed to that single user. "notices": null, // Group of settings related to opening files in an editor. "openInEditor": null, // If enabled, all members of the org will be treated as admins (e.g. can edit, apply, delete) for all batch changes created in that org. "orgs.allMembersBatchChangesAdmin": false, // Key-value pairs of code host URLs to Swarm URLs. Keys should have no prefix and should not end with a slash, like "perforce.company.com:1666". Values should look like "https://swarm.company.com/", with a slash at the end. "perforce.codeHostToSwarmMap": {}, // DEPRECATED: This setting will be removed in a future version of Sourcegraph. "quicklinks": null, // The default number of lines to show as context below and above search results. Default is 1. "search.contextLines": 1, // Whether query patterns are treated case sensitively. Patterns are case insensitive by default. "search.defaultCaseSensitive": false, // Defines default properties for search behavior. The default is `smart`, which provides query assistance that automatically runs alternative queries when appropriate. When `precise`, search behavior strictly searches for the precise meaning of the query. "search.defaultMode": null, // The default pattern type for search queries. Note: to disable keyword search and use the previous behavior, set "search.defaultPatternType: standard". "search.defaultPatternType": null, // The number of results we send down during a search. Note: this is different to the count: in the query. The search will continue once we hit displayLimit and updated filters and statistics will continue to stream down. Defaults to 1500. "search.displayLimit": 1500, // Disable search suggestions below the search bar when constructing queries. Defaults to false. "search.hideSuggestions": false, // Whether searches should include searching archived repositories. "search.includeArchived": false, // Whether searches should include searching forked repositories. "search.includeForks": false, // DEPRECATED: Saved search queries "search.savedQueries": null, // Predefined search snippets that can be appended to any search (also known as search scopes) "search.scopes": null, ////////////////////////////////////////////////////////////// // CodeInsights ////////////////////////////////////////////////////////////// // The number of seconds to execute the aggregation for when running in extended timeout mode. This value should always be less than any proxy timeout if one exists. The maximum value is equal to searchLimits.maxTimeoutSeconds "insights.aggregations.extendedTimeout": 55, ////////////////////////////////////////////////////////////// // Experimental ////////////////////////////////////////////////////////////// // Experimental features and settings. "experimentalFeatures": null }

Configuration Notes

Settings Hierarchy and Inheritance

Settings follow a cascade model where more specific settings override general ones:

  1. User settings - highest priority, affects individual users only
  2. Organization settings - medium priority, affects all organization members
  3. Global settings - lowest priority, affects all users on the instance

Frontend Restart Requirements

Some settings changes require a frontend restart to take effect:

  • Changes to global settings may trigger automatic frontend restarts
  • In Kubernetes deployments, manually restart frontend pods: kubectl delete pods -l app=sourcegraph-frontend

Deprecated Settings

Several settings are deprecated and should be migrated:

  • motd - Replace with notices for better functionality and styling options
  • quicklinks - Will be removed in future versions
  • search.savedQueries - Functionality integrated into search interface

Performance Impact Settings

  • search.displayLimit affects initial search result loading - higher values increase memory usage
  • basicCodeIntel.globalSearchesEnabled can impact performance on large instances
  • insights.aggregations.extendedTimeout extends query timeouts but may increase load

Security Considerations

User Privacy and Data Protection

  • Global settings visibility - Global settings are visible to all users; avoid including sensitive information
  • Notice content - Notices are displayed to all users; ensure content is appropriate for your organization
  • Search behavior - Default search settings affect what users can discover across repositories

Access Control Configuration

  • orgs.allMembersBatchChangesAdmin grants administrative privileges to all organization members - use carefully
  • basicCodeIntel.includeArchives and basicCodeIntel.includeForks may expose archived or forked repositories users shouldn't access
  • Settings should align with repository permission policies to prevent unauthorized access

Code Intelligence Security

  • codeIntel.disableSearchBased may expose code patterns through search-based fallbacks
  • codeIntel.mixPreciseAndSearchBasedReferences combines precise and search results - ensure both are appropriate
  • Trace logging (codeIntel.traceExtension) may expose code content in logs

Common Examples

Basic User Experience Configuration

JSON
{ "fileSidebarVisibleByDefault": true, "search.defaultCaseSensitive": false, "search.defaultPatternType": "keyword", "search.displayLimit": 1500 }

Search Optimization

JSON
{ "search.contextLines": 3, "search.includeArchived": false, "search.includeForks": false, "search.hideSuggestions": false, "basicCodeIntel.globalSearchesEnabled": true, "basicCodeIntel.unindexedSearchTimeout": 30000 }

Code Intelligence Configuration

JSON
{ "codeIntel.disableRangeQueries": false, "codeIntel.disableSearchBased": false, "codeIntel.mixPreciseAndSearchBasedReferences": true, "basicCodeIntel.indexOnly": false }

Organization Batch Changes Setup

JSON
{ "orgs.allMembersBatchChangesAdmin": false }

Notices and Alerts Configuration

JSON
{ "notices": [ { "message": "📢 Scheduled maintenance window: **Saturday 2-4 PM UTC**", "location": "top", "dismissible": true, "variant": "warning" } ], "alerts.showMajorMinorUpdates": true, "alerts.showPatchUpdates": false, "alerts.hideObservabilitySiteAlerts": false }

History and Interface Preferences

JSON
{ "history.defaultPageSize": 50, "history.preferAbsoluteTimestamps": false, "fileSidebarVisibleByDefault": true }

Code Insights Extended Configuration

JSON
{ "insights.aggregations.extendedTimeout": 45 }

Best Practices

Settings Management Strategy

  1. Use global settings sparingly - Only configure settings that should apply to all users
  2. Leverage organization settings - Configure team-specific preferences at the organization level
  3. Document setting changes - Maintain records of why specific settings were configured
  4. Test setting changes - Verify settings work as expected before applying organization-wide

User Experience Optimization

  1. Configure sensible defaults - Set search and display preferences that work for most users
  2. Enable helpful features - Turn on code intelligence features unless they cause performance issues
  3. Minimize distractions - Use notices judiciously to avoid alert fatigue
  4. Respect user preferences - Allow users to override organization settings when appropriate

Performance Considerations

  1. Monitor search performance - Adjust displayLimit and timeout settings based on instance performance
  2. Balance code intelligence features - Enable features that provide value without overwhelming the system
  3. Consider repository scale - Disable global searches on very large instances if needed
  4. Test timeout settings - Ensure Code Insights timeouts are appropriate for your query complexity

Maintenance and Updates

  1. Review deprecated settings - Regularly audit and migrate away from deprecated configurations
  2. Update alerting preferences - Configure update notifications based on your maintenance schedule
  3. Validate settings hierarchy - Ensure organization and global settings work together as intended
  4. Plan for setting changes - Coordinate setting updates with users when they affect user experience

Communication Best Practices

  1. Use clear notice messaging - Write notices that clearly communicate important information
  2. Choose appropriate notice styling - Use warning/danger variants for critical information
  3. Make notices actionable - Include links to relevant documentation or actions users should take
  4. Time-bound temporary notices - Remove notices when they're no longer relevant

Additional details on settings

Notices

Notices can be added in global, organization, or user settings. The notices setting is a list of notice configurations with the following options:

  1. message: the markdown copy to be displayed in the banner
  2. location: where the banner will be shown. Either on the home page with "home" or at the top of the page with "top"
  3. dismissible (optional): boolean (true or false). If true, users will be able to close the notice and not see it again. If false, it will persist on the instance until the configuration is removed.
  4. variant (optional): one of "primary", "secondary", "success", "danger", "warning", "info", "note" the style of the notice. Although specifics such as color depend on the theme in general danger or primary will draw more attention than secondary or note. The default style depends on the location of the notice.
  5. styleOverrides (optional): a configuration object with the following elements:
    1. backgroundColor (optional): a hexadecimal color code for forcing a specific background color.
    2. textColor (optional): a hexadecimal color code for forcing a specific text color.
    3. textCentered (optional): boolean (true or false). If true, the text will be centered in the banner.

Example settings:

JSON
"notices": [ { "message": "Your important message here! [Include a link for more information](http://example.com).", "location": "top", "dismissible": true, "variant": "danger", "styleOverrides": { "styleOverrides": { "backgroundColor": "#7f1d1d", "textColor": "#fecaca", "textCentered": true } } } ]