Community
Questions Library
Docs
Blog
Events
Swag
Github
Slack
JupiterOne
Discussions
Release Notes
Contact Us
Duo - AskJ1 Community
<main> <article class="userContent"> <h2 data-id="duo-jupiterone-integration-benefits">Duo + JupiterOne Integration Benefits</h2> <ul><li><p>Visualize Duo users, groups, devices, applications, and access keys in the<br> JupiterOne graph.</p></li> <li><p>Map Duo users to employees in your JupiterOne account.</p></li> <li><p>Monitor changes to Duo users, groups, and access management data using<br> JupiterOne alerts.</p></li> <li><p>Create an employee entity that is used to map users across your organization<br> to an employee via a matching email property.</p></li> </ul><h2 data-id="how-it-works">How it Works</h2> <ul><li><p>JupiterOne periodically fetches Duo users, groups, and access management data<br> to update the graph.</p></li> <li><p>Write JupiterOne queries to review and monitor updates to the graph.</p></li> <li>Configure alerts to take action when the JupiterOne graph changes.</li> </ul><h2 data-id="requirements">Requirements</h2> <ul><li><p>JupiterOne requires the Duo API hostname. JupiterOne also requires the API<br> integration key and API secret key that have been configured for read access.</p></li> <li><p>You must have permission in JupiterOne to install new integrations.</p></li> </ul><h2 data-id="support">Support</h2> <p>If you need help with this integration, please contact<br><a rel="nofollow" href="https://support.jupiterone.io">JupiterOne Support</a>.</p> <h2 data-id="integration-walkthrough">Integration Walkthrough</h2> <h3 data-id="in-duo">In Duo</h3> <p>You will need to create an API key (<code class="code codeInline" spellcheck="false" tabindex="0">Integration Key</code> + <code class="code codeInline" spellcheck="false" tabindex="0">Secret Key</code>) from your<br> Duo Admin Panel. You may need to contact Duo Support to request API access. See<br> up-to-date instructions in <a rel="nofollow" href="https://duo.com/docs/adminapi">Duo Support Docs</a>.</p> <h4 data-id="required-api-permissions">Required API Permissions</h4> <p>JupiterOne requires at a minimum the following API permissions be enabled:</p> <ul><li>Grant administrators</li> <li>Grant settings</li> <li>Grant read resource</li> </ul><h3 data-id="in-jupiterone">In JupiterOne</h3> <ol><li>From the top navigation of the J1 Search homepage, select <strong>Integrations</strong>.</li> <li>Scroll to the <strong>Duo</strong> integration tile and click it.</li> <li>Click the <strong>Add Configuration</strong> button and configure the following settings:</li> </ol><ul><li><p>Enter the <strong>Account Name</strong> by which you'd like to identify this Duo account in<br> JupiterOne. Ingested entities will have this value stored in <code class="code codeInline" spellcheck="false" tabindex="0">tag.AccountName</code><br> when <strong>Tag with Account Name</strong> is checked.</p></li> <li><p>Enter a <strong>Description</strong> that will further assist your team when identifying<br> the integration instance.</p></li> <li><p>Select a <strong>Polling Interval</strong> that you feel is sufficient for your monitoring<br> needs. You may leave this as <code class="code codeInline" spellcheck="false" tabindex="0">DISABLED</code> and manually execute the integration.</p></li> <li><p>Enter the <strong>API Hostname</strong> of your Duo account.</p></li> <li>Enter the <strong>API Integration Key</strong> configured with read access in Duo.</li> <li>Enter the <strong>Secret Key</strong> configured with read access in Duo.</li> </ul><ol start="4"><li>Click <strong>Create Configuration</strong> once all values are provided.</li> </ol><h2 data-id="how-to-uninstall">How to Uninstall</h2> <ol><li>From the top navigation of the J1 Search homepage, select <strong>Integrations</strong>.</li> <li>Scroll to the <strong>Duo</strong> integration tile and click it.</li> <li>Identify and click the <strong>integration to delete</strong>.</li> <li>Click the <strong>trash can</strong> icon.</li> <li>Click the <strong>Remove</strong> button to delete the integration.</li> </ol><p><br></p> <h2 data-id="data-model">Data Model</h2> <h3 data-id="entities">Entities</h3> <p>The following entities are created:</p> <table><thead><tr><th>Resources</th> <th>Entity <code class="code codeInline" spellcheck="false" tabindex="0">_type</code></th> <th>Entity <code class="code codeInline" spellcheck="false" tabindex="0">_class</code></th> </tr></thead><tbody><tr><td>Account</td> <td><code class="code codeInline" spellcheck="false" tabindex="0">duo_account</code></td> <td><code class="code codeInline" spellcheck="false" tabindex="0">Account</code></td> </tr><tr><td>Admin</td> <td><code class="code codeInline" spellcheck="false" tabindex="0">duo_admin</code></td> <td><code class="code codeInline" spellcheck="false" tabindex="0">User</code></td> </tr><tr><td>Device</td> <td><code class="code codeInline" spellcheck="false" tabindex="0">duo_phone</code></td> <td><code class="code codeInline" spellcheck="false" tabindex="0">Device</code></td> </tr><tr><td>Group</td> <td><code class="code codeInline" spellcheck="false" tabindex="0">duo_group</code></td> <td><code class="code codeInline" spellcheck="false" tabindex="0">UserGroup</code></td> </tr><tr><td>Integration</td> <td><code class="code codeInline" spellcheck="false" tabindex="0">duo_integration</code></td> <td><code class="code codeInline" spellcheck="false" tabindex="0">Application</code></td> </tr><tr><td>MFA Token</td> <td><code class="code codeInline" spellcheck="false" tabindex="0">mfa_device</code></td> <td><code class="code codeInline" spellcheck="false" tabindex="0">AccessKey</code></td> </tr><tr><td>User</td> <td><code class="code codeInline" spellcheck="false" tabindex="0">duo_user</code></td> <td><code class="code codeInline" spellcheck="false" tabindex="0">User</code></td> </tr></tbody></table><h3 data-id="relationships">Relationships</h3> <p>The following relationships are created:</p> <table><thead><tr><th>Source Entity <code class="code codeInline" spellcheck="false" tabindex="0">_type</code></th> <th>Relationship <code class="code codeInline" spellcheck="false" tabindex="0">_class</code></th> <th>Target Entity <code class="code codeInline" spellcheck="false" tabindex="0">_type</code></th> </tr></thead><tbody><tr><td><code class="code codeInline" spellcheck="false" tabindex="0">duo_account</code></td> <td><strong>HAS</strong></td> <td><code class="code codeInline" spellcheck="false" tabindex="0">duo_admin</code></td> </tr><tr><td><code class="code codeInline" spellcheck="false" tabindex="0">duo_account</code></td> <td><strong>HAS</strong></td> <td><code class="code codeInline" spellcheck="false" tabindex="0">duo_group</code></td> </tr><tr><td><code class="code codeInline" spellcheck="false" tabindex="0">duo_account</code></td> <td><strong>HAS</strong></td> <td><code class="code codeInline" spellcheck="false" tabindex="0">duo_integration</code></td> </tr><tr><td><code class="code codeInline" spellcheck="false" tabindex="0">duo_account</code></td> <td><strong>HAS</strong></td> <td><code class="code codeInline" spellcheck="false" tabindex="0">duo_user</code></td> </tr><tr><td><code class="code codeInline" spellcheck="false" tabindex="0">duo_group</code></td> <td><strong>HAS</strong></td> <td><code class="code codeInline" spellcheck="false" tabindex="0">duo_user</code></td> </tr><tr><td><code class="code codeInline" spellcheck="false" tabindex="0">duo_user</code></td> <td><strong>ASSIGNED</strong></td> <td><code class="code codeInline" spellcheck="false" tabindex="0">mfa_device</code></td> </tr><tr><td><code class="code codeInline" spellcheck="false" tabindex="0">duo_user</code></td> <td><strong>USES</strong></td> <td><code class="code codeInline" spellcheck="false" tabindex="0">duo_phone</code></td> </tr></tbody></table><p><br></p> </article> </main>