Exporting and importing custom themes and site configuration
You can use the portal commands in the toolkit CLI to replicate changes from one Developer Portal instance to another. You might want to use these commands to copy your themes or a configuration change, from a staging environment to a production environment.
Before you begin
To complete this scenario, you must have a staging Developer Portal and a production Developer Portal enabled. You must have administrator access, and the permissionsettings:manage
, to
both to complete this scenario. The tutorial Creating the Portal explains how to enable the portal if you have not already done
so.About this scenario
In this scenario, on your staging Developer Portal, you create a theme and make some configuration changes. Then, you use the toolkit CLI to replicate the changes on your production Developer Portal.
- Create a custom theme on the staging Developer Portal.
- Add a field to an
application content type to change the
site-config
on the staging Developer Portal. - Use the
cli
to export the custom themes andsite-config
on the staging Developer Portal. - Use the
cli
to import the custom themes andsite-config
on the production Developer Portal.
Create a custom theme on the staging Developer Portal
- Log in to your staging Developer Portal as an administrator.
- If the administrator dashboard isn’t displayed, click Manage to display it.
- Click
Generate sub-theme
window is displayed.
. The - Enter a Sub-theme name, and select CSS for the Sub-theme type. (If you prefer, you can select SCSS, but this extension to CSS is for advanced theme developers, and isn’t covered by this scenario.)
- Select the Default template to base your
sub-theme
on. You can create asub-theme
based on a color template. However, for this scenario you use the default connect_theme template. - Click Generate.
- Download the generated
sub-theme
to a location of your choice, and extract all the files from the .zip file.
On your computer, navigate to the files that you extracted. Find the overrides.css file in here banka_theme/banka_theme/css/overrides.css. You can now customize the overrides.css file.
- Open the overrides.css file in your chosen editor.
- Customize your
sub-theme
by entering the following elements into the overrides.css file:/* Body of the home page */ body.path-frontpage.contexthome { color: #152935; background-color: #d1f0f7; } /* Header of the home page */ .navbar { background-color: #a0a0a0; } /* Footer of the home page */ footer.footer { background-color: #dee0e2; } footer.footer ul.nav > li > a { color: #454A4C; }
- Save the overrides.css file.
You can now install and enable your customized theme.
- After you finish updating the overrides.css file, compress all the theme
files back into the .zip
sub-theme
file that you downloaded originally. - In the Developer Portal,
click . The
Install new theme
window is displayed. - In Upload a module or theme archive to install click Browse, and navigate to your newly updated compressed theme file.
- Click Install to install the theme onto your site.
- Click Enable newly added themes, and find your new theme in the list of
Disabled themes
. Click Enable and set as default to set your new customsub-theme
as the default theme for your site. - Return to the Developer Portal home
page by clicking Back to site. You can now see your custom theme.
Add a field to an application content type to change the site-config
on the
staging Developer Portal
- Log in to your staging Developer Portal as an administrator.
- If the administrator dashboard isn’t displayed, click Manage to display it.
- Click .
- Click + Add field.
- In
Add a new field
, select Text (plain, long). Enter Company name as the label title. - Click Save and continue.
- Leave the
Allowed number of values
set to 1 and click Save field settings. - Click Save field settings. You can now see your new field.
Use the toolkit CLI
to export the custom themes and site-config
on the staging Developer Portal
- Log in to the management server.
apic login --server management_server --realm realm --username org_username --password org_password
For example,apic login -s api.stagingexample.com --realm provider/default-idp-2 --username ibm --password Qwerty123£
For more information about variable options, see Logging in to a management server.
- Export your custom themes. The custom-theme:create-export command creates an export task against the portal of the specified
catalog
andorg
. The command then polls the status of the task until it hasFINISHED
and the artifacts are streamed back.Note: The command continues to poll until the maximum polling time of 15 minutes is reached. At which point you can use the commands custom-theme:get-export-status and custom-theme:get-export to get the status and potentially an artifact.apic --mode portaladmin custom-theme:create-export --catalog name/id --org name/id --server management_server
- The theme .tgz is saved to the directory in which you ran the command.
- The saved .tgz has the format
custom_theme_createExport-20200217134637.tgz
. - You can save your exports into your change control management system.
For example,apic --mode portaladmin custom-theme:create-export --catalog dev --org ibm --server api.stagingexample.com
- Export your site config.
The site-config:create-export command creates an export task against the portal of the specified
catalog
andorg
, the command then polls the status of the task until it hasFINISHED
and the artifacts are streamed back.apic --mode portaladmin site-config:create-export --catalog name/id --org name/id --server management_server
- The site config .tgz is saved to the directory in which you ran the command.
- The saved .tgz has the format
site_config_createExport-20200217134637.tgz
. - You can save your exports into your change control management system.
For example,apic --mode portaladmin site-config:create-export --catalog dev --org ibm --server api.stagingexample.com
Use the toolkit CLI
to import the custom themes and site-config
on the production Developer Portal
- Log in to the management server.
apic login --server management_server --realm realm --username org_username --password org_password
For example,apic login -s api.productionexample.com --realm provider/default-idp-2 --username ibm --password Qwerty123£
For more information about variable options, see Logging in to a management server.
- Import your custom themes. The custom-theme:create-import command uses the supplied .tgz file to import the custom themes into the portal of the specified
catalog
andorg
. The command then polls the status of the task until the task has eitherFINISHED
successfully, or failed because of an error.Note: The command continues to poll until the maximum polling time of 15 minutes is reached. At which point you can use the command custom-theme:get-import-status to get the status of the import.apic --mode portaladmin custom-theme:create-import --catalog name/id --org name/id --server management_server /PATH/TO/THEME/TGZ
For example,apic --mode portaladmin custom-theme:create-import --catalog prod --org ibm --server api.productionexample.com C:/users/example/desktop/custom_theme_createExport-20200217134637.tgz
- Import your site config.
The site-config:create-import command uses the supplied .tgz file to import the site config into the portal of the specified
catalog
andorg
. The command then polls the status of the task until the task has eitherFINISHED
successfully, or failed because of an error.apic --mode portaladmin site-config:create-import --catalog name/id --org name/id --server management_server /PATH/TO/CONFIG/TGZ
For example,apic --mode portaladmin site-config:create-import --catalog prod --org ibm --server api.productionexample.com C:/users/example/desktop/site_config_createExport-20200217134637.tgz
What you did in this scenario
In this scenario, you created a theme and changed the configuration on your staging Developer Portal. Then, you used the toolkit CLI to replicate the changes on to your production Developer Portal.
You can now see the changes that you made on your production Developer Portal.