apiconnect-explorer
Version:
- [Getting Started](#getting-started) - [Configuration](#configuration) * [Required](#required) * [Optional](#optional) - [Usage in React](#usage-in-react) - [Usage outside of React](#usage-outside-of-react) - [Detailed description of options](#detail
191 lines (189 loc) • 35.3 kB
JavaScript
/** ******************************************************* {COPYRIGHT-TOP} ***
* Licensed Materials - Property of IBM
*
* (C) Copyright IBM Corporation 2017, 2025
*
* All Rights Reserved.
* US Government Users Restricted Rights - Use, duplication or disclosure
* restricted by GSA ADP Schedule Contract with IBM Corp.
********************************************************** {COPYRIGHT-END} * */
window.apiConnectExplorer = {
attachPoint: '#root',
options: {
loggedIn: false,
tryIt: true,
headerActive: false,
apiMaxDepth: 9,
routerType: 'hash',
exampleArrayItems: 3,
// removeIBMKeys: true,
// enable proxyUrl to route through the webpack dev proxy
// proxyUrl: "/api/proxyService"
infoSectionEntries: [
[
{
"class": "testInfo",
"html": "Test Info Section<p>This is HTML content added to the infosection.</p><p>This has <b>HTML</b> tags in it.</p>",
"location": "OVERVIEW"
},
{
"class": "testInfo2",
"html": "Test Info Section 2<p>This is more HTML content added to the infosection.</p><p>This has <b>HTML</b> tags in it.</p>",
"location": "OVERVIEW"
},
{
"class": "definitionsInfo",
"html": "Definitions Info Section<p>Extra information for the definitions page.</p><p>This is more information <a href='http://www.example.com/'>example.com</a></p>",
"location": "DEFINITIONS"
}
]
],
documentationEntries: [
[
{ title: "Test Documentation", url: "/assets/testDocumentation.html", extractPortalContent: true },
{ title: "Not found url", url: "/notFoundURL.html" }
]
]
},
apps: [
{
"name": "Application One",
"description": "The first application",
"redirectUri": ["https://apictest1.example.com/redirect"],
"credentials": [
{
"client_id": "c866ff37f155bbf107ccc969781dedfc", // pragma: whitelist secret
"description": "Default",
"name": "credential-for-application-one",
"title": "Credential for Application One"
}
],
"subscribed": false
},
{
"name": "Application Two",
"description": "The second application",
"redirectUri": ["https://example2.com/redirectUri", "https://apictest.example2.com/redirect"],
"credentials": [
{
"client_id": "4bcb6f8359de971613702013bdc50c44", // pragma: whitelist secret
"description": "Default"
},
{
"client_id": "e159aaf8-b789-479b-859f-app2cred2", // pragma: whitelist secret
"description": "Something else",
}
],
"subscribed": true
},
{
"name": "Application Three",
"description": "The third application",
"redirectUri": [],
"credentials": [
{
"client_id": "51414fa6-a2e7-443a-a684-app3cred1", // pragma: whitelist secret
"description": "Default"
}
],
"subscribed": false
},
{
"name": "Application Four",
"description": "The fourth application",
"redirectUri": null,
"credentials": [
{
"client_id": "51414fa6-a2e7-443a-a684-app4cred1", // pragma: whitelist secret
"description": "Default"
}
],
"subscribed": false
},
{
"name": "Application Five",
"description": "The fifth application",
"redirectUri": [""],
"credentials": [
{
"client_id": "51414fa6-a2e7-443a-a684-app5cred5", // pragma: whitelist secret
"description": "Default"
}
],
"subscribed": true
},
{
"name": "Application Six",
"description": "The sixth application",
"redirectUri": "https://example6.com/redirectUri",
"credentials": [
{
"client_id": "51414fa6-a2e7-443a-a684-app6cred1", // pragma: whitelist secret
"description": "Default"
}
],
"subscribed": true
},
{
"name": "my other app",
"redirectUri": [],
"credentials": [
{
"client_id": "00a9564ce1cb5d6d4b4e113d175dac57", // pragma: whitelist secret
"description": null
},
{
"client_id": "fe8349efddf3059c355fa3aa6dec6e3f", // pragma: whitelist secret
"description": "Credential for my other app",
"name": "credential-for-my-other-app",
"title": "Credential for my other app"
},
{
"client_id": "6b2bbcd0fe7410358024efc2e349dce2", // pragma: whitelist secret
"description": null,
"name": "cred-no-desc-summary",
"title": "cred no desc/summary",
},
{
"client_id": "8d8398c82c178921dd8dd9081f7a304b", // pragma: whitelist secret
"description": "this is a description",
"name": "cred-with-desc-summary",
"title": "cred with desc/summary",
}
],
"subscribed": false
}
],
/* docs: [
{
"name": "introduction",
"title": "Introduction",
"format": "b64html",
"content": "PGFydGljbGUgaWQ9ImludHJvZHVjdGlvbiIgY2xhc3M9InBhZ2UiPgoKICA8ZGl2IGNsYXNzPSJhcGljLWV4cGxvcmVyLWRvY3BhZ2VfdGl0bGUiPgogICAgPGgyIGNsYXNzPSJhcGljLWV4cGxvcmVyLWRvY3BhZ2VfdGl0bGUtdGV4dCI+CiAgICAgIDxzcGFuIGNsYXNzPSJleHBsb3Jlci1kb2MtLWhlYWRlciBpbnRyby1oZWFkZXIiPgogICAgICAgIE9wZW4gQVBJIEV4cGxvcmVyIERvY3VtZW50YXRpb24KICAgICAgPC9zcGFuPgogICAgPC9oMj4KICA8L2Rpdj4KICA8ZGl2IGNsYXNzPSJhcGljLWV4cGxvcmVyLWRvY3BhZ2VfY29udGVudCBpbnRyby1jb250ZW50Ij4KICAgIDxzZWN0aW9uPgogICAgICA8aDI+SW50cm9kdWN0aW9uPC9oMj4KICAgICAgPHA+CiAgICAgICAgVGhlIHBsYXRmb3JtIFJFU1QgQVBJcyBkb2N1bWVudGVkIGhlcmUgZm9yIElCTSBBUEkgQ29ubmVjdCB2MTAgcHJvdmlkZSBjb21wbGV0ZSBhY2Nlc3MgdG8gdGhlIGNhcGFiaWxpdHkgb2YgdGhlIHBsYXRmb3JtLiBUaGV5IG1heSBiZSB1c2VkIHRvIGF1dG9tYXRlIGFkbWluaXN0cmF0aW9uIG9mIHRoZSBwbGF0Zm9ybTsgZm9yIHNjcmlwdHMgYW5kIHRvb2xzIHRvIHN1cHBvcnQgYSBjb250aW51b3VzIGludGVncmF0aW9uIGVudmlyb25tZW50IGZvciBBUEkgZGV2ZWxvcG1lbnQgYW5kIHB1Ymxpc2hpbmc7IGFuZCBmb3IgbWFuYWdlbWVudCBvZiBjYXRhbG9ncyBvZiBBUElzIGFuZCB0aGVpciBzdWJzY3JpYmVycy4gVGhlIG9wZXJhdGlvbnMgcHJvdmlkZWQgaW4gdGhlIFJFU1QgQVBJIGFsc28gY29ycmVzcG9uZCBkaXJlY3RseSB3aXRoIGNvbW1hbmRzIGluIHRoZSB0b29sa2l0IENMSS4KICAgICAgPC9wPgogICAgPC9zZWN0aW9uPgogICAgPHNlY3Rpb24+CiAgICAgIDxoMj5BUElzPC9oMj4KICAgICAgPHA+CiAgICAgICAgVGhlIGNhcGFiaWxpdHkgb2YgdGhlIHBsYXRmb3JtIGlzIGNvbXByaXNlZCBvZiB0aHJlZSBBUElzIHdoaWNoIGFyZSBvcmllbnRlZCBhdCBkaWZmZXJlbnQgc2V0cyBvZiB1c2UgY2FzZXM6CiAgICAgIDwvcD4KICAgICAgPGRpdiBjbGFzcz0ic2hvdy1leHBsb3Jlci1hcGlzIj48L2Rpdj4KICAgIDwvc2VjdGlvbj4KICA8L2Rpdj4KPC9hcnRpY2xlPgo="
},
{
"name": "concepts",
"title": "Concepts",
"format": "b64html",
"content": "<article id="concepts" class="page">
  <div class="apic-explorer-docpage_title">
    <h2 class="apic-explorer-docpage_title-text">
      <span class="explorer-doc--header concepts-header">
        Concepts
      </span>
    </h2>
  </div>
  <div class="apic-explorer-docpage_content concepts-content">
    <section class="concepts-table">
      <h2>Concepts</h2>
      <p>The primary concepts exposed by the API Connect platform are represented in the top-level resource paths.</p>
      <div class="concept concept-apps">
        <div class="concept-icon">
        </div>
        <div class="concept-title">
          <div class="concept-name">Apps</div>
          <div class="concept-tag">/apps</div>
        </div>
        <div class="concept-description">
          Apps represent registered client applications created by API consumers. An app has one or more client IDs that are associated with subscriptions to APIs.
        </div>
      </div>
      <div class="concept concept-catalogs">
        <div class="concept-icon">
        </div>
        <div class="concept-title">
          <div class="concept-name bx--type-gamma">Catalogs</div>
          <div class="concept-tag">/catalogs</div>
        </div>
        <div class="concept-description">
          A catalog is a logical container for the deployment and consumption of APIs. A catalog represents the execution environment for APIs, and its contents are visible to consumers in its associated developer portal.
        </div>
      </div>
      <div class="concept concept-cloud">
        <div class="concept-icon">
        </div>
        <div class="concept-title">
          <div class="concept-name">Cloud</div>
          <div class="concept-tag">/cloud</div>
        </div>
        <div class="concept-description">
          The cloud represents the API Connect system. It has <code>settings</code> that represent its operational configuration.
        </div>
      </div>
      <div class="concept concept-org">
        <div class="concept-icon">
        </div>
        <div class="concept-title">
          <div class="concept-name">Consumer organizations</div>
          <div class="concept-tag">/consumer-orgs</div>
        </div>
        <div class="concept-description">
          A consumer organization is the scope in which a consumer user (app developers) creates and owns apps and subscriptions. Consumer organizations exist in the context of a catalog.
        </div>
      </div>
      <div class="concept concept-me">
        <div class="concept-icon">
          <svg id="_Layer_" data-name=" Layer " xmlns="http://www.w3.org/2000/svg" width="52" height="52" viewBox="-10 -10 40 40"><defs><style>.cls-1{fill:none;}.cls-2{fill:#5a6872;}</style></defs><title>user_18</title><g id="_Group_" data-name=" Group "><rect id="_Rectangle_" data-name=" Rectangle " class="cls-1" width="18" height="18" /></g><path class="cls-2" d="M9,11A5,5,0,1,0,4,6,5,5,0,0,0,9,11ZM9,2A4,4,0,1,1,5,6,4,4,0,0,1,9,2Z" /><path class="cls-2" d="M13,12H5a2,2,0,0,0-2,2v3H15V14A2,2,0,0,0,13,12Z" /></svg>
        </div>
        <div class="concept-title">
          <div class="concept-name">Me</div>
          <div class="concept-tag">/me</div>
        </div>
        <div class="concept-description">
          The <code>/me</code> resource represents the profile of the current authenticated user. 
        </div>
      </div>
      <div class="concept concept-oauth-endpoint">
        <div class="concept-icon">
          <svg id="_Layer_" data-name=" Layer " xmlns="http://www.w3.org/2000/svg" width="52" height="52" viewBox="-10 -10 40 40"><defs><style>.cls-1{fill:none;}.cls-2{fill:#5a6872;}</style></defs><title>secure_18</title><g id="_Group_" data-name=" Group "><rect id="_Rectangle_" data-name=" Rectangle " class="cls-1" width="18" height="18"/></g><path class="cls-2" d="M13.5,8.34086v-2.844a4.5,4.5,0,0,0-9,0v2.844a5.5,5.5,0,1,0,9,0Zm-7-2.844a2.5,2.5,0,0,1,5,0v1.105a5.474,5.474,0,0,0-5,0Zm1.487,8.752L5.5,11.77786l1-1,1.467,1.474,3.533-3.474,1,1Z"/></svg>
        </div>
        <div class="concept-title">
          <div class="concept-name">OAuth endpoints</div>
          <div class="concept-tag">/oauth2</div>
        </div>
        <div class="concept-description">
          The <code>/oauth2</code> resource provides the authorization and token endpoints for clients of the platform REST APIs (see the authentication topic).
        </div>
      </div>
      <div class="concept concept-org">
        <div class="concept-icon">
        </div>
        <div class="concept-title">
          <div class="concept-name bx--type-gamma">Provider organizations</div>
          <div class="concept-tag">/orgs</div>
        </div>
        <div class="concept-description">
          A provider organization is the scope in which all API provider content is created and configured. This includes API and API product definitions, catalogs, and other configuration objects associated with catalogs. The <em><strong>admin org</strong></em> is a
          special organization that provides the ownership scope for the configuration objects used at the cloud level, and the login context for admin users.
        </div>
      </div>
      <div class="concept concept-spaces">
        <div class="concept-icon">
        </div>
        <div class="concept-title">
          <div class="concept-name bx--type-gamma">Spaces</div>
          <div class="concept-tag">/spaces</div>
        </div>
        <div class="concept-description">
          Spaces are administrative partitions with a <em><strong>catalog</strong></em>, used for collaborative management of APIs by different teams.
        </div>
      </div>
      <div class="concept concept-user-reg">
        <div class="concept-icon">
        </div>
        <div class="concept-title">
          <div class="concept-name bx--type-gamma">User registries</div>
          <div class="concept-tag">/user-registries</div>
        </div>
        <div class="concept-description">
          User registries provide the scope in which information about users and their credentials are held.
        </div>
      </div>
      <p>
        For consumer users, APIs and API Products visible on the developer portal appear as <code>/apis</code> or <code>/public-apis</code>, and <code>/products</code> or <code>/public-products</code>
        respectively. Public API content is visible without authentication, while the non-public content is accessible according to the visibility with which it is published.
      </p>
    </section>
    <section>
      <h2>Scopes</h2>
      <p>The API Connect platform REST APIs are organized around the following conceptual scopes.</p>
      <h3>Cloud scope</h3>
      <p>Cloud scope is the top-level scope for the API Connect system as a whole. Its configuration can only be performed through the admin API. The API paths below <code>cloud</code> provide access to the cloud settings; default role and permissions settings;
        the set of configured integrations (adapters to other infrastructure services such as user registries and billing); the set of API provider organizations and their associated invitations; and the set of registered clients for the system.</p>
      <h3>Organization scope</h3>
      <p>Organization scope is the ownership scope for content and configuration definitions (APIs, catalogs, apps, and configurations representing user registries, TLS profiles, keystore definitions and so on). Most of these resources are created or found using paths
        that begin with <code>/org/{orgs}</code> or paths that have <code>{orgs}</code> or paths that have <code>{orgs}</code> as their first path parameter. Many of the configuration objects that appear in the context of cloud settings
        (/cloud/settings) are objects that are created and owned by the <code>admin</code> organization, which is an organization to which the set of administrator users for the cloud belong.</p>
      <h3>Catalog and space scopes</h3>
      <p>Catalog and space scopes are the contexts in which published API content is managed, and consumer users are administered. (Spaces are optional finer-grained partitions of a catalog.)</p>
    </section>
  </div>
</article>
"
},
{
"name": "authentication",
"title": "Authentication",
"docs": [{
"name": "auth_clientid_secret",
"title": "Obtaining a Client ID and Secret",
"format": "b64html",
"content": "PGFydGljbGUgaWQ9ImNsaWVudC1pZC1zZWNyZXQiIGNsYXNzPSJwYWdlIj4KICA8ZGl2IGNsYXNzPSJhcGljLWV4cGxvcmVyLWRvY3BhZ2VfdGl0bGUiPgogICAgPGgyIGNsYXNzPSJhcGljLWV4cGxvcmVyLWRvY3BhZ2VfdGl0bGUtdGV4dCI+CiAgICAgIDxzcGFuIGNsYXNzPSJleHBsb3Jlci1kb2MtLWhlYWRlciBjbGllbnQtaWQtc2VjcmV0LWhlYWRlciI+CiAgICAgIE9idGFpbmluZyBhIENsaWVudCBJRCBhbmQgU2VjcmV0CiAgICAgIDwvc3Bhbj4KICAgIDwvaDI+CiAgPC9kaXY+CiAgPGRpdiBjbGFzcz0iYXBpYy1leHBsb3Jlci1kb2NwYWdlX2NvbnRlbnQgY2xpZW50LWlkLXNlY3JldC1jb250ZW50Ij4KICAgIDxzZWN0aW9uPgogICAgICA8cD5FYWNoIGNsaWVudCBhcHAgdGhhdCBhY2Nlc3NlcyB0aGUgQVBJIENvbm5lY3QgUkVTVCBBUEkgbXVzdCBiZSByZWdpc3RlcmVkIHdpdGggdGhlIEFQSSBDb25uZWN0IGNsb3VkLiBUaGUgcHJvY2VzcyBvZiByZWdpc3RlcmluZyBhIGNsaWVudCBhc3NvY2lhdGVzIHRoZSBhcHBzJ3MgY2xpZW50IElEIHdpdGggYSBzZXQgb2Ygc2NvcGVzIHRoYXQgZGV0ZXJtaW5lIHdoaWNoIG9wZXJhdGlvbnMgdGhlIGFwcCBtYXkgYWNjZXNzLjwvcD4KICAgICAgPHA+VG8gcmVnaXN0ZXIgYSBjbGllbnQgYXBwLCB1c2UgdGhlIDx0dD5hcGljIHJlZ2lzdHJhdGlvbnM6Y3JlYXRlPC90dD4gQVBJIENvbm5lY3QgdG9vbGtpdCBDTEkgY29tbWFuZC4gVGhlIGNvbW1hbmQgdGFrZXMgYW4gaW5wdXQgSlNPTiBvYmplY3Qgd2l0aCB0aGUgZm9sbG93aW5nIGZpZWxkczo8L3A+CiAgICAgIDxkbD4KICAgICAgICA8ZHQ+bmFtZTwvZHQ+CiAgICAgICAgPGRkPnNob3J0IG5hbWUgdG8gaWRlbnRpZnkgdGhlIGNsaWVudDwvZGQ+CiAgICAgICAgCiAgICAgICAgPGR0PnRpdGxlPC9kdD4KICAgICAgICA8ZGQ+ZGlzcGxheSBuYW1lIG9mIHRoZSBjbGllbnQ8L2RkPgogICAgICAgIAogICAgICAgIDxkdD5jbGllbnRfaWQ8L2R0PgogICAgICAgIDxkZD5hIGdlbmVyYXRlZCBjbGllbnQgSUQgdmFsdWU8L2RkPgoKICAgICAgICA8ZHQ+Y2xpZW50X3NlY3JldDwvZHQ+CiAgICAgICAgPGRkPmEgZ2VuZXJhdGVkIGNsaWVudCBzZWNyZXQgdmFsdWU8L2RkPgoKICAgICAgICA8ZHQ+Y2xpZW50X3R5cGU8L2R0PgogICAgICAgIDxkZD5vbmUgb2YgPHR0PnBvcnRhbDwvdHQ+LCA8dHQ+Z2F0ZXdheTwvdHQ+LCA8dHQ+dG9vbGtpdDwvdHQ+LCA8dHQ+Y29uc3VtZXJfdG9vbGtpdDwvdHQ+LCA8dHQ+dWk8L3R0PiwgPHR0PmNvbnN1bWVyX3VpPC90dD4sIDx0dD5pYm1fY2xvdWQ8L3R0PiwgPHR0Pm1pZ3JhdGlvbjwvdHQ+LCA8dHQ+anVodTwvdHQ+PC9kZD4KICAgICAgPC9kbD4KICAgIDwvc2VjdGlvbj4KICAgIDxzZWN0aW9uPgogICAgICA8cD5JbiBvcmRlciB0byBydW4gdGhpcyBjb21tYW5kLCB5b3UgbXVzdCBmaXJzdCBsb2cgaW4gdG8gdGhlIEFQSSBDb25uZWN0IHNlcnZlciBhcyBhbiBhZG1pbiB1c2VyIHVzaW5nIHRoZSA8dHQ+YXBpYyBsb2dpbjwvdHQ+IGNvbW1hbmQuIFdpdGggbm8gYXJndW1lbnRzLCB0aGUgbG9naW4gY29tbWFuZCBwcm9tcHRzIGZvciB5b3VyIHVzZXIgY3JlZGVudGlhbHMgYW5kIHRoZSByZWFsbSBpbiB3aGljaCB0aGUgdXNlciBhY2NvdW50IGV4aXN0cy4gVGhlIHJlYWxtIGNvcnJlc3BvbmRzIHRvIHRoZSB1c2VyIHJlZ2lzdHJ5IGluIHdoaWNoIHRoZSB1c2VyIGNyZWRlbnRpYWxzIGFyZSBoZWxkLjwvcD4KICAgICAgPHA+SWYgaXQncyB5b3VyIGZpcnN0IHRpbWUgbG9nZ2luZyBpbiB1c2luZyB0aGUgdG9vbGtpdCBDTEksIHlvdSdsbCBuZWVkIHRvIGZpbmQgdGhlIGlkZW50aXR5IHByb3ZpZGVyIHRvIHdoaWNoIHlvdXIgdXNlcmlkIGJlbG9uZ3MuIFlvdSBjYW4gbGlzdCB0aGUgc2V0IG9mIGFkbWluIGlkZW50aXR5IHByb3ZpZGVycyBpbiB0aGUgc3lzdGVtIHVzaW5nIHRoZSA8dHQ+YXBpYyBpZGVudGl0eS1wcm92aWRlcnM6bGlzdDwvdHQ+IGNvbW1hbmQuPC9wPgogICAgPC9zZWN0aW9uPgogICAgPHNlY3Rpb24+CiAgICAgIDxoMz5saXN0aW5nIGlkZW50aXR5IHByb3ZpZGVyczwvaDM+CiAgICAgIDxkaXYgaWQ9ImdldC1yZWFsbXZhbHVlLXJlcXVlc3QiIGNsYXNzPSJzaG93LWV4cGxvcmVyLWNvZGVzbmlwcGV0Ij4KJCBhcGljIGlkZW50aXR5LXByb3ZpZGVyczpsaXN0IC0tc2NvcGUgYWRtaW4gLS1zZXJ2ZXIgYXBpYy5pYm0uY29tCmRlZmF1bHQtaWRwLTEKICAgICAgPC9kaXY+CiAgICA8L3NlY3Rpb24+CiAgICA8c2VjdGlvbj4KICAgICAgPGgzPmFwaWMgbG9naW4gZXhhbXBsZTwvaDM+CiAgICAgIDxkaXYgY2xhc3M9InNob3ctZXhwbG9yZXItY29kZXNuaXBwZXQiPgokIGFwaWMgbG9naW4KRW50ZXIgeW91ciBBUEkgQ29ubmVjdCBjcmVkZW50aWFscwpTZXJ2ZXI/IGNocmlzbS5hcmdvLXNsLmRldi5jaW9uZGVtYW5kLmNvbQpSZWFsbT8gYWRtaW4vZGVmYXVsdC1pZHAtMQpVc2VybmFtZT8gY2hyaXMKUGFzc3dvcmQ/IApMb2dnZWQgaW50byBhcGljLmlibS5jb20gc3VjY2Vzc2Z1bGx5CiAgICAgIDwvZGl2PgogICAgICA8cD4oTm90ZSB0aGF0IHRoZSByZWFsbSBuYW1lIHVzZWQgZm9yIHRoZSBsb2dpbiBoYXMgdGhlIHZhbHVlICdhZG1pbi8nIHByZWZpeGVkIHRvIHRoZSByZWFsbSBuYW1lLik8L3A+CiAgICA8L3NlY3Rpb24+CiAgICA8c2VjdGlvbj4KICAgICAgPGgzPmFwaWMgcmVnaXN0cmF0aW9uczpjcmVhdGUgZXhhbXBsZTwvaDM+CiAgICAgIDxwPlRoaXMgSlNPTiBjb250ZW50ICg8dHQ+YXBwMS5qc29uPC90dD4pIHByb3ZpZGVzIHRoZSBwYXJhbWV0ZXJzIGZvciByZWdpc3RlcmluZyBhbiBhcHAgbmFtZWQgPHR0PmFwcDE8L3R0PiB1c2luZyB0aGUgPHR0PnRvb2xraXQ8L3R0PiBjbGllbnQgdHlwZSBhbmQgYSBwcmUtZGVmaW5lZCBjbGllbnQgSUQgYW5kIHNlY3JldDo8L3A+CiAgICAgIDxkaXYgY2xhc3M9InNob3ctZXhwbG9yZXItY29kZXNuaXBwZXQiPgp7CiAgIm5hbWUiOiAiYXBwMSIsCiAgImNsaWVudF9pZCI6ICJhcHAxaWQiLCAKICAiY2xpZW50X3NlY3JldCI6ICJhcHAxc2VjcmV0IiwKICAiY2xpZW50X3R5cGUiOiAidG9vbGtpdCIKfQogICAgICA8L2Rpdj4KICAgICAgPHA+VGhpcyBleGFtcGxlIHNob3dzIHRoZSByZWdpc3RyYXRpb24gY29tbWFuZCB0byByZWdpc3RlciB0aGlzIGFwcDo8L3A+CiAgICAgIDxkaXYgY2xhc3M9InNob3ctZXhwbG9yZXItY29kZXNuaXBwZXQiPgokIGFwaWMgcmVnaXN0cmF0aW9uczpjcmVhdGUgLS1zZXJ2ZXIgYXBpYy5pYm0uY29tIGFwcDEuanNvbgphcHAxICAgaHR0cHM6Ly9hcGljLmlibS5jb20vYXBpL2Nsb3VkL3JlZ2lzdHJhdGlvbnMvNTExOTYyMjItNzg4Yy00NzRmLWI0YzctMGIzNTFjZTUwOWRlCiAgICAgIDwvZGl2PgogICAgPC9zZWN0aW9uPgo8L2FydGljbGU+Cg=="
},
{
"name": "auth_bearertoken",
"title": "Getting and Using a Bearer Token",
"format": "b64html",
"content": "  <article id="bearer-token" class="page">
    <div class="apic-explorer-docpage_title">
      <h2 class="apic-explorer-docpage_title-text">
        <span class="explorer-doc--header bearer-token-header">
        Obtaining and Using a Bearer Token
        </span>
      </h2>
    </div>
    <div class="apic-explorer-docpage_content bearer-token-content">
      <p>Calls to the API Connect platform REST APIs are authenticated using a bearer token, which is obtained from the <code>/api/token</code> endpoint.</p>
      <section>
        <h3>Requesting a bearer token</h3>
        <p>
          The request to obtain a bearer token is equivalent to an OAuth 2.0 access token request using
          the Resource Owner Password Credentials grant type. However, the request contents must be sent as a JSON payload rather than as form data.
        </p>
        <p>The JSON payload for the bearer token request contains the following fields:</p>
        <dl>
          <dt>username:</dt>
          <dd>the username for the API Connect user making the request</dd>
          
          <dt>password:</dt>
          <dd>the password for the API Connect user making the request</dd>
          
          <dt>realm:</dt>
          <dd>indicates the user registry in which the API Connect user credentials are held</dd>
          
          <dt>client_id:</dt>
          <dd>the client ID of the app making the request</dd>
          
          <dt>client_secret:</dt>
          <dd>the client secret of the app making the request</dd>
          
          <dt>grant_type:</dt>
          <dd>password (fixed value)</dd>
        </dl>
        <p>Here is a curl example showing a bearer token request and successful response:</p>
        <h4>Request</h4>
        <div id="get-bearertoken-request" class="show-explorer-codesnippet">curl -v -k -X POST -d '{"username": "chris", "password": "****", "realm": "provider/default-idp-2", "client_id": "caa87d9a-8cd7-4686-8b6e-ee2cdc5ee267", "client_secret": "3ecff363-7eb3-44be-9e07-6d4386c48b0b", "grant_type": "password"}' -H 'Content-Type: application/json' -H 'Accept: application/json' https://apiconnect-dev.ibm.com/api/token</div>
        <h4>Response</h4>
        <div id="get-bearertoken-response" class="show-explorer-codesnippet">{
  "access_token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJqdGkiOiI1MGVmOGQzOC1lMTUxLTQ4NjctYmIwOS0wNDA0N2UxZjM3NDciLCJuYW1lc3BhY2UiOiIzYjQ1ODU4Ni1kZGMwLTQ1NDYtOThkZi03MmUxMzMzYjA5ZWE6MTYzZDY4MWYtZWUwMC00YWRhLWFiNWQtZDVkMzRlYjdlODVjOjBjODQ0NTgyLTQ1YWMtNDQ2My1hOTc1LThiNmQ1ZjY5MTE1ZCIsImF1ZCI6Ii9hcGkvY2xvdWQvcmVnaXN0cmF0aW9ucy8zOTBhNjVhYS00M2FhLTQ3MzUtYjA0OS04MTk3MjIyZDI3ZDAiLCJzdWIiOiIvYXBpL3VzZXItcmVnaXN0cmllcy8zYjQ1ODU4Ni1kZGMwLTQ1NDYtOThkZi03MmUxMzMzYjA5ZWEvMTYzZDY4MWYtZWUwMC00YWRhLWFiNWQtZDVkMzRlYjdlODVjL3VzZXJzLzBjODQ0NTgyLTQ1YWMtNDQ2My1hOTc1LThiNmQ1ZjY5MTE1ZCIsImlzcyI6IklCTSBBUEkgQ29ubmVjdCIsImV4cCI6MTUzMjU4NjE1MiwiaWF0IjoxNTMyNTU3MzUyLCJncmFudF90eXBlIjoicGFzc3dvcmQiLCJ1c2VyX3JlZ2lzdHJ5X3VybCI6Ii9hcGkvdXNlci1yZWdpc3RyaWVzLzNiNDU4NTg2LWRkYzAtNDU0Ni05OGRmLTcyZTEzMzNiMDllYS8xNjNkNjgxZi1lZTAwLTRhZGEtYWI1ZC1kNWQzNGViN2U4NWMiLCJyZWFsbSI6InByb3ZpZGVyL2RlZmF1bHQtaWRwLTIiLCJ1c2VybmFtZSI6ImNocmlzIiwiaWRfdG9rZW4iOiJleUpoYkdjaU9pSklVekkxTmlJc0luUjVjQ0k2SWtwWFZDSjkuZXlKbWFYSnpkRjl1WVcxbElqb2lRMmh5YVhNaUxDSnNZWE4wWDI1aGJXVWlPaUpOSWl3aWRYTmxjbDlwWkNJNkltSmpOakk0TVdVMUxXUmxOMkl0TkRKbU5pMDRZakkwTFdKak5qY3lZVEEyWmpRd05TSXNJblZ6WlhKdVlXMWxJam9pWTJoeWFYTWlMQ0pwWVhRaU9qRTFNekkxTlRjek5USjkuelpzTXI0OUJkdU9DUlcxb24yWjdsZDI4bnJKRVVDZTA1bmM5MldRX3doNCIsInNjb3BlcyI6WyJjbG91ZDp2aWV3IiwiY2xvdWQ6bWFuYWdlIiwicHJvdmlkZXItb3JnOnZpZXciLCJwcm92aWRlci1vcmc6bWFuYWdlIiwib3JnOnZpZXciLCJvcmc6bWFuYWdlIiwiZHJhZnRzOnZpZXciLCJkcmFmdHM6ZWRpdCIsImNoaWxkOnZpZXciLCJjaGlsZDpjcmVhdGUiLCJjaGlsZDptYW5hZ2UiLCJwcm9kdWN0OnZpZXciLCJwcm9kdWN0OnN0YWdlIiwicHJvZHVjdDptYW5hZ2UiLCJhcHByb3ZhbDp2aWV3IiwiYXBwcm92YWw6bWFuYWdlIiwiYXBpLWFuYWx5dGljczp2aWV3IiwiYXBpLWFuYWx5dGljczptYW5hZ2UiLCJjb25zdW1lci1vcmc6dmlldyIsImNvbnN1bWVyLW9yZzptYW5hZ2UiLCJhcHA6dmlldzphbGwiLCJhcHA6bWFuYWdlOmFsbCIsIm15OnZpZXciLCJteTptYW5hZ2UiLCJ3ZWJob29rOnZpZXciXX0.1ybezGJrJWgRZ8ec5cjyGQTKcWA3iwTbV5AubXCox60",
  "token_type": "Bearer",
  "expires_in": 28800
}
        </div>
      </section>
      <section>
        <h3>Finding Realm Values</h3>
        <p>The realm value used in a bearer token request is a value that identifies the user registry in which the requesting user's credentials are held. This may not be the same realm value as was used to register the app; it will be the same only if the user executing the app is the same user that performed the app registration.</p>
        <p>
          You can query the set of user registries to obtain the configured realm values using an unauthenticated call to the <code>/cloud/admin/identity-providers</code> 
          or <code>/cloud/provider/identity-providers</code> URL for admin users or API provider users respectively.
        </p>
      </section>
      <p>Here is an example request and successful response:</p>
      <h4>Request</h4>
      <div id="get-realmvalue-request" class="show-explorer-codesnippet">
curl -v -k -H "Accept: application/json" https://apiconnect-dev.ibm.com/api/cloud/provider/identity-providers
      </div>
      <h4>Response</h4>
      <div id="get-realmvalue-response" class="show-explorer-codesnippet">
{
  "total_results": 1,
  "results": [
   {
     "name": "default-idp-2",
     "title": "API Manager User Registry",
     "default": true,
     "registry_type": "lur"
   }
  ]
}
  </div>
  <p>A realm value consists of a user registry name qualified with the context in which it used, in the form context/user-registry-name, where the context is <code>admin</code> for cloud administrator users or <code>provider</code> for API provider users. The realm value corresponding to the API Manager User Registry from the example above is:
  </p>
  <div id="realmvalue-example" class="show-explorer-codesnippet">  provider/default-idp-2</div>
  <p>For consumer users, the realm context is given by the catalog in which the user is registered. The list of user registries for a catalog can be accessed at the <code>/catalogs/{org}/{catalog}/configured-catalog-user-registries</code> URL.
        </p>
   </section>
  </div>
      <section>
        <h2>Using a Bearer Token</h2>
        <p>
          Once obtained, the bearer token may be used to make authenticated API calls. The bearer token is sent as the value of the Authorization header, prefixed by the word <code>bearer:</code> (including the colon). Here's an example of an
          authenticated call to the <code>/me</code> resource using the bearer token obtained above:
        </p>
        <h3>Request</h3>
        <div id="use-bearertoken-request" class="show-explorer-codesnippet">curl -v -k -H 'Accept: application/json' -H "Authorization: bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJqdGkiOiI1MGVmOGQzOC1lMTUxLTQ4NjctYmIwOS0wNDA0N2UxZjM3NDciLCJuYW1lc3BhY2UiOiIzYjQ1ODU4Ni1kZGMwLTQ1NDYtOThkZi03MmUxMzMzYjA5ZWE6MTYzZDY4MWYtZWUwMC00YWRhLWFiNWQtZDVkMzRlYjdlODVjOjBjODQ0NTgyLTQ1YWMtNDQ2My1hOTc1LThiNmQ1ZjY5MTE1ZCIsImF1ZCI6Ii9hcGkvY2xvdWQvcmVnaXN0cmF0aW9ucy8zOTBhNjVhYS00M2FhLTQ3MzUtYjA0OS04MTk3MjIyZDI3ZDAiLCJzdWIiOiIvYXBpL3VzZXItcmVnaXN0cmllcy8zYjQ1ODU4Ni1kZGMwLTQ1NDYtOThkZi03MmUxMzMzYjA5ZWEvMTYzZDY4MWYtZWUwMC00YWRhLWFiNWQtZDVkMzRlYjdlODVjL3VzZXJzLzBjODQ0NTgyLTQ1YWMtNDQ2My1hOTc1LThiNmQ1ZjY5MTE1ZCIsImlzcyI6IklCTSBBUEkgQ29ubmVjdCIsImV4cCI6MTUzMjU4NjE1MiwiaWF0IjoxNTMyNTU3MzUyLCJncmFudF90eXBlIjoicGFzc3dvcmQiLCJ1c2VyX3JlZ2lzdHJ5X3VybCI6Ii9hcGkvdXNlci1yZWdpc3RyaWVzLzNiNDU4NTg2LWRkYzAtNDU0Ni05OGRmLTcyZTEzMzNiMDllYS8xNjNkNjgxZi1lZTAwLTRhZGEtYWI1ZC1kNWQzNGViN2U4NWMiLCJyZWFsbSI6InByb3ZpZGVyL2RlZmF1bHQtaWRwLTIiLCJ1c2VybmFtZSI6ImNocmlzIiwiaWRfdG9rZW4iOiJleUpoYkdjaU9pSklVekkxTmlJc0luUjVjQ0k2SWtwWFZDSjkuZXlKbWFYSnpkRjl1WVcxbElqb2lRMmh5YVhNaUxDSnNZWE4wWDI1aGJXVWlPaUpOSWl3aWRYTmxjbDlwWkNJNkltSmpOakk0TVdVMUxXUmxOMkl0TkRKbU5pMDRZakkwTFdKak5qY3lZVEEyWmpRd05TSXNJblZ6WlhKdVlXMWxJam9pWTJoeWFYTWlMQ0pwWVhRaU9qRTFNekkxTlRjek5USjkuelpzTXI0OUJkdU9DUlcxb24yWjdsZDI4bnJKRVVDZTA1bmM5MldRX3doNCIsInNjb3BlcyI6WyJjbG91ZDp2aWV3IiwiY2xvdWQ6bWFuYWdlIiwicHJvdmlkZXItb3JnOnZpZXciLCJwcm92aWRlci1vcmc6bWFuYWdlIiwib3JnOnZpZXciLCJvcmc6bWFuYWdlIiwiZHJhZnRzOnZpZXciLCJkcmFmdHM6ZWRpdCIsImNoaWxkOnZpZXciLCJjaGlsZDpjcmVhdGUiLCJjaGlsZDptYW5hZ2UiLCJwcm9kdWN0OnZpZXciLCJwcm9kdWN0OnN0YWdlIiwicHJvZHVjdDptYW5hZ2UiLCJhcHByb3ZhbDp2aWV3IiwiYXBwcm92YWw6bWFuYWdlIiwiYXBpLWFuYWx5dGljczp2aWV3IiwiYXBpLWFuYWx5dGljczptYW5hZ2UiLCJjb25zdW1lci1vcmc6dmlldyIsImNvbnN1bWVyLW9yZzptYW5hZ2UiLCJhcHA6dmlldzphbGwiLCJhcHA6bWFuYWdlOmFsbCIsIm15OnZpZXciLCJteTptYW5hZ2UiLCJ3ZWJob29rOnZpZXciXX0.1ybezGJrJWgRZ8ec5cjyGQTKcWA3iwTbV5AubXCox60" https://v6gw0726a.argo2-sl.dev.ciondemand.com/api/me</div>
        <h3>Response</h3>
        <div id="use-bearertoken-response" class="show-explorer-codesnippet">{
          "type": "me",
          "api_version": "2.0.0",
          "name": "34b10eca-3874-4cdc-acb8-38de8e82eb85",
          "state": "enabled",
          "username": "chris",
          "email": "chris@ibm.com",
          "first_name": "Chris",
          "last_name": "M",
          "url": "https://apiconnect-dev.com/api/user-registries/32c68d9e-3fd6-4571-b9c9-fa7550e07569/2083359e-5234-4039-ad4f-40dcf7ce586e/users/34b10eca-3874-4cdc-acb8-38de8e82eb85"
          }</div>
        <p>The <code>/me</code> resource returns information about the user making the request.</p>
      </section>
    </div>
  </article>
"
}
]
}
], */
apis: window.apis
};