In life it is rare that we break from the broad-strokes of the Hero's Journey. Hero, is an on-chain primitive that brings this ability to Web3 with a simple, yet powerful, API.
- No rent-seeking mechanisms.
- Permissionless and ownerless from day 1.
- Bifurcated reward token model.
This primitive designed for:
- on-chain quests, journeys and rewards
- on-chain user acquisition strategies
- on-chain gamification
The Hero's Journey is a narrative-structured EVM-primitive built on the devices used for thousands of years to tell stories... a story of a hero who goes on a journey, and in a decisive crisis wins a victory, and then comes home changed or transformed.
In Web3, this desire has come-form from creators, organizations and communities to create a narrative structure that can be used to craft and tell user stories of their own.
Users are hard to get in Web3, but gamifying the experience is one of the most effective ways to do so. Hero is a primitive that allows you to do just that.
The Hero's Journey API is a simple API that allows you to create a Journey, and for Heroes to complete Quests and earn rewards.
The supporting schema of the Hero's Journey API is as follows:
////////////////////////////////////////////////////////
/// SCHEMA ///
////////////////////////////////////////////////////////
struct Stop {
ERC1155 badge;
uint8 mandatory;
uint256 id;
uint256 balance;
}
struct Transaction {
address target;
bytes data;
uint256 value;
}
struct Reward {
ERC20 token;
uint256 id;
uint256 amount;
}
struct Badge {
bool accountBound;
uint256 id;
uint256 amount;
string uri;
address[] delegates;
}
struct Quest {
address to;
bytes data;
uint256 value;
uint256 max;
uint256 stopsRequired;
Stop[] stops; /// ----------------- @dev Required to complete quest.
Transaction[] transactions; /// --- @dev Transactions inside quest.
Reward[] rewards; /// ------------- @dev ERC20 token(s).
Badge badge; /// ------------------ @dev ERC1155 badge.
}
struct Adventure {
IBadger badgerOrganization;
address caller;
uint256 start;
uint256 end;
Quest[] quests; /// ---------------- @dev Quests available to complete.
}
////////////////////////////////////////////////////////
/// EVENTS ///
////////////////////////////////////////////////////////
event JourneyPinned(
Journey indexed journey,
address indexed caller,
uint256 start,
uint256 end
);
event JourneyUnpinned();
event QuestCompleted(address indexed caller, uint256 questId);
As the name suggests, this function pins a Journey to the Bulletin Board. A Journey is a collection of Quests that Heroes can embark on, to any length, criteria of completion and rewards you desire.
As the inverse of pinJourney
, this function being called by the Journey caller prevents any new Heroes from completing any quest in the Journey and withdraws all remaining reward tokens back to the Journey caller.
This function is called by a Hero to embark on a Quest. Like the journeys and quests in your favorite books, the hero must have the required balance
of the badge
in their wallet to embark on the Quest. Upon completion, the Hero is rewarded with the rewards
and badge
as defined in the Quest automatically without any additional validation or delay of payment.
With the unique approach of a bifurcated model, Hero may compensate a Hero in Payment Tokens
as well as a Badge
, all handled automatically in the process of completing a Quest.
This means:
-
a Journey can be setup to require a Hero to have a certain amount of a token, or a certain amount of a badge, or a combination of both.
-
the Quests inside a Journey can be sequential and require multiple levels of completion to increase user retention rates. As a Hero completes Level 1 Quest, they are rewarded with a Badge and gain acess to Level 2. As they complete Level 2 Quest, they are rewarded with a Badge and a Payment Token.
-
the determination of
rewardEarned
is known at the time of the quest being embarked upon therefore the Hero can be rewarded immediately with no subjection to grading required.
Everyone but RabbitHole may copy and fork this code.