> ## Documentation Index
> Fetch the complete documentation index at: https://docs.stackone.com/llms.txt
> Use this file to discover all available pages before exploring further.

# Google Directory OAuth 2.0 connector profile – StackOne setup guide

> Set up the OAuth 2.0 connector profile for Google Directory in StackOne. One-time admin setup required before your users can link Google Directory accounts via Hub.

<Warning>Super Admin or Admin privileges in Google Workspace are required to complete this setup.</Warning>

<Panel>
  <div className="not-prose guides-scope-selector" data-guides-scope-selector data-guide-actions-json="[{&#x22;id&#x22;:&#x22;googledirectory_unified_list_groups&#x22;,&#x22;label&#x22;:&#x22;List Unified Groups&#x22;,&#x22;scopes&#x22;:[&#x22;https://www.googleapis.com/auth/admin.directory.group.readonly&#x22;]},{&#x22;id&#x22;:&#x22;googledirectory_unified_get_group&#x22;,&#x22;label&#x22;:&#x22;Get Unified Group&#x22;,&#x22;scopes&#x22;:[&#x22;https://www.googleapis.com/auth/admin.directory.group.readonly&#x22;]},{&#x22;id&#x22;:&#x22;googledirectory_unified_list_organizations&#x22;,&#x22;label&#x22;:&#x22;List Unified Organizations&#x22;,&#x22;scopes&#x22;:[&#x22;https://www.googleapis.com/auth/admin.directory.domain.readonly&#x22;]},{&#x22;id&#x22;:&#x22;googledirectory_unified_get_organization&#x22;,&#x22;label&#x22;:&#x22;Get Unified Organization&#x22;,&#x22;scopes&#x22;:[&#x22;https://www.googleapis.com/auth/admin.directory.domain.readonly&#x22;]},{&#x22;id&#x22;:&#x22;googledirectory_unified_list_resource_types&#x22;,&#x22;label&#x22;:&#x22;List Unified Resource Types&#x22;,&#x22;scopes&#x22;:[&#x22;https://www.googleapis.com/auth/admin.directory.user.readonly&#x22;]},{&#x22;id&#x22;:&#x22;googledirectory_unified_list_resource_users&#x22;,&#x22;label&#x22;:&#x22;List Unified Resource Users&#x22;,&#x22;scopes&#x22;:[&#x22;https://www.googleapis.com/auth/admin.directory.group.readonly&#x22;]},{&#x22;id&#x22;:&#x22;googledirectory_unified_list_roles&#x22;,&#x22;label&#x22;:&#x22;List Unified Roles&#x22;,&#x22;scopes&#x22;:[&#x22;https://www.googleapis.com/auth/admin.directory.user.readonly&#x22;]},{&#x22;id&#x22;:&#x22;googledirectory_unified_get_role&#x22;,&#x22;label&#x22;:&#x22;Get Unified Role&#x22;,&#x22;scopes&#x22;:[&#x22;https://www.googleapis.com/auth/admin.directory.user.readonly&#x22;]},{&#x22;id&#x22;:&#x22;googledirectory_unified_list_users&#x22;,&#x22;label&#x22;:&#x22;List Unified Users&#x22;,&#x22;scopes&#x22;:[&#x22;https://www.googleapis.com/auth/admin.directory.user.readonly&#x22;]},{&#x22;id&#x22;:&#x22;googledirectory_unified_get_user&#x22;,&#x22;label&#x22;:&#x22;Get Unified User&#x22;,&#x22;scopes&#x22;:[&#x22;https://www.googleapis.com/auth/admin.directory.user.readonly&#x22;]},{&#x22;id&#x22;:&#x22;googledirectory_list_users&#x22;,&#x22;label&#x22;:&#x22;List Users&#x22;,&#x22;scopes&#x22;:[&#x22;https://www.googleapis.com/auth/admin.directory.user.readonly&#x22;]},{&#x22;id&#x22;:&#x22;googledirectory_get_user&#x22;,&#x22;label&#x22;:&#x22;Get User&#x22;,&#x22;scopes&#x22;:[&#x22;https://www.googleapis.com/auth/admin.directory.user.readonly&#x22;]},{&#x22;id&#x22;:&#x22;googledirectory_create_user&#x22;,&#x22;label&#x22;:&#x22;Create User&#x22;,&#x22;scopes&#x22;:[&#x22;https://www.googleapis.com/auth/admin.directory.user&#x22;]},{&#x22;id&#x22;:&#x22;googledirectory_update_user&#x22;,&#x22;label&#x22;:&#x22;Update User&#x22;,&#x22;scopes&#x22;:[&#x22;https://www.googleapis.com/auth/admin.directory.user&#x22;]},{&#x22;id&#x22;:&#x22;googledirectory_delete_user&#x22;,&#x22;label&#x22;:&#x22;Delete User&#x22;,&#x22;scopes&#x22;:[&#x22;https://www.googleapis.com/auth/admin.directory.user&#x22;]},{&#x22;id&#x22;:&#x22;googledirectory_patch_user&#x22;,&#x22;label&#x22;:&#x22;Patch User&#x22;,&#x22;scopes&#x22;:[&#x22;https://www.googleapis.com/auth/admin.directory.user&#x22;]},{&#x22;id&#x22;:&#x22;googledirectory_list_groups&#x22;,&#x22;label&#x22;:&#x22;List Groups&#x22;,&#x22;scopes&#x22;:[&#x22;https://www.googleapis.com/auth/admin.directory.group.readonly&#x22;]},{&#x22;id&#x22;:&#x22;googledirectory_get_group&#x22;,&#x22;label&#x22;:&#x22;Get Group&#x22;,&#x22;scopes&#x22;:[&#x22;https://www.googleapis.com/auth/admin.directory.group.readonly&#x22;]},{&#x22;id&#x22;:&#x22;googledirectory_create_group&#x22;,&#x22;label&#x22;:&#x22;Create Group&#x22;,&#x22;scopes&#x22;:[&#x22;https://www.googleapis.com/auth/admin.directory.group&#x22;]},{&#x22;id&#x22;:&#x22;googledirectory_update_group&#x22;,&#x22;label&#x22;:&#x22;Update Group&#x22;,&#x22;scopes&#x22;:[&#x22;https://www.googleapis.com/auth/admin.directory.group&#x22;]},{&#x22;id&#x22;:&#x22;googledirectory_delete_group&#x22;,&#x22;label&#x22;:&#x22;Delete Group&#x22;,&#x22;scopes&#x22;:[&#x22;https://www.googleapis.com/auth/admin.directory.group&#x22;]},{&#x22;id&#x22;:&#x22;googledirectory_patch_group&#x22;,&#x22;label&#x22;:&#x22;Patch Group&#x22;,&#x22;scopes&#x22;:[&#x22;https://www.googleapis.com/auth/admin.directory.group&#x22;]},{&#x22;id&#x22;:&#x22;googledirectory_list_members&#x22;,&#x22;label&#x22;:&#x22;List Members&#x22;,&#x22;scopes&#x22;:[&#x22;https://www.googleapis.com/auth/admin.directory.group.readonly&#x22;]},{&#x22;id&#x22;:&#x22;googledirectory_get_member&#x22;,&#x22;label&#x22;:&#x22;Get Member&#x22;,&#x22;scopes&#x22;:[&#x22;https://www.googleapis.com/auth/admin.directory.group.readonly&#x22;]},{&#x22;id&#x22;:&#x22;googledirectory_create_member&#x22;,&#x22;label&#x22;:&#x22;Add Member To Group&#x22;,&#x22;scopes&#x22;:[&#x22;https://www.googleapis.com/auth/admin.directory.group&#x22;]},{&#x22;id&#x22;:&#x22;googledirectory_update_member&#x22;,&#x22;label&#x22;:&#x22;Update Member&#x22;,&#x22;scopes&#x22;:[&#x22;https://www.googleapis.com/auth/admin.directory.group&#x22;]},{&#x22;id&#x22;:&#x22;googledirectory_delete_member&#x22;,&#x22;label&#x22;:&#x22;Remove Member From Group&#x22;,&#x22;scopes&#x22;:[&#x22;https://www.googleapis.com/auth/admin.directory.group&#x22;]},{&#x22;id&#x22;:&#x22;googledirectory_patch_member&#x22;,&#x22;label&#x22;:&#x22;Patch Member&#x22;,&#x22;scopes&#x22;:[&#x22;https://www.googleapis.com/auth/admin.directory.group&#x22;]},{&#x22;id&#x22;:&#x22;googledirectory_has_member&#x22;,&#x22;label&#x22;:&#x22;Check Member Existence&#x22;,&#x22;scopes&#x22;:[&#x22;https://www.googleapis.com/auth/admin.directory.group.readonly&#x22;]},{&#x22;id&#x22;:&#x22;googledirectory_list_orgunits&#x22;,&#x22;label&#x22;:&#x22;List Organizational Units&#x22;,&#x22;scopes&#x22;:[&#x22;https://www.googleapis.com/auth/admin.directory.orgunit.readonly&#x22;]},{&#x22;id&#x22;:&#x22;googledirectory_get_orgunit&#x22;,&#x22;label&#x22;:&#x22;Get Organizational Unit&#x22;,&#x22;scopes&#x22;:[&#x22;https://www.googleapis.com/auth/admin.directory.orgunit.readonly&#x22;]},{&#x22;id&#x22;:&#x22;googledirectory_create_orgunit&#x22;,&#x22;label&#x22;:&#x22;Create Organizational Unit&#x22;,&#x22;scopes&#x22;:[&#x22;https://www.googleapis.com/auth/admin.directory.orgunit&#x22;]},{&#x22;id&#x22;:&#x22;googledirectory_update_orgunit&#x22;,&#x22;label&#x22;:&#x22;Update Organizational Unit&#x22;,&#x22;scopes&#x22;:[&#x22;https://www.googleapis.com/auth/admin.directory.orgunit&#x22;]},{&#x22;id&#x22;:&#x22;googledirectory_delete_orgunit&#x22;,&#x22;label&#x22;:&#x22;Delete Organizational Unit&#x22;,&#x22;scopes&#x22;:[&#x22;https://www.googleapis.com/auth/admin.directory.orgunit&#x22;]},{&#x22;id&#x22;:&#x22;googledirectory_patch_orgunit&#x22;,&#x22;label&#x22;:&#x22;Patch Organizational Unit&#x22;,&#x22;scopes&#x22;:[&#x22;https://www.googleapis.com/auth/admin.directory.orgunit&#x22;]},{&#x22;id&#x22;:&#x22;googledirectory_list_domains&#x22;,&#x22;label&#x22;:&#x22;List Domains&#x22;,&#x22;scopes&#x22;:[&#x22;https://www.googleapis.com/auth/admin.directory.domain.readonly&#x22;]},{&#x22;id&#x22;:&#x22;googledirectory_get_domain&#x22;,&#x22;label&#x22;:&#x22;Get Domain&#x22;,&#x22;scopes&#x22;:[&#x22;https://www.googleapis.com/auth/admin.directory.domain.readonly&#x22;]},{&#x22;id&#x22;:&#x22;googledirectory_create_domain&#x22;,&#x22;label&#x22;:&#x22;Create Domain&#x22;,&#x22;scopes&#x22;:[&#x22;https://www.googleapis.com/auth/admin.directory.domain&#x22;]},{&#x22;id&#x22;:&#x22;googledirectory_delete_domain&#x22;,&#x22;label&#x22;:&#x22;Delete Domain&#x22;,&#x22;scopes&#x22;:[&#x22;https://www.googleapis.com/auth/admin.directory.domain&#x22;]}]" style={{ borderRadius: '8px', padding: '16px', marginBottom: '24px' }}>
    <div className="guides-scope-selector__title" style={{ fontSize: '16px', fontWeight: '600', marginBottom: '12px' }}>Select Actions to adjust the guide</div>
    <div className="guides-scope-selector__muted" style={{ fontSize: '13px', marginBottom: '12px' }}>Some actions may require additional configuration in the provider to be accessible. Choose the actions you need and the guide will be updated.</div>

    <div style={{ display: 'flex', gap: '8px', marginBottom: '12px', flexWrap: 'wrap' }}>
      <input type="text" placeholder="Search actions..." className="guides-scope-selector__input" data-guide-action-search style={{ padding: '8px 12px', borderRadius: '6px', fontSize: '13px', flex: 1, minWidth: '160px' }} />

      <button type="button" className="guides-scope-selector__quick-btn" data-guide-select-all style={{ padding: '6px 10px', borderRadius: '6px', fontSize: '12px', cursor: 'pointer' }}>Select all</button>
      <button type="button" className="guides-scope-selector__quick-btn" data-guide-clear style={{ padding: '6px 10px', borderRadius: '6px', fontSize: '12px', cursor: 'pointer' }}>Clear</button>
    </div>

    <div className="guides-scope-selector__list" style={{ maxHeight: '240px', overflowY: 'auto', borderRadius: '6px', marginBottom: '12px' }}>
      <div className="guides-scope-selector__list-header" style={{ display: 'flex', alignItems: 'center', gap: '10px', padding: '8px 12px', fontSize: '12px', fontWeight: '600', position: 'sticky', top: 0, zIndex: 1 }}>
        <div style={{ width: '16px', flexShrink: 0 }} />

        <div style={{ flex: 1, textAlign: 'left' }}>Action</div>
        <div style={{ minWidth: '120px', marginLeft: 'auto', textAlign: 'right' }}>Scope(s)</div>
      </div>

      <div className="guides-scope-selector__muted" data-guide-loading style={{ padding: '16px', textAlign: 'center', fontSize: '13px' }}>Loading actions...</div>
      <div className="guides-scope-selector__muted" data-guide-no-results hidden style={{ padding: '16px', textAlign: 'center', fontSize: '13px' }}>No actions match your search.</div>
    </div>

    <div className="guides-scope-selector__url-section" style={{ marginTop: '12px', paddingTop: '12px' }}>
      <div className="guides-scope-selector__muted" style={{ fontSize: '12px', fontWeight: '500', marginBottom: '6px' }}>Dynamic Guide URL</div>

      <div style={{ display: 'flex', alignItems: 'center', gap: '8px', flexWrap: 'wrap' }}>
        <input type="text" readOnly className="guides-scope-selector__input" data-guide-url style={{ flex: 1, minWidth: '200px', padding: '8px 10px', borderRadius: '6px', fontSize: '12px', fontFamily: 'monospace' }} />

        <button type="button" className="guides-scope-selector__copy-btn" data-guide-copy-url style={{ width: '120px', padding: '8px 14px', borderRadius: '6px', fontSize: '13px', fontWeight: '500', cursor: 'pointer', whiteSpace: 'nowrap', marginLeft: 'auto' }}>Copy URL</button>
      </div>

      <div style={{ marginTop: '12px' }}>
        <div className="guides-scope-selector__muted" style={{ fontSize: '12px', fontWeight: '500', marginBottom: '6px' }}>Scopes Selected</div>

        <div style={{ display: 'flex', alignItems: 'stretch', gap: '8px', flexWrap: 'wrap' }}>
          <pre className="guides-scope-selector__input" role="textbox" aria-readonly="true" tabIndex={0} data-guide-scopes-output style={{ flex: 1, minWidth: '200px', minHeight: '88px', maxHeight: '120px', overflowY: 'auto', margin: 0, padding: '8px 10px', borderRadius: '6px', fontSize: '12px', fontFamily: 'monospace', whiteSpace: 'pre-wrap' }} />

          <div className="guides-scope-selector__muted" style={{ display: 'flex', flexDirection: 'column', gap: '8px', fontSize: '12px', fontWeight: '500', flexShrink: 0, alignItems: 'flex-start' }}>
            <div style={{ whiteSpace: 'nowrap' }}>Separator</div>

            <select className="guides-scope-selector__input" data-guide-scope-delimiter style={{ width: '100%', padding: '6px 10px', borderRadius: '6px', fontSize: '12px' }}>
              <option value="space">Space</option>
              <option value="comma">Comma</option>
              <option value="semicolon">Semicolon</option>
              <option value="pipe">Pipe</option>
              <option value="newline">Newline</option>
            </select>

            <button type="button" className="guides-scope-selector__copy-btn" data-guide-copy-scopes style={{ width: '120px', padding: '8px 14px', borderRadius: '6px', fontSize: '13px', fontWeight: '500', cursor: 'pointer', whiteSpace: 'nowrap' }}>Copy scopes</button>
          </div>
        </div>
      </div>
    </div>
  </div>
</Panel>

<section data-guide-section data-guide-scopes="">
  <h2>Create or select a Google Cloud project</h2>

  <p>To use Admin SDK API with OAuth 2.0, you need a Google Cloud project.</p>

  <Steps>
    <Step title="Sign in to Google Cloud">
      <div data-guide-step data-guide-scopes="" data-guide-display-scopes-list="">
        <p>Sign in to your <a href="https://console.cloud.google.com/" target="_blank" rel="noopener noreferrer">Google Cloud Console</a>.</p>
      </div>
    </Step>

    <Step title="Create or select a project">
      <div data-guide-step data-guide-scopes="" data-guide-display-scopes-list="">
        <p>Select an existing project from the dropdown at the top of the page, or create a new one by clicking <strong>New Project</strong> and filling in the <strong>Project name</strong>, <strong>Organization</strong>, and <strong>Parent resource</strong> fields, then clicking <strong>Create</strong>.</p>
      </div>
    </Step>
  </Steps>
</section>

<section data-guide-section data-guide-scopes="">
  <h2>Enable the Admin SDK API</h2>

  <p>Enable the Admin SDK API for your project. This step is required whether you created a new project or selected an existing one.</p>

  <Steps>
    <Step title="Open the API Library">
      <div data-guide-step data-guide-scopes="" data-guide-display-scopes-list="">
        <p>In the Google Cloud Console, navigate to <strong>APIs & Services</strong> > <strong>Library</strong>.</p>
      </div>
    </Step>

    <Step title="Enable Admin SDK API">
      <div data-guide-step data-guide-scopes="" data-guide-display-scopes-list="">
        <p>Search for "Admin SDK API", click on it.</p>

        <ul>
          <li><strong>New project</strong>: Click <strong>Enable</strong> to activate the API.</li>
          <li><strong>Existing project</strong>: If the API is already enabled, the button will show <strong>Manage</strong>. If it shows <strong>Enable</strong>, click it to enable the API.</li>
        </ul>
      </div>
    </Step>
  </Steps>
</section>

<section data-guide-section data-guide-scopes="">
  <h2>Configure Google Auth Platform</h2>

  <p>Before creating OAuth credentials, ensure Google Auth Platform is configured.</p>

  <Steps>
    <Step title="Navigate to Google Auth Platform">
      <div data-guide-step data-guide-scopes="" data-guide-display-scopes-list="">
        <p>In the Google Cloud Console, go to <strong>APIs & Services</strong> > <strong>OAuth consent screen</strong>. This will open the Google Auth Platform dashboard.</p>
      </div>
    </Step>

    <Step title="Start configuration">
      <div data-guide-step data-guide-scopes="" data-guide-display-scopes-list="">
        <p>If you have already configured Auth Platform (the OAuth Overview page with usage metrics is shown), skip this step and navigate to the <strong>Branding</strong> page from the sidebar. Otherwise, you will see a <strong>Get started</strong> button — click it to begin the configuration process.</p>
      </div>
    </Step>

    <Step title="Enter app information">
      <div data-guide-step data-guide-scopes="" data-guide-display-scopes-list="">
        <p>Fill in the required fields for your application.</p>

        <ul>
          <li><strong>App name</strong>: Enter a name for your application (e.g., StackOne Integration).</li>
          <li><strong>User support email</strong>: Select an email for user inquiries.</li>
          <li>Click <strong>Next</strong> to continue.</li>
        </ul>
      </div>
    </Step>

    <Step title="Select audience">
      <div data-guide-step data-guide-scopes="" data-guide-display-scopes-list="">
        <p>Choose the appropriate user type for your application.</p>

        <ul>
          <li><strong>Internal</strong>: Only users within your Google Workspace organization can authorize (no app verification required).</li>
          <li><strong>External</strong>: Any Google account can authorize (requires app verification for production use).</li>
          <li>Click <strong>Next</strong> to continue.</li>
        </ul>
      </div>
    </Step>

    <Step title="Enter contact information">
      <div data-guide-step data-guide-scopes="" data-guide-display-scopes-list="">
        <p>Provide email addresses for Google to notify you about any changes to your project. Click <strong>Next</strong> to continue.</p>
      </div>
    </Step>

    <Step title="Finish configuration">
      <div data-guide-step data-guide-scopes="" data-guide-display-scopes-list="">
        <p>Review your settings, agree to the Google API Services User Data Policy, and click <strong>Create</strong> to complete the setup.</p>
      </div>
    </Step>
  </Steps>
</section>

<section data-guide-section data-guide-scopes="">
  <h2>Configure scopes</h2>

  <p>In Google Auth Platform, go to <strong>Data Access</strong> and click <strong>Add or Remove Scopes</strong> to configure the OAuth scopes your application needs.</p>

  <Steps>
    <Step title="Add scopes">
      <div data-guide-step data-guide-scopes="https://www.googleapis.com/auth/admin.directory.user,https://www.googleapis.com/auth/admin.directory.user.readonly,https://www.googleapis.com/auth/admin.directory.group,https://www.googleapis.com/auth/admin.directory.group.readonly,https://www.googleapis.com/auth/admin.directory.orgunit,https://www.googleapis.com/auth/admin.directory.orgunit.readonly,https://www.googleapis.com/auth/admin.directory.domain,https://www.googleapis.com/auth/admin.directory.domain.readonly,https://www.googleapis.com/auth/userinfo.email" data-guide-display-scopes-list="https://www.googleapis.com/auth/admin.directory.user,https://www.googleapis.com/auth/admin.directory.user.readonly,https://www.googleapis.com/auth/admin.directory.group,https://www.googleapis.com/auth/admin.directory.group.readonly,https://www.googleapis.com/auth/admin.directory.orgunit,https://www.googleapis.com/auth/admin.directory.orgunit.readonly,https://www.googleapis.com/auth/admin.directory.domain,https://www.googleapis.com/auth/admin.directory.domain.readonly,https://www.googleapis.com/auth/userinfo.email">
        <div className="connector-guide-actions-badge" data-guide-actions-badge data-guide-actions-badge-scopes="https://www.googleapis.com/auth/admin.directory.user,https://www.googleapis.com/auth/admin.directory.user.readonly,https://www.googleapis.com/auth/admin.directory.group,https://www.googleapis.com/auth/admin.directory.group.readonly,https://www.googleapis.com/auth/admin.directory.orgunit,https://www.googleapis.com/auth/admin.directory.orgunit.readonly,https://www.googleapis.com/auth/admin.directory.domain,https://www.googleapis.com/auth/admin.directory.domain.readonly,https://www.googleapis.com/auth/userinfo.email" style={{ display: 'block', width: 'fit-content', maxWidth: '100%', padding: '2px 8px', borderRadius: '8px', fontSize: '12px', marginBottom: '8px', marginTop: '-10px', whiteSpace: 'nowrap', overflowX: 'auto', overflowY: 'hidden', msOverflowStyle: 'none', scrollbarWidth: 'none' }}>
          <span>Enables actions: </span><span data-guide-actions-badge-labels>Add Member To Group, Check Member Existence, Create Domain, Create Group, Create Organizational Unit, Create User, Delete Domain, Delete Group, Delete Organizational Unit, Delete User, Get Domain, Get Group, Get Member, Get Organizational Unit, Get Unified Group, Get Unified Organization, Get Unified Role, Get Unified User, Get User, List Domains, List Groups, List Members, List Organizational Units, List Unified Groups, List Unified Organizations, List Unified Resource Types, List Unified Resource Users, List Unified Roles, List Unified Users, List Users, Patch Group, Patch Member, Patch Organizational Unit, Patch User, Remove Member From Group, Update Group, Update Member, Update Organizational Unit, Update User</span>
        </div>

        <p>Add scopes based on the Google Directory resources you need to access. Each resource has a read-write scope for full management and a read-only scope for read-only access.</p>

        <ul>
          <li><strong>User management</strong> (list, get, create, update, delete users): `https://www.googleapis.com/auth/admin.directory.user` or `admin.directory.user.readonly` for read-only</li>
          <li><strong>Group management</strong> (list, get, create, update, delete groups): `https://www.googleapis.com/auth/admin.directory.group` or `admin.directory.group.readonly` for read-only</li>
          <li><strong>Organizational unit management</strong> (list, get, create, update, delete org units): `https://www.googleapis.com/auth/admin.directory.orgunit` or `admin.directory.orgunit.readonly` for read-only</li>
          <li><strong>Domain management</strong> (list, get domains): `https://www.googleapis.com/auth/admin.directory.domain` or `admin.directory.domain.readonly` for read-only</li>
          <li><strong>Connection identity</strong> (unified\_get\_me): `https://www.googleapis.com/auth/userinfo.email` — populates the email/name on the IAM credentials record. Without this scope the name field is null.</li>
        </ul>

        <div style={{ marginTop: '8px' }} data-guide-display-scopes>
          <div className="connector-guide-scopes-container">
            <ul className="not-prose" style={{ listStyleType: "'- '", paddingLeft: '1em', margin: 0 }}>
              <li style={{ overflowWrap: 'anywhere', wordBreak: 'break-word' }} data-guide-display-scope="https://www.googleapis.com/auth/admin.directory.user">
                <button type="button" className="connector-guide-scope-copy" aria-label="Copy https://www.googleapis.com/auth/admin.directory.user" title="Copy scope" data-copy="https://www.googleapis.com/auth/admin.directory.user">
                  <span className="connector-guide-scope-copy__label">[https://www.googleapis.com/auth/admin.directory.user](https://www.googleapis.com/auth/admin.directory.user)</span>
                  <span className="connector-guide-scope-copy__icon" aria-hidden="true">⧉</span>
                </button>
              </li>

              <li style={{ overflowWrap: 'anywhere', wordBreak: 'break-word' }} data-guide-display-scope="https://www.googleapis.com/auth/admin.directory.user.readonly">
                <button type="button" className="connector-guide-scope-copy" aria-label="Copy https://www.googleapis.com/auth/admin.directory.user.readonly" title="Copy scope" data-copy="https://www.googleapis.com/auth/admin.directory.user.readonly">
                  <span className="connector-guide-scope-copy__label">[https://www.googleapis.com/auth/admin.directory.user.readonly](https://www.googleapis.com/auth/admin.directory.user.readonly)</span>
                  <span className="connector-guide-scope-copy__icon" aria-hidden="true">⧉</span>
                </button>
              </li>

              <li style={{ overflowWrap: 'anywhere', wordBreak: 'break-word' }} data-guide-display-scope="https://www.googleapis.com/auth/admin.directory.group">
                <button type="button" className="connector-guide-scope-copy" aria-label="Copy https://www.googleapis.com/auth/admin.directory.group" title="Copy scope" data-copy="https://www.googleapis.com/auth/admin.directory.group">
                  <span className="connector-guide-scope-copy__label">[https://www.googleapis.com/auth/admin.directory.group](https://www.googleapis.com/auth/admin.directory.group)</span>
                  <span className="connector-guide-scope-copy__icon" aria-hidden="true">⧉</span>
                </button>
              </li>

              <li style={{ overflowWrap: 'anywhere', wordBreak: 'break-word' }} data-guide-display-scope="https://www.googleapis.com/auth/admin.directory.group.readonly">
                <button type="button" className="connector-guide-scope-copy" aria-label="Copy https://www.googleapis.com/auth/admin.directory.group.readonly" title="Copy scope" data-copy="https://www.googleapis.com/auth/admin.directory.group.readonly">
                  <span className="connector-guide-scope-copy__label">[https://www.googleapis.com/auth/admin.directory.group.readonly](https://www.googleapis.com/auth/admin.directory.group.readonly)</span>
                  <span className="connector-guide-scope-copy__icon" aria-hidden="true">⧉</span>
                </button>
              </li>

              <li style={{ overflowWrap: 'anywhere', wordBreak: 'break-word' }} data-guide-display-scope="https://www.googleapis.com/auth/admin.directory.orgunit">
                <button type="button" className="connector-guide-scope-copy" aria-label="Copy https://www.googleapis.com/auth/admin.directory.orgunit" title="Copy scope" data-copy="https://www.googleapis.com/auth/admin.directory.orgunit">
                  <span className="connector-guide-scope-copy__label">[https://www.googleapis.com/auth/admin.directory.orgunit](https://www.googleapis.com/auth/admin.directory.orgunit)</span>
                  <span className="connector-guide-scope-copy__icon" aria-hidden="true">⧉</span>
                </button>
              </li>

              <li style={{ overflowWrap: 'anywhere', wordBreak: 'break-word' }} data-guide-display-scope="https://www.googleapis.com/auth/admin.directory.orgunit.readonly">
                <button type="button" className="connector-guide-scope-copy" aria-label="Copy https://www.googleapis.com/auth/admin.directory.orgunit.readonly" title="Copy scope" data-copy="https://www.googleapis.com/auth/admin.directory.orgunit.readonly">
                  <span className="connector-guide-scope-copy__label">[https://www.googleapis.com/auth/admin.directory.orgunit.readonly](https://www.googleapis.com/auth/admin.directory.orgunit.readonly)</span>
                  <span className="connector-guide-scope-copy__icon" aria-hidden="true">⧉</span>
                </button>
              </li>

              <li style={{ overflowWrap: 'anywhere', wordBreak: 'break-word' }} data-guide-display-scope="https://www.googleapis.com/auth/admin.directory.domain">
                <button type="button" className="connector-guide-scope-copy" aria-label="Copy https://www.googleapis.com/auth/admin.directory.domain" title="Copy scope" data-copy="https://www.googleapis.com/auth/admin.directory.domain">
                  <span className="connector-guide-scope-copy__label">[https://www.googleapis.com/auth/admin.directory.domain](https://www.googleapis.com/auth/admin.directory.domain)</span>
                  <span className="connector-guide-scope-copy__icon" aria-hidden="true">⧉</span>
                </button>
              </li>

              <li style={{ overflowWrap: 'anywhere', wordBreak: 'break-word' }} data-guide-display-scope="https://www.googleapis.com/auth/admin.directory.domain.readonly">
                <button type="button" className="connector-guide-scope-copy" aria-label="Copy https://www.googleapis.com/auth/admin.directory.domain.readonly" title="Copy scope" data-copy="https://www.googleapis.com/auth/admin.directory.domain.readonly">
                  <span className="connector-guide-scope-copy__label">[https://www.googleapis.com/auth/admin.directory.domain.readonly](https://www.googleapis.com/auth/admin.directory.domain.readonly)</span>
                  <span className="connector-guide-scope-copy__icon" aria-hidden="true">⧉</span>
                </button>
              </li>

              <li style={{ overflowWrap: 'anywhere', wordBreak: 'break-word' }} data-guide-display-scope="https://www.googleapis.com/auth/userinfo.email">
                <button type="button" className="connector-guide-scope-copy" aria-label="Copy https://www.googleapis.com/auth/userinfo.email" title="Copy scope" data-copy="https://www.googleapis.com/auth/userinfo.email">
                  <span className="connector-guide-scope-copy__label">[https://www.googleapis.com/auth/userinfo.email](https://www.googleapis.com/auth/userinfo.email)</span>
                  <span className="connector-guide-scope-copy__icon" aria-hidden="true">⧉</span>
                </button>
              </li>
            </ul>
          </div>
        </div>
      </div>
    </Step>

    <Step title="Select scopes from the list">
      <div data-guide-step data-guide-scopes="" data-guide-display-scopes-list="">
        <p>In the <strong>Update selected scopes</strong> side panel that opens, check the required scopes from the list.</p>
      </div>
    </Step>

    <Step title="Manually add scopes (if needed)">
      <div data-guide-step data-guide-scopes="" data-guide-display-scopes-list="">
        <p>If a required scope is not shown in the list, use the <strong>Manually add scopes</strong> section.</p>

        <ul>
          <li>Enter the full scope URL in the input field.</li>
          <li>Click <strong>Add to table</strong>.</li>
        </ul>
      </div>
    </Step>

    <Step title="Apply and save">
      <div data-guide-step data-guide-scopes="" data-guide-display-scopes-list="">
        <p>Confirm and persist your scope configuration.</p>

        <ul>
          <li>Click <strong>Update</strong> to apply the selected scopes. The side panel will close.</li>
          <li>On the <strong>Data Access</strong> page, click <strong>Save</strong> to persist the scope configuration.</li>
        </ul>
      </div>
    </Step>

    <Step title="Understand admin privilege requirements">
      <div data-guide-step data-guide-scopes="" data-guide-display-scopes-list="">
        <p>Adding the correct OAuth scope is necessary but not sufficient for user management actions. If you receive a <strong>403 Forbidden</strong> error when running actions such as listing or getting users, this indicates the Google account used to authorize the connection does not have the required admin role in Google Workspace.<br /><br />The Google Directory API requires the authenticated account to have <strong>Super Admin</strong> or an appropriate <strong>Delegated Admin</strong> role in your Google Workspace organization. To resolve this, ensure the account used to connect is assigned the Super Admin role or the relevant delegated admin privilege in the <a href="https://admin.google.com/" target="_blank" rel="noopener noreferrer">Google Admin Console</a>.</p>
      </div>
    </Step>
  </Steps>
</section>

<section data-guide-section data-guide-scopes="">
  <h2>Create OAuth 2.0 client credentials</h2>

  <p>Set up OAuth client credentials to authenticate with Admin SDK API. If you already have an existing OAuth 2.0 client, you can reuse it by adding the StackOne redirect URI and generating a new secret.</p>

  <Steps>
    <Step title="Navigate to Credentials">
      <div data-guide-step data-guide-scopes="" data-guide-display-scopes-list="">
        <p>In the Google Cloud Console, go to <strong>APIs & Services</strong> > <strong>Credentials</strong>.</p>
      </div>
    </Step>

    <Step title="Option A — Create a new OAuth client">
      <div data-guide-step data-guide-scopes="" data-guide-display-scopes-list="">
        <p>Skip this step if you are using an existing client.</p>

        <ul>
          <li>Click <strong>+ Create Credentials</strong> and select <strong>OAuth client ID</strong>.</li>
          <li>Select <strong>Web application</strong> as the application type.</li>
          <li>Enter a <strong>Name</strong> for your OAuth client (e.g., StackOne Directory Integration).</li>
          <li>Under <strong>Authorized redirect URIs</strong>, click <strong>Add URI</strong> and enter `https://api.stackone.com/connect/oauth2/googledirectory/callback`.</li>
          <li>Click <strong>Create</strong>. A dialog will display your <strong>Client ID</strong> and <strong>Client Secret</strong> — copy and store them securely.</li>
        </ul>
      </div>
    </Step>

    <Step title="Option B — Use an existing OAuth client">
      <div data-guide-step data-guide-scopes="" data-guide-display-scopes-list="">
        <p>Skip this step if you created a new client above.</p>

        <ul>
          <li>Click on your existing OAuth 2.0 client ID from the list.</li>
          <li>Under <strong>Authorized redirect URIs</strong>, click <strong>Add URI</strong>, enter `https://api.stackone.com/connect/oauth2/googledirectory/callback`, and click <strong>Save</strong>.</li>
          <li>Under <strong>Client secrets</strong>, click <strong>+ Add secret</strong> to generate a new secret. Copy it and store it securely — it will not be shown again.</li>
          <li>Your <strong>Client ID</strong> is shown on the same page under <strong>Additional information</strong>.</li>
        </ul>
      </div>
    </Step>
  </Steps>
</section>

## Creating the StackOne Connector Profile

To create the Connector Profile in StackOne for <strong>Google Directory</strong>:

<Steps>
  <Step title="Navigate to Connector Profiles">
    Login to StackOne and navigate to [Connector Profiles](https://app.stackone.com/connector_profiles)
  </Step>

  <Step title="Create New Connector Profile">
    <ul>
      <li>Click <strong>+ Connector Profile</strong></li>
      <li>Search for and select <strong>Google Directory</strong></li>
      <li>Select <strong>Type</strong> as <strong>OAuth 2.0</strong></li>

      <li>
        Fill out the fields using details retrieved from your provider:

        <ul style={{ marginLeft: '20px' }}>
          <li><strong>Client ID</strong></li>
          <li><strong>Client Secret</strong></li>
          <li><strong>Scopes</strong> (Optional)</li>
        </ul>
      </li>

      <li>(Optional) Select <strong>Actions</strong> to be enabled for this Connector Profile</li>
      <li>Click <strong>Create profile</strong></li>
    </ul>
  </Step>
</Steps>

Congratulations! The new Connector Profile will now show up in your project ready to be used. You can now continue to <a href="/guides/accounts-section#linking-accounts">Link Accounts</a> for <strong>Google Directory</strong>.
