Skip to content

Commit

Permalink
Rebase onto master
Browse files Browse the repository at this point in the history
  • Loading branch information
ewilz committed Nov 28, 2018
1 parent 3a81987 commit 4e0ec95
Show file tree
Hide file tree
Showing 11 changed files with 1,781 additions and 2,339 deletions.
24 changes: 6 additions & 18 deletions contracts/Challenge/PLCRVotingChallenge.sol
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,6 @@ contract PLCRVotingChallenge is ChallengeInterface {
Registry public registry;
PLCRVoting public voting; /// address of PLCRVoting Contract
uint public pollID; /// pollID of PLCRVoting
bool challengeResolved; /// true is challenge has officially been resolved to passed or failed
uint public commitEndDate; /// expiration date of commit period for poll
uint public revealEndDate; /// expiration date of reveal period for poll
uint public voteQuorum; /// number of votes required for a proposal to pass
Expand Down Expand Up @@ -101,15 +100,14 @@ contract PLCRVotingChallenge is ChallengeInterface {

/**
@dev Called by a voter to claim their reward for each completed vote
@param _salt The salt of a voter's commit hash
*/
function claimVoterReward(uint _salt) public {
function claimVoterReward() public {
// Ensures the voter has not already claimed tokens
require(tokenClaims[msg.sender] == false);
require(ended());

uint voterTokens = voting.getNumPassingTokens(msg.sender, pollID, _salt);
uint reward = voterReward(msg.sender, _salt);
uint voterTokens = voting.getNumPassingTokens(msg.sender, pollID);
uint reward = voterReward(msg.sender);

voterTokensClaimed += voterTokens;
voterRewardsClaimed += reward;
Expand All @@ -126,12 +124,11 @@ contract PLCRVotingChallenge is ChallengeInterface {
/**
@dev Calculates the provided voter's token reward.
@param _voter The address of the voter whose reward balance is to be returned
@param _salt The salt of the voter's commit hash in the given poll
@return The uint indicating the voter's reward
*/
function voterReward(address _voter, uint _salt)
function voterReward(address _voter)
public view returns (uint) {
uint voterTokens = voting.getNumPassingTokens(_voter, pollID, _salt);
uint voterTokens = voting.getNumPassingTokens(_voter, pollID);
uint remainingRewardPool = rewardPool - voterRewardsClaimed;
uint remainingTotalTokens = voting.getTotalNumberOfTokensForWinningOption(pollID) - voterTokensClaimed;
return (voterTokens * remainingRewardPool) / remainingTotalTokens;
Expand Down Expand Up @@ -170,7 +167,7 @@ contract PLCRVotingChallenge is ChallengeInterface {
@return Returns tokens required by challenge contract
*/
function requiredTokenDeposit() public view returns(uint) {
return challengerStake;
return rewardPool;
}

/**
Expand All @@ -192,13 +189,4 @@ contract PLCRVotingChallenge is ChallengeInterface {
// if votes do not vote in favor of listing, challenge passes
return !voting.isPassed(pollID);
}

/**
@notice Checks if a challenge is resolved
@dev Checks whether challenge outome has been resolved to either passed or failed
@return Boolean indication if challenge is resolved
*/
function resolved() view public returns (bool) {
return challengeResolved;
}
}
70 changes: 3 additions & 67 deletions contracts/Registry.sol
Original file line number Diff line number Diff line change
Expand Up @@ -22,8 +22,8 @@ contract Registry {
event _ListingRemoved(bytes32 indexed listingHash);
event _ListingWithdrawn(bytes32 indexed listingHash, address indexed owner);
event _TouchAndRemoved(bytes32 indexed listingHash);
event _ChallengeFailed(bytes32 indexed listingHash, uint indexed challengeID, uint rewardPool, uint totalTokens);
event _ChallengeSucceeded(bytes32 indexed listingHash, uint indexed challengeID, uint rewardPool, uint totalTokens);
event _ChallengeFailed(bytes32 indexed listingHash, uint indexed challengeID);
event _ChallengeSucceeded(bytes32 indexed listingHash, uint indexed challengeID);
event _RewardClaimed(uint indexed challengeID, uint reward, address indexed voter);
event _ExitInitialized(bytes32 indexed listingHash, uint exitTime, uint exitDelayEndDate, address indexed owner);

Expand Down Expand Up @@ -171,8 +171,7 @@ contract Registry {
require(msg.sender == listing.owner);
require(isWhitelisted(_listingHash));
// Cannot exit during ongoing challenge
ChallengeInterface challenge = challengeForListingHash(_listingHash);
require(listing.challengeID == 0 || challenge.ended());
require(listing.challengeID == 0 || challenges[listing.challengeID].resolved);

// Make sure the exit was initialized
require(listing.exitTime > 0);
Expand Down Expand Up @@ -251,51 +250,6 @@ contract Registry {
}
}

<<<<<<< HEAD
// ----------------
// TOKEN FUNCTIONS:
// ----------------

/**
@dev Called by a voter to claim their reward for each completed vote. Someone
must call updateStatus() before this can be called.
@param _challengeID The PLCR pollID of the challenge a reward is being claimed for
*/
function claimReward(uint _challengeID) public {
Challenge storage challengeInstance = challenges[_challengeID];
// Ensures the voter has not already claimed tokens and challengeInstance results have
// been processed
require(challengeInstance.tokenClaims[msg.sender] == false);
require(challengeInstance.resolved == true);

uint voterTokens = voting.getNumPassingTokens(msg.sender, _challengeID);
uint reward = voterTokens.mul(challengeInstance.rewardPool)
.div(challengeInstance.totalTokens);

// Subtracts the voter's information to preserve the participation ratios
// of other voters compared to the remaining pool of rewards
challengeInstance.totalTokens -= voterTokens;
challengeInstance.rewardPool -= reward;

// Ensures a voter cannot claim tokens again
challengeInstance.tokenClaims[msg.sender] = true;

require(token.transfer(msg.sender, reward));

emit _RewardClaimed(_challengeID, reward, msg.sender);
}

/**
@dev Called by a voter to claim their rewards for each completed vote. Someone
must call updateStatus() before this can be called.
@param _challengeIDs The PLCR pollIDs of the challenges rewards are being claimed for
*/
function claimRewards(uint[] _challengeIDs) public {
// loop through arrays, claiming each individual vote reward
for (uint i = 0; i < _challengeIDs.length; i++) {
claimReward(_challengeIDs[i]);
}
=======
function resolveChallenge(bytes32 _listingHash) private {
Listing storage listing = listings[_listingHash];
ChallengeInterface challenge = challengeForListingHash(_listingHash);
Expand All @@ -315,31 +269,13 @@ contract Registry {
_ChallengeSucceeded(_listingHash, challengeID);
}
challenges[challengeID].resolved = true;
>>>>>>> Refactor Registry to use Abstracted Challenge Contracts
}

// --------
// GETTERS:
// --------

/**
<<<<<<< HEAD
@dev Calculates the provided voter's token reward for the given poll.
@param _voter The address of the voter whose reward balance is to be returned
@param _challengeID The pollID of the challenge a reward balance is being queried for
@return The uint indicating the voter's reward
*/
function voterReward(address _voter, uint _challengeID)
public view returns (uint) {
uint totalTokens = challenges[_challengeID].totalTokens;
uint rewardPool = challenges[_challengeID].rewardPool;
uint voterTokens = voting.getNumPassingTokens(_voter, _challengeID);
return voterTokens.mul(rewardPool).div(totalTokens);
}

/**
=======
>>>>>>> Refactor Registry to use Abstracted Challenge Contracts
@dev Determines whether the given listingHash be whitelisted.
@param _listingHash The listingHash whose status is to be examined
*/
Expand Down
Loading

0 comments on commit 4e0ec95

Please sign in to comment.