Meriti (MERIT) is the governance token of the Meriti Ecosystem that consists of a range of disruptive crypto projects. We believe in challenging the status quo and dream of transforming the human race into a civilization rooted in radical transparency in which honesty and kindness are rewarded, literally. The true power of Blockchain technology is yet to be witnessed, and its use-case wouldn't be limited to virtual coins and online casinos. Keep reading to know more about how we plan to harness the power of Blockchain to radically transform the Education, Commerce, Charity industries, and many more industries.
Unable to find manual contract audit (e.g. Certik, PeckShield, Solidity...)
Contract locking ether found:
Contract Meriti (#101-698) has payable functions:
- Meriti.receive() (#636)
But does not have a function to withdraw the ether
Remove the payable attribute or add a withdraw function.
Additional information: link
Meriti.updateLockPeriod(uint256) (#603-606) should emit an event for:
- lockPeriod = newPeriod (#604)
Emit an event for critical parameter changes.
Additional information: link
SafeMath.mod(uint256,uint256) (#87-89) is never used and should be removed
SafeMath.mod(uint256,uint256,string) (#91-98) is never used and should be removed
Remove unused functions.
Additional information: link
Pragma version0.8.10 (#3) necessitates a version too recent to be trusted. Consider deploying with 0.6.12/0.7.6/0.8.7
solc-0.8.10 is not recommended for deployment
Deploy with any of the following Solidity versions: 0.5.16 - 0.5.17, 0.6.11 - 0.6.12, 0.7.5 - 0.7.6 Use a simple pragma version that allows any of these versions. Consider using the latest version of Solidity for testing.
Additional information: link
Constant Meriti._name (#126) is not in UPPER_CASE_WITH_UNDERSCORES
Constant Meriti._symbol (#127) is not in UPPER_CASE_WITH_UNDERSCORES
Constant Meriti._decimals (#129) is not in UPPER_CASE_WITH_UNDERSCORES
Variable Meriti._maxTxAmount (#132) is not in mixedCase
Variable Meriti._rOwned (#134) is not in mixedCase
Variable Meriti._tOwned (#135) is not in mixedCase
Variable Meriti._lockedTime (#136) is not in mixedCase
Variable Meriti._allowances (#138) is not in mixedCase
Variable Meriti._isExcludedFromFee (#140) is not in mixedCase
Variable Meriti._isExcluded (#141) is not in mixedCase
Variable Meriti._rTotal (#163) is not in mixedCase
Variable Meriti._marketingAddress (#172) is not in mixedCase
Variable Meriti._futureProjectsAddress (#173) is not in mixedCase
Variable Meriti._charityAddress (#174) is not in mixedCase
Follow the Solidity naming convention.
Additional information: link
Variable Meriti._getRValues(uint256,uint256,uint256,uint256,uint256).rFutureProjects (#680) is too similar to Meriti._getTValues(uint256).tFutureProjects (#654)
Variable Meriti._getRValues(uint256,uint256,uint256,uint256,uint256).rFutureProjects (#680) is too similar to Meriti._transferBothExcluded(address,address,uint256).tFutureProjects (#554)
Variable Meriti._getRValues(uint256,uint256,uint256,uint256,uint256).rFutureProjects (#680) is too similar to Meriti._getRValues(uint256,uint256,uint256,uint256,uint256).tFutureProjects (#665)
Variable Meriti._getRValues(uint256,uint256,uint256,uint256,uint256).rFutureProjects (#680) is too similar to Meriti._transferFromExcluded(address,address,uint256).tFutureProjects (#527)
Variable Meriti._getRValues(uint256,uint256,uint256,uint256,uint256).rFutureProjects (#680) is too similar to Meriti._transferToExcluded(address,address,uint256).tFutureProjects (#500)
Variable Meriti._transferToExcluded(address,address,uint256).rTransferAmount (#506) is too similar to Meriti._transferFromExcluded(address,address,uint256).tTransferAmount (#528)
Variable Meriti._transferStandard(address,address,uint256).rTransferAmount (#481) is too similar to Meriti._getTValues(uint256).tTransferAmount (#656)
Variable Meriti._getRValues(uint256,uint256,uint256,uint256,uint256).rTransferAmount (#681) is too similar to Meriti._getTValues(uint256).tTransferAmount (#656)
Variable Meriti._transferStandard(address,address,uint256).rTransferAmount (#481) is too similar to Meriti._transferBothExcluded(address,address,uint256).tTransferAmount (#555)
Variable Meriti._getRValues(uint256,uint256,uint256,uint256,uint256).rTransferAmount (#681) is too similar to Meriti._transferBothExcluded(address,address,uint256).tTransferAmount (#555)
Variable Meriti._transferBothExcluded(address,address,uint256).rTransferAmount (#560) is too similar to Meriti._transferFromExcluded(address,address,uint256).tTransferAmount (#528)
Variable Meriti._transferToExcluded(address,address,uint256).rTransferAmount (#506) is too similar to Meriti._transferToExcluded(address,address,uint256).tTransferAmount (#501)
Variable Meriti._transferToExcluded(address,address,uint256).rTransferAmount (#506) is too similar to Meriti._transferStandard(address,address,uint256).tTransferAmount (#476)
Variable Meriti._transferStandard(address,address,uint256).rTransferAmount (#481) is too similar to Meriti._transferFromExcluded(address,address,uint256).tTransferAmount (#528)
Variable Meriti._getRValues(uint256,uint256,uint256,uint256,uint256).rTransferAmount (#681) is too similar to Meriti._transferFromExcluded(address,address,uint256).tTransferAmount (#528)
Variable Meriti._transferFromExcluded(address,address,uint256).rTransferAmount (#533) is too similar to Meriti._transferToExcluded(address,address,uint256).tTransferAmount (#501)
Variable Meriti._transferBothExcluded(address,address,uint256).rTransferAmount (#560) is too similar to Meriti._transferToExcluded(address,address,uint256).tTransferAmount (#501)
Variable Meriti._transferToExcluded(address,address,uint256).rTransferAmount (#506) is too similar to Meriti._getTValues(uint256).tTransferAmount (#656)
Variable Meriti._transferToExcluded(address,address,uint256).rTransferAmount (#506) is too similar to Meriti._transferBothExcluded(address,address,uint256).tTransferAmount (#555)
Variable Meriti._transferStandard(address,address,uint256).rTransferAmount (#481) is too similar to Meriti._transferToExcluded(address,address,uint256).tTransferAmount (#501)
Variable Meriti._getRValues(uint256,uint256,uint256,uint256,uint256).rTransferAmount (#681) is too similar to Meriti._transferToExcluded(address,address,uint256).tTransferAmount (#501)
Variable Meriti._takeFutureProjects(uint256).rFutureProjects (#627) is too similar to Meriti._transferStandard(address,address,uint256).tFutureProjects (#475)
Variable Meriti._takeFutureProjects(uint256).rFutureProjects (#627) is too similar to Meriti._getRValues(uint256,uint256,uint256,uint256,uint256).tFutureProjects (#665)
Variable Meriti._takeFutureProjects(uint256).rFutureProjects (#627) is too similar to Meriti._getTValues(uint256).tFutureProjects (#654)
Variable Meriti._takeFutureProjects(uint256).rFutureProjects (#627) is too similar to Meriti._transferToExcluded(address,address,uint256).tFutureProjects (#500)
Variable Meriti._takeFutureProjects(uint256).rFutureProjects (#627) is too similar to Meriti._takeFutureProjects(uint256).tFutureProjects (#625)
Variable Meriti._takeFutureProjects(uint256).rFutureProjects (#627) is too similar to Meriti._transferBothExcluded(address,address,uint256).tFutureProjects (#554)
Variable Meriti._getRValues(uint256,uint256,uint256,uint256,uint256).rFutureProjects (#680) is too similar to Meriti._transferStandard(address,address,uint256).tFutureProjects (#475)
Variable Meriti._takeFutureProjects(uint256).rFutureProjects (#627) is too similar to Meriti._transferFromExcluded(address,address,uint256).tFutureProjects (#527)
Variable Meriti._getRValues(uint256,uint256,uint256,uint256,uint256).rFutureProjects (#680) is too similar to Meriti._takeFutureProjects(uint256).tFutureProjects (#625)
Variable Meriti._transferBothExcluded(address,address,uint256).rTransferAmount (#560) is too similar to Meriti._getTValues(uint256).tTransferAmount (#656)
Variable Meriti._transferStandard(address,address,uint256).rTransferAmount (#481) is too similar to Meriti._transferStandard(address,address,uint256).tTransferAmount (#476)
Variable Meriti._transferFromExcluded(address,address,uint256).rTransferAmount (#533) is too similar to Meriti._getTValues(uint256).tTransferAmount (#656)
Variable Meriti._transferBothExcluded(address,address,uint256).rTransferAmount (#560) is too similar to Meriti._transferBothExcluded(address,address,uint256).tTransferAmount (#555)
Variable Meriti._transferFromExcluded(address,address,uint256).rTransferAmount (#533) is too similar to Meriti._transferFromExcluded(address,address,uint256).tTransferAmount (#528)
Variable Meriti._transferBothExcluded(address,address,uint256).rTransferAmount (#560) is too similar to Meriti._transferStandard(address,address,uint256).tTransferAmount (#476)
Variable Meriti._getRValues(uint256,uint256,uint256,uint256,uint256).rTransferAmount (#681) is too similar to Meriti._transferStandard(address,address,uint256).tTransferAmount (#476)
Variable Meriti._transferFromExcluded(address,address,uint256).rTransferAmount (#533) is too similar to Meriti._transferBothExcluded(address,address,uint256).tTransferAmount (#555)
Variable Meriti._transferFromExcluded(address,address,uint256).rTransferAmount (#533) is too similar to Meriti._transferStandard(address,address,uint256).tTransferAmount (#476)
Prevent variables from having similar names.
Additional information: link
Meriti.slitherConstructorVariables() (#101-698) uses literals with too many digits:
- _maxTxAmount = 500000000 * 10 ** 9 (#132)
Use: Ether suffix, Time suffix, or The scientific notation
Additional information: link
Meriti._tTotal (#162) should be constant
Add the constant attributes to state variables that never change.
Additional information: link
name() should be declared external:
- Meriti.name() (#280-282)
symbol() should be declared external:
- Meriti.symbol() (#284-286)
decimals() should be declared external:
- Meriti.decimals() (#288-290)
totalSupply() should be declared external:
- Meriti.totalSupply() (#292-294)
balanceOf(address) should be declared external:
- Meriti.balanceOf(address) (#296-299)
transfer(address,uint256) should be declared external:
- Meriti.transfer(address,uint256) (#301-308)
allowance(address,address) should be declared external:
- Meriti.allowance(address,address) (#310-317)
approve(address,uint256) should be declared external:
- Meriti.approve(address,uint256) (#319-326)
isExcludedFromReward(address) should be declared external:
- Meriti.isExcludedFromReward(address) (#328-330)
excludeFromReward(address) should be declared external:
- Meriti.excludeFromReward(address) (#332-340)
transferFrom(address,address,uint256) should be declared external:
- Meriti.transferFrom(address,address,uint256) (#355-370)
presaleTokenTransfer(address,uint256) should be declared external:
- Meriti.presaleTokenTransfer(address,uint256) (#576-587)
Use the external attribute for functions never called from the contract.
Additional information: link
Meriti.constructor(address,address,address,address).marketing (#176) lacks a zero-check on :
- _marketingAddress = marketing (#177)
Meriti.constructor(address,address,address,address).futureProjects (#176) lacks a zero-check on :
- _futureProjectsAddress = futureProjects (#178)
Meriti.constructor(address,address,address,address).charity (#176) lacks a zero-check on :
- _charityAddress = charity (#179)
Meriti.constructor(address,address,address,address).msgSender (#181) lacks a zero-check on :
- _owner = msgSender (#182)
Meriti.constructor(address,address,address,address).presaleAdd (#176) lacks a zero-check on :
- _presaleAddress = presaleAdd (#183)
Meriti.updateMarketingAddress(address).newAdd (#249) lacks a zero-check on :
- _marketingAddress = newAdd (#251)
Meriti.updateFutureProjectsAddress(address).newAdd (#258) lacks a zero-check on :
- _futureProjectsAddress = newAdd (#260)
Meriti.updateCharityAddress(address).newAdd (#267) lacks a zero-check on :
- _charityAddress = newAdd (#269)
Check that the address is not zero.
Additional information: link
Meriti._transfer(address,address,uint256) (#411-435) uses timestamp for comparisons
Dangerous comparisons:
- _lockedTime[from] > 0 (#420)
- require(bool,string)(block.timestamp >= _lockedTime[from].add(lockPeriod),Wait for Presale Lockup) (#421)
Avoid relying on block.timestamp.
Additional information: link
Meriti.includeInReward(address) (#342-353) has costly operations inside a loop:
- _excluded.pop() (#349)
Use a local variable to hold the loop computation result.
Additional information: link
Meriti._rTotal (#163) is set pre-construction with a non-constant function or state variable:
- (MAX.sub((MAX.mod(_tTotal))))
Remove any initialization of state variables via non-constant state variables or function calls. If variables must be set upon contract deployment, locate initialization in the constructor instead.
Additional information: link
Unable to find website, listings and other project-related information
Token has no active CoinGecko listing / rank
Token has no active CoinMarketCap listing / rank
Young tokens have high risks of price dump / death
Young tokens have high risks of price dump / death
Last post in Twitter was more than 30 days ago
Unable to find Discord account