Azure Static Web Apps
This guide describes publishing Dendron notes to Azure Static Web Apps using Azure Devops and Azure Pipelines.
Why
From the Microsoft docs:
Azure Static Web Apps is a service that automatically builds and deploys full stack web apps to Azure from a code repository. The workflow of Azure Static Web Apps is tailored to a developer's daily workflow. Apps are built and deployed based off code changes.
In this example, the goal is to share your notes with internal colleagues easily via an published Dendron website. If your team already uses Azure, this may be an attractive option.
Due to the fact that the vaults will contain work related information, there are certain requirements:
- No public hosting
- Manually select persons with access
- If someone leaves the company, they should not have access anymore
- Low maintenance and management overhead
Prerequisites
- You already have your workspace under version control and a repository on Azure DevOps.
- You have configured your
dendron.yml
for publication.
Setup
Remove any comments in the sample configurations, if you want to copy them. They help humans, but machines might not like them as JSON usually doesn't expect comments.
Create an Azure Static Web App
- Create a new static web app.
- In the overview, select "Manage Deployment Token" and copy it for later.
- Optional: Set a custom domain.
Build pipeline
-
Prepare
package.json
, in the root of you Dendron workspace repo, to contain a proper build script that generates the site.// package.json "scripts": { "build": "npx dendron publish init && npx dendron publish export && mv .next/out docs" },
-
Set up the Azure build pipeline for that repo. The example will rebuild the website every time a new commit is pushed to the
master
branch.// azure-pipelines.yml trigger: - master pool: vmImage: ubuntu-latest steps: - task: AzureStaticWebApp@0 inputs: app_location: '/' output_location: 'docs' azure_static_web_apps_api_token: '$(web-app-token)'
This configuration uses a builder called
Oryx
to automatically detect the project type (viapackage.json
) and callsnpm run build
automatically. This is a basic layout that can be modified for your use case. -
Set up the web-app-token. Edit the pipeline on the DevOps site. Select "Variables" and create a new secret variable called
web-app-token
. Paste the token you copied earlier. -
Run the pipeline. Your site should now be publically (!) available. Let's fix that...
Securing Access
In this example, every potential reader of the vault has an Active Directory account already. This can be leveraged to create role based access control (RBAC) to the vault. By default, Azure AD, GitHub and Twitter authentication are supported.
We'll be limiting access only to Azure AD, in this example, but the Microsoft Azure documentation can be referrenced if wanting to learn more about other forms of authentication.
-
At the root of your repository, create a file called
staticwebapp.config.json
. This is a very basic example, more options can be found here.// staticwebapp.config.json { "routes": [ { // redirect /login to the Active Directory endpoint for authentication. "route": "/login", "rewrite": "/.auth/login/aad" }, { // disable twitter authentication "route": "/.auth/login/twitter", "statusCode": 404 }, { // disable github authentication "route": "/.auth/login/github", "statusCode": 404 }, { // all AAD authenticated users can access this website. // the "authenticated" role can be replaced with others by first creating them on the static web app role management page, // then adding the role name to the "allowedRoles" array. "route": "/*", "allowedRoles": [ "authenticated" ] } ], "responseOverrides": { "401": { // If access is denied because of a missing role (=anonymous users), redirect them to login. "redirect": "/login", "statusCode": 302 } }, "globalHeaders": { "content-security-policy": "default-src https: 'unsafe-eval' 'unsafe-inline'; object-src 'none'" }, "mimeTypes": { ".json": "text/json" } }
-
Update
package.json
to copystaticwebapp.config.json
to the built site.// package.json "scripts": { "build": "npx dendron publish init && npx dendron publish export && mv .next/out docs && cp staticwebapp.config.json docs/" },
-
Push all the changes to the repository.
After logging in using the generated URL, the user will be allowed to access your vault and will appear in role management. You can remove users and reassign roles here.
Optional: Further restricting access
If wanting to further restrict access to your Azure Static Web Apps:
- Back in the Azure Portal, go to your Static Web App and select "Role management"
- Click "Invite"
- Enter the email address of a colleague/yourself and set the role to
reader
Read the docs for more information on RBAC in Azure Static Web Apps.
Upgrading
For upgrading CLI, and dendron workspace configurations, make sure to do the following to have the latest and greatest updates in your published site.
Congratulations, you just published your notes π±
Backlinks