Proxying assets
- Tier: Free, Premium, Ultimate
- Offering: GitLab Self-Managed, GitLab Dedicated
A possible security concern when managing a public-facing GitLab instance is the ability to steal a user’s IP address by referencing images in issues and comments.
For example, adding data:image/s3,"s3://crabby-images/1e450/1e45017854b9f97459de5ba582f4ac35f28430d7" alt="Example image"
to
an issue description causes the image to be loaded from the external
server to be displayed. However, this also allows the external server
to log the IP address of the user.
One way to mitigate this is by proxying any external images to a server you control.
GitLab can be configured to use an asset proxy server when requesting external images/videos/audio in issues and comments. This helps ensure that malicious images do not expose the user’s IP address when they are fetched.
We currently recommend using cactus/go-camo as it supports proxying video, audio, and is more configurable.
Installing Camo server
A Camo server is used to act as the proxy.
To install a Camo server as an asset proxy:
-
Deploy a
go-camo
server. Helpful instructions can be found in building cactus/go-camo. -
Make sure your instance of GitLab is running, and that you have created a private API token. Using the API, configure the asset proxy settings on your GitLab instance. For example:
curl --request "PUT" "https://gitlab.example.com/api/v4/application/settings?\ asset_proxy_enabled=true&\ asset_proxy_url=https://proxy.gitlab.example.com&\ asset_proxy_secret_key=<somekey>" \ --header 'PRIVATE-TOKEN: <my_private_token>'
The following settings are supported:
Attribute Description asset_proxy_enabled
Enable proxying of assets. If enabled, requires: asset_proxy_url
.asset_proxy_secret_key
Shared secret with the asset proxy server. asset_proxy_url
URL of the asset proxy server. asset_proxy_whitelist
(Deprecated: Use asset_proxy_allowlist
instead) Assets that match these domains are NOT proxied. Wildcards allowed. Your GitLab installation URL is automatically allowed.asset_proxy_allowlist
Assets that match these domains are NOT proxied. Wildcards allowed. Your GitLab installation URL is automatically allowed. -
Restart the server for the changes to take effect. Each time you change any values for the asset proxy, you need to restart the server.
Using the Camo server
Once the Camo server is running and you’ve enabled the GitLab settings, any image, video, or audio that references an external source are proxied to the Camo server.
For example, the following is a link to an image in Markdown:
data:image/s3,"s3://crabby-images/456b3/456b3689fb331c2da9207c5ccf2ae46696e31871" alt="logo"
The following is an example of a source link that could result:
http://proxy.gitlab.example.com/f9dd2b40157757eb82afeedbf1290ffb67a3aeeb/68747470733a2f2f61626f75742e6769746c61622e636f6d2f696d616765732f70726573732f6c6f676f2f6a70672f6769746c61622d69636f6e2d7267622e6a7067
Docs
Edit this page to fix an error or add an improvement in a merge request.
Create an issue to suggest an improvement to this page.
Product
Create an issue if there's something you don't like about this feature.
Propose functionality by submitting a feature request.
Feature availability and product trials
View pricing to see all GitLab tiers and features, or to upgrade.
Try GitLab for free with access to all features for 30 days.
Get help
If you didn't find what you were looking for, search the docs.
If you want help with something specific and could use community support, post on the GitLab forum.
For problems setting up or using this feature (depending on your GitLab subscription).
Request support