Local script features
Embedding local script features in Izanami allows to leverage the power and flexibility of script features without needing to deploy a WASMO instance in production._createMdxContent
This strategy implies that you'll be on your own to handle plugins versions and lifecycle, though wasmo-CLI could help with this.
data:image/s3,"s3://crabby-images/2fb48/2fb489237b3a6eb5c444379428affff38daf4af0" alt=""
Since this method requires embedding Base64 encoded WASM scripts in Izanami
database, it's recommended to use languages that produce lightweight WASM
files, such as go
or OPA
.
Creating your script with WASMO cli
In this example, we'll create a script feature that returns true if request context contains "mobile".
We want this feature to be active for following contexts :
prod/mobile
mobile
dev/mobile
mobile
- ...
and to be inactive for following contexts :
prod
dev
- empty context
- ...
First you'll need to install WASMO CLI.
Then instantiate a new project.
Wasmo provide some built-in templates, we'll be using the Izanami opa
one for this example.
You'll need to open a command shell for this.
wasmo init --name=izanami-mobile --template=izanami_opa
data:image/s3,"s3://crabby-images/2fb48/2fb489237b3a6eb5c444379428affff38daf4af0" alt=""
If you want to use go instead of opa for this tutorial, simply replace
izanami_opa
with izanami_go
.
This command should create a izanami-mobile
directory where you run it.
This directory should contain two files : main.go
and go.mod
.
For our feature, we'll only need to modify main.go
with the following code:
- Open Policy Agent (OPA)
- Go
package example
import rego.v1
default can_access = false
can_access if {
some x in input.executionContext
x == "mobile"
}
package main
import (
"github.com/extism/go-pdk"
"github.com/buger/jsonparser"
)
func containsString(arr []string, s string) string {
for _, v := range arr {
if v == s {
return "true"
}
}
return "false"
}
func bytesToString(bytes []byte) []string {
var context []string
jsonparser.ArrayEach(bytes, func(value []byte, dataType jsonparser.ValueType, offset int, err error) {
if err != nil {
}
context = append(context, string(value))
})
return context
}
//export execute
func execute() int32 {
input := pdk.Input()
var values, dataType, offset, err = jsonparser.Get(input, "executionContext")
_ = dataType
_ = offset
if err != nil {}
var context = bytesToString(values)
mem := pdk.AllocateString(`{
"active": `+ containsString(context, "mobile") + `
}`)
pdk.OutputMemory(mem)
return 0
}
func main() {}
This code may seem obscure at first, however it does a quite basic task :
- It reads
executionContext
fields provided by Izanami, that indicates the context that was used for querying Izanami. - It converts
executionContext
content from bytes to array of string (data are transferred as byte from Izanami to WASM). - It checks if
mobile
contexts is present somewhere in context path
As you can see, Open Policy Agent is arguably best suited for this kind of script.
Once you're done editing the file, build your script with the following command :
wasmo build --host=OneShotDocker --path=izanami-mobile
This will generate an izanami-mobile-1.0.0.wasm
file at the root of your directory.
You can now convert this file to base64, for instance, with the following command :
openssl base64 -A -in ./izanami-mobile/izanami-mobile-1.0.0.wasm -out out.txt
data:image/s3,"s3://crabby-images/2fb48/2fb489237b3a6eb5c444379428affff38daf4af0" alt=""
Izanami requires base64 to be on a single line, that's why we use the -A
flag in the above command.
Once you've got your Base64 script, you'll need to create a WASM Base64 feature in Izanami.
To do this, select "New WASM script" feature type, then indicate that WASM script is of type "Base64". Then you'll need to paste your base64 WASM script in the appropriate input.
data:image/s3,"s3://crabby-images/4dded/4dded299457bfa577ba652c7513720105ceb09ec" alt=""
Once your feature is created, we can test it.
Let's first see if it works with a basic mobile
context.
data:image/s3,"s3://crabby-images/740fd/740fdc7f2f6585273c0e0ad6ea76a34ded722891" alt=""
Our script also works with subcontext containing a mobile
subcontext.
data:image/s3,"s3://crabby-images/bd48d/bd48dece69f0177b7145f2054d45d48a2e6c1e98" alt=""
As expected, it does not activate feature for a context that does not contain mobile
.
data:image/s3,"s3://crabby-images/8f56c/8f56caf401dfca7ca783a3e502f1f4d3bf633969" alt=""