secrets, holding the API key. Create it with the TenantClient. The tail is the per-map local name; the host stores it as z:<tid>:<tail>.
readers must be set explicitly — the KV governor defaults to deny, so leaving it off makes the contract’s own secret read fail with AccessDenied. MapAlreadyExists is idempotent — safe to re-run when re-deploying.
Map visibility quick reference:
"private"— only your contracts can access this map (default, use it for everything sensitive)."public"— world-readable via/api/dev/public-kv/<tid>/<tail>. Map tail must start withpublic:. Never put PII in a public map.