Skip to content

Conversation

@tabaktoni
Copy link
Member

Motivation and Resolution

Proposed solution for the Contract class method options
Chainable withOptions()
Fix #1252

RPC version (if applicable)

Usage related changes

Old

const status = await cairo1Contract.get_bet(1, {
          formatResponse: { name: 'string', description: 'string' },
        });

NEW

const status = await cairo1Contract
        .withOptions({
          formatResponse: { name: 'string', description: 'string' },
        })
        .get_bet(1);

Checklist:

  • Performed a self-review of the code
  • Rebased to the last commit of the target branch (or merged it into my branch)
  • Linked the issues which this PR resolves
  • Documented the changes in code (API docs will be generated automatically)
  • Updated the tests
  • All tests are passing

@penovicp
Copy link
Collaborator

penovicp commented Nov 4, 2024

Copying what I wrote for PR#1253 about using spread Calldata as the argument so we can keep it in mind for this PR:

I believe the spread Calldata branch can also be removed ([...Calldata] | [...Calldata, ContractOptions] from the reworked ArgsOrCalldataWithOptions type). It is supported by splitArgsAndOptions itself, however, splitArgsAndOptions is in all its usages followed by the getCalldata() utility that filters the argument based on the __compiled__ marker which isn't propagated if the Calldata is spread. This means that the only spread input that should be able to work is method(...Calldata, { parseRequest: false }).

I don't see any utility in restoring the full support, so refactoring the code to exclude the supported scenario seems preferable, it should also simplify detecting whether a ContractOptions object is used.

The point made about the spread being filtered out later in the code execution still applies so the only supported scenario, updated for the changes from this PR, is the following:

  contract
    .withOptions({ parseRequest: false })
    .method(...Calldata)

An option is to keep it as is, but in that case we should probably clarify the behaviour in the documentation.

@tabaktoni tabaktoni merged commit b59952e into beta Mar 6, 2025
1 of 2 checks passed
github-actions bot pushed a commit that referenced this pull request Mar 10, 2025
# [7.0.0-beta.2](v7.0.0-beta.1...v7.0.0-beta.2) (2025-03-10)

### Bug Fixes

* contract withOptions Fix/1252 ([#1255](#1255)) ([b59952e](b59952e))
* update ws impl, add TEST_WS_URL, update token constants ([411eeec](411eeec))

### Features

* the WebSockets ([#1251](#1251)) ([fabca27](fabca27)), closes [#1272](#1272)
* v7 fee, new methods, tests ([#1337](#1337)) ([00743de](00743de))
@github-actions
Copy link
Contributor

🎉 This PR is included in version 7.0.0-beta.2 🎉

The release is available on:

Your semantic-release bot 📦🚀

github-actions bot pushed a commit that referenced this pull request Mar 28, 2025
# [7.0.0](v6.24.1...v7.0.0) (2025-03-28)

* Implement RPC 0.8 and V3 transactions ([#1328](#1328)) ([316ae27](316ae27))

### Bug Fixes

* contract withOptions Fix/1252 ([#1255](#1255)) ([b59952e](b59952e))
* update ws impl, add TEST_WS_URL, update token constants ([411eeec](411eeec))

### Features

* drop fetch-cookie dependency ([9a57daf](9a57daf))
* drop isomorphic-fetch dependency ([9da0083](9da0083))
* prune deprecated functionalities ([cbd18f5](cbd18f5))
* the WebSockets ([#1251](#1251)) ([fabca27](fabca27)), closes [#1272](#1272)
* Update Beta to latest Develop ([#1312](#1312)) ([2958051](2958051)), closes [#949](#949) [#970](#970)
* v7 fee, new methods, tests ([#1337](#1337)) ([00743de](00743de))

### BREAKING CHANGES

* Removed multiple functionalities that have been marked as deprecated
* Library defaults to RPC 0.8 with the corresponding API changes, dropped RPC 0.6 support
PhilippeR26 added a commit to PhilippeR26/starknet.js that referenced this pull request May 5, 2025
docs: update guide

build: ledger app v2.3.0

chore: upgrade name to 2.3.1 and polish doc

docs: update guide

chore: upgrade name to 2.3.1 and polish doc

feat: prune deprecated functionalities

BREAKING CHANGE: Removed multiple functionalities that have been marked as deprecated

chore(release): 7.0.0-beta.4 [skip ci]

* repair snip-12 enum type nested dependency ([starknet-io#1289](starknet-io#1289)) ([1cd4219](starknet-io@1cd4219))

* drop fetch-cookie dependency ([9a57daf](starknet-io@9a57daf))
* drop isomorphic-fetch dependency ([9da0083](starknet-io@9da0083))
* prune deprecated functionalities ([cbd18f5](starknet-io@cbd18f5))

* Removed multiple functionalities that have been marked as deprecated

chore(release): 7.0.0 [skip ci]

* Implement RPC 0.8 and V3 transactions ([starknet-io#1328](starknet-io#1328)) ([316ae27](starknet-io@316ae27))

* contract withOptions Fix/1252 ([starknet-io#1255](starknet-io#1255)) ([b59952e](starknet-io@b59952e))
* update ws impl, add TEST_WS_URL, update token constants ([411eeec](starknet-io@411eeec))

* drop fetch-cookie dependency ([9a57daf](starknet-io@9a57daf))
* drop isomorphic-fetch dependency ([9da0083](starknet-io@9da0083))
* prune deprecated functionalities ([cbd18f5](starknet-io@cbd18f5))
* the WebSockets ([starknet-io#1251](starknet-io#1251)) ([fabca27](starknet-io@fabca27)), closes [starknet-io#1272](starknet-io#1272)
* Update Beta to latest Develop ([starknet-io#1312](starknet-io#1312)) ([2958051](starknet-io@2958051)), closes [starknet-io#949](starknet-io#949) [starknet-io#970](starknet-io#970)
* v7 fee, new methods, tests ([starknet-io#1337](starknet-io#1337)) ([00743de](starknet-io@00743de))

* Removed multiple functionalities that have been marked as deprecated
* Library defaults to RPC 0.8 with the corresponding API changes, dropped RPC 0.6 support

fix: preserve value for numeric arguments within address padding utility

chore(release): 7.0.1 [skip ci]

* preserve value for numeric arguments within address padding utility ([abc7958](starknet-io@abc7958))

docs: generate documentation version

docs: expand v7 migration guide (starknet-io#1368)

---------
Co-authored-by: Petar Penovic <[email protected]>

fix: make the provider create method generic to enable it when mixins are applied (starknet-io#1370)

fix: ensure enum replacement objects are reachable for type resolution (starknet-io#1375)

docs: update guides for v7 (starknet-io#1376)

---------
Co-authored-by: Petar Penovic <[email protected]>

feat: update to rpc 0.8.1

chore(release): 7.1.0 [skip ci]

* ensure enum replacement objects are reachable for type resolution ([starknet-io#1375](starknet-io#1375)) ([eb8b10d](starknet-io@eb8b10d))
* make the provider create method generic to enable it when mixins are applied ([starknet-io#1370](starknet-io#1370)) ([1f48dc6](starknet-io@1f48dc6))

* update to rpc 0.8.1 ([83e17b8](starknet-io@83e17b8))

style: remove comment
@penovicp penovicp deleted the fix/1252-break branch August 27, 2025 23:00
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Projects

None yet

Development

Successfully merging this pull request may close these issues.

splitArgsAndOptions with single argument containing options

2 participants