/open-banking-docs

The documentation microsite for Axway Open Banking

Primary LanguageShell

Amplify Open Banking Docs

This repository contains the documentation for the Amplify Open Banking solution. It follows the docs-as-code approach currently used by Axway for publishing product documentation.

This overview outlines the main points of note in that context with some "Getting Stared" style sections for making developers as productive as possible.

Note the expectation is that a user of this repository is very familiar with using git, GitHub and the process of source controlling configuration items. The docs-as-code approach is an extension of those practices.

Development

It's pretty simple. Ensure you have the following installed:

  • Hugo.
  • git.
  • Node.js/NPM.

Then clone the repository and run build.sh to start a local server:

git clone https://github.com/Axway/open-banking-docs
cd open-banking-docs
./build.sh

The development server is by default hosted at http://localhost:1313.

Content

All content is created in the content/en/docs directory as shown below.

content
| -- en
|    | -- docs
|    |    | -- deployment
|    |    | -- overview
|    |    |    | -- integration
|    |    |    | -- technical
|    |    | -- reference
|    |    |    | -- brazil

To explain the directories:

Directory Purpose
content/en/docs Content "homepage". Shows overview of open banking and puts solution in context.
content/en/docs/deployment Deployment guides.
content/en/docs/overview Overview of solution and features.
content/en/docs/overview/integration Integration overview with sequence diagrams showing interactions between system components.
content/en/docs/overview/technical Technical architecture overview with information on Kubernetes architecture and a high-availability implementation.
content/en/docs/reference Reference information not directly related to solution functionality.
content/en/docs/reference/brazil Reference information on the Brazil market.

Text and Images

The process for adding new content to an existing directory is simple:

  • Add a file to the relevant directory. For example, to add a new integration subpage create a file called example.md in content/en/docs/overview/integration
  • Add Front Matter to the page as described below and add content in Markdown format below the Front Matter.
  • To add an that cannot be referenced remotely copy the image to the static/Images.
  • To add a sequence diagram follow the guidelines in the PlantUML section.

To create new content in a new directory:

  • Create the new directory in the correct place in the directory structure.
  • Create a new Markdown file called _index.md in the new directory. This creates the overview page that links all subpages within the new directory.
  • Add Front Matter to _index.md and some content that introduces the section.
  • Follow the guide above for creating a new page in an existing directory.

PlantUML

All sequence diagrams are written using PlantUML syntax. This is a text-based language that is transformed to a display format by the PlantUML Java Library.

While there are solutions that support the real-time rendering of native PlantUML content this does not appear to be supported by our current docs-as-code stack. The PlantUML must therefore be converted to SVG and stored as an image as follows:

  • Convert the source PlantUML file using a converter of your choice or the conversion script in this repository. Note to use this you must have plantuml.jar installed locally.
  • Copy the SVG file to static/Images.

Front Matter

This section is for guidance only

Front Matter is the metadata that informs Hugo/docsy about the characteristics of the page being loaded. It is a series of key/value pairs that can be expressed in a number of formats - in the case of Axway Open Docs, in YAML.

An example of Front Matter is shown below (note this is not exhaustive and there are many more keys available in both Hugo and the docsy theme):

---
title: "Deployment"
linkTitle: "Deployment"
weight: 4
description: Deploying the Amplify Open Banking solution
---

The keys in this example are defined as follows:

  • title: Sets the page title.
  • linkTitle: Sets the name of any links to the page rendered in the sidebar or by a parent page.
  • weight: Sets the ordering of the page in the sidebar - a lower number displays the page in the navigation list first while a higher number displays the page in the navigation list last. To avoid renumbering existing pages when a new page is added, it is suggested to spread the numbers used for the weight out by increments of 5 or more.
  • description: Description of the page, which is rendered on the page under the title.

Its worth noting that both title and description provide a useful introduction to a given page, so should be used rather than Markdown content containing the same thing. This looks neater and stops repetitive content being served.

Lifecycle

To date this project implements GitHub Flow, which is a simple and easy-to-use method doing documentation updates.

The outline process is as follows:

  • The relevant subject matter expert creates a new branch and starts work on their changes.
  • When they are happy they commit and push to the branch.
  • They then create a Pull Request, which creates a Preview site that can reviewed on Netlify (link to the site is shown in the Pull Request page). The technical writer then reviews and suggest changes, etc.
  • When approved the changes are merged to master. This kicks off a deployment in Netlify to the Netlify site.
  • The final step is a merge to production, which does not necessarily need to be performed at each merge to master on GitHub. This happens through a manual push to Zoomin, the production provider for https://docs.axway.com.

Production is handled by the technical writer assigned to the project.