## Setup

To personalize docs with information about the currently logged in user, ReadMe will make a request to your **Personalized Docs Webhook**, which is an endpoint that will need to be set up within an application that has secure access to user data. This endpoint will receive `POST` requests from ReadMe any time a user logs in, and will need to return a JSON object with information about the user, which will then be surfaced in the documentation.

There are 3 main steps to getting this set up that we will walk through in more detail:

  1. Create an API endpoint that ReadMe will make a `POST` request to (i.e., a **Personalized Docs Webhook**)

  2. Verify the request signature to ensure that it's a secure request from ReadMe

  3. Fetch data for the user and send it back to ReadMe

We also have a video walkthrough of this process below:



### 1. Create a Personalized Docs Webhook

ReadMe will make a `POST` request to your Personalized Docs Webhook. This is an endpoint that you configure in your project dashboard. This endpoint should bypass any standard authentication that you may have set up and should be able to accept requests from [dash.readme.com](🔗). We will send the email of the user that logged in as JSON in the request body.

**Example HTTP Request from ReadMe**



### 2. Verify the Request Signature

It's important to make sure all requests to this endpoint are coming from ReadMe so you're not sending sensitive user data to a bad actor. All requests from ReadMe have a signature header that can be used to make sure the request originated with ReadMe and wasn't modified in transit. We have packages in several major languages verify this header is valid.

Secret Key

You can find your project's secret key on the "Set Up API Keys" setting page in your project's Developer Dashboard section.



If the call to `verifyWebhook` succeeds then the request is verified, you can safely return any user data needed.

### 3. Fetch User and Respond With JSON

Once the request is verified to be from ReadMe, the next step is to fetch the necessary data for the user that has logged in. This step is going to vary depending on what your API looks like and how your data is stored. ReadMe will send the logged in user's email address in the `POST` body, which can be used to fetch the user's information from the database (or wherever their API key and other necessary info is stored).

The general flow will be as follows:

  1. Get email address from `requestBody.email` (the specific way to access the email will vary depending on your server framework)

  2. Fetch user from your database/backend

  3. Return user data as JSON. These values should match the names in the API Specification. You can find a full reference of everything we expect [here](🔗). Example of common pieces of data that are good to return:

    1. API key or any required API authentication

    2. Server information (customer specific URL, subdomain, etc)



### Full Code Example

You can see a full working example in this Recipe.

Setting Up the Personalized Docs Webhook
Open Recipe


## Configuring in ReadMe & Testing

When setting up your Developer Dashboard, you’ll be prompted to **Set Up API Keys** as part of the two-step onboarding process. There is a section titled Webhooks with instructions on how to deploy the Personalized Docs Webhook. In **step 3** you will be able to test the Personalized Docs Webhook you just created and, in **step 4**, you can save it to your project. Once everything is working, ReadMe will make the request to this endpoint every time a user logs into your ReadMe docs.



For customers on our Enterprise plan, you can configure your Personalized Docs Webhook in your Enterprise Group dashboard in the **Personalized Docs** page, located within the Group Settings section.

## FAQ

**I want to replace the default ReadMe login with my company's login instead, is that possible?**

This is possible but requires a little bit more work to configure! You can read all about using a custom login with ReadMe [here](🔗).

**I already have JWT set up, do I need to set up this endpoint as well to get all the functionality?**

Nope! You are still able to send user data via JWT. The same user data can be passed to ReadMe via JWT and it will continue to behave the same way in your documentation.

While there are no plans to deprecate JWT, we recommend the **Personalized Docs Webhook** approach detailed above because it is more secure and can handle more data in the user data payload than JWT can.

**Is there any way to know if my Personalized Docs Webhook endpoint fails? Will ReadMe stop firing events to it?**

There currently is no auto-retry functionality nor do we stop firing events for projects with the the Personalized Docs Webhook set up. If we do ever ship such changes, we'll make sure that all affected users will be notified well in advance.

For the best troubleshooting experience (for both you and your API end users), we recommend doing the following:

  • Set up the Personalized Docs Webhook endpoint within the API that you're documenting in ReadMe (but don't worry about documenting this endpoint!)

  • [Integrate the Metrics SDK](🔗) into your API

By doing this, you can isolate and debug any issues with your API (and by extension, your Personalized Docs Webhook setup) within the [My Developers](🔗) page of your dashboard.