These instruction assumes that you have Maven based build for your project.
In the main pom.xml of the project, in the repositories section, add this repository if it is not configured there yet.
    <repository>
      <id>bloomreach-forge</id>
      <name>Bloomreach Forge Maven 2 repository.</name>
      <url>https://maven.bloomreach.com/repository/maven2-forge/</url>
      <snapshots>
        <enabled>false</enabled>
      </snapshots>
      <releases>
        <updatePolicy>never</updatePolicy>
      </releases>
      <layout>default</layout>
    </repository>
        In the main pom.xml of the project, in the properties section, add this property. For the correct version number, check the Release Notes page.
    <bloomreach.forge.iframeperspective.version>version.number</bloomreach.forge.iframeperspective.version>
        Make sure you have the dependency definition in the root pom.xml of your project:
<dependencyManagement>
  <dependencies>
    <dependency>
      <groupId>org.bloomreach.forge.iframeperspective</groupId>
      <artifactId>iframeperspective</artifactId>
      <version>${bloomreach.forge.iframeperspective.version}</version>
    </dependency>
  </dependencies>
</dependencyManagement>
        
          Add the following dependency to either cms-dependencies/pom.xml
          or cms/pom.xml in the earlier versions that don't have that:
        
  <dependencies>
    <dependency>
      <groupId>org.bloomreach.forge.iframeperspective</groupId>
      <artifactId>iframeperspective</artifactId>
    </dependency>
  </dependencies>
        
          To add an IFrame based perspective configuration, add configuration nodes to the
          /hippo:configuration/hippo:frontend/cms/cms-static/ node in the repository.
          In the following example two IFrame based perspectives are added.
        
definitions:
  config:
    /hippo:configuration/hippo:frontend/cms/cms-static:
      /example-iframe-perspective:
        jcr:primaryType: frontend:plugin
        jcr:mixinTypes: ['frontend:navigationitem']
        frontend:appPath: example-iframe-perspective
        hipposys:userrole: xm.cms.user
        plugin.class: org.bloomreach.forge.iframeperspective.IFramePerspective
        wicket.id: service.tab
        iframe.src: https://bloomreach-forge.github.io/
      /example-iframe-perspective-second:
        jcr:primaryType: frontend:plugin
        jcr:mixinTypes: ['frontend:navigationitem']
        frontend:appPath: example-iframe-perspective-second
        hipposys:userrole: xm.cms.user
        plugin.class: org.bloomreach.forge.iframeperspective.IFramePerspective2
        wicket.id: service.tab
        iframe.src: https://bloomreach-forge.github.io/iframe-perspective/
        
          Note: each perspective must have unique, mandatory frontend:appPath property. See also
          Create a Custom Perspective
          page for more detail.
        
          Note: the CMS UI does not support multiple custom perspective plugin configurations
          with the same plugin.class property value. That's why the second example shown above is set to use
          org.bloomreach.forge.iframeperspective.IFramePerspective2 instead.
          For convenience, this project provides 9 different class names for the same feature
          (org.bloomreach.forge.iframeperspective.IFramePerspective2 ~ org.bloomreach.forge.iframeperspective.IFramePerspective10).
          This allows developers to avoid adding a custom class extending org.bloomreach.forge.iframeperspective.IFramePerspective
          in their projects.
        
          Also, the translation key-value pairs for each perspective must be added to /hippo:configuration/hippo:translations/hippo:navigation/navigationitem
          like the following example:
        
definitions:
  config:
    /hippo:configuration/hippo:translations/hippo:navigation/navigationitem/displayName/en:
      example-iframe-perspective: Example IFrame Perspective
      example-iframe-perspective-second: Example IFrame Perspective 2nd
        
          Note: The translation keys must be the same as the frontend:appPath property values.
          See the
          Create a Custom Perspective
          page for further detail.
        
You can configure the followings:
| Property | Example value | Default value | Description | 
|---|---|---|---|
| iframe.src | http://documentation.bloomreach.org | The initial source of the IFrame element | |
| x-frame-options | SAMEORIGIN | 
              Optionally set X-Frame-Options response header if configured.
               See https://developer.mozilla.org/en-US/docs/Web/HTTP/X-Frame-Options for details.  | 
          |
| content-security-policy | Refer to the specification | 
              Optionally set Content-Security-Policy response header if configured.
               See https://developer.mozilla.org/en-US/docs/Web/Security/CSP/Introducing_Content_Security_Policy and https://www.owasp.org/index.php/Content_Security_Policy for details.  | 
          |
| x-content-security-policy | Refer to the specification | 
              Optionally set X-Content-Security-Policy response header if configured.
               See https://developer.mozilla.org/en-US/docs/Web/Security/CSP/Introducing_Content_Security_Policy and https://www.owasp.org/index.php/Content_Security_Policy for details.  | 
          |
| x-webkit-csp | Refer to the specification | 
              Optionally set X-Webkit-CSP response header if configured.
               See https://developer.mozilla.org/en-US/docs/Web/Security/CSP/Introducing_Content_Security_Policy and https://www.owasp.org/index.php/Content_Security_Policy for details.  | 
          |
| iframe.* | 
              If there is any property with name starting with 'iframe.', then the remaining part after 'iframe.' will be added
              as an additional attribute of the iframe element.
              For example, if you add 'iframe.name' with value, 'myiframe', then the iframe will have name="myiframe" HTML attribute.
             | 
          
          Add another value i.e. "bloomreach-forge.github.io" to the frame-src property of the
          /hippo:configuration/hippo:modules/application-settings/hippo:moduleconfig/content-security-policy node in the repository.
        
definitions:
  config:
    /hippo:configuration/hippo:modules/application-settings/hippo:moduleconfig/content-security-policy:
      frame-src:
        operation: add
        value: [bloomreach-forge.github.io]