An open API service indexing awesome lists of open source software.

https://github.com/crossmint/stellar-smart-account


https://github.com/crossmint/stellar-smart-account

Last synced: 8 months ago
JSON representation

Awesome Lists containing this project

README

          

# Stellar Smart Account

[![Rust](https://img.shields.io/badge/rust-1.75+-orange.svg)](https://www.rust-lang.org)
[![Soroban SDK](https://img.shields.io/badge/soroban--sdk-22.0.0-blue.svg)](https://soroban.stellar.org/)
[![Test Status](https://github.com/Crossmint/stellar-smart-account/workflows/Test/badge.svg)](https://github.com/Crossmint/stellar-smart-account/actions)
[![License](https://img.shields.io/badge/license-Apache%202.0-blue.svg)](LICENSE)

A comprehensive smart contract system for Stellar/Soroban that provides enterprise-grade account management with multi-signature support, role-based access control, and policy-based authorization. Designed for both human users and AI agents requiring sophisticated permission systems.

## 🌟 Features

- **πŸ” Multi-Signature Account**: Advanced smart account with customizable authentication
- **🏭 Contract Factory**: Secure deployment system with role-based access control
- **🎯 Role-Based Permissions**: Admin and Standard signer roles with optional policies
- **πŸ“‹ Policy System**: Time-based, contract allow/deny lists, external delegation, and extensible policies
- **πŸ”Œ Plugin System**: Extensible architecture with install/uninstall lifecycle and authorization hooks
- **🌐 External Delegation**: Delegate authorization decisions to external policy contracts
- **πŸ€– AI Agent Ready**: Built for both human users and automated systems
- **⚑ Soroban Native**: Leverages Stellar's smart contract platform capabilities
- **πŸ”„ Upgradeable**: Built-in contract upgrade support with permission controls
- **πŸ“š TypeScript Bindings**: Auto-generated JavaScript/TypeScript libraries

## πŸ—οΈ Architecture

The system consists of two main smart contracts and supporting JavaScript libraries:

```
stellar-smart-account/
β”œβ”€β”€ contracts/
β”‚ β”œβ”€β”€ smart-account/ # Multi-signature account contract with plugin support
β”‚ β”œβ”€β”€ contract-factory/ # Secure contract deployment factory
β”‚ β”œβ”€β”€ deny-list-policy/ # Example external policy contract
β”‚ β”œβ”€β”€ initializable/ # Contract initialization utilities
β”‚ β”œβ”€β”€ storage/ # Storage management utilities
β”‚ └── upgradeable/ # Contract upgrade utilities
β”œβ”€β”€ packages/
β”‚ β”œβ”€β”€ smart_account/ # TypeScript bindings for smart account
β”‚ └── factory/ # TypeScript bindings for factory
└── examples/ # Usage examples and demos
```

### Smart Account Contract

The core smart account provides:

- **Multiple Signature Schemes**: Ed25519 and Secp256r1 (WebAuthn/passkeys), extensible to others
- **Flexible Authorization**: Role-based access with policy enforcement
- **Multi-Signature Support**: Customizable authorization logic
- **Plugin Architecture**: Extensible functionality through installable plugins
- **External Delegation**: Delegate authorization to external policy contracts
- **Soroban Integration**: Native account interface implementation

### Contract Factory

Secure deployment system featuring:

- **Role-Based Deployment**: Only authorized deployers can create contracts
- **Deterministic Addresses**: Predictable contract addresses using salt values
- **Access Control Integration**: Built on OpenZeppelin Stellar contracts

## πŸš€ Quick Start

### Prerequisites

- Rust 1.75+ with `wasm32-unknown-unknown` target
- [Stellar CLI](https://soroban.stellar.org/docs/getting-started/setup)
- Node.js 18+ (for JavaScript bindings)

### Installation

1. **Clone the repository**:
```bash
git clone https://github.com/Crossmint/stellar-smart-account.git
cd stellar-smart-account
```

2. **Build the contracts**:
```bash
stellar contract build
```

3. **Run tests**:
```bash
cargo test
```

4. **Install JavaScript dependencies** (optional):
```bash
cd packages/smart_account && npm install
cd ../factory && npm install
```

## πŸ”‘ Authentication & Permissions

### Signer Roles

| Role | Capabilities | Use Cases |
|------|-------------|-----------|
| **Admin** | Full access, can upgrade contracts | System administrators, emergency access |
| **Standard** | Normal operations, cannot modify signers, optional policy restrictions | Regular users, application accounts, AI agents with policies |

### Policy Types

- **Time-Based**: Restrict signer validity to specific time windows
- **Contract Allow List**: Only permit interactions with specified contracts
- **Contract Deny List**: Block interactions with specified contracts
- **External Delegation**: Delegate authorization decisions to external policy contracts
- **Extensible**: Add custom policies for spending limits, rate limiting, etc.

### Example: Time-Restricted AI Agent

```rust
// Create an AI agent with time-limited access
let time_policy = TimeWindowPolicy {
not_before: start_timestamp,
not_after: end_timestamp,
};

let ai_signer = Signer::Ed25519(
Ed25519Signer::new(ai_agent_pubkey),
SignerRole::Standard(vec![SignerPolicy::TimeWindowPolicy(time_policy)])
);
```

### Example: External Policy Delegation

```rust
// Delegate authorization to an external policy contract
let external_policy = ExternalPolicy {
policy_address: deny_list_contract_address,
};

let restricted_signer = Signer::Ed25519(
Ed25519Signer::new(signer_pubkey),
SignerRole::Standard(vec![SignerPolicy::ExternalValidatorPolicy(external_policy)])
);
```

### Example: Plugin Installation

```rust
// Initialize smart account with plugins
SmartAccount::__constructor(
env,
vec![admin_signer],
vec![analytics_plugin_address, logging_plugin_address]
);

// Install additional plugins after deployment
SmartAccount::install_plugin(&env, new_plugin_address)?;
```

## πŸ§ͺ Testing

Run the full test suite:

```bash
# Run all tests
cargo test

# Run with coverage
cargo install cargo-tarpaulin
cargo tarpaulin --out Html
```

## πŸ’Ύ Soroban Storage Strategy and Costs

For optimal performance and cost on Soroban, this project uses storage types deliberately:
- Persistent storage: durable, TTL-based entries with rent; best for long-lived, potentially larger datasets
- Instance storage: bundled with the contract entry, automatically loaded each call; best for small data needed on most calls
- Temporary storage: short TTL and cheaper rent; not used here for critical state

Applied to the Smart Account:
- Signers (SignerKey -> Signer): Persistent
- Admin count (ADMIN_COUNT_KEY): Persistent
- Plugins registry (PLUGINS_KEY): Instance (invoked on every __check_auth)
- Migration flag (MIGRATING): Instance

Why this mapping:
- Plugins are accessed on every call in __check_auth, so keeping the plugin registry in Instance storage avoids separate persistent reads on each invocation.
- Signers and admin count are long-lived and can grow; storing them in Persistent avoids growing the contract instance entry and respects durability expectations.

Notes:
- Instance storage is limited by the ledger entry size limit (approximately 128 KB for the contract entry), so only small, frequently accessed data should be kept there.
- Persistent entries accrue rent over time and can be restored after archival if TTL expires by paying a fee.

Potential future optimizations (not implemented here):
- Skip plugin callbacks when auth contexts are clearly unrelated
- Maintain a fast β€œhas_plugins” indicator to early-exit
- Track a subset of β€œauth-hook” plugins to invoke only those on __check_auth

The project maintains 80%+ test coverage with comprehensive integration tests.

## πŸ”§ Development

### Adding New Signer Types

1. Define the signer struct in `src/auth/signers/`
2. Implement the `SignatureVerifier` trait
3. Add variants to `SignerKey`, `Signer`, and `SignerProof` enums
4. Update match statements in implementation files

### Adding New Policies

1. Create policy struct in `src/auth/policy/`
2. Implement `AuthorizationCheck` and `PolicyCallback` traits
3. Add to `SignerPolicy` enum
4. Update policy validation logic

See the [Smart Account Architecture Documentation](contracts/smart-account/README.md) for detailed extension guides.

## 🌐 Network Support

The contracts are designed for deployment on:

- **Stellar Testnet**: For development and testing
- **Stellar Futurenet**: For experimental features
- **Stellar Mainnet**: For production deployments

## 🀝 Contributing

1. Fork the repository
2. Create a feature branch: `git checkout -b feature/amazing-feature`
3. Make your changes and add tests
4. Ensure tests pass: `cargo test`
5. Commit your changes: `git commit -m 'Add amazing feature'`
6. Push to the branch: `git push origin feature/amazing-feature`
7. Open a Pull Request

## πŸ“„ License

This project is licensed under the Apache License 2.0 - see the [LICENSE](LICENSE) file for details.

---

Crossmint Logo

### Built with ❀️ by **Crossmint**

*The enterprise infrastructure powering the next generation of cross-chain applications*

**[πŸš€ Explore Crossmint Wallets](https://docs.crossmint.com/wallets/overview)** | **[🌐 Visit Crossmint.com](https://crossmint.com/)**