diff --git a/.github/workflows/certora_4337.yml b/.github/workflows/certora_4337.yml index d30ad49f..d6dd5c0e 100644 --- a/.github/workflows/certora_4337.yml +++ b/.github/workflows/certora_4337.yml @@ -23,12 +23,17 @@ jobs: steps: - uses: actions/checkout@v3 + - name: Install pnpm + uses: pnpm/action-setup@v3 + with: + version: 9 + - name: Install python uses: actions/setup-python@v4 with: { python-version: 3.11 } - name: Install certora cli - run: pip install -Iv certora-cli==6.1.3 + run: pip install -Iv certora-cli==7.3.0 - name: Install solc run: | @@ -37,7 +42,7 @@ jobs: sudo mv solc-static-linux /usr/local/bin/solc8.23 - name: Install dependencies - run: pnpm install + run: pnpm install - name: Verify rule ${{ matrix.rule }} working-directory: ./modules/4337 diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index ce442acd..bb310d45 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -6,10 +6,13 @@ jobs: runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 + - name: Install pnpm + uses: pnpm/action-setup@v3 + with: + version: 9 - uses: actions/setup-node@v4 with: node-version: 20.x - cache: npm - cache-dependency-path: package-lock.json - - run: npm ci - - run: npm run fmt:global-check + cache: pnpm + - run: pnpm install + - run: pnpm run fmt:global-check diff --git a/.github/workflows/ci_4337.yml b/.github/workflows/ci_4337.yml index df4b06f0..8236bc89 100644 --- a/.github/workflows/ci_4337.yml +++ b/.github/workflows/ci_4337.yml @@ -9,13 +9,16 @@ jobs: runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 + - name: Install pnpm + uses: pnpm/action-setup@v3 + with: + version: 9 - uses: actions/setup-node@v4 with: node-version: 20.x - cache: npm - cache-dependency-path: package-lock.json + cache: pnpm - run: | - npm ci + pnpm install npm run coverage -w modules/4337 - name: Coveralls uses: coverallsapp/github-action@master @@ -26,24 +29,31 @@ jobs: runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 + + - name: Install pnpm + uses: pnpm/action-setup@v3 + with: + version: 9 - uses: actions/setup-node@v4 with: node-version: 20.x - cache: npm - cache-dependency-path: package-lock.json + cache: pnpm - run: | - npm ci + pnpm install npm run test:4337 -w modules/4337 lint: runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 + - name: Install pnpm + uses: pnpm/action-setup@v3 + with: + version: 9 - uses: actions/setup-node@v4 with: node-version: 20.x - cache: npm - cache-dependency-path: package-lock.json + cache: pnpm - run: | - npm ci + pnpm install npm run lint -w modules/4337 npm run fmt:check -w modules/4337 diff --git a/.github/workflows/ci_4337_gas_metering.yml b/.github/workflows/ci_4337_gas_metering.yml index c4b5a541..c99a6e5c 100644 --- a/.github/workflows/ci_4337_gas_metering.yml +++ b/.github/workflows/ci_4337_gas_metering.yml @@ -10,6 +10,10 @@ jobs: runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 + - name: Install pnpm + uses: pnpm/action-setup@v3 + with: + version: 9 - uses: actions/setup-node@v4 with: node-version: ${{ matrix.node-version }} @@ -17,6 +21,6 @@ jobs: - name: Install dependencies run: pnpm install - run: | - npm run fmt:check -w examples/4337-gas-metering - npm run lint -w examples/4337-gas-metering - npm run build -w examples/4337-gas-metering + pnpm run --filter "@safe-global/safe-modules-example-4337-gas-metering" fmt:check + pnpm run --filter "@safe-global/safe-modules-example-4337-gas-metering" lint + pnpm run --filter "@safe-global/safe-modules-example-4337-gas-metering" build diff --git a/.github/workflows/ci_4337_local_bundler.yml b/.github/workflows/ci_4337_local_bundler.yml index 62e4dddf..099478ed 100644 --- a/.github/workflows/ci_4337_local_bundler.yml +++ b/.github/workflows/ci_4337_local_bundler.yml @@ -9,11 +9,16 @@ jobs: runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 + + - name: Install pnpm + uses: pnpm/action-setup@v3 + with: + version: 9 + - uses: actions/setup-node@v4 with: node-version: 20.x - cache: npm - cache-dependency-path: package-lock.json + cache: pnpm - run: | - npm ci - npm run lint -w packages/4337-local-bundler + pnpm install + pnpm run --filter "@safe-global/safe-4337-local-bundler" lint diff --git a/.github/workflows/ci_4337_upstream_bundler.yml b/.github/workflows/ci_4337_upstream_bundler.yml index 4f7f857e..340681ab 100644 --- a/.github/workflows/ci_4337_upstream_bundler.yml +++ b/.github/workflows/ci_4337_upstream_bundler.yml @@ -15,12 +15,17 @@ jobs: runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 + + - name: Install pnpm + uses: pnpm/action-setup@v3 + with: + version: 9 + - uses: actions/setup-node@v4 with: node-version: 20.x - cache: npm - cache-dependency-path: package-lock.json + cache: pnpm - run: | - npm ci + pnpm install npm run test:4337:upstream -w modules/4337 npm run test:4337:upstream -w modules/passkey diff --git a/.github/workflows/ci_passkey.yml b/.github/workflows/ci_passkey.yml index 05968a44..eee8ce1b 100644 --- a/.github/workflows/ci_passkey.yml +++ b/.github/workflows/ci_passkey.yml @@ -9,14 +9,17 @@ jobs: runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 + - name: Install pnpm + uses: pnpm/action-setup@v3 + with: + version: 9 - uses: actions/setup-node@v4 with: node-version: 20.x - cache: npm - cache-dependency-path: package-lock.json + cache: pnpm - run: | - npm ci - npm run coverage -w modules/passkey + pnpm install + pnpm run --filter "@safe-global/safe-passkey" coverage - uses: coverallsapp/github-action@master with: path-to-lcov: modules/passkey/coverage/lcov.info @@ -25,37 +28,46 @@ jobs: runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 + - name: Install pnpm + uses: pnpm/action-setup@v3 + with: + version: 9 - uses: actions/setup-node@v4 with: node-version: 20.x - cache: npm - cache-dependency-path: package-lock.json + cache: pnpm - run: | - npm ci - npm run lint -w modules/passkey - npm run fmt:check -w modules/passkey - npm run build -w modules/passkey + pnpm install + pnpm run --filter "@safe-global/safe-passkey" lint + pnpm run --filter "@safe-global/safe-passkey" fmt:check + pnpm run --filter "@safe-global/safe-passkey" build e2e: runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 + - name: Install pnpm + uses: pnpm/action-setup@v3 + with: + version: 9 - uses: actions/setup-node@v4 with: node-version: 20.x - cache: npm - cache-dependency-path: package-lock.json + cache: pnpm - run: | - npm ci - npm run test:4337 -w modules/passkey + pnpm install + pnpm run --filter "@safe-global/safe-passkey" test:4337 benchmark: runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 + - name: Install pnpm + uses: pnpm/action-setup@v3 + with: + version: 9 - uses: actions/setup-node@v4 with: node-version: 20.x - cache: npm - cache-dependency-path: package-lock.json + cache: pnpm - run: | - npm ci - npm run bench -w modules/passkey + pnpm install + pnpm run --filter "@safe-global/safe-passkey" bench diff --git a/.github/workflows/ci_passkey_example.yml b/.github/workflows/ci_passkey_example.yml index 57ac18d6..141055ad 100644 --- a/.github/workflows/ci_passkey_example.yml +++ b/.github/workflows/ci_passkey_example.yml @@ -11,13 +11,16 @@ jobs: runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 + - name: Install pnpm + uses: pnpm/action-setup@v3 + with: + version: 9 - uses: actions/setup-node@v4 with: node-version: 20.x - cache: npm - cache-dependency-path: package-lock.json + cache: pnpm - run: | - npm ci + pnpm install npm run lint -w examples/4337-passkeys npm run build -w examples/4337-passkeys env: diff --git a/.npmrc b/.npmrc index 3e775efb..0e74e441 100644 --- a/.npmrc +++ b/.npmrc @@ -1 +1,2 @@ auto-install-peers=true +shamefully-hoist=true \ No newline at end of file diff --git a/.prettierignore b/.prettierignore index dcc49149..97ce6975 100644 --- a/.prettierignore +++ b/.prettierignore @@ -1,3 +1,5 @@ +# They're excluded on the global level because each of them defines its own linting and formatting rules examples/** modules/** packages/** +pnpm-lock.yaml \ No newline at end of file diff --git a/examples/4337-passkeys/package.json b/examples/4337-passkeys/package.json index b19bdbc3..d74307ba 100644 --- a/examples/4337-passkeys/package.json +++ b/examples/4337-passkeys/package.json @@ -13,7 +13,7 @@ "dependencies": { "@account-abstraction/contracts": "0.7.0", "@safe-global/safe-4337": "0.3.0", - "@safe-global/safe-passkey": "0.2.0-alpha.1", + "@safe-global/safe-passkey": "workspace:0.2.0-alpha.2", "@web3modal/ethers": "^4.1.11", "ethers": "^6.12.1", "react": "^18.3.1", diff --git a/modules/4337/certora/conf/Safe4337Module.conf b/modules/4337/certora/conf/Safe4337Module.conf index 7f663561..abaf4149 100644 --- a/modules/4337/certora/conf/Safe4337Module.conf +++ b/modules/4337/certora/conf/Safe4337Module.conf @@ -8,12 +8,14 @@ "msg": "Safe4337Module: General Ruleset", "optimistic_hashing": true, "optimistic_loop": true, + "optimistic_fallback": true, "process": "emv", "prover_args": [ - " -optimisticFallback true -s z3 -copyLoopUnroll 5 -mediumTimeout 5" + "-s z3 -copyLoopUnroll 5 -mediumTimeout 5" ], "rule_sanity": "basic", "solc": "solc8.23", + "solc_allow_path": "../../node_modules", "verify": "Safe4337Module:certora/specs/Safe4337Module.spec", "packages": [ "@account-abstraction=../../node_modules/@account-abstraction", diff --git a/modules/4337/certora/conf/TransactionExecutionMethods.conf b/modules/4337/certora/conf/TransactionExecutionMethods.conf index cac80abb..ab74ddb4 100644 --- a/modules/4337/certora/conf/TransactionExecutionMethods.conf +++ b/modules/4337/certora/conf/TransactionExecutionMethods.conf @@ -8,12 +8,14 @@ "msg": "Safe4337Module: TransactionExecutionMethods Ruleset", "optimistic_hashing": true, "optimistic_loop": true, + "optimistic_fallback": true, "process": "emv", "prover_args": [ - " -optimisticFallback true -s z3 -copyLoopUnroll 5 -mediumTimeout 5 -depth 30" + "-s z3 -copyLoopUnroll 5 -mediumTimeout 5 -depth 30" ], "rule_sanity": "advanced", "solc": "solc8.23", + "solc_allow_path": "../../node_modules", "verify": "Safe4337Module:certora/specs/TransactionExecutionMethods.spec", "packages": [ "@account-abstraction=../../node_modules/@account-abstraction", diff --git a/modules/4337/certora/conf/ValidationDataLastBitOne.conf b/modules/4337/certora/conf/ValidationDataLastBitOne.conf index 98b4f1c1..b3c06fe2 100644 --- a/modules/4337/certora/conf/ValidationDataLastBitOne.conf +++ b/modules/4337/certora/conf/ValidationDataLastBitOne.conf @@ -8,12 +8,14 @@ "msg": "Safe4337Module: ValidationDataLastBitOne when checkSignatures revert", "optimistic_hashing": true, "optimistic_loop": true, + "optimistic_fallback": true, "process": "emv", "prover_args": [ - " -optimisticFallback true -s z3 -copyLoopUnroll 5 -mediumTimeout 5 -depth 30" + "-s z3 -copyLoopUnroll 5 -mediumTimeout 5 -depth 30" ], "rule_sanity": "basic", "solc": "solc8.23", + "solc_allow_path": "../../node_modules", "verify": "Safe4337Module:certora/specs/ValidationDataLastBitOne.spec", "packages": [ "@account-abstraction=../../node_modules/@account-abstraction", diff --git a/modules/passkey/package.json b/modules/passkey/package.json index b603b0c3..0d37c586 100644 --- a/modules/passkey/package.json +++ b/modules/passkey/package.json @@ -1,6 +1,6 @@ { "name": "@safe-global/safe-passkey", - "version": "0.2.0-alpha.1", + "version": "0.2.0-alpha.2", "author": "@safe-global", "description": "Safe Passkey Owner", "homepage": "https://github.com/safe-global/safe-modules/tree/main/modules/passkey", diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index abd770f7..649a3325 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -91,8 +91,8 @@ importers: specifier: 0.3.0 version: 0.3.0(ethers@6.12.1(bufferutil@4.0.8)(utf-8-validate@5.0.10)) '@safe-global/safe-passkey': - specifier: 0.2.0-alpha.1 - version: 0.2.0-alpha.1(ethers@6.12.1(bufferutil@4.0.8)(utf-8-validate@5.0.10)) + specifier: workspace:0.2.0-alpha.2 + version: link:../../modules/passkey '@web3modal/ethers': specifier: ^4.1.11 version: 4.1.11(@types/react@18.3.2)(bufferutil@4.0.8)(ethers@6.12.1(bufferutil@4.0.8)(utf-8-validate@5.0.10))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(utf-8-validate@5.0.10) diff --git a/pnpm-workspace.yaml b/pnpm-workspace.yaml index bbc0b1eb..f956dbf8 100644 --- a/pnpm-workspace.yaml +++ b/pnpm-workspace.yaml @@ -1,4 +1,4 @@ packages: - 'examples/*' - 'packages/*' - - 'modules/*' \ No newline at end of file + - 'modules/*'