falco
falco is VCL parser and linter optimized for Fastly.
Disclaimer
This is a VCL parser, but dedicate to Fastly's VCL (version 2.x), so we don't care about latest Varnish (7.x or later) syntax.
The Varnish may have additional syntax, builtin function, predefined variables, but this tool may not parse correctly.
Additionally, Fastly provides its special builtin functio, predefined variables. It's not compatibility for Varnish.
But this is tool is optimized for them, we could parse and lint their declarations.
Motivation
Fastly is really fantastic CDN, but sometimes we have problem for deployment operation.
On deploy custom VCL's to the Fastly, VCLs are validated when activate new service version.
Typically our deployment flow using custom VCLs is following:
- Clone active service and create new version
- Delete existing custom VCLs
- Upload new VCL files to the Fastly
- Activate new sevice version // <= Validate VCLs on the Fastly cloud
Above flows take a time, and then if we have some mistakes on VCL e.g. missing semicolon X(, the deployment will fail.
Additionally, unnecessary service version will be created by our trivial issue.
To solve them, we made Fastly dedicated VCL parser and linter tool to notice syntax error and unexpected mistakes before starting above deployment flow.
Installation
Donwload binary from releaes page according your platform and place under the $PATH
.
Usage
Command help displays following:
falco -h
=======================================
falco: Fastly VCL parser / linter
=======================================
Usage:
falco [main vcl file]
Flags:
-I, --include_path : Add include path
-t, --transformer : Specify transformer
-h, --help : Show this help
-v, : Verbose warning lint result
-vv, : Varbose all lint result
Example:
falco -I . -vv /path/to/vcl/main.vcl
Note:
Youe VCL will have dependent modules and loaded via include [module]
. falco
accept include path from -I, --include_path
flag and search and load destination module from include path.
Currently, we don't support snippets which are managed in Fastly:
- Edge Distionary
- VCL Snippets
- Log defnitions
- Etc
Above snippets will be injected to your VCL top or extracting FASTLY XXX
macro, but this tool does aims to run locally, not communicating with Fastly service.
However, we're planning to solve them using Fastly API.
Lint error
falco
has builtin lint rules. see rules in detail.
Error Levels
falco
reports three of severity on linting:
ERROR
VCL may cause error on Fastly, or may cause unexpected behavior for actual works.
WRANING
VCL could work, but may have potencial bug and cause unexpected behavior for actual works.
falco
does not output warnings as default. To see them, run with -v
option.
VCL is fine, but we suggest to improve your VCL considing from Fastly recommendation.
falco
does not output informations ad default. To see them, run with -vv
option.
falco
is planning to transpile Fastly VCL to the other programing language e.g Go (HTTP service), node.js (Lambda@Edge) to use temporal CDN instead of Fastly.
Contribution
- Fork this repository
- Customize / Fix problem
- Send PR :-)
- Or feel free to create issue for us. We'll look into it
License
MIT License
Author
Yoshiaki Sugimoto