# Using ASRouter Devtools ## How to enable ASRouter devtools - In `about:config`, set `browser.newtabpage.activity-stream.asrouter.devtoolsEnabled` to `true` - Visit `about:asrouter`, or click on the wrench icon on a new tab. ## Overview ![ASRouter image general](./asrouter-general.png) ### How to enable/disable a provider To enable a provider such as `cfr`, Look at the list of "Message Providers" at the top of the General page. Make sure the checkbox is checked next to the provider you want to enable. To disable it, uncheck the checkbox. You should see a red label indicating the provider is now disabled. ### How to filter messages In order to see all active messages for a current provider such as `cfr`, use the drop down selector under the "Messages" section. Select the name of the provider you are interested in. You can also filter messages based on the template such as `spotlight` or by messaging group such as `eco`. ### How to preview a message To preview a message in asrouter, simply click on the "Show" button on top of the message. ## Targeting The targeting section can be accessed by visiting `about:asrouter#devtools-targeting` or selecting "Targeting" from the menu. It enables you to evaluate JEXL expressions and modify targeting parameters. ![ASRouter image targeting](./asrouter-targeting.png) 1. Evaluating a JEXL Expression - In the "Evaluate JEXL expression" section, you will see a text area where you can enter your JEXL expression. - Once you've entered your expression, click the "Evaluate" button to process it. - The result will appear in a read-only text area next to the input field. If the evaluation is successful, a green checkmark (✅) will appear below the result. If it fails, a red cross (❌) will be shown instead. 2. Modifying Targeting Parameters - Below the expression evaluator, you'll find a list of targeting parameters. Each parameter is displayed in a table with its name and a text area where you can modify the value. - When you modify the values, the changes are automatically saved. - To copy all the current targeting parameters to your clipboard, click the "Copy parameters" button. The button will change to `Parameters copied!` afterwards. 3. Setting Attribution Parameters - The "Attribution parameters" section provides several fields where you can specify attribution data for testing purposes. These parameters include: * Source * Medium * Campaign * Content * Experiment * Variation * User Agent * Download Token ## Impressions This section can be accessed by visiting `about:asrouter#devtools-impressions` or selecting "Impressions" from the menu. It allows you to view and manage different types of impression data, such as message impressions, group impressions, and screen impressions. You can edit and reset these impressions. ![ASRouter image impressions](./asrouter-impressions.png) 1. Message Impressions - Message impressions are stored as an object where each key is a message ID, and each value is an array of timestamps. These impressions are cleaned up when a message with that ID is no longer available in ASrouter (such as when an experiment ends). - You can edit the JSON message impressions directly in the text area. After editing the JSON, click the "Save" button to apply the changes. - If you want to reset the message impressions to their default state, click the "Reset" button. 2. Group Impressions - Group impressions are stored as an object where each key is a group ID, and each value is an array of timestamps. Unlike message impressions, group impressions are not cleaned up. - You can edit the JSON for group impressions in the text area. Click the "Save" button to save your changes. - To reset the group impressions to their default state, click the "Reset" button. 3. Screen Impressions - Screen impressions are stored in an object where each key is a screen ID, and the corresponding value is the most recent timestamp that the screen was shown. These impressions are also not cleaned up. - You can modify the screen impressions by editing the JSON directly. Click the "Save" button to save your changes. - If needed, you can click the "Reset" button to restore the original screen impressions data. ## Errors This section can be accessed by visiting `about:asrouter#devtools-errors` or selecting "Errors" from the menu. If there are any providers with errors, an error table will be displayed. ## How to test data collection All of Messaging System, including ASRouter, is instrumented in Glean. To test this instrumentation, please consult [this guide](/toolkit/components/glean/user/instrumentation_tests.md), and: - In about:config, set: - `browser.newtabpage.activity-stream.telemetry` to `true` - To view additional debug logs for messaging system or about:welcome, set: - `messaging-system.log` to `debug` - `browser.aboutwelcome.log` to `debug` - You can now view telemetry logs in the browser console