Set metadata for the given custom page

put

/developers/services/v1/portal/customization/pages/{pageId}/metadata

Add a new custom page to the Developer Portal based on the provided JSON.

Request

Supported Media Types
Path Parameters
Body ()
Custom page metadata
Root Schema : CustomPageMetadata
Type: object
The custom page metadata provides information for the Developer portal framework about how to load and render a custom page.
Show Source
  • Specifies whether the page is visible when the Developer Portal is accessed without authentication. Defaults to false.
  • button
    Controls the appearance of the custom page's Navigation Bar button.
  • Specifies whether the page should be used as the landing (home) page of the Developer Portal. The property can take the following values:
    • Never: the page is not used as home page. This is the default
    • Always: the page is used as the home page.
    • Authenticated: the page is used as home page only if a user is logged in.
    • Unauthenticated: the page is used as home page only if the Developer Portal is accessed anonymously.
  • module
    The custom page is added to the Developer Portal as a dynamically loaded module. This parameter sepcifies various properties of the module.
Nested Schema : button
Type: object
Controls the appearance of the custom page's Navigation Bar button.
Show Source
Nested Schema : module
Type: object
The custom page is added to the Developer Portal as a dynamically loaded module. This parameter sepcifies various properties of the module.
Show Source
  • Defines the Help link for the custom page. The Help button will open the specified page in a new tab. If not defined, the start page of the standard Developer Portal documentation will be displayed.
  • implementation

    Configures parameters for the Developer Portal on how the page should be loaded. All file names specified by properties in this object must be relative to the zipped content you uploaded for the page.

    Your page is typically built from HTML, CSS and JS files. The implementation object controls how these files get loaded into the Developer Portal.

  • urlScheme
    Defines the URL path(s) associated with the module. This path will be appended to "/developers/" when you navigate to the page.
Nested Schema : icon
Type: object
Icon data for the custom button.
Show Source
Nested Schema : text
Type: object
Specifies the text of the Navigation Bar button.
Show Source
Nested Schema : implementation
Type: object

Configures parameters for the Developer Portal on how the page should be loaded. All file names specified by properties in this object must be relative to the zipped content you uploaded for the page.

Your page is typically built from HTML, CSS and JS files. The implementation object controls how these files get loaded into the Developer Portal.

Show Source
  • css
    The CSS files listed here will be loaded by adding <link> tags to the <head> element of the Developer portal page.
  • The name of the HTML file that renders your page. This should not be a full HTML document, just an HTML segment (typically a <div> tag) that gets embedded into the Developer Portal's HTML DOM.
  • js
    The JS files listed here will be loaded by adding <script> tags to the <head> element of the Developer portal page.
  • requirejs
    The Developer Portal is a RequireJS-based application and the recommended way of implementing a custom page is to write it as RequireJS modules.
Nested Schema : urlScheme
Type: array
Defines the URL path(s) associated with the module. This path will be appended to "/developers/" when you navigate to the page.
Nested Schema : css
Type: array
The CSS files listed here will be loaded by adding <link> tags to the <head> element of the Developer portal page.
Nested Schema : js
Type: array
The JS files listed here will be loaded by adding <script> tags to the <head> element of the Developer portal page.
Nested Schema : requirejs
Type: object
The Developer Portal is a RequireJS-based application and the recommended way of implementing a custom page is to write it as RequireJS modules.
Show Source
  • If the custom page consists of multiple RequireJS modules, the root location of the page file hierarchy must be specified for RequireJS. This property represents an alias name for the root location, which the Developer adds to the RequireJS path configuration. The custom page's RequireJS modules can then reference other modules by using the "<alias>/..." references in their dependency list.
  • Specifies the start module of the page. Since it will be loaded through RequireJS, the .js extension must be omitted.

    The define() method of the start module should return an object with an init() method. When the module is loaded and the init() method exists, the Developer portal calls it with two parameters:

    • container: A container object the properties and methods of which the custom page can access the overall Developer Portal environment.
    • element: The parent HTMLElement into which the HTML of the page is embedded.
Back to Top

Response

204 Response

None

401 Response

Authentication required.

404 Response

Not allowed to set.
Back to Top

Examples

The following example shows how to add or update the metadata file for a custom page by submitting a PUT request on the REST resource using cURL. For more information about cURL, see Use cURL. To add and manage custom pages, see Manage Custom Pages in Developer Portal..

curl -i -X PUT
-H 'Authorization: Bearer access_token' 
-H 'Content-Type: application/json' 
-d 'metadata=@metadata.json'
http://example.com/developers/services/v1/portal/customization/pages/{pageId}/metadata

Where:

  • access_token refers to the access token generated by Oracle Identity Cloud Service for the Oracle API Platform Cloud Service account. See Security, Authentication and Authorization.

  • example.com refers to the path where Developer Portal is deployed.

  • {pageId}refers to the name of the custom page. For example, Home.

  • metadata.json is the metadata file. The following is the sample of the metadata.json:

{
  "homePage": "always",
  "module": { "urlScheme": "home",
    "documentationUrl": "https://docs.oracle.com/en/cloud/paas/api-platform-cloud/apfdv/index.html",
    "implementation": {
      "document": "index.html",
      "requirejs": {
        "path": "home",
        "start": "js/start"
      },
      "css": ["css/main.css"]
    }
  },
  "button": {
    "order": 500,
    "text": {
      "root": "Home" - this is just the button text, does not correlate with the page id
    },
    "icon": {
      "image": ""
    }
  }
}

Example of Response Headers

The following shows an example of the response headers.

HTTP/1.1 204 No Content
Date: Fri, 05 Sep 2018 05:38:18 GMT
Content-length: 0
X-oracle-dms-ecid: fd4f7481-e810-498f-9ef3-3cc199fcc455-0006eb27
X-oracle-dms-rid: 0:1
Back to Top