Skip to main content

Caravan: A shared wallet for everyday adventures

Project description

Overview

Caravan: A shared wallet for everyday adventures

Design

Caravan is a simple, yet flexible, multi-owner smart contract wallet designed for high-value, day-to-day activities. It is designed to support multiple users (up to 11) working together to co-sign and execute important transactions.

Out of the box, Caravan is designed to be used via CaravanProxy, which is a simple, upgradeable forwarding proxy that calls (via delegateproxy) to a singleton deployment of Caravan. It is only designed to be used via the Proxy, as it is intended to be a long-term stateful contract containing important assets that we don't want to lose when upgrading to a newer version of the code.

The singleton deployment is deployed once per chain and is used as that chain's official copy of that particular version. The versioning of this repo matches the versioning of the deployments on-chain, where the git tag should match 1:1 to the value of VERSION() on the singleton (as well as your personal proxy).

To create a new Caravan, this project has a simplified factory CaravanFactory intended to serve as the officially recommended way to create new instances of the proxy contract. It also serves as the official registry of released versions, allowing users to discover new releases to upgrade to purely on-chain. Proxy instances are deployed using CREATE2 with a salt chosen by the initial set of signers, initial signer threshold, and a user-specifiable tag (which allows the creation of multiple wallets per combo). This makes it possible to recreate the same Caravan on multiple chains, without worrying about having a specific nonce.

There are two types of EIP712 structures used within Caravan: Update and Execute. They are designed to ensure that only important administrative updates occur via Update, and common, non-admin transactions occur via Execute. This is done to create a physical separation between critical, configuration-modifying transactions, and non-critical ones. It is highly recommended to downstream signing infra that works w/ Caravan to create a clear UX distinction between these two types of calls, making it clear that critical actions can impact the operational safety of a Caravan.

[!NOTE] The way that signatures are collected to be placed on-chain is out of scope for this specification.

Additionally, both types of transactions have "Guards" which are 3rd party contracts that should implement pre- and post-execution checks on their respective transaction types. Use cases for Guards can include (for admin Updates) adding timelocked update restrictions, blacklisting certain addresses, or (for normal Executes) adding per diem limits on asset transfers, restricting calls to certain contracts, etc. Having two separate Guards, one for each transaction type, is useful because an Execute Guard being non-functional does not represent an existential threat to the operation of the wallet, only with an Update Guard. This should encourage the use of Guards for proper operation of the wallet in day-to-day operational scenarios, increasing overall safety when using Caravan.

Finally, Caravan implements "Modules" which are contracts that can be enabled in the wallet (through an Update action) that are allowed to bypass the signer signature check when commiting arbitrary Execute transactions. This functionality is extremely useful for adding automation to your day-to-day operations, making your operation of the wallet safer and less prone to social engineering exploits.

[!NOTE] Technically, while it is possible to use Caravan for a "personal" multisig (where you own all the signers on the wallet), it is suggested to make use of something like Purse (with a secure cold wallet instead) to add automation and advanced capabilities to your personal, high-valued wallets.


Caravan is inspired by Safe Smart Account.

Contributing

This project is written in Vyper.

This project uses ape to compile, test and script it. See the Installation Guide for help installing it.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

caravan_py-0.2.2.tar.gz (259.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

caravan_py-0.2.2-py3-none-any.whl (83.6 kB view details)

Uploaded Python 3

File details

Details for the file caravan_py-0.2.2.tar.gz.

File metadata

  • Download URL: caravan_py-0.2.2.tar.gz
  • Upload date:
  • Size: 259.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.17 {"installer":{"name":"uv","version":"0.9.17","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Fedora Linux","version":"43","id":"","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for caravan_py-0.2.2.tar.gz
Algorithm Hash digest
SHA256 ccd5f13be85cfcecf10404fe23d36a13a4586bfa3916fa001241cc108ffe1d1e
MD5 41bba44245459543649df935dcde7f34
BLAKE2b-256 2667bcd9121f8bfb35487c352364fa3ac627c7e242a885592e31be7e827d9966

See more details on using hashes here.

File details

Details for the file caravan_py-0.2.2-py3-none-any.whl.

File metadata

  • Download URL: caravan_py-0.2.2-py3-none-any.whl
  • Upload date:
  • Size: 83.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.17 {"installer":{"name":"uv","version":"0.9.17","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Fedora Linux","version":"43","id":"","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for caravan_py-0.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 2fe7ca5621e03b9a48843b4f1a59c4f7b02d730e3ecad409afb217a066f4d696
MD5 b510bd02b0d8734c23a76fefda5eddc5
BLAKE2b-256 53aebb0f63e8126ccfdb7dbcab3f2c07ca6a9446cce7649fa79390f24db943ef

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page