.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
- Install the
ReadMe.Metrics
NuGet package using Visual Studio or VS Code or the following command:
dotnet add package ReadMe.Metrics
- Find the file that creates your
app
. This is often in aStartup.cs
orProgram.cs
file depending on your version of .NET, and is located in your root directory. Find the where yourapp
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();
});
- Add the logging middleware to your API server. This will be added immediately after your custom middleware from step 2.
app.UseMiddleware<ReadMe.Metrics>();
- 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.
Field | Type | Description |
---|---|---|
apiKey | string | Required 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. |
label | string | This will be the users' display name in the API Metrics Dashboard, as it's much easier to remember a name than an API key. |
email | string | Email 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:
Parameter | Description |
---|---|
readmeAPIKey | Required 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. |
options | Additional 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.
Option | Type | Description |
---|---|---|
baseLogUrl | string | This 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. |
allowList | Array of strings | If included, denyList will be ignored and all parameters but those in this list will be redacted. |
denyList | Array of strings | An 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' }}} ). |
development | bool | Defaults 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
- 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". - 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
Updated 7 months ago