Skip to content

feat(antd-js,antd-php,antd-zig,antd-lua)!: adopt put/get convention + PaymentMode on REST SDKs (G4)#125

Merged
Nic-dorman merged 1 commit into
mainfrom
nic/rest-sdks-payment-mode-rename
May 21, 2026
Merged

feat(antd-js,antd-php,antd-zig,antd-lua)!: adopt put/get convention + PaymentMode on REST SDKs (G4)#125
Nic-dorman merged 1 commit into
mainfrom
nic/rest-sdks-payment-mode-rename

Conversation

@Nic-dorman
Copy link
Copy Markdown
Collaborator

Summary

Final fan-out tranche — the four REST-only SDKs that have no proto/gRPC work to do. Same naming + paymentMode semantics as the typed SDKs (#116, #117, #118, #119, #120, #121, #122, #123, #124).

Method renames (per SDK idiom)

  • dataPutPrivatedataPut (POST /v1/data)
  • dataGetPrivatedataGet (POST /v1/data/get with data_map body)
  • fileUploadPublicfilePutPublic (POST /v1/files/public)
  • fileDownloadPublicfileGetPublic (POST /v1/files/public/get)
  • NEW: filePut (POST /v1/files), fileGet (POST /v1/files/get)

PaymentMode (Auto / Merkle / Single)

  • antd-js: const PaymentMode = { Auto, Merkle, Single } as const + matching type.
  • antd-php: enum PaymentMode: string.
  • antd-zig: pub const PaymentMode = enum { auto, merkle, single, pub fn wire }.
  • antd-lua: models.PaymentMode = { AUTO = "auto", ... }.

Threaded through dataPut, dataPutPublic, dataCost, filePut, filePutPublic, fileCost with .Auto as the default.

Result-type shake-up

  • New result types per SDK: DataPutResult, DataPutPublicResult, FilePutResult, FilePutPublicResult — each carries chunksStored + paymentModeUsed; file variants also carry storageCostAtto + gasCostWei.
  • PutResult kept for chunkPut only; FileUploadResult removed.

Test plan

  • antd-js: npm test (63/63) + ant dev example all -l js (six examples OK).
  • antd-php: vendor/bin/phpunit tests (31/31) + ant dev example all -l php (all OK).
  • antd-zig: zig build test (zig 0.14.1, pass) + ant dev example all -l zig (all OK).
  • antd-lua: busted spec/ (26/26) + ant dev example all -l lua (all OK).

🤖 Generated with Claude Code

@Nic-dorman Nic-dorman force-pushed the nic/v2-340-file-upload-private branch from cc9cea2 to 7e3d414 Compare May 21, 2026 15:41
@Nic-dorman Nic-dorman changed the base branch from nic/v2-340-file-upload-private to main May 21, 2026 15:44
… PaymentMode on REST SDKs (G4)

Final fan-out tranche — the four REST-only SDKs that have no proto/gRPC
work to do. Same naming + paymentMode semantics as the typed SDKs (#116,
#117, #118, #119, #120, #121, #122, #123, #124).

Per-SDK summary:

- antd-js: new `PaymentMode` const + types `DataPutResult`,
  `DataPutPublicResult`, `FilePutResult`, `FilePutPublicResult`
  (`FileUploadResult` removed; `PutResult` kept for `chunkPut`).
  Method renames on `RestClient`: `dataPutPrivate` -> `dataPut`,
  `dataGetPrivate` -> `dataGet`, `fileUploadPublic` -> `filePutPublic`,
  `fileDownloadPublic` -> `fileGetPublic`. NEW: `filePut` + `fileGet`.
  `paymentMode` option added to data/file put + cost. package-lock.json
  refresh picks up the existing `ethers` devDep that example 07 imports.

- antd-php: new `PaymentMode` backed enum + readonly result classes; same
  method renames on `AntdClient` (sync + async variants).

- antd-zig: new `PaymentMode` enum with `.wire()`; result-type rename mirrors
  the others; `dataGet` switches to POST /v1/data/get with `data_map` body
  (replaces the old GET-with-querystring path).

- antd-lua: new `models.PaymentMode` table of wire strings; method renames
  on `Client`; `data_get` / `file_get` / `file_put_public` / `file_get_public`
  go through POST bodies on the new routes.

Validated on dev2:
- antd-js: npm test (63/63 pass) + ant dev example all -l js (all six OK).
- antd-php: phpunit (31/31 pass) + ant dev example all -l php (all OK).
- antd-zig: zig 0.14.1 build test (pass) + ant dev example all -l zig.
- antd-lua: busted (26/26 pass) + ant dev example all -l lua (all OK).

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
@Nic-dorman Nic-dorman force-pushed the nic/rest-sdks-payment-mode-rename branch from 8db8975 to 60197aa Compare May 21, 2026 15:50
@Nic-dorman Nic-dorman merged commit 7e193ac into main May 21, 2026
@Nic-dorman Nic-dorman deleted the nic/rest-sdks-payment-mode-rename branch May 21, 2026 16:02
Nic-dorman added a commit that referenced this pull request May 21, 2026
Cuts v0.8.0 atop v0.7.1. Substantial breaking-change roll-up of the
put/get rename, the private-file PUT/GET gap close, and several minor
surface cleanups -- bundled here so the v1.0 cut can ship stable on top.

## Breaking (antd daemon)

- feat(antd)!: bind to 127.0.0.1 by default on REST and gRPC (#107).
  Previously bound 0.0.0.0; use --bind-rest / --bind-grpc to override.
- chore: remove dead graph_entry surface from antd proto + 5 SDKs (#92).
  GraphService and its 4 RPCs are gone; REST mounts dropped.
- chore: remove dir_upload_public / dir_download_public surface (#95).
  Use file_put_public on a directory path instead; the daemon recurses.
- feat(antd)!: normalize put/get convention + close private-file PUT and
  GET gaps (#115). Method renames across proto + REST + SDKs:
    data_put_private    -> data_put
    data_get_private    -> data_get
    file_upload_public  -> file_put_public
    file_download_public -> file_get_public
  New: file_put / file_get for the private file path (previously only
  the public variant existed). New typed results: DataPutResult,
  DataPutPublicResult, FilePutResult, FilePutPublicResult; PutResult
  is now annotated as chunk_put only.

## Additive

- feat(antd): honor payment_mode on gRPC put/cost paths and REST cost
  endpoints (#114). Optional kwarg threaded through every put/cost
  signature; empty/omitted maps to "auto" so older clients keep working.
- feat: external-signer public uploads + single-chunk prepare/finalize
  across 15 SDKs (#90).
- docs+spec: openapi.yaml refreshed for the v1.0 surface, including
  POST /v1/chunks/prepare and /v1/chunks/finalize for single-chunk
  external-signer publish (#126).

## SDK fan-out (PaymentMode + put/get convention, all 15)

#116 antd-go, #117 antd-py/ruby/elixir, #118 antd-rust, #119 antd-csharp,
#120 antd-java, #121 antd-swift, #122 antd-dart, #123 antd-kotlin,
#124 antd-cpp, #125 antd-js/php/zig/lua, #127 antd-mcp.

## SDK example + build fixes

- fix(antd-go): make 03-files example self-contained and runnable (#91)
- fix(examples): make 04-files runnable across cpp/rust/elixir/lua/php/ruby/zig (#93)
- fix(examples): runnable dart 04_files + java Example03Files; add java Example03Chunks (#94)
- feat: gRPC transport example for antd-py and antd-rust (#113)
- feat(antd-py): 07_external_signer example + ant-dev dispatcher entry (#98)
- feat(antd-js): 07-external-signer example + antd-py empty-payments fix (#99)
- feat(rust/go): 07-external-signer examples (#100)
- feat(antd-csharp): 07_external_signer example (#101)
- feat(antd-java): 07_external_signer example (#102)
- feat(antd-kotlin): 07_external_signer example (#103)
- feat(antd-dart): 07_external_signer example (#104)
- feat(antd-ruby): 07_external_signer example (#105)
- feat(antd-php): 07_external_signer example (#106)
- chore(antd-kotlin): drop stale GraphDescendant from local proto copy (#108)

## Docs / infra

- docs: external-signer flow reference + ABI + python smoke test (#97)
- docs: add SECURITY.md with threat model and disclosure policy (#109)
- docs!: refresh per-SDK READMEs + llms-full.txt + openapi.yaml for v1.0 surface (#126)
- ci: add Go lint + test + vuln scanning for antd-go (#112)
- ci: extend antd-rust to sibling-repo parity (fmt + clippy + audit + doc) (#111)
- ci: skip antd/openapi.yaml and llms-full.txt from triggering CI (#128)
- chore(scripts): add full-stack + integration sweep helpers (#96)
- fix(antd-rust): regenerate Cargo.lock to unbreak --locked CI (#110)

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant