Skip to content

mgbmrjnppv/varnish-plus-cli

 
 

Repository files navigation

Varnish Plus CLI

Download latest release Software License Build Status

This self-contained phar (PHP archive) can be used to work with the Varnish Admin Console VAC.

It provides:

  • A command to compile twig templates into a single file.
  • A command to deploy the configuration with the VAC API.

Installation

$ wget https://github.com/liip/varnish-plus-cli/releases/latest/download/varnish-plus-cli.phar
$ chmod u+x varnish-plus-cli.phar

Usage

There is no configuration file for this tool. The expected usage is that you write a makefile or bash script that calls the tool with the right arguments.

Compile the VCL with twig

The VAC only supports one single VCL file. It is good practice to separate your VCL into several files for better overview. With twig, instead of VCL statement include "sub.vcl, you will use the twig instruction {% include 'sub.vcl.twig' %}.

Additionally, you can use variables in twig, e.g. to handle different environments.

The vcl:twig:compile command configures twig on the specified directory and compiles a template that is the entry point. You can specify twig variables with the --twig-variable option:

$ ./varnish-plus-cli.phar vcl:twig:compile ../varnish-project/templates envs/local.vcl.twig output.vcl --twig-variable maintenance=1 --twig-variable grace=3600

Run ./varnish-plus-cli.phar vcl:twig:compile --help for a full explanation of all arguments.

Deploy a VCL to a VAC instance

vcl:deploy takes a VCL file and deploys it to a VAC at the location specified by the vcl name and group.

$ ./varnish-plus-cli.phar vcl:deploy -u https://$HOST --username $USERNAME  --password $PASSWORD --vcl-name $VCL_NAME --vcl-group $VCL_GROUP $FILENAME

Run ./dist/varnish-plus-cli.phar vcl:deploy --help for a full explanation of all arguments.

Example Makefile

Note: Makefiles work with tabs, not spaces. When copying this example ensure the file is indented with tabs.

DIST_DIR ?= dist
BIN_DIR ?= bin
TEMPLATE_DIR ?= templates

TEMPLATE_FILES = $(shell find $(TEMPLATE_DIR) -type f -name '*')

all: install compile

install: $(BIN_DIR) $(BIN_DIR)/varnish-plus-cli.phar

$(BIN_DIR):
	mkdir -p $(BIN_DIR)

$(BIN_DIR)/varnish-plus-cli.phar:
	wget https://github.com/liip/varnish-plus-cli/releases/latest/download/varnish-plus-cli.phar
	mv varnish-plus-cli.phar $(BIN_DIR)/
	chmod u+x $(BIN_DIR)/varnish-plus-cli.phar

# Add all possible VCLs you want to generate
compile: $(DIST_DIR)/dev.vcl $(DIST_DIR)/local.vcl $(DIST_DIR)/dev.maintenance.vcl

# maintenance is an example rule where you specify a custom twig variable which changes something in the VCL to
# indicate that the current node is in maintenance mode (could be anything, of course).
$(DIST_DIR)/%.maintenance.vcl: $(TEMPLATE_FILES)
	$(BIN_DIR)/varnish-plus-cli.phar vcl:twig:compile --twig-variable maintenance=true $(TEMPLATE_DIR) envs/$*.vcl.twig $@

# this assumes that there's the following directory layout:
# 
# .
# ├── Makefile
# ├── templates
# │   └── envs
#     │   ├── dev.vcl.twig
#     │   ├── local.vcl.twig
$(DIST_DIR)/%.vcl: $(TEMPLATE_FILES)
	$(BIN_DIR)/varnish-plus-cli.phar vcl:twig:compile $(TEMPLATE_DIR) envs/$*.vcl.twig $@

.PHONY: install compile all

Development

Setup

$ git clone ...
$ composer install

Create .phar file

$ make dist

Code Quality

We use phpstan and php-cs-fixer for code style purposes:

$ make phpcs
# to fix code style issues automatically
$ make fix-cs

About

A CLI tool to work with Varnish Plus

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • PHP 91.3%
  • Makefile 8.7%