Skip to content

Developer Documentation

Here you will find all you need to know about developing and managing your site on LibOps.

Initial setup

sitectl

If you haven't already, install sitectl on your local machine.

sitectl has many useful commands to interact with your site. You can learn more about them by visiting the sitectl docs or by running this command in your terminal:

sitectl --help

Quick start

Your site's public URL, libops CLI commands ran against your site, and uploading code to an environment using SFTP, are all managed by libops.yml

A quick way to configure your working machine to properly authenticate to your LibOps site is by running this command:

cd /path/to/libops/sites
sitectl set developer
git add libops.yml
git commit -m "Adding myself to libops.yml"
git push origin development

After the GitHub Actions finish running for that git push in your GitHub repository, you could get a login link to your development environment by running

sitectl drush uli

More info on libops set developer

sitectl set developer does three things:

  1. Adds the Google Cloud account you're authenticated as with the gcloud command to your libops.yml developer mapping. This is what authenticates you when running LibOps CLI commands against your site
  2. Adds your current public IP address to the HTTPS and SSH firewalls. The default value can be overriden with the --ip flag
  3. Adds your public SSH key to libops.yml so you can SFTP to your environment

Authentication Overview

Google Cloud authentication

The LibOps CLI makes calls to the gcloud CLI for requests to LibOps services that require JWT authentication. In order to properly authenticate, you must configure your LibOps site to allow requests from your Google Cloud account. This configuration is done by adding your Google Cloud email address to the libops.yml developers mapping.

You can add your currently authenticated gcloud email by simply running the command

sitectl set developer

Or if you're adding someone else, you can add them with

sitectl set developer --google-account someone-else@instituion.edu

Firewall Settings

Until your site goes live, all your LibOps environments are behind a firewall so only you and your team can access the sites.

Ensure the public IPv4 address of the machine(s) you're working from is in the ssh-firewall and https-firewall lists in libops.yml. If the IP address you're visiting the site is not configured in libops.yml, you will not be able to access your site.

If you do not know your public IP you can run this command in your terminal to automatically detect your public IP address and configure your libops.yml:

sitectl set developer

Or if you know your IP address, you can pass it in with the --ip flag:

sitectl set developer --ip 1.2.3.4/32

SFTP Connection

Ensure your gcloud email and public SSH key(s) (i.e. ~/.ssh/id_rsa.pub) are added to developers in libops.yml

Your public SSH keys is required to be configured in libops.yml in order to SFTP to your environment and/or run interactive drush commands.

sitectl set developer --pub-key ~/.ssh/id_rsa.pub

GitHub Access

Currently GitHub access to your GitHub repository can only be managed from the LibOps website.

From there, you can add yourself and other GitHub users to your site by editing your site and adding their GitHub usernames.

Demonstration of adding GitHub user to site

Environments

By default, your LibOps site has a development and production environment.

You can make code changes in development, then deploy them to production once they're ready by creating a GitHub release.

If you have several features you're developing at any given time, you may want to have separate branches off of development to do so. Each branch you create off of the development branch automatically creates its own new environment.

GitHub branches equate to individual environments on LibOps. The exception to this is your production environment. Production code is pushed using GitHub releases/tags.

Cold starts

For LibOps sites that are not on a paid plan, both the development and production environments will power off after a period of no activity. This can cause the initial page load to take anywhere up to 60 seconds to load while the environment comes online. After coming online, your site will be responsive as you'd expect.

Paid plans will never have cold starts for the production environment.

Branch Naming Rules

Branch names must follow the docker tag naming convention. i.e.

The tag must be valid ASCII and can contain lowercase and uppercase letters, digits, underscores, periods, and hyphens. It cannot start with a period or hyphen and must be no longer than 128 characters.

URLs

Your GitHub repository will have the URLs for your development and production environments in the README.

When you create a new environment, this will create another URL to access the given environment. Once you create a branch in GitHub, you can get the URL to your environment by running

sitectl -e BRANCH_NAME get info | jq -r .drupal.url

Opening a PR will automatically add a comment to the PR with the URL to the environment, too.

Lifecycle

Once you're done developing a feature on a given branch, you can merge the branch into the main development branch. Then you can follow the normal deployment process.

Deleting the branch will delete the environment, including all files and the database in that environment.

Making code changes

Any commit pushed to GitHub will automatically deploy to the respective environment. Typically from the time the commit was received by GitHub until it's deployed and running in the environment takes around 2-3 minutes. You'll know the code has been fully deployed once the "deploy" GitHub Action in your repository is all green.

Demonstration of viewing deployment status in GitHub

While only using git to make code changes is certainly supported, often it's quicker and easier to use SFTP to iterate on a new feature in a LibOps environment. To do so, you will want to configure your IDE.

Configure your IDE for SFTP

To help you quickly iterate on new features for your site, you can use an SFTP plugin in your IDE to automatically upload code changes from your local machine to any non-production LibOps environment.

First, you'll need to configure you local machine to connect to your environment. The libops CLI has an easy utility to configure your ~/.ssh/config for LibOps. To do so, you can run the command

cd path/to/your/libops/site
sitectl config-ssh -e development

This will populate your ~/.ssh/config so any SSH client can establish a connection to your LibOps development environment at the hostname development.YOUR-LIBOPS-ID.site.

An example SFTP config for VSCode for your development environment is already configured in your site's GitHub repository. If you're using VSCode, and followed the instructions above, you should now be able to make edits on your LibOps development environment. Other SFTP Plugins can be configured similarly. The values needed to connect are

user: coder
host: development.YOUR-LIBOPS-ID.site
port: 2222
path: /code

Commit changes

After you're done making edits over SFTP, from your local machine you can git commit && git push your changes to the development branch, or create a new branch/PR then merge.

Deployment

To deploy your development branch to production, you can publish a new release in your GitHub repository.

After the new release is published a GitHub Action will deploy your code into production.