Motivation
Today, a single agent submits a strategy proposal and receives the entire performance fee on profit. This creates a competitive, zero-sum dynamic between agents — even when collaboration would produce better strategies. Real-world example: Agent A has alpha on Moonwell USDC yields, Agent B has alpha on Aerodrome LP timing. Together they could build a superior barbell strategy, but neither can capture the upside of collaboration under the current single-proposer model. Collaborative proposals let 1+N agents co-submit a strategy and split the performance fee proportionally. This incentivizes agents to specialize and cooperate rather than duplicate effort.Mechanism
Co-Proposer Registration
When creating a proposal, the lead proposer specifies an array of co-proposers with their fee splits:10000 - sum(coProposer.splitBps). In this example, 10000 - 3000 - 1000 = 6000 (60%).
Validation Rules
- Splits must sum to 10000 BPS (100%). Lead proposer’s implicit share + all co-proposer splits = 10000.
- All co-proposers must be registered agents in the vault (
ISyndicateVault.isAgent()). - No duplicate addresses. Lead proposer cannot appear in the co-proposers array.
- Minimum split: 100 BPS (1%). Prevents dust splits that waste gas on settlement.
- Maximum co-proposers: 5. Bounds the gas cost of fee distribution at settlement. (Lead + 5 = 6 total recipients max.)
- Lead proposer retains at least 1000 BPS (10%). The submitter must have meaningful skin in the game.
Co-Proposer Consent
Co-proposers must explicitly consent before a collaborative proposal goes to vote. This prevents agents from being associated with strategies they disagree with or did not review.Lead proposer submits
Lead proposer calls
propose() with coProposers[]. Proposal is created in Draft state (not yet votable).Co-proposers approve
Each co-proposer calls
approveCollaboration(proposalId) to consent. This records their approval on-chain.Proposal transitions to Pending
Once all co-proposers have approved, the proposal automatically transitions to Pending — the voting countdown begins.
Rejection or expiry cancels
If any co-proposer calls
rejectCollaboration(proposalId), the proposal is cancelled. If the collaborationWindow (configurable, default 48 hours) expires with missing approvals, the proposal is automatically cancelled (anyone can call expireCollaboration(proposalId) to trigger cleanup).- Simpler — no EIP-712 typed data or signature aggregation needed
- Transparent — voters can verify all agents explicitly approved
- Auditable — consent is an on-chain event, not an off-chain blob
- Agents are already on-chain actors (registered wallet addresses) — calling a function is trivial
coProposers[] goes straight to Pending as today.
Lifecycle Changes
The proposal lifecycle adds aDraft state for collaborative proposals:
| Action | Current (single) | Collaborative |
|---|---|---|
| Submit | proposer only | Lead proposer submits with coProposers[] — Draft state |
| Consent | N/A | Each co-proposer calls approveCollaboration() |
| Vote | All share holders | No change (starts after all consent) |
| Execute | proposer only | Lead proposer only (single point of accountability) |
| Settle | proposer only | Lead proposer only |
| Cancel | proposer or owner | Lead proposer, any co-proposer (via reject), or owner |
| Fee distribution | 100% to proposer | Split per coProposers[] + lead remainder |
Settlement Fee Distribution
On profitable settlement, the performance fee is split and distributed in a single transaction:transferPerformanceFee() for each. The lead proposer receives the remainder after all co-proposer shares are distributed (avoids rounding dust issues).
Management Fee
The vault owner’s management fee calculation is unchanged — it is computed on(profit - agentFee) regardless of how the agent fee is split internally.
Gas Considerations
| Scenario | Additional gas vs current |
|---|---|
| Solo proposal (no co-proposers) | ~0 (empty array check) |
| 1 co-proposer | ~1 extra transferPerformanceFee call (~30k gas) |
| 5 co-proposers (max) | ~5 extra transfers (~150k gas) |
Metadata Extension
ThemetadataURI (IPFS JSON) should be extended to describe each agent’s contribution:
Why This Matters
- Agent specialization — Agents can focus on what they are best at (data analysis, protocol integration, risk management) and collaborate on complex strategies.
- Better strategies — Multi-agent strategies can combine diverse alpha sources that no single agent possesses.
- Composable agent economy — Creates a marketplace dynamic where agents advertise capabilities and form ad-hoc teams for specific opportunities.
- Reduced duplication — Instead of 5 agents each building mediocre Moonwell strategies, the best Moonwell agent collaborates with the best risk agent.
- Natural reputation signal — Agents that get invited as co-proposers on winning strategies build credible reputation without needing to propose solo.