Skip to content

VIP4: Restrict VMOD function call sites

Dridi Boukelmoune edited this page Mar 14, 2016 · 7 revisions

Synopsis

Teach the VCC to conditionally refuse $Function or $Method calls.

Why?

It started with the fact that VRT functions sometimes expect to be called under certain conditions but nothing really documents or enforces such conditions. These functions could at least assert that their requirements are met if that is not already the case, but this is outside of this VIP's scope.

VMOD functions defined by the ad-hoc VCC can however express this kind of requirements when that makes sense. Besides VMOD constructs like the $Event function that are not visible in VCL or $Object constructors that can only be used in vcl_init all VMOD functions can be called from anywhere.

If a VMOD function calls a VRT function that has a special requirement, the VMOD author could document it, and the VCC could enforce it.

How?

A new $Restrict token followed by a list of blank-separated restrictions. There's already such a mechanism in generate.py and general consensus leans towards reusing the same parameters:

  • client (all client subroutines)
  • backend (all backend subroutines)
  • <subroutine> (a specific subroutine)

Example:

$Function VOID needs_a_bereq(...)
$Restrict backend pipe

Another example:

$Module mtstatus 3 Mean time status for Varnish Cache
$Event event_function

# Both functions use VRT_synth_page
$Function VOID mtstatus(REAL delta)
$Restrict synth

# This function gets the HTML contents from a file, it might be worth caching 
$Function VOID html(STRING file = "/usr/share/vmod-mtstatus/page.html")
$Restrict synth backend_error
Clone this wiki locally