# Send SmartBill Invoicing to your agent
Hand the extracted package to your coding agent with a concrete install brief instead of figuring it out manually.
## Fast path
- Download the package from Yavira.
- Extract it into a folder your agent can access.
- Paste one of the prompts below and point your agent at the extracted folder.
## Suggested prompts
### New install

```text
I downloaded a skill package from Yavira. Read SKILL.md from the extracted folder and install it by following the included instructions. Tell me what you changed and call out any manual steps you could not complete.
```
### Upgrade existing

```text
I downloaded an updated skill package from Yavira. Read SKILL.md from the extracted folder, compare it with my current installation, and upgrade it while preserving any custom configuration unless the package docs explicitly say otherwise. Summarize what changed and any follow-up checks I should run.
```
## Machine-readable fields
```json
{
  "schemaVersion": "1.0",
  "item": {
    "slug": "smartbill-invoicing",
    "name": "SmartBill Invoicing",
    "source": "tencent",
    "type": "skill",
    "category": "开发工具",
    "sourceUrl": "https://clawhub.ai/Maverick-AI-Tech/smartbill-invoicing",
    "canonicalUrl": "https://clawhub.ai/Maverick-AI-Tech/smartbill-invoicing",
    "targetPlatform": "OpenClaw"
  },
  "install": {
    "downloadUrl": "/downloads/smartbill-invoicing",
    "sourceDownloadUrl": "https://wry-manatee-359.convex.site/api/v1/download?slug=smartbill-invoicing",
    "sourcePlatform": "tencent",
    "targetPlatform": "OpenClaw",
    "packageFormat": "ZIP package",
    "primaryDoc": "SKILL.md",
    "includedAssets": [
      "references/invoice-example.json",
      "references/smartbill-api.md",
      "agents/openai.yaml",
      "scripts/smartbill_cli.py",
      "SKILL.md"
    ],
    "downloadMode": "redirect",
    "sourceHealth": {
      "source": "tencent",
      "status": "healthy",
      "reason": "direct_download_ok",
      "recommendedAction": "download",
      "checkedAt": "2026-05-07T17:22:31.273Z",
      "expiresAt": "2026-05-14T17:22:31.273Z",
      "httpStatus": 200,
      "finalUrl": "https://wry-manatee-359.convex.site/api/v1/download?slug=afrexai-annual-report",
      "contentType": "application/zip",
      "probeMethod": "head",
      "details": {
        "probeUrl": "https://wry-manatee-359.convex.site/api/v1/download?slug=afrexai-annual-report",
        "contentDisposition": "attachment; filename=\"afrexai-annual-report-1.0.0.zip\"",
        "redirectLocation": null,
        "bodySnippet": null
      },
      "scope": "source",
      "summary": "Source download looks usable.",
      "detail": "Yavira can redirect you to the upstream package for this source.",
      "primaryActionLabel": "Download for OpenClaw",
      "primaryActionHref": "/downloads/smartbill-invoicing"
    },
    "validation": {
      "installChecklist": [
        "Use the Yavira download entry.",
        "Review SKILL.md after the package is downloaded.",
        "Confirm the extracted package contains the expected setup assets."
      ],
      "postInstallChecks": [
        "Confirm the extracted package includes the expected docs or setup files.",
        "Validate the skill or prompts are available in your target agent workspace.",
        "Capture any manual follow-up steps the agent could not complete."
      ]
    }
  },
  "links": {
    "detailUrl": "https://openagent3.xyz/skills/smartbill-invoicing",
    "downloadUrl": "https://openagent3.xyz/downloads/smartbill-invoicing",
    "agentUrl": "https://openagent3.xyz/skills/smartbill-invoicing/agent",
    "manifestUrl": "https://openagent3.xyz/skills/smartbill-invoicing/agent.json",
    "briefUrl": "https://openagent3.xyz/skills/smartbill-invoicing/agent.md"
  }
}
```
## Documentation

### SmartBill Invoicing

Use scripts/smartbill_cli.py for deterministic SmartBill API calls instead of ad-hoc HTTP snippets.

### Workflow

Collect invoice input from the user.
Validate payload locally before sending:

python scripts/smartbill_cli.py validate-payload --input references/invoice-example.json --show-payload


Dry-run to inspect the normalized payload without calling the API:

python scripts/smartbill_cli.py create-invoice --input <invoice.json> --dry-run


Issue final invoice after explicit user confirmation:

python scripts/smartbill_cli.py create-invoice --input <invoice.json> --allow-final


Retrieve PDF once series and number are known:

python scripts/smartbill_cli.py download-invoice-pdf --series-name <SERIES> --number <NO> --output <file.pdf>
Use the exact number string returned by SmartBill (zero-padded, e.g. "0123"). Do not strip leading zeros or convert to an integer.
--output accepts absolute or relative paths and must end in .pdf.

### Required Environment

Set these before calling SmartBill:

SMARTBILL_USERNAME - SmartBill login email
SMARTBILL_TOKEN - SmartBill API token
SMARTBILL_COMPANY_VAT_CODE - default CIF (optional but recommended)

Optional overrides:

SMARTBILL_API_BASE (default: https://ws.smartbill.ro/SBORO/api)
SMARTBILL_TIMEOUT_SECONDS (default: 30)
SMARTBILL_RETRIES (default: 2)
SMARTBILL_DEBUG (default: unset) — set to 1, true, or yes to enable request/response debug logging to stderr

### Command Guide

validate-payload

Parse and normalize payload shape (bare invoice object or { "invoice": {...} } wrapper both accepted).
Validate minimum required structure before API calls.


create-invoice

Create invoice via POST /invoice.
Requires --allow-final to issue a final invoice.
Supports --dry-run (prints normalized payload, no API call) and --force-draft.
Pass --debug (or set SMARTBILL_DEBUG=1) to print full request/response payloads to stderr.


get-series

Query available SmartBill series via GET /series.


download-invoice-pdf

Fetch PDF via GET /invoice/pdf using CIF + series + number.
--output accepts an absolute or relative .pdf path. Relative paths are resolved against the current working directory. The resolved path must fall within an OpenClaw-allowed media root or the current working directory.

### Payload Format

The invoice payload is a flat JSON object sent directly to the SmartBill API. See references/invoice-example.json for the canonical minimal example and references/smartbill-api.md for field documentation.

Both formats are accepted as input to the CLI:

Bare invoice object: { "companyVatCode": "...", "client": {...}, ... }
Wrapped: { "invoice": { "companyVatCode": "...", "client": {...}, ... } }

The CLI unwraps automatically and sends the invoice object directly to the API.

### Operational Rules

Always use --dry-run first to confirm the normalized payload before hitting the API.
Treat final invoice issuance (isDraft: false) as a high-impact action requiring explicit user confirmation.
Set client.saveToDb: false and products[].saveToDb: false to avoid persisting test data.
Preserve SmartBill response data (series, number, message) in run logs. Store number verbatim as returned — it is zero-padded (e.g. "0123") and must never be stripped of leading zeros or cast to an integer.
Respect SmartBill rate limits: max 30 calls per 10 seconds.

### References

Read references/smartbill-api.md for payload field reference, endpoint mapping, and auth/rate-limit notes.
Use references/invoice-example.json as the canonical starting payload template.
## Trust
- Source: tencent
- Verification: Indexed source record
- Publisher: Maverick-AI-Tech
- Version: 1.0.9
## Source health
- Status: healthy
- Source download looks usable.
- Yavira can redirect you to the upstream package for this source.
- Health scope: source
- Reason: direct_download_ok
- Checked at: 2026-05-07T17:22:31.273Z
- Expires at: 2026-05-14T17:22:31.273Z
- Recommended action: Download for OpenClaw
## Links
- [Detail page](https://openagent3.xyz/skills/smartbill-invoicing)
- [Send to Agent page](https://openagent3.xyz/skills/smartbill-invoicing/agent)
- [JSON manifest](https://openagent3.xyz/skills/smartbill-invoicing/agent.json)
- [Markdown brief](https://openagent3.xyz/skills/smartbill-invoicing/agent.md)
- [Download page](https://openagent3.xyz/downloads/smartbill-invoicing)