Search
Varnish Enterprise

Introduction Installation Upgrading Troubleshooting Changelog Changelog for 6.0.x Changes (Varnish Cache 4.1) Changes (Varnish Cache Plus 4.1) Known Issues Features Backend SSL/TLS Client SSL/TLS termination Cluster In-Process TLS MSE 4 Basic Configuration / Getting Started Configuration Persisted caching Categories Configuration Reference MSE 3.0 Settings mkfs.mse Memory Governor MSE 2.0 NUMA Parallel ESI Backend health counter HTTP/2 Support JSON Logging TCP Only Probes Timeouts Transit Buffer Varnish scoreboard VMODs Accept Accounting ACL (aclplus) ActiveDNS Akamai Connector AWS VCL Body Access & Transformation (xbody) Brotli Cookie Plus (cookieplus) DeviceAtlas DeviceAtlas3 Digest Dynamic backends (goto) Edgestash File Format Geolocation (geoip/mmdb) Header Manipulation (headerplus) HTTP communication (http) Image JSON parsing (json) JWT Key value storage (kvstore) Least connections director (leastconn) Module to control the built-in HTTP2 transport (h2) MSE control (mse) MSE4 control (mse4) Probe Proxy ProxyV2 TLV Attribute Extraction (proxy) Pseudo Random Number Generator Purge (purge/softpurge) Real-time Status (rtstatus) Reverse DNS (resolver) Rewrite S3 VMOD Session Slicer SQLite3 Stale Standard (std) Stat (Prometheus) Strings (str) Synthetic backends (synthbackend) Tag-based invalidation (Ykey/Xkey) TCP configuration (tcp) TLS Total Encryption (crypto) Unified director object (udo) Uniform Resource Identifier (uri) Unix Socket Utilities (unix) URL Plus (urlplus) Utils Vsthrottle

ACL (aclplus)

Description

The aclplus vmod allows you to match IP addresses against ACLs similar to VCL ACLs. The key difference is that your ACLs don’t need to be bound to the active VCL and can be stored as strings in a separate VMOD such as vmod-kvstore or even backend responses.

Currently, IPv4 and IPv6 addresses and subnets are supported, and entries can be prefixed with an exclamation mark (!) for a negative match, like so: !10.0.0.1.

Syntax

ACLs are represented by a single-line CSV string:

127.0.0.1, !192.168.0.1, 192.168.0.0/16, ::1, !::2, fe00::1/16

The client IP will be matched against all ACLs, and if a match is found and no negation is encountered then access will be granted. If any matching negations are found then access will always be denied. Granted here meaning the match() API function returning true.

Example

Assuming a CSV file containing a domain name in the first column, followed by IP addresses complying to the syntax described above:

vcl 4.0;

import aclplus;
import kvstore;

sub vcl_init {
  new purgers = kvstore.init();
  purgers.init_file("/some/path/data.csv", ",");
  new regions = kvstore.init();
  region.init_file("/some/path/data.csv", ",");
  new region_cnf = kvstore.init();
  region_cnf.init_file("/some/path/data.csv", ",");
}

sub vcl_recv {
  if (req.method == "PURGE") {
    if (aclplus.match(client.ip, purgers.get(req.http.host, "error"))) {
      return (purge);
    }
    return (synth(405));
  }
  set req.http.region_cnf = region_cnf.get(aclplus.find(client.ip,
	    regions.get(req.http.host, "error")));
  if (req.http.region_cnf == "cluster2-EMEA") {
/*Do stuff*/
  }

}

API

match

BOOL match(IP, STRING)

Returns true if the supplied IP address matches the text-representation of an ACL. Works with both IPv4 and IPv6.

Arguments: None

Type: Function

Returns: Bool

find

STRING find(IP, STRING)

Similar to match(), but instead of returning true/false, returns the rule that was matched from the supplied ACL list, returns NULL on no match.

Arguments: None

Type: Function

Returns: String

Availability

The aclplus VMOD is available in Varnish Enterprise version 6.0.0r0 and later.


®Varnish Software, Wallingatan 12, 111 60 Stockholm, Organization nr. 556805-6203