.NET Setup

🚧

Any issues?

Integrations can be tricky! Contact support if you have any questions/issues.

Overview

If you're a developer, it takes a few small steps to send your API logs to ReadMe so your team can get deep insights into your API's usage with ReadMe Metrics. Here's an overview of how the integration works:

  • Add the ReadMe.Metrics NuGet package to your API server and integrate the middleware.
  • The .NET SDK sends ReadMe the details of your API's incoming requests and outgoing responses, with the option for you to redact any private parameters or headers.
  • ReadMe uses these request and response details to create an API Metrics Dashboard which can be used to analyze specific API calls or monitor aggregate usage data. Additionally, if your users log into your API documentation we'll show them logs of the requests they made!

ASP.NET Core Integration

  1. Install the ReadMe.Metrics NuGet package using Visual Studio or VS Code or the following command:
dotnet add package ReadMe.Metrics
  1. Find the file that creates your app. This is often in a Startup.cs or Program.cs file depending on your version of .NET, and is located in your root directory. Find the where your app is created, and add the following line before the routing is enabled. For full details on each option, read more about the Group Object.
app.Use(async (context, next) =>
{
    HttpRequest req = context.Request;

    context.Items["apiKey"] = <Extract API users API key from the request>
    context.Items["label"] = <Extract API users display name from the request>
    context.Items["email"] = <Extract API users email address from the request>

    await next();
});
  1. Add the logging middleware to your API server. This will be added immediately after your custom middleware from step 2.
app.UseMiddleware<ReadMe.Metrics>();
  1. Locate appsettings.json in the root directory of your Application. Add the following JSON to your configuration and fill in any applicable values. For full details on each option read more about the ReadMe Object in appsettings.json.
"readme": {
    "apiKey": "<Your ReadMe API Key>",
    "options": {
        "allowList": [ "<Any parameters you want allowed in your log. See docs>" ],
        "denyList": [ "<Any parameters you want removed from your log. See docs>"],
        "development": true, // Where to bucket your data, development or production
        "baseLogUrl": "https://example.readme.io" // Your ReadMe website's base url. For now, make sure to use the readme.io domain or your custom subdomain.
    }
}

For a full example take a look at our example projects:

ASP.NET Core Middleware Reference

Group Object

Before assigning the ReadMe.Metrics middleware you should assign custom middleware to extract certain grouping parameters, as seen in step 2 of the ASP.NET Core Integration. The grouping parameters includes three values: apiKey, label and email. While only apiKey is required, we recommend providing all three values to get the most out of the metrics dashboard.

FieldTypeDescription
apiKeystringRequired API Key used to make the request. Note that this is different from the readmeAPIKey described above and should be a value from your API that is unique to each of your users, not part of ReadMe's API.
labelstringThis will be the users' display name in the API Metrics Dashboard, as it's much easier to remember a name than an API key.
emailstringEmail of the user that is making the call.

Example

app.Use(async (context, next) =>
{
    HttpRequest req = context.Request;

    context.Items["apiKey"] = <Extract API users API key from the request>
    context.Items["label"] = <Extract API users display name from the request>
    context.Items["email"] = <Extract API users email address from the request>

    await next();
});

ReadMe Object in appsettings.json

The ASP.NET Core middleware extracts the following parameters from appsettings.json file:

ParameterDescription
readmeAPIKeyRequired The API key for your ReadMe project. This ensures your requests end up in your dashboard. You can read more about the API key in our docs.
optionsAdditional options. You can read more under Options Object.

Options Object

This is an optional object used to restrict traffic being sent to readme server based on given values in allowList or denyList arrays.

OptionTypeDescription
baseLogUrlstringThis value is used when building the x-documentation-url header (see docs below). It is your ReadMe documentation's base URL (e.g. https://example.readme.io). If not provided, we will make one API call a day to determine your base URL (more info in Documentation URL.

Note: .readme.com will not work. Make sure to use .readme.io, or your custom hostname.
allowListArray of stringsIf included, denyList will be ignored and all parameters but those in this list will be redacted.
denyListArray of stringsAn array of parameter names that will be redacted from the query parameters, request body (when JSON or form-encoded), response body (when JSON) and headers. For nested request parameters use dot notation (e.g. a.b.c to redact the field c within { a: { b: { c: 'foo' }}}).
developmentboolDefaults to false. When true, the log will be marked as a development log. This is great for separating staging or test data from data coming from customers.

Example

{
  "apiKey": "abcd123",
  "options": {
    "denyList": ["password", "secret"],
    "development": true,
    "baseLogUrl": "https://example.readme.io"
  }
}

Documentation URL

With the middleware loaded, all requests that funneled through it will receive a x-documentation-url header applied to the response. The value of this header will be the URL on ReadMe Metrics with which you can view the log for that request.

Make sure to supply a baseLogUrl option into your readme settings, which should evaluate to the public-facing URL of your ReadMe project.

Troubleshooting

  1. If you have the development flag set in your configuration, you can only view these logs on your dashboard (https://dash.readme.com/project/{your_project}/v1.0/overview with your subdomain instead of {your_project}) by clicking the gear icon in the top right and toggling on "Development Data".
  2. If you're still having issues, write into support with the following information:
    • The version of .NET you are using.
    • The value of the x-documentation-url header that is returned from calls to your API, or the GUID generated for your log.
    • Additionally, it would be useful to include:
      • Any other config values you are using.
      • The Method, URL, Query Parameters, Request Body and Headers of the API call you are trying to log.
      • The response of the API call to the metrics server (i.e. the value of response on this line).

Sample Applications