Skip to content

Setting up Scarf Packages

Prerequisites

  • You will need to sign up for a Scarf account.

    Note: You can sign up with a valid email address or your GitHub account.

  • To track a container, it must be published to a public registry; eg Docker Hub, GitHub Container Registry.

    Note: This guide will use the hello-world docker image.

Docker Packages

Creating a Docker Package

Using Scarf, users can pull your Docker container images via Scarf Gateway using your custom domain.

  1. Once signed in to Scarf, navigate to the home page.
  2. Click plus icon in the top navigation, then select New Package. Create a new package
  3. In the first drop-down click on the package type you would like to create. For this section you will click Docker. Enter the docker pull command
  4. Enter the current pull command for your Docker container.

    # `hello-world` package
    
    docker pull hello-world
    

    Enter the docker pull command

  5. Optional: You can add a custom domain or use the domain provided by Scarf Gateway.

  6. Click the Submit button to be redirected to a success screen with some additional information as to what you can do next.
  7. Click on on Go to your package to view your package details view.

    Enter the docker pull command

Now you’re all set to start tracking your Docker images with Scarf. Any time your image is downloaded, Scarf will report the following information:

  • System and OS statistics of your users
  • Company information of your users
  • Downloads by versions/tags

In the next section, you will create a tracking pixel that can be added to your project’s documentation or any other web properties associated with your project.

Downloading Docker Packages

In this section you will download your package with the pull command found in your package dashboard to start fetching data.

  1. Navigate to your package details view.

    Package dashboard

  2. Copy the Pull command.

  3. Navigate to a terminal on your computer and run the Pull command.

    Run Scarf pull command

    Note: Make sure the docker daemon is running on your computer. 6. Back to the package details view and click on View Analytics. You should now see the Package Insights starting to populate with data. It will usually take 30 minutes and up to 2-3 hours before you see data pulled in. Every time a user pulls your Docker container images from Scarf Gateway the data in your Package Insights will be updated. Data from packages

File Packages

File Packages on Scarf are a flexible and low-level package type that can track visits and downloads on arbitrary URLs. File packages were originally created to track published tar balls, but it has since expanded to many other use cases. You can think of File Packages as a powerful and fully customizable link shortener. Common use cases include:

  • Tracking downloads of GitHub release artifacts
  • Tracking downloads of every artifact on your company/project "downloads" page
  • Tracking downloads of Homebrew packages from a tap/formula that you control
  • Sending custom telemetry or other events from your application
  • Tracking and attributing visits to marketing and sales content on your site.

Creating a File Package

  1. Log in to your Scarf account.

  2. Click the plus icon in the top right navigation, then select New Package. Create a new package

  3. In the first drop-down click on the package type you would like to create. For this section you will click New File. Create a package

  4. Select a package owner from the dropdown of Organizations you belong to. Select package owner

  5. Give your package a name. Name your package

Adding an Outgoing and Incoming URL

This section explains what the Outgoing and Incoming URLs are and how to use a URL template.

1.) Add the URL path where your files are currently located. You can add a simple URL or a URL template like in the example. https://www.example.com/mypath/{version}/{platform}.tar.gz This example uses 2 variables {version} and {platform}.

Note: The Outgoing URL is the full URL to your asset on your HTTP/S hosting provider. It can be a URL template but if you use variables in your URL they need to also be used in your Incoming Path that define in the next step.

path where files are located

2.) Choose the domain where your files will be available from. You may choose to use your own domain for serving files. You may also choose to use <username>.gateway.scarf.sh provided by default by Scarf.

3.) Add the Incoming URL Path where Scarf will direct requests to fetch a file asset.

Note: Any variables used in your Outgoing URL path need to match your Incoming URL.

Add the Incoming URL Path

4.) Click Submit.

Adding Additional Routes

This example will show how to add an additional route. For curl-runnings an additional route that redirects to a specific version will be added, in this case, the most recent package release.

1.) In the top menu click on Tools then in the drop down menu click on Packages. Packages menu

2.) In the package list dashboard there will be a list of all your packages. These can be filtered by type of packages by selecting the package types you'd like to see. In our example as we just created a file package we're going to want to select File.

3.) Navigate to our newly create file package and in the top right of the box click the View Details button. Click the Show Detials button

4.) In the popup modal, use the File location input to add a new host URL. You can use a template URL here.

Example:

https://www.example.com/mypath/latest/{platform}.tar.gz

5.) Next, add the desired path format for your files. Make sure the variables from your Outgoing and Incoming URLs match if you use a template URL.

Example:

/latest/{platform}

Add desired route

6.) Click the Submit button.

7.) The modal will close and you will see the additional route you just added.

New file package route

npm Packages

NPM Packages on Scarf are a convenient way to collect usage and event telemetry from your npm packages by adding a dependency on [scarf-js](https://www.npmjs.com/package/@scarf/scarf).

  1. Log in to your Scarf account.

  2. Click the plus icon in the navigation, then select New Package. Create a new package

  3. In the first drop-down, select npm as the package type. Create a package

  4. Select the package owner from the dropdown list of Organizations you belong to. Select package owner

  5. Give your npm package a name. This name should match the name of your package on npm, or the same as the name in your package.json. Name your package

  6. Click Submit.

Configuring Telemetry for npm packages

Once an npm entry has been created, you are ready to configure your package by adding scarf as a dependency

npm i --save @scarf/scarf
Once your library is published to npm with this change, Scarf will automatically receive stats on install, no additional code is required! For additional details on configuration of the scarf-js library please refer to the scarf-js NPM entry.

Event Collection

Event Collection Packages

Event Collection Packages on Scarf are another flexible package type which can be used to collect event telemetry by fetching a URL or by importing event history. Event Collection Packages are an alias of File packages and share all the same traits. Common use cases include:

  • Sending custom telemetry or other events from your application
  • Importing log or event history from your hosted installations to Scarf

Creating an Event Collection Package

  1. Log in to your Scarf acccount.

Event Collection Packages

Event Collection Packages on Scarf are another flexible package type purpose built for telemetry data in general. Event data can be sent to a public Scarf Gateway URL of your choice, or by bulk ingesting events through our authenticated API. Event Collection Packages are an alias of File packages and share all the same traits. Common use cases include:

  • Sending custom telemetry or other events from your application
  • Importing historical event data from an external application into to Scarf

Creating an Event Collection Package

  1. Once signed in to Scarf, navigate to the home page.

  2. Click plus icon in the navigation, then select New Package. Create a new package

  3. In the first drop-down click on the package type you would like to create. For this section you will click Event Collection. Create a package

  4. Select the package owner from the dropdown. Select package owner

  5. Give your package a name. Name your package

Adding an Incoming URL

This section explains what the Incoming URLs are and how to use a URL template for Event Collection.

1.) Add the URL path where your events will be collected. This is the user visible endpoint your application will connect to for event submission. This setting while required is not relevant when submitting events via the Event Import API.

Note: You can use a URL template, but if you use variables in your URL they need to also be used in your Incoming Path that is defined in the next step.

path where files are located

2.) Choose the domain where your events will be submitted. You may choose to use your own domain or you may choose to use <username>.gateway.scarf.sh provided by default by Scarf.

3.) Click Submit.

4.) Configuring Telemetry Once an Event Collection package has been created, you are ready to collect Custom telemetry

Configuring Event Collection

Once an Event Collection package has been created, you are ready to collect Custom telemetry

Python Packages

Scarf Gateway configuration for a Python package entry has three main considerations:

  • pip Command: This is the current pip command used to install your package. For packages on PyPI.org, this will be of the form pip install my-pkg and will include the --extra-index-url https://my-python-project-domain.com if your package is hosted elsewhere. This defines the location where the users will be redirected to when installing your package.
  • Domain: This can be your own domain, or a Scarf-supplied domain, of the form <username>.gateway.scarf.sh. By default, your Scarf domain will be used if this field is left empty.
  • Telemetry: This allows you to gather insights into how your package is used without collecting any personally identifiable information.

Installing Python packages via requirements.txt Add the --extra-index-url option at the top of your requirements.txt:

--extra-index-url https://my-python-project-domain.com/simple/ 
my-pkg==0.0.1

NOTE: We have noticed indeterminate behavior in some versions of Pip that have resulted in the public registry being used for download regardless of the --extra-index-url addition.

If you elect to use your own domain, you'll need to add a CNAME for that domain to gateway.scarf.sh. Additionally we require you to verify your ownership of the domain by setting a TXT with a value that Scarf provides upon package creation. See your DNS provider's instructions for how to add CNAME and TXT records.

If you have questions or need help, join our Slack community.