The blockchain backbone powering Shine a decentralized music marketplace that empowers artists and listeners through direct connections, fair compensation, and transparency. These smart contracts serve as an immutable source of truth for the entire ecosystem, ensuring permanent records, true ownership, and data resilience. Even if the Shine platform disappears, users can always recover their music purchases, artist histories, royalties, and transaction records from the blockchain.
These smart contracts provide the decentralized foundation for the Shine music platform, featuring:
- Permanent Records: Immutable on-chain database of songs, albums, artists, and users
- True Ownership: Users genuinely own their digital music purchases
- Artist Support: Native royalty tracking and balance management for musicians
- Platform Resilience: Source of truth persists even if the main platform goes offline
- Upgradeable Architecture: Ability to deploy new Orchestrator versions without losing data
The Shine contracts follow a Database + Orchestrator pattern:
┌─────────────────────────────────────────┐
│ Orchestrator (v1, v2, v3...) │
│ (Business Logic & User Interface) │
└─────────────────────────────────────────┘
│ │ │ │
│ │ │ └─→ ISplitterDB
│ │ └─→ ISongDB
│ └─→ IAlbumDB
└─→ IUserDB
Each Database:
• Sealed under Ownable pattern
• Only accessible via current Orchestrator (owner)
• Permanent, immutable records
• Can point to new Orchestrator versions
- Stores user and artist profiles and metadata
- Tracks user balances and accumulated royalties (for artists)
- Manages user wallet addresses
- Tracks user purchase history
- Supports user/artist banning/unbanning
- Unified account system for both listeners and creators
key features:
├── register() - Register new user/artist
├── changeBasicData() - Update profile
├── changeAddress() - Transfer account to new address
├── addBalance() / deductBalance() - Financial tracking
├── addAccumulatedRoyalties() - Royalty tracking (artists)
├── addSong() / deleteSong() - Purchase history
└── ban/unban - Moderation capabilities- Stores album metadata (title, artist, songs, pricing)
- Tracks purchases and gifts by user
- Manages special editions with limited supply
- Supports album banning (removed from platform)
- Emits events for all state changes
key features:
├── register() - Create new album
├── purchase() - Record user purchase
├── gift() - Record gifted album
├── refund() - Handle refunds
└── ban/unban - Moderation- Stores individual song metadata
- Tracks song ownership (purchased/gifted)
- Manages song availability and pricing
- Supports song banning
- Links to artist information
key features:
├── register() - Create new song
├── purchase() - Record purchase
├── gift() - Record gift
├── refund() - Handle refunds
└── ban/unban - Moderation- Manages revenue split configurations
- Distributes earnings among multiple artists/users
- Uses basis points for precise percentage calculations (10000 bp = 100%)
- Ensures split configurations always sum to 100%
- Supports both song-level and user-level splits
key features:
├── set() - Configure split for song/user
├── getSplits() - Retrieve split configuration
└── calculateSplit() - Calculate distribution amountsOrchestrator.sol - Central Business Logic Hub
- Coordinates all database interactions
- Enforces business rules and access control
- Manages stablecoin payments and fees
- Handles complex multi-contract transactions
- Implements royalty distribution
key features:
├── Registration & Profile Management
│ ├── register() - Register users/artists
│ ├── chnageBasicData() - Update profiles
│ └── changeAddress() - Transfer accounts
│
├── Fund Management
│ ├── depositFunds() - Add funds to account
│ ├── depositFundsToAnotherUser() - Gift funds
│ ├── makeDonation() - Direct artist donations
│ └── withdrawFunds() - Withdraw earnings
│
├── Music Transactions
│ ├── registerSong() - Register new songs
│ ├── registerAlbum() - Register new albums
│ ├── purchaseSong() - Buy individual songs
│ ├── purchaseAlbum() - Buy full albums
│ ├── giftSong() - Gift music to users
│ ├── giftAlbum() - Gift albums
│ └── refundSong() / refundAlbum() - Process refunds
│
└── Admin Functions
├── Fee collection
├── Stablecoin management (with timelock)
├── Ban/unban users, songs, albums
├── Circuit breaker controls
└── Database address configurationUser calls:
Orchestrator.purchaseSong(songId, userId)
↓
Orchestrator validates:
• Song exists & not banned
• User exists & not banned
• User hasn't already owned
• Sufficient stablecoin balance
↓
Orchestrator calls SongDB.purchase()
→ SongDB marks ownership
→ SongDB increments purchase counter
→ SongDB emits Purchased event
↓
Orchestrator calls UserDB.addSong()
→ UserDB adds to purchase history
→ UserDB emits SongListChangedSingle event
↓
Orchestrator handles payment:
• Calculate: net price + platform fee
• Deduct from user balance
• Check SplitterDB for revenue splits
• Distribute to artist(s) via UserDB.addBalance()
• Collect platform fee
↓
Transaction complete
Immutable record created on blockchain
- All data stored permanently on-chain
- Immutable transaction history
- Accessible even if platform UI disappears
- True decentralized source of truth
- Ownable Pattern: Each database sealed under its Orchestrator
- Role-Based: Users, artists, admin all have distinct permissions
- Upgradeable: Point databases to new Orchestrator without data loss
- Unique ID generation via
IdUtils(sequential, collision-proof) - Ownership tracking (purchased vs. gifted)
- Purchase counters and timestamps
- Event logging for all state changes
- Immutable Databases: Can never be destroyed
- Migration Path: Deploy new Orchestrator, redirect pointers
- Proxy Alternative: Or implement proxy pattern for direct logic updates
- Community Recovery: Anyone can query data even if official platform goes down
- Foundry installed: https://book.getfoundry.sh/getting-started/installation
- Solidity ^0.8.20
# Clone repository
git clone <repository-url>
cd Shine_contracts
# Install dependencies
forge install
# Build contracts
forge build$ forge build$ forge testRun specific tests:
$ forge test --match-contract AlbumDB
$ forge test --match-path test/uint/correct/*.sol -vFormat code:
$ forge fmtGenerate gas snapshots:
$ forge snapshotStart local Ethereum node:
$ anvilDeploy locally:
$ forge script script/SongDataBase.s.sol --rpc-url http://localhost:8545 --broadcastDeploy to network:
$ forge script script/SongDataBase.s.sol:SongDataBaseScript \
--rpc-url <your_rpc_url> \
--private-key <your_private_key> \
--broadcastThis project uses the SHINE-PPL-1.0 (Shine Platform Partnership License), a custom license that:
- Allows deployment and use of Shine
- Requires partnerships for commercial use
- Protects the Shine brand and ecosystem
- Ensures fair compensation for platform development
Shine_contracts/
├── src/
│ ├── contracts/
│ │ ├── database/
│ │ │ ├── AlbumDB.sol # Album management
│ │ │ ├── SongDB.sol # Song records
│ │ │ ├── SplitterDB.sol # Revenue splitting
│ │ │ └── UserDB.sol # User & artist profiles
│ │ └── orchestrator/
│ │ ├── Orchestrator.sol # Central logic hub
│ │ └── library/
│ │ ├── ErrorsLib.sol
│ │ ├── EventsLib.sol
│ │ └── StructsLib.sol
│ └── library/
│ ├── IdUtils.sol # Sequential ID generation
│ └── IERC20.sol # ERC20 interface
│
├── test/
│ ├── uint/ # Unit tests
│ │ ├── correct/ # Happy path tests
│ │ └── revert/ # Revert condition tests
│ └── fuzz/ # Fuzzing tests
│
├── script/
│ └── SongDataBase.s.sol # Deployment scripts
│
├── lib/
│ ├── forge-std/ # Foundry standard library
│ └── solady/ # Optimized Solady utilities
│
├── foundry.toml # Foundry configuration
├── Makefile # Convenient make commands
└── README.md # This file
- Deploy Orchestrator with initial owner, stablecoin, and fee %
- Deploy AlbumDB, SongDB, UserDB, SplitterDB with Orchestrator address
- Set database addresses in Orchestrator
- Enable breaker flags for operational readiness
- Deploy new Orchestrator version with improved logic
- Point all databases to new Orchestrator
- OR implement proxy pattern for direct logic updates
- Historical data remains intact and queryable
- Purchase songs and albums permanently
- Gift music to other users
- View complete purchase history
- Recover purchase records from blockchain even if platform down
- Register as users with artist capabilities
- Track accumulated royalties
- Configure revenue splits for collaborations
- Withdraw earnings to blockchain address
- Maintain permanent record of published works
- Decentralized source of truth
- Fee collection and reporting
- User/artist banning for moderation
- Graceful upgrades through new Orchestrator versions
- Solady (
@solady/auth/Ownable.sol): Optimized Ownable implementation - Foundry Std (
forge-std): Testing and scripting utilities - ERC20 Interface: Standard token interactions
SHINE-PPL-1.0 (Shine Platform Partnership License)
Contributions welcome! Please ensure:
- All tests pass (
forge test) - Code formatted (
forge fmt) - Comments documented
- No unsafe patterns
- Gas-optimized where possible
For questions or issues:
- Check existing documentation
- Review contract comments and NatSpec
- Examine test files for usage examples
- Contact 11:11 Labs
Made with ❤️ by 11:11 Labs
⣿⡇⣿⣿⣿⠛⠁⣴⣿⡿⠿⠧⠹⠿⠘⣿⣿⣿⡇⢸⡻⣿⣿⣿⣿⣿⣿⣿
⢹⡇⣿⣿⣿⠄⣞⣯⣷⣾⣿⣿⣧⡹⡆⡀⠉⢹⡌⠐⢿⣿⣿⣿⡞⣿⣿⣿
⣾⡇⣿⣿⡇⣾⣿⣿⣿⣿⣿⣿⣿⣿⣄⢻⣦⡀⠁⢸⡌⠻⣿⣿⣿⡽⣿⣿
⡇⣿⠹⣿⡇⡟⠛⣉⠁⠉⠉⠻⡿⣿⣿⣿⣿⣿⣦⣄⡉⠂⠈⠙⢿⣿⣝⣿
⠤⢿⡄⠹⣧⣷⣸⡇⠄⠄⠲⢰⣌⣾⣿⣿⣿⣿⣿⣿⣶⣤⣤⡀⠄⠈⠻⢮
⠄⢸⣧⠄⢘⢻⣿⡇⢀⣀⠄⣸⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣧⡀⠄⢀
⠄⠈⣿⡆⢸⣿⣿⣿⣬⣭⣴⣿⣿⣿⣿⣿⣿⣿⣯⠝⠛⠛⠙⢿⡿⠃⠄⢸
⠄⠄⢿⣿⡀⣿⣿⣿⣾⣿⣿⣿⣿⣿⣿⣿⣿⣿⣷⣿⣿⣿⣿⡾⠁⢠⡇⢀
⠄⠄⢸⣿⡇⠻⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣏⣫⣻⡟⢀⠄⣿⣷⣾
⠄⠄⢸⣿⡇⠄⠈⠙⠿⣿⣿⣿⣮⣿⣿⣿⣿⣿⣿⣿⣿⡿⢠⠊⢀⡇⣿⣿
⠒⠤⠄⣿⡇⢀⡲⠄⠄⠈⠙⠻⢿⣿⣿⠿⠿⠟⠛⠋⠁⣰⠇⠄⢸⣿⣿⣿