Refer to http://openanx.org/ for further information.
There is a subreddit at https://www.reddit.com/r/OpenANX/, and a slack at https://openanx.slack.com/.
-
Token Identifier
- symbol
OAX
- name
openANX Token
- decimals
18
- symbol
-
Tranche 1 30,000,000 (30%) OAX Crowdsale Dates
- START_DATE = 1498136400 Thursday, 22-Jun-17 13:00:00 UTC / 1pm GMT 22 June 2017
- END_DATE = 1500728400 Saturday, 22-Jul-17 13:00:00 UTC / 1pm GMT 22 July 2017
-
Total of 100,000,000 OAX tokens
- Tranche 1 30,000,000 (30%) OAX Crowdsale
- Soft cap of 13,000,000 OAX (ETH equivalence of USD 9,750,000)
- Hard cap of 30,000,000 OAX (ETH equivalence of USD 22,500,000)
- Tokens from precommitments funded via fiat and other currencies will be included in this tranche
- Tranche 2 30,000,000 (30%) OAX - locked for 1 year from token launch for Additional Token Sale (ATS)
- 30,000,000 Tranche 2 token sale - Additional Token Sale (ATS). These tokens are subject to a lock-up for 1 year from token launch
- 20,000,000 (20%) OAX retained by the foundation, locked for 2 years from token launch
- 20,000,000 allocated to founding supporters (directors, advisors and early backers) of the foundation, consisting of:
- 14,000,000 (70%) locked for 1 year from token launch
- 6,000,000 (30%) locked for 2 years from token launch
- Tranche 1 30,000,000 (30%) OAX Crowdsale
-
OAX Token Price
- The price for an OAX token will be set as the equivalence of USD 0.75 ETH based on ETH/USD @ 12:00 GMT Jun 21 2017
- The indicative price per OAX token is 0.00290923 ETH as of 8 June 2017
- 1 OAX = 0.00290923 ETH
- 1 ETH = 1 / 0.00290923 = 343.733565238912015 OAX
- This will be encoded as an unsigned integer, 1,000 ETH = 343734 OAX with six significant figures tokensPerKEther = 343734
-
Precommitments
- Some participants will be able to purchase the crowdsale tokens through precommitments using fiat and other currencies
- openANX will allocate the tokens for these participants prior to the public crowdsale commencement
-
Minimum Funding And Refunds
- There is no minimum funding level in the smart contract as the precommitments already exceed the minimum funding level
- There is therefore no requirements for this crowdsale contract to provide refunds to participants
- ETH contributed to the crowdsale smart contract will be immediately transferred into a wallet specified by openANX
-
Crowdsale Wallet
- The wallet receiving the ethers during the crowdsale has to be specifed as a parameter during the deployment of the crowdsale contract
- This wallet address can be changed at any time during the crowdsale period
-
Minimum and Maximum Contributions
- There is the ability to set a minimum and maximum contribution per transaction. Set one or both of these to 0 if this restriction is not required
-
Soft And Hard Cap
- There will be a soft cap and a hard cap specified in the crowdsale smart contract
- openANX will be able to execute the
finalise()
function to close the crowdsale once the number of issued tokens exceeds the soft cap - openANX will also be able to execute the
finalise()
function after the crowdsale end date if the soft cap is not reached
-
finalise()
The Crowdsale- openANX calls
finalise()
to close the crowdsale, either after the soft cap is breached to the end of the crowdsale period, or after the crowdsale end date - The
finalise()
function will allocate the 1 and 2 year locked tokens, unsold tranche1 tokens and tranche2 tokens
- openANX calls
-
KYC
- Participants can contribute to the crowdsale by sending ETH to the OAX 'openANX Token' smart contract and will be issued OAX tokens
- Participants will only be able to transfer their issued OAX tokens after being successfully KYC verified by openANX and unless otherwise agreed by Open ANX Foundation, in no circumstance shall such transfer be possibly prior to the Release Date scheduled for July 29th (being one week after the scheduled end of the Contribution Window).
- There will be no refund if the KYC verification is determined to be unsuccessful
- The KYC smart contract will just encode a simple Yes/No on an accounts KYC status
- Once KYC approved, an account cannot be KYC disapproved
- OAX tokens are otherwise able to be transferred freely without further KYC requirements
-
Unsold Tranche 1 Tokens
- Any tokens unsold from the tranche 1 quote will be locked away from 1 year along with the tranche 2 tokens
-
Locked Tokens
- Accounts holding 1 or 2 year locked tokens will also be able to participant in the public crowdsale
- BK Complete KYC functions
- BK Testing different scenarios
- Scenario where funding below soft cap and above soft cap
- Unlocking of tokens in 1 year and 2 years
- Public crowdsale participant can also have locked tokens
- BK Develop and test token contract upgrade path
- BK Security audit
- JB Security audit
Following are the functions that can be called at the different phases of the crowdsale contract
-
Owner can call
setWallet(...)
to set the wallet address -
Owner can call
kycVerify(...)
to verify participants, but this should be done after the crowdsale as the participants can transfer tokens immediately after being verified
- Owner can call
setTokensPerKEther(...)
to set the token issuance rate - Owner can call
addPrecommitment(...)
to add precommitment balances
- Participants can send ETH to the default
()
function and receive tokens - Owner can call
finalise()
if soft cap breached or we are past the end date
- Owner calls
kycVerify(...)
to verify participants, but this should be done after the crowdsale as the participants can transfer tokens immediately after being verified - Participant can call the normal
transfer(...)
,approve(...)
andtransferFrom(...)
to transfer tokens
- Participants with locked tokens can called the
lockedTokens.unlock1Y()
andlockedTokens.unlock2Y()
to unlock their tokens
See test for details.
- Check START_DATE and END_DATE
- Check Solidity release history for potential bugs
- Deploy contract to Mainnet with specified wallet address as the deployment parameter
- Verify the source code on EtherScan.io
Enjoy. (c) OpenANX and BokkyPooBah / Bok Consulting Pty Ltd 2017. The MIT Licence.