AshLua exposes Ash actions to Lua scripts evaluated through the lua
Elixir package, ensuring a consistent actor / tenant / context are propagated into every Ash call.
The Lua surface is derived from Ash.Info.Manifest.generate/1 — every public action becomes a
callable at <domain>.<resource>.<action> (names overridable via the AshLua.Domain and
AshLua.Resource DSL extensions).
Example
defmodule MyApp.Accounts do
use Ash.Domain, otp_app: :my_app, extensions: [AshLua.Domain]
resources do
resource MyApp.Accounts.User
end
end
defmodule MyApp.Accounts.User do
use Ash.Resource,
domain: MyApp.Accounts,
extensions: [AshLua.Resource]
# ... attributes / actions ...
end
AshLua.eval!("""
local user, err = accounts.user.create({ name = "Zach" })
assert(err == nil)
return user.id
""", otp_app: :my_app, actor: current_user)Action callables always return (result, nil) on success and (nil, err_table) on failure.
Wrap a call in Lua's built-in assert() for raise semantics:
local user = assert(accounts.user.create({ name = "Zach" }))Actor / tenant / context
All three are host-supplied via the eval opts and are never reflected to or mutable from the script — there is no way for a Lua script to read or change the actor, tenant, or context.
Summary
Functions
Evaluates a Lua script in a freshly-built VM and returns {results, %Lua{}}.
Builds a %Lua{} VM with Ash bindings installed, ready for repeated Lua.eval!/2 calls.
Functions
Evaluates a Lua script in a freshly-built VM and returns {results, %Lua{}}.
Options
:otp_app(required unless:manifestis given) — passed toAsh.Info.Manifest.generate/1.:actor,:tenant,:context— host-supplied; merged into every Ash call.:manifest— a pre-built%Ash.Info.Manifest{}to skip regeneration.:lua— a pre-built%Lua{}to install bindings on (e.g. with extraLua.set!/3callbacks).:decode— forwarded toLua.eval!/3; defaults totrue.
Builds a %Lua{} VM with Ash bindings installed, ready for repeated Lua.eval!/2 calls.
Accepts the same :otp_app / :actor / :tenant / :context / :manifest / :lua
options as eval!/2.