├── .all-contributorsrc
├── .gitignore
├── .travis.yml
├── 1.jpg
├── LICENSE
├── README.md
├── examples
├── 2020-06.mk
├── ENS
│ ├── ENS.xml
│ ├── Makefile
│ ├── item-view.css
│ ├── item-view.en.js
│ ├── package-lock.json
│ ├── package.json
│ ├── records.en.js
│ ├── recordsBundle.en.js
│ ├── renew.en.js
│ ├── shared.css
│ ├── view.css
│ ├── view.en.js
│ └── viewBundle.en.js
├── EntryToken
│ ├── EntryToken.xml
│ ├── Makefile
│ ├── enter.en.js
│ ├── enter.en.shtml
│ ├── icon.en.shtml
│ ├── js
│ │ ├── generalized-time-test.html
│ │ └── generalized-time.js
│ ├── shared.css
│ ├── shong.wang.p12
│ └── token.en.js
├── Karma
│ ├── Makefile
│ ├── attestations.en.shtml
│ ├── item-view.en.shtml
│ ├── karma.xml
│ ├── market.en.shtml
│ ├── start.en.shtml
│ └── style.css
├── UEFA
│ ├── Makefile
│ ├── UEFA.en.js
│ ├── UEFA.xml
│ ├── UEFA.zh.js
│ └── shared.css
├── action
│ ├── Makefile
│ ├── XDAI-bridge.xml
│ ├── shared.css
│ └── xdai-bridge.en.js
├── edcon
│ ├── Makefile
│ ├── shared.css
│ ├── unicon.en.js
│ └── unicon.xml
├── erc20
│ ├── AAVE
│ │ ├── LICENSE
│ │ ├── Makefile
│ │ ├── README.md
│ │ ├── aDAI.xml
│ │ ├── enable.en.js
│ │ ├── shared.css
│ │ ├── supply.en.js
│ │ └── withdraw.en.js
│ ├── BestRates
│ │ └── bestRates.en.js
│ ├── COMP
│ │ ├── COMP.xml
│ │ ├── Makefile
│ │ ├── README.md
│ │ ├── about.en.js
│ │ ├── claim.en.js
│ │ ├── delegate.en.js
│ │ └── shared.css
│ ├── Compound
│ │ ├── Makefile
│ │ ├── cBAT.xml
│ │ ├── cDAI.xml
│ │ ├── cETH.xml
│ │ ├── cREP.xml
│ │ ├── cSAI.xml
│ │ ├── cUSDC.xml
│ │ ├── cWBTC.xml
│ │ ├── cZRX.xml
│ │ ├── enable.en.js
│ │ ├── shared.css
│ │ ├── supply.en.js
│ │ └── withdraw.en.js
│ ├── DAI
│ │ ├── DAI.xml
│ │ ├── Makefile
│ │ ├── dai-bridge.en.js
│ │ └── shared.css
│ ├── DDEX
│ │ ├── Makefile
│ │ ├── guide.en.js
│ │ ├── pDAI.xml
│ │ ├── pETH.xml
│ │ ├── pUSDT.xml
│ │ └── shared.css
│ ├── DeFiMoneyMarket
│ │ ├── Makefile
│ │ ├── enable.en.js
│ │ ├── mDAI.xml
│ │ ├── mETH.xml
│ │ ├── mUSDC.xml
│ │ ├── shared.css
│ │ ├── supply.en.js
│ │ └── withdraw.en.js
│ ├── NEST
│ │ ├── Makefile
│ │ ├── NEST.xml
│ │ ├── deposit.en.js
│ │ ├── dividend.en.js
│ │ ├── enable.en.js
│ │ ├── shared.css
│ │ └── withdraw.en.js
│ ├── SAI
│ │ ├── Makefile
│ │ ├── SAI.xml
│ │ ├── important.en.js
│ │ └── shared.css
│ ├── USDC
│ │ ├── Makefile
│ │ └── USDC.xml
│ ├── Uniswap
│ │ ├── Makefile
│ │ ├── about.en.shtml
│ │ ├── daiPool.xml
│ │ ├── saiPool.xml
│ │ ├── sethPool.xml
│ │ ├── shared.css
│ │ ├── usdcPool.xml
│ │ ├── wbtcPool.xml
│ │ └── wethPool.xml
│ ├── WETH
│ │ ├── Makefile
│ │ ├── WETH.xml
│ │ ├── shared.css
│ │ ├── weth-unwrap.en.js
│ │ └── weth-wrap.en.js
│ └── dForce
│ │ ├── Makefile
│ │ ├── USDx.xml
│ │ ├── guide.en.js
│ │ ├── moreInfo.en.js
│ │ └── shared.css
├── fifa
│ ├── Makefile
│ ├── fifa.en.js
│ ├── fifa.xml
│ └── shared.css
└── validate.sh
├── img
└── readme
│ └── tokenscript-examples.jpg
├── resources
└── fast-token-onboarding
│ ├── README.md
│ ├── erc20.canonicalized.xml
│ ├── erc721.canonicalized.xml
│ └── sign.sh
└── tutorial
├── README.md
├── img
└── QR_EntryToken_ETH_address.png
├── step-1-forming-the-layout.md
├── step-2-assembling-the-XML-file.md
├── step-3-debugging-and-testing.md
├── step-4-signing-and-publishing.md
└── tutorial-files
├── Coin.sol
├── Coin.xml
├── Makefile
├── app.css
└── mint.shtml
/.all-contributorsrc:
--------------------------------------------------------------------------------
1 | {
2 | "files": [
3 | "README.md"
4 | ],
5 | "imageSize": 100,
6 | "commit": false,
7 | "contributors": [
8 | {
9 | "login": "James-Sangalli",
10 | "name": "James Sangalli",
11 | "avatar_url": "https://avatars2.githubusercontent.com/u/16630514?v=4",
12 | "profile": "https://github.com/James-Sangalli",
13 | "contributions": [
14 | "code"
15 | ]
16 | },
17 | {
18 | "login": "colourful-land",
19 | "name": "Weiwu Zhang",
20 | "avatar_url": "https://avatars3.githubusercontent.com/u/548435?v=4",
21 | "profile": "https://github.com/colourful-land",
22 | "contributions": [
23 | "code"
24 | ]
25 | },
26 | {
27 | "login": "jzaki",
28 | "name": "James Zaki",
29 | "avatar_url": "https://avatars3.githubusercontent.com/u/939603?v=4",
30 | "profile": "https://github.com/jzaki",
31 | "contributions": [
32 | "code"
33 | ]
34 | },
35 | {
36 | "login": "JamesSmartCell",
37 | "name": "James Brown",
38 | "avatar_url": "https://avatars2.githubusercontent.com/u/12689544?v=4",
39 | "profile": "https://github.com/JamesSmartCell",
40 | "contributions": [
41 | "code"
42 | ]
43 | },
44 | {
45 | "login": "hboon",
46 | "name": "Hwee-Boon Yar",
47 | "avatar_url": "https://avatars1.githubusercontent.com/u/56189?v=4",
48 | "profile": "https://github.com/hboon",
49 | "contributions": [
50 | "code"
51 | ]
52 | },
53 | {
54 | "login": "zhangzhongnan928",
55 | "name": "Victor Zhang",
56 | "avatar_url": "https://avatars0.githubusercontent.com/u/33795543?v=4",
57 | "profile": "https://github.com/zhangzhongnan928",
58 | "contributions": [
59 | "code"
60 | ]
61 | },
62 | {
63 | "login": "hellolucas",
64 | "name": "Lucas Toledo",
65 | "avatar_url": "https://avatars3.githubusercontent.com/u/17125002?v=4",
66 | "profile": "https://github.com/hellolucas",
67 | "contributions": [
68 | "code"
69 | ]
70 | },
71 | {
72 | "login": "ChintanRathod",
73 | "name": "Chintan Rathod",
74 | "avatar_url": "https://avatars0.githubusercontent.com/u/4371780?s=460&u=aeffa77e91dfaf95990f355328b2b0636bcb9877&v=4",
75 | "profile": "https://github.com/ChintanRathod",
76 | "contributions": [
77 | "code"
78 | ]
79 | },
80 | {
81 | "login": "coreycaplan3",
82 | "name": "Corey Caplan",
83 | "avatar_url": "https://avatars3.githubusercontent.com/u/13280244?s=460&u=4a4261476b882e93238af58910e3b39150216454&v=4",
84 | "profile": "https://github.com/coreycaplan3",
85 | "contributions": [
86 | "code"
87 | ]
88 | }
89 | ],
90 | "contributorsPerLine": 5,
91 | "projectName": "tokenscript-examples",
92 | "projectOwner": "AlphaWallet",
93 | "repoType": "github",
94 | "repoHost": "https://github.com",
95 | "skipCi": true
96 | }
97 |
--------------------------------------------------------------------------------
/.gitignore:
--------------------------------------------------------------------------------
1 | *.pdf
2 | *.TEST
3 | .DS_Store
4 | .idea
5 | *.canonicalized.xml
6 | *.canonicalized.xml.*
7 | !resources/fast-token-onboarding/*.canonicalized.xml
8 | *.tsml
9 | *.p12
10 | !shong.wang.p12
11 | /examples/ENS/node_modules/
12 |
--------------------------------------------------------------------------------
/.travis.yml:
--------------------------------------------------------------------------------
1 | os: osx
2 |
3 | language: bash
4 |
5 | branches:
6 | only:
7 | - master
8 | env:
9 | - LC_CTYPE=en_US.UTF-8 LANG=en_US.UTF-8
10 |
11 | before_install:
12 | - brew update
13 | - brew install xmlsectool
14 | - brew install xmlstarlet
15 |
16 | script:
17 | - cd examples && ./validate.sh */*.xml */*/*.xml
18 |
19 | after_success:
20 | - bash <(curl -s https://codecov.io/bash)
21 |
--------------------------------------------------------------------------------
/1.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/SmartTokenLabs/TokenScript-Examples/ddfe8425b5d27277aed3f4a15594b23da8caf416/1.jpg
--------------------------------------------------------------------------------
/LICENSE:
--------------------------------------------------------------------------------
1 | MIT License
2 |
3 | Copyright (c) 2020 AlphaWallet
4 |
5 | Permission is hereby granted, free of charge, to any person obtaining a copy
6 | of this software and associated documentation files (the "Software"), to deal
7 | in the Software without restriction, including without limitation the rights
8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9 | copies of the Software, and to permit persons to whom the Software is
10 | furnished to do so, subject to the following conditions:
11 |
12 | The above copyright notice and this permission notice shall be included in all
13 | copies or substantial portions of the Software.
14 |
15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21 | SOFTWARE.
22 |
--------------------------------------------------------------------------------
/examples/2020-06.mk:
--------------------------------------------------------------------------------
1 | ifeq ($(TOKENSCRIPT_SCHEMA),)
2 | TOKENSCRIPT_SCHEMA=http://tokenscript.org/2020/06/tokenscript.xsd
3 | endif
4 |
5 | ifeq ($(XMLSECTOOL),)
6 | XMLSECTOOL=xmlsectool
7 | endif
8 |
9 | ifeq ($(XMLLINT),)
10 | XMLLINT=xmllint
11 | endif
12 |
13 | ifeq ($(XMLSEC),)
14 | XMLSEC=xmlsec1 # xmlsec for Linux/Windows
15 | endif
16 |
17 | ifeq ($(SIGNATURE_ALGORITHM),)
18 | SIGNATURE_ALGORITHM=rsa-sha256
19 | endif
20 |
21 | help:
22 | # Needs a target, example: $$ make EntryToken.canonicalized.xml
23 | #
24 | # Let's say you have a TokenScript "EntryToken.xml"
25 | # - to validate and canonicalize, add 'canonicalized' in the filename
26 | @echo $$ make EntryToken.canonicalized.xml
27 | # - to sign, use tsml as file extension:
28 | @echo $$ make EntryToken.tsml
29 |
30 | %.canonicalized.xml : %.xml
31 | # XML canonicalization and validation against TS schema
32 | $(XMLLINT) --c14n $^ > $@ && \
33 | $(XMLLINT) --noout --schema $(TOKENSCRIPT_SCHEMA) $@ || \
34 | (mv $@ $@.TEST && exit 1)
35 |
36 | %.tsml: %.canonicalized.xml
37 | ifeq (,$(KEYPARAMS))
38 | @echo ---------------- KEYPARAMS missing. Examples on how to use this ----------------
39 | @echo Example using key file and certificate files
40 | @echo $$ make SIGNATURE_ALGORITHM=ecdsa-sha256 KEYPARAMS='"--key ~/KEYS/aw.app.key --certificate ~/KEYS/positiveSSL/aw_app.crt --keyInfoKeyName AlphaWallet"' $@
41 | @echo Example using keystore file
42 | @echo $$ make KEYPARAMS='--keystore shong.wang.p12 --keyPassword=shong.wang --keyInfoName="Shong Wang"' $@
43 | @echo replace it with your .p12 file and your password
44 | rm $^
45 | else
46 | # Signing with xmlsec requires original .xml file to contain the Signature tag.
47 | # $(XMLSEC) sign --pkcs12:"$(KEYINFO)" $(KEYSTORE) --pwd "$(KEYPASSWORD)" --output $@ $^
48 | # For now use xmlsectool...
49 | $(XMLSECTOOL) --sign --digest SHA-256 --signatureAlgorithm http://www.w3.org/2001/04/xmldsig-more#$(SIGNATURE_ALGORITHM) --inFile $^ --outFile $@ --signaturePosition LAST $(KEYPARAMS)
50 | # removing the canonicalized created for validation
51 | rm $^
52 | endif
53 |
--------------------------------------------------------------------------------
/examples/ENS/ENS.xml:
--------------------------------------------------------------------------------
1 |
2 |
5 |
6 |
7 |
8 |
9 |
10 |
11 | ]>
12 |
21 |
22 |
23 |
24 |
25 |
26 |
27 |
28 |
29 |
30 |
31 |
32 |
33 |
34 |
35 |
36 | ENS
37 |
38 |
39 |
40 | 0x57f1887a8BF19b14fC0dF6Fd9B2acc9Af147eA85
41 |
42 |
43 | 0x00000000000C2E074eC69A0dFb2997BA6C7d2e1e
44 |
45 |
46 | 0x4976fb03C32e5B8cfe2b6cCB31c09Ba78EBaBa41
47 |
48 |
49 |
50 |
51 | 0x283af0b28c62c092c9727f1ee09c02ca627eb7f5
52 |
53 |
54 |
55 |
56 |
57 |
58 |
59 |
60 |
61 | &item-view-style;
62 | &item-view.en;
63 |
64 |
65 | &view-style;
66 | &view.en;
67 |
68 |
69 |
70 |
71 |
72 | Records
73 |
74 |
75 |
76 | 1.3.6.1.4.1.1466.115.121.1.15
77 |
78 | new record value
79 |
80 |
81 |
82 |
83 |
84 |
85 |
86 | 1.3.6.1.4.1.1466.115.121.1.15
87 |
88 |
89 |
90 |
91 | email
92 |
93 |
94 |
95 |
96 |
97 |
98 |
99 |
100 |
101 | email
102 |
103 |
104 |
105 |
106 |
107 |
108 | &style;
109 | &records.en;
110 |
111 |
112 |
113 |
114 |
115 |
116 | Renew
117 |
118 |
119 |
120 | 1.3.6.1.4.1.1466.115.121.1.36
121 |
122 | renewal price per year
123 |
124 |
125 |
126 |
127 |
128 | 31556952
129 |
130 |
131 |
132 |
133 |
134 |
135 |
136 |
137 |
138 | 31556952
139 |
140 |
141 |
142 |
143 |
144 | &style;
145 | &renew.en;
146 |
147 |
148 |
149 |
150 |
151 |
152 | 1.3.6.1.4.1.1466.115.121.1.15
153 |
154 |
155 |
156 |
157 |
158 |
159 | 1.3.6.1.4.1.1466.115.121.1.36
160 |
161 |
162 |
163 |
164 |
165 |
166 |
167 |
168 |
169 |
170 | 1.3.6.1.4.1.1466.115.121.1.15
171 |
172 |
173 |
174 |
175 |
176 |
177 |
178 |
179 |
180 |
181 |
--------------------------------------------------------------------------------
/examples/ENS/Makefile:
--------------------------------------------------------------------------------
1 | include ../2020-06.mk
2 |
--------------------------------------------------------------------------------
/examples/ENS/item-view.css:
--------------------------------------------------------------------------------
1 | .item-view-container {
2 | width: 360px;
3 | height: 80px;
4 | background-color: #ffffff;
5 | }
6 |
7 | .arrow {
8 | position: absolute;
9 | left: 95%;
10 | top: 50%;
11 | margin-left: auto;
12 | margin-right: auto;
13 | display: block;
14 | padding-top: 11%;
15 | }
16 |
17 | .ensInfoBox {
18 | float: right;
19 | }
20 |
21 | .ENS-logo {
22 | width: 40px;
23 | height: 40px;
24 | object-fit: contain;
25 | float: left;
26 | padding: 7% 2.5% 5%;
27 | }
28 |
29 | .ens-title {
30 | width: 264px;
31 | height: 25%;
32 | font-family: SourceSansPro, sans-serif;
33 | font-size: 20px;
34 | font-weight: normal;
35 | font-stretch: normal;
36 | font-style: normal;
37 | line-height: 1.7;
38 | letter-spacing: normal;
39 | color: #000000;
40 | }
41 |
42 | .token-interface-details {
43 | width: 282px;
44 | height: 20px;
45 | font-family: SourceSansPro, sans-serif;
46 | font-size: 12px;
47 | font-weight: normal;
48 | font-stretch: normal;
49 | font-style: normal;
50 | line-height: 1.67;
51 | letter-spacing: normal;
52 | color: #727272;
53 | }
54 |
55 | #ensNameText {
56 | width: 264px;
57 | height: 34px;
58 | font-family: SourceSansPro-Regular, sans-serif;
59 | font-size: 20px;
60 | font-weight: normal;
61 | font-stretch: normal;
62 | font-style: normal;
63 | line-height: 1.7;
64 | letter-spacing: normal;
65 | color: #000000;
66 | }
67 |
68 | #ensInfo {
69 | width: 282px;
70 | height: 20px;
71 | font-family: SourceSansPro-Regular, sans-serif;
72 | font-size: 12px;
73 | font-weight: normal;
74 | font-stretch: normal;
75 | font-style: normal;
76 | line-height: 1.67;
77 | letter-spacing: normal;
78 | color: #727272;
79 | }
80 |
--------------------------------------------------------------------------------
/examples/ENS/item-view.en.js:
--------------------------------------------------------------------------------
1 | //
24 |
25 |
26 |
27 |
28 |
29 |
${this.props.fullName}
30 |
31 |
32 |
Ethereum Name Service | ERC721
33 |
34 |
35 |
36 |
37 |
38 |
39 | `;
40 | }
41 | }
42 |
43 | web3.tokens.dataChanged = (oldTokens, updatedTokens, tokenCardId) => {
44 | const currentTokenInstance = updatedTokens.currentInstance;
45 | let token = new Token(currentTokenInstance);
46 | document.getElementById(tokenCardId).innerHTML = token.render();
47 | token.displayWarningNotOnLatestRegistry();
48 | };
49 |
50 | //]]>
51 |
--------------------------------------------------------------------------------
/examples/ENS/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "ENS",
3 | "version": "1.0.0",
4 | "description": "",
5 | "main": "subdomain.en.js",
6 | "scripts": {
7 | "build": "browserify records.en.js > recordsBundle.en.js && browserify view.en.js > viewBundle.en.js"
8 | },
9 | "keywords": [],
10 | "author": "",
11 | "license": "MIT",
12 | "dependencies": {
13 | "eth-ens-namehash": "^2.0.8"
14 | },
15 | "devDependencies": {
16 | "browserify": "^16.5.1"
17 | }
18 | }
19 |
--------------------------------------------------------------------------------
/examples/ENS/shared.css:
--------------------------------------------------------------------------------
1 | h3 { color: #111; font-family: 'Open Sans', sans-serif; font-size: 20px; font-weight: 300; line-height: 32px; }
2 |
3 | #inputBox {
4 | text-align: center;
5 | }
6 |
7 | html,
8 | body {
9 | height: 100%;
10 | }
11 | html {
12 | font-size: 14px;
13 | }
14 | #duration {
15 | -webkit-appearance: menulist-button;
16 | height: 25px;
17 | width: 50%;
18 | }
19 | body {
20 | margin: 0px;
21 | padding: 0px;
22 | overflow-x: hidden;
23 | min-width: 320px;
24 | background: #FFFFFF;
25 | font-family: 'Lato', 'Helvetica Neue', Arial, Helvetica, sans-serif;
26 | font-size: 14px;
27 | line-height: 1.4285em;
28 | color: rgba(0, 0, 0, 0.87);
29 | font-smoothing: antialiased;
30 | }
31 | .ui.container {
32 | display: block;
33 | max-width: 100% !important;
34 | }
35 | @media only screen and (max-width: 767px) {
36 | .ui.container {
37 | width: auto !important;
38 | margin-left: 1em !important;
39 | margin-right: 1em !important;
40 | }
41 | }
42 | @media only screen and (min-width: 768px) and (max-width: 991px) {
43 | .ui.container {
44 | width: 723px;
45 | margin-left: auto !important;
46 | margin-right: auto !important;
47 | }
48 | }
49 | @media only screen and (min-width: 992px) and (max-width: 1199px) {
50 | .ui.container {
51 | width: 933px;
52 | margin-left: auto !important;
53 | margin-right: auto !important;
54 | }
55 | }
56 | @media only screen and (min-width: 1200px) {
57 | .ui.container {
58 | width: 1127px;
59 | margin-left: auto !important;
60 | margin-right: auto !important;
61 | }
62 | }
63 | .ui.segment {
64 | position: relative;
65 | background: #FFFFFF;
66 | -webkit-box-shadow: 0px 1px 2px 0 rgba(34, 36, 38, 0.15);
67 | box-shadow: 0px 1px 2px 0 rgba(34, 36, 38, 0.15);
68 | margin: 0.5rem 0em;
69 | padding: 0.5em 0.5em;
70 | border-radius: 0.28571429rem;
71 | border: 1px solid rgba(34, 36, 38, 0.15);
72 | text-align: center;
73 | }
74 | .ui.segment:first-child {
75 | margin-top: 0em;
76 | }
77 | .ui.segment:last-child {
78 | margin-bottom: 0em;
79 | }
80 | input {
81 | position: relative;
82 | font-weight: normal;
83 | font-style: normal;
84 | font-size: 12px;
85 | display: -ms-inline-flexbox;
86 | display: inline-flex;
87 | color: rgba(0, 0, 0, 0.87);
88 | padding: 9.5px 14px;
89 | width: 300px;
90 | border-color: #D8D8D8;
91 | }
92 | input[type=text]:focus {
93 | border-color: #D8D8D8;
94 | background: #FAFAFA;
95 | color: rgba(0, 0, 0, 0.87);
96 | -webkit-box-shadow: none;
97 | box-shadow: none;
98 | }
99 | label {
100 | font-size: 12px;
101 | font-weight: 500;
102 | margin-top: 6px;
103 | }
104 |
--------------------------------------------------------------------------------
/examples/ENS/view.css:
--------------------------------------------------------------------------------
1 | #view {
2 | width: 100%;
3 | height: 100%;
4 | }
5 |
6 | .title-container {
7 | margin-top: 10%;
8 | width: 100%;
9 | height: 200px;
10 | background-color: #ffffff;
11 | text-align: center;
12 | }
13 |
14 | .ENS-logo {
15 | width: 60px;
16 | height: 60px;
17 | object-fit: contain;
18 | display: inline-block;
19 | }
20 |
21 | .ensNameContainer {
22 | width: 100%;
23 | height: 15%;
24 | font-family: SourceSansPro, sans-serif;
25 | font-size: 36px;
26 | font-weight: normal;
27 | font-stretch: normal;
28 | font-style: normal;
29 | line-height: 1.69;
30 | letter-spacing: normal;
31 | text-align: center;
32 | color: #000000;
33 | word-wrap: break-word;
34 | }
35 |
36 | .separator {
37 | width: 100%;
38 | height: 1px;
39 | background-color: #e9e9e9;
40 | }
41 |
42 | .expiry-information {
43 | width: 100%;
44 | height: 29px;
45 | font-family: SourceSansPro, sans-serif;
46 | font-size: 15px;
47 | font-weight: normal;
48 | font-stretch: normal;
49 | font-style: normal;
50 | line-height: 1.67;
51 | letter-spacing: normal;
52 | text-align: center;
53 | color: #727272;
54 | }
55 |
56 | .resolver-title-box {
57 | width: 100%;
58 | height: 50px;
59 | background-color: #ffffff;
60 | }
61 |
62 | .resolver-title-text {
63 | width: 246px;
64 | height: 41px;
65 | font-family: SourceSansPro, sans-serif;
66 | font-size: 24px;
67 | font-weight: bold;
68 | font-stretch: normal;
69 | font-style: normal;
70 | line-height: 1.71;
71 | letter-spacing: normal;
72 | color: #000000;
73 | }
74 |
75 | .status-box {
76 | width: 100%;
77 | height: 64px;
78 | }
79 |
80 | .status-title {
81 | width: 212px;
82 | height: 22px;
83 | font-family: SourceSansPro, sans-serif;
84 | font-size: 13px;
85 | font-weight: normal;
86 | font-stretch: normal;
87 | font-style: normal;
88 | line-height: 1.69;
89 | letter-spacing: normal;
90 | color: #727272;
91 | }
92 |
93 | #resolvedImage {
94 | width: 24px;
95 | height: 24px;
96 | object-fit: contain;
97 | }
98 |
99 | #resolvedText {
100 | width: 182px;
101 | height: 29px;
102 | font-family: SourceSansPro-Semibold, sans-serif;
103 | font-size: 17px;
104 | font-weight: 600;
105 | font-stretch: normal;
106 | font-style: normal;
107 | line-height: 1.71;
108 | letter-spacing: normal;
109 | color: #75b943;
110 | float: right;
111 | display: contents;
112 | }
113 |
114 | .resolverAddressBox {
115 | width: 100%;
116 | /*height: 94px;*/
117 | }
118 |
119 | .subtitle {
120 | width: 100%;
121 | height: 2px;
122 | font-family: SourceSansPro, sans-serif;
123 | font-size: 13px;
124 | font-weight: normal;
125 | font-stretch: normal;
126 | font-style: normal;
127 | line-height: 1.69;
128 | letter-spacing: normal;
129 | color: #727272;
130 | }
131 |
132 | .viewText {
133 | width: 100%;
134 | /*height: 58px;*/
135 | font-family: SourceSansPro, sans-serif;
136 | font-size: 17px;
137 | font-weight: normal;
138 | font-stretch: normal;
139 | font-style: normal;
140 | line-height: 1.71;
141 | letter-spacing: normal;
142 | color: #2f2f2f;
143 | word-wrap: break-word;
144 | }
145 |
146 |
147 |
148 |
149 |
150 |
151 |
--------------------------------------------------------------------------------
/examples/EntryToken/EntryToken.xml:
--------------------------------------------------------------------------------
1 |
2 |
4 |
5 |
6 |
7 |
8 | ]>
9 |
16 |
17 |
18 | Ticket
19 | Tickets
20 |
21 |
22 | Boleto de admisión
23 | Boleto de admisiónes
24 |
25 |
26 | 入場券
27 | 入場券
28 |
29 |
30 |
31 | 0x63cCEF733a093E5Bd773b41C96D3eCE361464942
32 | 0xFB82A5a2922A249f32222316b9D1F5cbD3838678
33 | 0x2B58A9403396463404c2e397DBF37c5EcCAb43e5
34 |
35 |
36 |
37 |
38 |
39 |
40 |
41 |
42 | Expired Ticket
43 | Expired Tickets
44 |
45 | 已经过期的票
46 |
47 |
48 |
49 |
50 |
51 |
52 | &icon.en;
53 |
54 |
55 |
56 |
57 |
58 |
59 |
60 |
66 |
67 | Enter
68 | 入場
69 | Entrar
70 |
71 |
72 |
73 |
74 | &enter.en.shtml;
75 |
76 |
77 |
78 |
79 | 1.3.6.1.4.1.1466.115.121.1.15
80 |
81 |
82 |
83 |
84 |
85 |
86 |
87 |
88 |
89 |
90 | 1.3.6.1.4.1.1466.115.121.1.24
91 |
92 | Time
93 | 时间
94 |
95 |
96 |
97 |
98 |
99 |
100 | 1.3.6.1.4.1.1466.115.121.1.7
101 |
102 |
103 |
104 |
105 |
106 |
107 |
108 |
109 |
110 | 1.3.6.1.4.1.1466.115.121.1.15
111 |
112 |
113 |
114 |
115 |
116 |
117 |
118 |
119 |
120 | 1.3.6.1.4.1.1466.115.121.1.15
121 |
122 |
123 |
124 |
125 |
126 |
127 |
128 |
129 |
130 | 1.3.6.1.4.1.1466.115.121.1.15
131 |
132 |
133 |
134 |
135 |
136 |
137 |
138 |
139 |
140 |
--------------------------------------------------------------------------------
/examples/EntryToken/Makefile:
--------------------------------------------------------------------------------
1 | include ../2020-06.mk
2 |
--------------------------------------------------------------------------------
/examples/EntryToken/enter.en.js:
--------------------------------------------------------------------------------
1 | // {
10 | const currentTokenInstance = updatedTokens.currentInstance;
11 | document.getElementById(tokenCardId).innerHTML = new Token(currentTokenInstance).render();
12 | };
13 |
14 | document.addEventListener("DOMContentLoaded", function() {
15 | window.onload = function startup() {
16 | // 1. call API to fetch challenge
17 | fetch('http://stormbird.duckdns.org:8080/api/getChallenge')
18 | .then(function (response) {
19 | return response.text()
20 | })
21 | .then(function (response) {
22 | document.getElementById('msg').innerHTML = 'Challenge: ' + response
23 | window.challenge = response
24 | })
25 | }
26 |
27 | window.onConfirm = function onConfirm(signature) {
28 | if (window.challenge === undefined || window.challenge.length == 0) return
29 | const challenge = window.challenge
30 | document.getElementById('status').innerHTML = 'Wait for signature...'
31 | // 2. sign challenge to generate response
32 | web3.personal.sign({ data: challenge }, function (error, value) {
33 | if (error != null) {
34 | document.getElementById('status').innerHTML = error
35 | window.onload();
36 | return
37 | }
38 |
39 | document.getElementById('status').innerHTML = 'Verifying credentials ...'
40 | // 3. open door
41 | let contractAddress = document.getElementById("contractAddress").textContent;
42 | fetch(`http://stormbird.duckdns.org:8080/api/checkSignature?contract=${contractAddress}&challenge=${challenge}&sig=${value}`)
43 | .then(function (response) {
44 | return response.text()
45 | })
46 | .then(function (response) {
47 | if (response == "pass") {
48 | document.getElementById('status').innerHTML = 'Entrance granted!'
49 | window.close()
50 | } else {
51 | document.getElementById('status').innerHTML = 'Failed with: ' + response
52 | }
53 | })
54 | });
55 | window.challenge = '';
56 | document.getElementById('msg').innerHTML = '';
57 | }
58 | });
59 | //]]>
60 |
--------------------------------------------------------------------------------
/examples/EntryToken/enter.en.shtml:
--------------------------------------------------------------------------------
1 | Welcome to Craig Wright's house!
2 | Preparing to unlock the entrance door.
3 |
4 |
5 |
--------------------------------------------------------------------------------
/examples/EntryToken/js/generalized-time-test.html:
--------------------------------------------------------------------------------
1 |
3 |
4 |
5 | Generalized Time testing page
6 |
8 |
9 |
10 | You will see a few alerts
11 |
18 |
19 |
20 |
--------------------------------------------------------------------------------
/examples/EntryToken/js/generalized-time.js:
--------------------------------------------------------------------------------
1 | ;(function() {
2 | 'use strict'
3 |
4 | function pad2(num) {
5 | if (num < 10) return '0' + num
6 | return '' + num
7 | }
8 |
9 | function pad4(num) {
10 | if (num < 10) return '000' + num
11 | if (num < 100) return '00' + num
12 | if (num < 1000) return '0' + num
13 | return '' + num
14 | }
15 |
16 | function GeneralizedTime(generalizedTime) {
17 | this.rawData = generalizedTime;
18 | }
19 |
20 | GeneralizedTime.prototype.getYear = function () {
21 | return parseInt(this.rawData.substring(0, 4), 10);
22 | }
23 |
24 | GeneralizedTime.prototype.getMonth = function () {
25 | return parseInt(this.rawData.substring(4, 6), 10) - 1;
26 | }
27 |
28 | GeneralizedTime.prototype.getDay = function () {
29 | return parseInt(this.rawData.substring(6, 8), 10)
30 | },
31 |
32 | GeneralizedTime.prototype.getHours = function () {
33 | return parseInt(this.rawData.substring(8, 10), 10)
34 | },
35 |
36 | GeneralizedTime.prototype.getMinutes = function () {
37 | var minutes = parseInt(this.rawData.substring(10, 12), 10)
38 | if (minutes) return minutes
39 | return 0
40 | },
41 |
42 | GeneralizedTime.prototype.getSeconds = function () {
43 | var seconds = parseInt(this.rawData.substring(12, 14), 10)
44 | if (seconds) return seconds
45 | return 0
46 | },
47 |
48 | GeneralizedTime.prototype.getMilliseconds = function () {
49 | var startIdx
50 | if (time.indexOf('.') !== -1) {
51 | startIdx = this.rawData.indexOf('.') + 1
52 | } else if (time.indexOf(',') !== -1) {
53 | startIdx = this.rawData.indexOf(',') + 1
54 | } else {
55 | return 0
56 | }
57 |
58 | var stopIdx = time.length - 1
59 | var fraction = '0' + '.' + time.substring(startIdx, stopIdx)
60 | var ms = parseFloat(fraction) * 1000
61 | return ms
62 | },
63 |
64 | GeneralizedTime.prototype.getTimeZone = function () {
65 | let time = this.rawData;
66 | var length = time.length
67 | var symbolIdx
68 | if (time.charAt(length - 1 ) === 'Z') return 0
69 | if (time.indexOf('+') !== -1) {
70 | symbolIdx = time.indexOf('+')
71 | } else if (time.indexOf('-') !== -1) {
72 | symbolIdx = time.indexOf('-')
73 | } else {
74 | return NaN
75 | }
76 |
77 | var minutes = time.substring(symbolIdx + 2)
78 | var hours = time.substring(symbolIdx + 1, symbolIdx + 2)
79 | var one = (time.charAt(symbolIdx) === '+') ? 1 : -1
80 |
81 | var intHr = one * parseInt(hours, 10) * 60 * 60 * 1000
82 | var intMin = one * parseInt(minutes, 10) * 60 * 1000
83 | var ms = minutes ? intHr + intMin : intHr
84 | return ms
85 | }
86 |
87 | if (typeof exports === 'object') {
88 | module.exports = GeneralizedTime
89 | } else if (typeof define === 'function' && define.amd) {
90 | define(GeneralizedTime)
91 | } else {
92 | window.GeneralizedTime = GeneralizedTime
93 | }
94 | }())
95 |
--------------------------------------------------------------------------------
/examples/EntryToken/shared.css:
--------------------------------------------------------------------------------
1 | .ts-count {
2 | font-family: "SourceSansPro";
3 | font-weight: bolder;
4 | font-size: 21px;
5 | color: rgb(117, 185, 67);
6 | }
7 | .ts-category {
8 | font-family: "SourceSansPro";
9 | font-weight: lighter;
10 | font-size: 21px;
11 | color: rgb(67, 67, 67);
12 | }
13 | .ts-venue {
14 | font-family: "SourceSansPro";
15 | font-weight: lighter;
16 | font-size: 16px;
17 | color: rgb(67, 67, 67);
18 | }
19 | .ts-date {
20 | font-family: "SourceSansPro";
21 | font-weight: bold;
22 | font-size: 14px;
23 | color: rgb(112, 112, 112);
24 | margin-left: 7px;
25 | margin-right: 7px;
26 | }
27 | .ts-time {
28 | font-family: "SourceSansPro";
29 | font-weight: lighter;
30 | font-size: 16px;
31 | color: rgb(112, 112, 112);
32 | }
33 | html {
34 | }
35 |
36 | body {
37 | padding: 0px;
38 | margin: 0px;
39 | }
40 |
41 | div {
42 | margin: 0px;
43 | padding: 0px;
44 | }
45 |
46 | .data-icon {
47 | height:16px;
48 | vertical-align: middle
49 | }
50 |
51 | .tbml-count {
font-family: "SourceSansPro";
font-weight: bolder;
font-size: 21px;
color: rgb(117, 185, 67);
}
.tbml-category {
font-family: "SourceSansPro";
font-weight: lighter;
font-size: 21px;
color: rgb(67, 67, 67);
}
.tbml-venue {
font-family: "SourceSansPro";
font-weight: lighter;
font-size: 16px;
color: rgb(67, 67, 67);
}
.tbml-date {
font-family: "SourceSansPro";
font-weight: bold;
font-size: 14px;
color: rgb(112, 112, 112);
margin-left: 7px;
margin-right: 7px;
}
.tbml-time {
font-family: "SourceSansPro";
font-weight: lighter;
font-size: 16px;
color: rgb(112, 112, 112);
}
html {
}
body {
padding: 0px;
margin: 0px;
}
div {
margin: 0px;
padding: 0px;
}
.data-icon {
height:16px;
vertical-align: middle
}
52 |
53 |
54 |
--------------------------------------------------------------------------------
/examples/EntryToken/shong.wang.p12:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/SmartTokenLabs/TokenScript-Examples/ddfe8425b5d27277aed3f4a15594b23da8caf416/examples/EntryToken/shong.wang.p12
--------------------------------------------------------------------------------
/examples/EntryToken/token.en.js:
--------------------------------------------------------------------------------
1 | //
110 |
111 | x${this.props._count} ${this.props.label}
112 |
113 |
114 | ${this.props.building}
115 |
116 |
117 |
118 |
119 |
120 |
121 |
${date}
122 |
123 |
124 | ${time}, ${this.props.locality}
125 |
126 | `;
127 | }
128 | }
129 |
130 | web3.tokens.dataChanged = (oldTokens, updatedTokens, tokenCardId) => {
131 | const currentTokenInstance = updatedTokens.currentInstance;
132 | document.getElementById(tokenCardId).innerHTML = new Token(currentTokenInstance).render();
133 | };
134 |
135 | //]]>
136 |
--------------------------------------------------------------------------------
/examples/Karma/Makefile:
--------------------------------------------------------------------------------
1 | include ../2020-06.mk
2 |
--------------------------------------------------------------------------------
/examples/Karma/karma.xml:
--------------------------------------------------------------------------------
1 |
2 |
4 |
5 |
6 |
7 |
8 | ]>
9 |
17 |
18 |
19 | Car Ownership Token
20 | Car Ownership Tokens
21 |
22 |
23 | Token de propiedad del automóvil
24 | Token de propiedad del automóviles
25 |
26 |
27 | 汽车所有权令牌
28 | 汽车所有权令牌
29 |
30 |
31 |
32 | 0x75cb2cc380d1387a79ee64b1b7c9fa051139a319
33 |
34 |
35 |
36 |
37 |
38 |
39 |
40 |
41 |
42 |
43 | &item-view.en;
44 |
45 |
46 |
47 | &item-view.en;
48 |
49 |
50 |
51 |
52 |
53 | Start
54 | 开车
55 | Start
56 |
57 |
58 |
59 | &start.en;
60 |
61 |
62 |
63 |
64 | Attestations
65 | 认证
66 | Attestationes
67 |
68 |
69 |
70 | &attestations.en;
71 |
72 |
73 |
74 |
75 | Market
76 | 市场
77 | Market
78 |
79 |
80 |
81 | &market.en;
82 |
83 |
84 |
85 |
86 | 1.3.6.1.4.1.1466.115.121.1.15
87 |
88 |
89 |
90 |
91 |
92 |
93 |
94 |
95 |
96 |
97 | 1.3.6.1.4.1.1466.115.121.1.24
98 |
99 | Time
100 | 时间
101 |
102 |
103 |
104 |
105 |
106 |
107 | 1.3.6.1.4.1.1466.115.121.1.7
108 |
109 |
110 |
111 |
112 |
113 |
114 |
115 |
116 |
117 | 1.3.6.1.4.1.1466.115.121.1.15
118 |
119 |
120 |
121 |
122 |
123 |
124 |
125 |
126 |
127 | 1.3.6.1.4.1.1466.115.121.1.15
128 |
129 |
130 |
131 |
132 |
133 |
134 |
135 |
136 |
137 | 1.3.6.1.4.1.1466.115.121.1.15
138 |
139 |
140 |
141 |
142 |
143 |
144 |
145 |
146 |
147 |
--------------------------------------------------------------------------------
/examples/Karma/market.en.shtml:
--------------------------------------------------------------------------------
1 |
19 |
20 |
21 |
List for Sale
22 |
23 |
24 |
Auction
25 |
26 |
27 |
Collateralise
28 |
29 |
30 |
List for Hire
31 |
32 |
33 |
--------------------------------------------------------------------------------
/examples/UEFA/Makefile:
--------------------------------------------------------------------------------
1 | include ../2020-06.mk
2 |
--------------------------------------------------------------------------------
/examples/UEFA/shared.css:
--------------------------------------------------------------------------------
1 | .tbml-category {
2 | font-family: "SourceSansPro";
3 | font-weight: 400;
4 | font-size: 12px;
5 | color: white;
6 | }
7 | .tbml-venue {
8 | font-family: "SourceSansPro";
9 | font-weight: 500;
10 | font-size: 15px;
11 | color: white;
12 | display: block;
13 | padding-top: 3%;
14 | }
15 | .tbml-match {
16 | font-family: "SourceSansPro";
17 | font-weight: bold;
18 | font-size: 19px;
19 | color: white;
20 | padding: 2%;
21 | background-color: rgb(117, 185, 67);
22 | display: block;
23 | text-align: center;
24 | margin-top: 1px;
25 | width: 80%;
26 | margin: auto;
27 | margin-top: 8%;
28 | }
29 | .tbml-time {
30 | font-family: "SourceSansPro";
31 | font-weight: lighter;
32 | font-size: 15px;
33 | color: white;
34 | }
35 | .data-icon {
36 | height: 20px;
37 | vertical-align: middle;
38 | color: white;
39 | }
40 | .ticket {
41 | background-image: url('');
42 | border-radius: 15px;
43 | display: flex;
44 | flex-direction: column;
45 | background-size: cover;
46 | height: -webkit-fill-available;
47 | width: -webkit-fill-available;
48 | }
49 | .ticketname {
50 | font-family: "SourceSansPro";
51 | font-weight: 500;
52 | font-size: 15px;
53 | color: white;
54 | width: 100%;
55 | display: block;
56 | padding-top: 3%;
57 | }
58 | .tbml-city {
59 | font-family: "SourceSansPro";
60 | font-weight: bolder;
61 | font-size: 25px;
62 | color: white;
63 | display: block;
64 | padding-top: 3%;
65 | }
66 |
67 | .ticket-bottom-section {
68 | padding-left: 3%;
69 | display: flex;
70 | width: 100%;
71 | margin: auto;
72 | padding-bottom: 10%;
73 | align-self: center;
74 | }
75 | .left-column{
76 | flex: 70%;
77 | align-items: center;
78 | display: block;
79 | padding-top: 5%;
80 | }
81 | .right-column{
82 | flex: 30%;
83 | display: block;
84 | }
85 | .uefa-logo {
86 | height: 60px;
87 | width: -webkit-fill-available;
88 | display: block;
89 | margin: auto;
90 | }
91 | .date {
92 | font-family: "SourceSansPro";
93 | font-weight: 400;
94 | font-size: 12px;
95 | color: white;
96 | }
97 | .top-section {
98 | display: flex;
99 | flex-direction: row;
100 | padding: 5%;
101 | margin-bottom: 30%;
102 | }
103 | .local-time {
104 | font-family: "SourceSansPro";
105 | font-weight: lighter;
106 | font-size: 10px;
107 | color: white;
108 | }
109 |
110 | .left-col {
111 | flex: 50%;
112 | margin-left: 2%;
113 | }
114 | .right-col {
115 | flex: 50%;
116 | }
117 | .white-line {
118 | border: 5% solid white;
119 | width: -webkit-fill-available;
120 | margin-bottom: 3%;
121 | }
122 | .redeemed {
123 | color: #cffFAB;
124 | font-family: "SourceSansPro";
125 | font-weight: 500;
126 | font-size: 15px;
127 | }
--------------------------------------------------------------------------------
/examples/action/Makefile:
--------------------------------------------------------------------------------
1 | include ../2020-06.mk
2 |
--------------------------------------------------------------------------------
/examples/action/XDAI-bridge.xml:
--------------------------------------------------------------------------------
1 |
2 |
4 |
5 | ]>
6 |
13 |
14 | Convert to DAI
15 | 將xDAI轉爲DAI
16 |
17 |
18 | 1.3.6.1.4.1.1466.115.121.1.36
19 |
20 | Amount
21 | 代幣金額
22 |
23 |
24 |
26 |
27 |
28 |
29 |
31 |
32 |
33 |
34 |
35 |
36 |
39 |
40 |
41 |
42 | 0x6b175474e89094c44da98b954eedeac495271d0f
43 |
44 |
45 |
46 |
63 |
64 |
65 | 0x7301CFA0e1756B71869E93d4e4Dca5c7d0eb0AA6
66 |
67 |
68 |
69 |
70 |
71 |
72 |
73 |
74 |
--------------------------------------------------------------------------------
/examples/action/shared.css:
--------------------------------------------------------------------------------
1 | h3 { color: #111; font-family: 'Open Sans', sans-serif; font-size: 20px; font-weight: 300; line-height: 32px; }
2 |
3 | #inputBox {
4 | text-align: center;
5 | }
6 |
7 | html,
8 | body {
9 | height: 100%;
10 | }
11 | html {
12 | font-size: 14px;
13 | }
14 | body {
15 | margin: 0px;
16 | padding: 0px;
17 | overflow-x: hidden;
18 | min-width: 320px;
19 | background: #FFFFFF;
20 | font-family: 'Lato', 'Helvetica Neue', Arial, Helvetica, sans-serif;
21 | font-size: 14px;
22 | line-height: 1.4285em;
23 | color: rgba(0, 0, 0, 0.87);
24 | font-smoothing: antialiased;
25 | }
26 | .ui.container {
27 | display: block;
28 | max-width: 100% !important;
29 | }
30 | @media only screen and (max-width: 767px) {
31 | .ui.container {
32 | width: auto !important;
33 | margin-left: 1em !important;
34 | margin-right: 1em !important;
35 | }
36 | }
37 | @media only screen and (min-width: 768px) and (max-width: 991px) {
38 | .ui.container {
39 | width: 723px;
40 | margin-left: auto !important;
41 | margin-right: auto !important;
42 | }
43 | }
44 | @media only screen and (min-width: 992px) and (max-width: 1199px) {
45 | .ui.container {
46 | width: 933px;
47 | margin-left: auto !important;
48 | margin-right: auto !important;
49 | }
50 | }
51 | @media only screen and (min-width: 1200px) {
52 | .ui.container {
53 | width: 1127px;
54 | margin-left: auto !important;
55 | margin-right: auto !important;
56 | }
57 | }
58 | .ui.segment {
59 | position: relative;
60 | background: #FFFFFF;
61 | -webkit-box-shadow: 0px 1px 2px 0 rgba(34, 36, 38, 0.15);
62 | box-shadow: 0px 1px 2px 0 rgba(34, 36, 38, 0.15);
63 | margin: 0.5rem 0em;
64 | padding: 0.5em 0.5em;
65 | border-radius: 0.28571429rem;
66 | border: 1px solid rgba(34, 36, 38, 0.15);
67 | text-align: center;
68 | }
69 | .ui.segment:first-child {
70 | margin-top: 0em;
71 | }
72 | .ui.segment:last-child {
73 | margin-bottom: 0em;
74 | }
75 | input {
76 | position: relative;
77 | font-weight: normal;
78 | font-style: normal;
79 | font-size: 12px;
80 | display: -ms-inline-flexbox;
81 | display: inline-flex;
82 | color: rgba(0, 0, 0, 0.87);
83 | padding: 9.5px 14px;
84 | width: 300px;
85 | border-color: #D8D8D8;
86 | }
87 | input[type=text]:focus {
88 | border-color: #D8D8D8;
89 | background: #FAFAFA;
90 | color: rgba(0, 0, 0, 0.87);
91 | -webkit-box-shadow: none;
92 | box-shadow: none;
93 | }
94 | label {
95 | font-size: 12px;
96 | font-weight: 500;
97 | margin-top: 6px;
98 | }
--------------------------------------------------------------------------------
/examples/edcon/Makefile:
--------------------------------------------------------------------------------
1 | include ../2020-06.mk
2 |
--------------------------------------------------------------------------------
/examples/edcon/unicon.en.js:
--------------------------------------------------------------------------------
1 | //
17 |
18 |
19 |
20 | TYPE ${this.props.category}
21 |
22 |
23 |
24 | `;
25 | }
26 | }
27 |
28 | web3.tokens.dataChanged = (oldTokens, updatedTokens, tokenCardId) => {
29 | const currentTokenInstance = updatedTokens.currentInstance;
30 | document.getElementById(tokenCardId).innerHTML = new Token(currentTokenInstance).render();
31 | };
32 | //]]>
33 |
--------------------------------------------------------------------------------
/examples/edcon/unicon.xml:
--------------------------------------------------------------------------------
1 |
2 |
4 |
5 | ]>
6 |
14 |
15 |
16 | Ticket
17 | Tickets
18 |
19 |
20 |
21 |
22 | 0xF6b8DD8Ba9996bEaE6Ad0eE3481F1E9cF080A9eB
23 |
24 |
25 |
26 |
27 |
28 |
29 |
30 |
31 |
32 |
33 | &style;
34 |
35 |
36 |
37 | &style;
38 |
39 |
40 |
41 |
42 |
43 |
44 |
45 | 1.3.6.1.4.1.1466.115.121.1.24
46 |
47 | Time
48 |
49 |
50 |
51 |
52 |
53 |
54 |
55 |
56 |
57 | 1.3.6.1.4.1.1466.115.121.1.15
58 |
59 | City
60 |
61 |
62 |
63 |
64 |
65 | Welthandelspl. 1, 1020 Wien, Austria
66 |
67 |
68 |
69 |
70 |
71 |
72 |
73 | 1.3.6.1.4.1.1466.115.121.1.15
74 |
75 | Venue
76 |
77 |
78 |
79 |
80 |
81 | Vienna University of Economics and Business
82 |
83 |
84 |
85 |
86 |
87 |
88 |
89 | 1.3.6.1.4.1.1466.115.121.1.15
90 |
91 | Cat
92 | 等级
93 | Cat
94 |
95 |
96 |
97 |
98 |
99 | A
100 |
101 |
102 | B
103 |
104 |
105 | C
106 |
107 |
108 | D
109 |
110 |
111 | E
112 |
113 |
114 |
115 |
116 |
117 |
118 |
119 | 1.3.6.1.4.1.1466.115.121.1.27
120 |
121 | №
122 |
123 |
124 |
125 |
126 |
127 |
128 |
129 | 1.3.6.1.4.1.1466.115.121.1.27
130 |
131 | Redeemed
132 |
133 |
134 |
135 |
136 |
137 |
138 |
139 |
140 |
141 |
142 |
143 |
--------------------------------------------------------------------------------
/examples/erc20/AAVE/LICENSE:
--------------------------------------------------------------------------------
1 | MIT License
2 |
3 | Copyright (c) 2020 David Truong
4 |
5 | Permission is hereby granted, free of charge, to any person obtaining a copy
6 | of this software and associated documentation files (the "Software"), to deal
7 | in the Software without restriction, including without limitation the rights
8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9 | copies of the Software, and to permit persons to whom the Software is
10 | furnished to do so, subject to the following conditions:
11 |
12 | The above copyright notice and this permission notice shall be included in all
13 | copies or substantial portions of the Software.
14 |
15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21 | SOFTWARE.
22 |
--------------------------------------------------------------------------------
/examples/erc20/AAVE/Makefile:
--------------------------------------------------------------------------------
1 | include ../../2020-06.mk
2 |
--------------------------------------------------------------------------------
/examples/erc20/AAVE/README.md:
--------------------------------------------------------------------------------
1 | # WIP: AlphaWallet integration
2 | Modelled on AlphaWallet's Compound 'integration', as suggested from AlphaWallet.
3 |
4 | ## Information
5 | See [TokenScript examples directory](https://github.com/AlphaWallet/TokenScript-Examples)
6 |
--------------------------------------------------------------------------------
/examples/erc20/AAVE/shared.css:
--------------------------------------------------------------------------------
1 | h3 { color: #111; font-family: 'Open Sans', sans-serif; font-size: 20px; font-weight: 300; line-height: 32px; }
2 |
3 | #inputBox {
4 | text-align: center;
5 | }
6 |
7 | html,
8 | body {
9 | height: 100%;
10 | }
11 | html {
12 | font-size: 14px;
13 | }
14 | body {
15 | margin: 0px;
16 | padding: 0px;
17 | overflow-x: hidden;
18 | min-width: 320px;
19 | background: #FFFFFF;
20 | font-family: 'Lato', 'Helvetica Neue', Arial, Helvetica, sans-serif;
21 | font-size: 14px;
22 | line-height: 1.4285em;
23 | color: rgba(0, 0, 0, 0.87);
24 | font-smoothing: antialiased;
25 | }
26 | .ui.container {
27 | display: block;
28 | max-width: 100% !important;
29 | }
30 | @media only screen and (max-width: 767px) {
31 | .ui.container {
32 | width: auto !important;
33 | margin-left: 1em !important;
34 | margin-right: 1em !important;
35 | }
36 | }
37 | @media only screen and (min-width: 768px) and (max-width: 991px) {
38 | .ui.container {
39 | width: 723px;
40 | margin-left: auto !important;
41 | margin-right: auto !important;
42 | }
43 | }
44 | @media only screen and (min-width: 992px) and (max-width: 1199px) {
45 | .ui.container {
46 | width: 933px;
47 | margin-left: auto !important;
48 | margin-right: auto !important;
49 | }
50 | }
51 | @media only screen and (min-width: 1200px) {
52 | .ui.container {
53 | width: 1127px;
54 | margin-left: auto !important;
55 | margin-right: auto !important;
56 | }
57 | }
58 | .ui.segment {
59 | position: relative;
60 | background: #FFFFFF;
61 | -webkit-box-shadow: 0px 1px 2px 0 rgba(34, 36, 38, 0.15);
62 | box-shadow: 0px 1px 2px 0 rgba(34, 36, 38, 0.15);
63 | margin: 0.5rem 0em;
64 | padding: 0.5em 0.5em;
65 | border-radius: 0.28571429rem;
66 | border: 1px solid rgba(34, 36, 38, 0.15);
67 | text-align: center;
68 | }
69 | .ui.segment:first-child {
70 | margin-top: 0em;
71 | }
72 | .ui.segment:last-child {
73 | margin-bottom: 0em;
74 | }
75 | input {
76 | position: relative;
77 | font-weight: normal;
78 | font-style: normal;
79 | font-size: 12px;
80 | display: -ms-inline-flexbox;
81 | display: inline-flex;
82 | color: rgba(0, 0, 0, 0.87);
83 | padding: 9.5px 14px;
84 | width: 300px;
85 | border-color: #D8D8D8;
86 | }
87 | input[type=text]:focus {
88 | border-color: #D8D8D8;
89 | background: #FAFAFA;
90 | color: rgba(0, 0, 0, 0.87);
91 | -webkit-box-shadow: none;
92 | box-shadow: none;
93 | }
94 | label {
95 | font-size: 12px;
96 | font-weight: 500;
97 | margin-top: 6px;
98 | }
--------------------------------------------------------------------------------
/examples/erc20/COMP/COMP.xml:
--------------------------------------------------------------------------------
1 |
2 |
4 |
5 |
6 |
7 | ]>
8 |
17 |
18 |
19 | COMP
20 |
21 |
22 | 0xc00e94Cb662C3520282E6f5717214004A7f26888
23 |
24 |
25 |
26 | 0x3d9819210A31b4961b30EF54bE2aeD79B9c9Cd3B
27 |
28 |
29 |
30 |
31 |
32 |
33 |
34 |
35 |
36 | About
37 |
38 |
39 |
40 |
41 |
42 |
43 |
44 |
45 |
46 | Claim COMP
47 |
48 |
49 |
50 |
51 |
52 |
53 |
54 |
55 |
56 |
57 |
58 |
59 |
60 |
61 |
62 |
63 | Delegate Vote
64 |
65 |
66 |
67 | 1.3.6.1.4.1.1466.115.121.1.15
68 |
69 |
70 | Delegate to Address
71 |
72 |
73 |
74 |
75 |
76 |
77 |
78 |
79 |
80 |
81 |
82 |
83 |
84 |
85 |
86 |
87 |
88 |
89 |
90 |
91 |
92 | 1.3.6.1.4.1.1466.115.121.1.36
93 |
94 |
95 | compAccrued
96 |
97 |
98 |
99 |
100 |
101 |
102 |
103 |
--------------------------------------------------------------------------------
/examples/erc20/COMP/Makefile:
--------------------------------------------------------------------------------
1 | ifeq ($(TOKENSCRIPT_SCHEMA),)
2 | TOKENSCRIPT_SCHEMA=http://tokenscript.org/2020/06/tokenscript.xsd
3 | endif
4 |
5 | ifeq ($(XMLSECTOOL),)
6 | XMLSECTOOL=xmlsectool
7 | endif
8 |
9 | ifeq ($(XMLLINT),)
10 | XMLLINT=xmllint
11 | endif
12 |
13 | ifeq ($(XMLSEC),)
14 | XMLSEC=xmlsec1 # xmlsec for Linux/Windows
15 | endif
16 |
17 |
18 | ifndef KEY
19 | KEY=1
20 | endif
21 |
22 | SIGNATURE_ALGORITHM=rsa-sha256
23 |
24 | help:
25 | # Needs a target, example: $$ make EntryToken.canonicalized.xml
26 | #
27 | # Let's say you have a TokenScript "EntryToken.xml"
28 | # - to validate and canonicalize, add 'canonicalized' in the filename
29 | @echo $$ make EntryToken.canonicalized.xml
30 | # - to sign, use tsml as file extension:
31 | @echo $$ make EntryToken.tsml
32 |
33 | %.canonicalized.xml : %.xml
34 | # XML canonicalization and validation against TS schema
35 | $(XMLLINT) --c14n $^ > $@ && \
36 | $(XMLLINT) --noout --schema $(TOKENSCRIPT_SCHEMA) $@ || \
37 | (mv $@ $@.TEST && exit 1)
38 |
39 | %.tsml: %.canonicalized.xml
40 | ifeq (,$(KEYPASSWORD))
41 | $(error KEYPASSWORD is not set)
42 | endif
43 | ifeq (,$(KEYSTORE))
44 | @echo ---------------- Keystore missing. Try this ----------------
45 | @echo $$ make KEYSTORE=shong.wang.p12 KEYPASSWORD=shong.wang KEYINFO='"Shong Wang"' $@
46 | @echo replace it with your .p12 file and your password
47 | rm $^
48 | else
49 | # Signing with xmlsec requires original .xml file to contain the Signature tag.
50 | # $(XMLSEC) sign --pkcs12:"$(KEYINFO)" $(KEYSTORE) --pwd "$(KEYPASSWORD)" --output $@ $^
51 | # For now use xmlsectool...
52 | $(XMLSECTOOL) --sign --keyInfoKeyName "$(KEYINFO)" --digest SHA-256 --signatureAlgorithm http://www.w3.org/2001/04/xmldsig-more#$(SIGNATURE_ALGORITHM) --inFile $^ --outFile $@ --keystore $(KEYSTORE) --keystoreType PKCS12 --key $(KEY) --keyPassword "$(KEYPASSWORD)" --signaturePosition LAST
53 | # removing the canonicalized created for validation
54 | rm $^
55 | endif
56 |
--------------------------------------------------------------------------------
/examples/erc20/COMP/README.md:
--------------------------------------------------------------------------------
1 | ## Congratulations on generating a TokenScript for your token!
2 |
3 | ### For more information
4 | Check out the tutorial here: https://github.com/AlphaWallet/TokenScript-Examples/tree/master/tutorial, it includes comprehensive information on what a TokenScript is, how to use it on AlphaWallet and AlphaWallet forks, what tools you need to debug and more!
5 |
6 | ### Happy with your TokenScript and wanna show off your token to everyone on AlphaWallet?
7 | Submit a pull request with your token added to https://github.com/AlphaWallet/TokenScript-Examples
8 |
9 | ### Learn More about AlphaWallet
10 | iOS download: https://apps.apple.com/us/app/alphawallet/id1358230430
11 |
12 | Android download: https://play.google.com/store/apps/details?id=io.stormbird.wallet&hl=en_AU
13 |
14 | Website: AlphaWallet.com
15 |
16 | GitHub: https://github.com/AlphaWallet/
17 |
18 | Forum: https://community.tokenscript.org/
19 |
20 | Twitter: @AlphaWallet
21 |
22 | Telegram: t.me/AlphaWalletGroup
23 |
24 | Facebook: https://www.facebook.com/AlphaWallet/
25 |
--------------------------------------------------------------------------------
/examples/erc20/COMP/shared.css:
--------------------------------------------------------------------------------
1 | h3 { color: #111; font-family: 'Open Sans', sans-serif; font-size: 20px; font-weight: 300; line-height: 32px; }
2 |
3 | #inputBox {
4 | text-align: center;
5 | }
6 |
7 | html,
8 | body {
9 | height: 100%;
10 | }
11 | html {
12 | font-size: 14px;
13 | }
14 | body {
15 | margin: 0px;
16 | padding: 0px;
17 | overflow-x: hidden;
18 | min-width: 320px;
19 | background: #FFFFFF;
20 | font-family: 'Lato', 'Helvetica Neue', Arial, Helvetica, sans-serif;
21 | font-size: 14px;
22 | line-height: 1.4285em;
23 | color: rgba(0, 0, 0, 0.87);
24 | font-smoothing: antialiased;
25 | }
26 | .ui.container {
27 | display: block;
28 | max-width: 100% !important;
29 | }
30 | @media only screen and (max-width: 767px) {
31 | .ui.container {
32 | width: auto !important;
33 | margin-left: 1em !important;
34 | margin-right: 1em !important;
35 | }
36 | }
37 | @media only screen and (min-width: 768px) and (max-width: 991px) {
38 | .ui.container {
39 | width: 723px;
40 | margin-left: auto !important;
41 | margin-right: auto !important;
42 | }
43 | }
44 | @media only screen and (min-width: 992px) and (max-width: 1199px) {
45 | .ui.container {
46 | width: 933px;
47 | margin-left: auto !important;
48 | margin-right: auto !important;
49 | }
50 | }
51 | @media only screen and (min-width: 1200px) {
52 | .ui.container {
53 | width: 1127px;
54 | margin-left: auto !important;
55 | margin-right: auto !important;
56 | }
57 | }
58 | .ui.segment {
59 | position: relative;
60 | background: #FFFFFF;
61 | -webkit-box-shadow: 0px 1px 2px 0 rgba(34, 36, 38, 0.15);
62 | box-shadow: 0px 1px 2px 0 rgba(34, 36, 38, 0.15);
63 | margin: 0.5rem 0em;
64 | padding: 0.5em 0.5em;
65 | border-radius: 0.28571429rem;
66 | border: 1px solid rgba(34, 36, 38, 0.15);
67 | text-align: center;
68 | }
69 | .ui.segment:first-child {
70 | margin-top: 0em;
71 | }
72 | .ui.segment:last-child {
73 | margin-bottom: 0em;
74 | }
75 | input {
76 | position: relative;
77 | font-weight: normal;
78 | font-style: normal;
79 | font-size: 12px;
80 | display: -ms-inline-flexbox;
81 | display: inline-flex;
82 | color: rgba(0, 0, 0, 0.87);
83 | padding: 9.5px 14px;
84 | width: 300px;
85 | border-color: #D8D8D8;
86 | }
87 | input[type=text]:focus {
88 | border-color: #D8D8D8;
89 | background: #FAFAFA;
90 | color: rgba(0, 0, 0, 0.87);
91 | -webkit-box-shadow: none;
92 | box-shadow: none;
93 | }
94 | label {
95 | font-size: 12px;
96 | font-weight: 500;
97 | margin-top: 6px;
98 | }
--------------------------------------------------------------------------------
/examples/erc20/Compound/Makefile:
--------------------------------------------------------------------------------
1 | include ../../2020-06.mk
2 |
--------------------------------------------------------------------------------
/examples/erc20/Compound/cBAT.xml:
--------------------------------------------------------------------------------
1 |
2 |
4 |
5 |
6 |
7 | ]>
8 |
16 |
17 | cBAT
18 |
19 |
20 | 0x6C8c6b02E7b2BE14d4fA6022Dfd6d75921D90E4E
21 |
22 |
23 | 0x0d8775f648430679a709e98d2b0cb6250d2887ef
24 |
25 |
26 |
27 |
28 |
29 |
30 | contract already enabled
31 |
32 |
33 |
34 |
35 | contract not enabled
36 |
37 |
38 |
39 |
40 |
41 |
42 | Enable
43 |
44 |
45 |
46 |
47 | 0x6C8c6b02E7b2BE14d4fA6022Dfd6d75921D90E4E
48 | 115792089237316195423570985008687907853269984665640564039457584007913129639935
49 |
50 |
51 |
52 |
53 | &style;
54 | &enable.en;
55 |
56 |
57 |
58 |
59 |
60 | Deposit
61 |
62 |
63 | 1.3.6.1.4.1.1466.115.121.1.36
64 |
65 | Amount to supply
66 |
67 |
68 |
70 |
71 |
72 |
73 |
74 |
75 |
76 |
77 |
78 |
79 |
80 |
81 | &style;
82 | &mint.en;
83 |
84 |
85 |
86 |
87 |
88 | Withdraw
89 |
90 |
91 | 1.3.6.1.4.1.1466.115.121.1.36
92 |
93 | Amount to withdraw
94 |
95 |
96 |
97 |
98 |
99 |
100 |
101 |
102 |
103 |
104 |
105 |
106 |
107 | &style;
108 | &redeem.en;
109 |
110 |
111 |
112 |
113 |
114 |
115 | 1.3.6.1.4.1.1466.115.121.1.36
116 |
117 |
118 |
119 |
120 | 0x6C8c6b02E7b2BE14d4fA6022Dfd6d75921D90E4E
121 |
122 |
123 |
124 |
125 |
126 |
127 |
128 | 1.3.6.1.4.1.1466.115.121.1.36
129 |
130 | Balance
131 | 餘額
132 |
133 |
134 |
135 |
136 |
137 |
138 |
139 |
140 |
141 |
142 |
143 |
144 | 1.3.6.1.4.1.1466.115.121.1.36
145 |
146 | Exchange Rate
147 |
148 |
149 |
150 |
151 |
152 |
153 |
154 |
155 | 1.3.6.1.4.1.1466.115.121.1.36
156 |
157 | Balance
158 | 餘額
159 |
160 |
161 |
162 |
163 |
164 |
165 |
166 |
167 |
168 |
169 |
170 | 1.3.6.1.4.1.1466.115.121.1.36
171 |
172 | Supply Interest Rate
173 |
174 |
175 |
176 |
177 |
178 |
179 |
180 |
181 |
--------------------------------------------------------------------------------
/examples/erc20/Compound/cETH.xml:
--------------------------------------------------------------------------------
1 |
2 |
4 |
5 |
6 | ]>
7 |
15 |
16 | cETH
17 |
18 |
19 | 0x4ddc2d193948926d02f9b1fe9e1daa0718270ed5
20 |
21 |
22 |
23 |
24 |
25 |
26 |
27 |
28 | Deposit
29 |
30 |
31 | 1.3.6.1.4.1.1466.115.121.1.36
32 |
33 | Amount to supply
34 |
35 |
36 |
38 |
39 |
40 |
41 |
42 |
43 |
44 |
45 |
46 |
47 |
48 |
49 | &style;
50 | &mint.en;
51 |
52 |
53 |
54 |
55 |
56 | Withdraw
57 |
58 |
59 | 1.3.6.1.4.1.1466.115.121.1.36
60 |
61 | Amount to withdraw
62 |
63 |
64 |
65 |
66 |
67 |
68 |
69 |
70 |
71 |
72 |
73 |
74 |
75 | &style;
76 | &redeem.en;
77 |
78 |
79 |
80 |
81 |
82 |
83 |
84 |
85 | 1.3.6.1.4.1.1466.115.121.1.36
86 |
87 | Exchange Rate
88 |
89 |
90 |
91 |
92 |
93 |
94 |
95 |
96 | 1.3.6.1.4.1.1466.115.121.1.36
97 |
98 | Balance
99 | 餘額
100 |
101 |
102 |
103 |
104 |
105 |
106 |
107 |
108 |
109 |
110 |
111 | 1.3.6.1.4.1.1466.115.121.1.36
112 |
113 | Supply Interest Rate
114 |
115 |
116 |
117 |
118 |
119 |
120 |
121 |
122 |
--------------------------------------------------------------------------------
/examples/erc20/Compound/shared.css:
--------------------------------------------------------------------------------
1 | h3 { color: #111; font-family: 'Open Sans', sans-serif; font-size: 20px; font-weight: 300; line-height: 32px; }
2 |
3 | #inputBox {
4 | text-align: center;
5 | }
6 |
7 | html,
8 | body {
9 | height: 100%;
10 | }
11 | html {
12 | font-size: 14px;
13 | }
14 | body {
15 | margin: 0px;
16 | padding: 0px;
17 | overflow-x: hidden;
18 | min-width: 320px;
19 | background: #FFFFFF;
20 | font-family: 'Lato', 'Helvetica Neue', Arial, Helvetica, sans-serif;
21 | font-size: 14px;
22 | line-height: 1.4285em;
23 | color: rgba(0, 0, 0, 0.87);
24 | font-smoothing: antialiased;
25 | }
26 | .ui.container {
27 | display: block;
28 | max-width: 100% !important;
29 | }
30 | @media only screen and (max-width: 767px) {
31 | .ui.container {
32 | width: auto !important;
33 | margin-left: 1em !important;
34 | margin-right: 1em !important;
35 | }
36 | }
37 | @media only screen and (min-width: 768px) and (max-width: 991px) {
38 | .ui.container {
39 | width: 723px;
40 | margin-left: auto !important;
41 | margin-right: auto !important;
42 | }
43 | }
44 | @media only screen and (min-width: 992px) and (max-width: 1199px) {
45 | .ui.container {
46 | width: 933px;
47 | margin-left: auto !important;
48 | margin-right: auto !important;
49 | }
50 | }
51 | @media only screen and (min-width: 1200px) {
52 | .ui.container {
53 | width: 1127px;
54 | margin-left: auto !important;
55 | margin-right: auto !important;
56 | }
57 | }
58 | .ui.segment {
59 | position: relative;
60 | background: #FFFFFF;
61 | -webkit-box-shadow: 0px 1px 2px 0 rgba(34, 36, 38, 0.15);
62 | box-shadow: 0px 1px 2px 0 rgba(34, 36, 38, 0.15);
63 | margin: 0.5rem 0em;
64 | padding: 0.5em 0.5em;
65 | border-radius: 0.28571429rem;
66 | border: 1px solid rgba(34, 36, 38, 0.15);
67 | text-align: center;
68 | }
69 | .ui.segment:first-child {
70 | margin-top: 0em;
71 | }
72 | .ui.segment:last-child {
73 | margin-bottom: 0em;
74 | }
75 | input {
76 | position: relative;
77 | font-weight: normal;
78 | font-style: normal;
79 | font-size: 12px;
80 | display: -ms-inline-flexbox;
81 | display: inline-flex;
82 | color: rgba(0, 0, 0, 0.87);
83 | padding: 9.5px 14px;
84 | width: 300px;
85 | border-color: #D8D8D8;
86 | }
87 | input[type=text]:focus {
88 | border-color: #D8D8D8;
89 | background: #FAFAFA;
90 | color: rgba(0, 0, 0, 0.87);
91 | -webkit-box-shadow: none;
92 | box-shadow: none;
93 | }
94 | label {
95 | font-size: 12px;
96 | font-weight: 500;
97 | margin-top: 6px;
98 | }
--------------------------------------------------------------------------------
/examples/erc20/DAI/DAI.xml:
--------------------------------------------------------------------------------
1 |
2 |
4 |
5 |
6 | ]>
7 |
15 |
16 | DAI
17 |
18 |
19 | 0x6b175474e89094c44da98b954eedeac495271d0f
20 |
21 |
22 |
23 |
24 |
25 |
26 |
27 | Convert to xDAI
28 |
29 |
30 | 1.3.6.1.4.1.1466.115.121.1.36
31 |
32 | Amount in DAI
33 | 代幣金額
34 |
35 |
36 |
38 |
39 |
40 |
41 |
42 |
43 |
44 |
45 | 0x4aa42145Aa6Ebf72e164C9bBC74fbD3788045016
46 |
47 |
48 |
49 |
50 |
51 | &style;
52 | &DAI-bridge.en;
53 |
54 |
55 |
56 |
57 | Best Rates
58 |
59 |
60 | &style;
61 | &bestRates.en;
62 |
63 |
64 |
65 |
66 | 1.3.6.1.4.1.1466.115.121.1.36
67 |
68 | DAI-Balance
69 |
70 |
71 |
72 |
73 |
74 |
75 |
76 |
77 |
78 |
79 |
--------------------------------------------------------------------------------
/examples/erc20/DAI/Makefile:
--------------------------------------------------------------------------------
1 | include ../../2020-06.mk
2 |
--------------------------------------------------------------------------------
/examples/erc20/DAI/shared.css:
--------------------------------------------------------------------------------
1 | h3 { color: #111; font-family: 'Open Sans', sans-serif; font-size: 20px; font-weight: 300; line-height: 32px; }
2 |
3 | #inputBox {
4 | text-align: center;
5 | }
6 |
7 | html,
8 | body {
9 | height: 100%;
10 | }
11 | html {
12 | font-size: 14px;
13 | }
14 | body {
15 | margin: 0px;
16 | padding: 0px;
17 | overflow-x: hidden;
18 | min-width: 320px;
19 | background: #FFFFFF;
20 | font-family: 'Lato', 'Helvetica Neue', Arial, Helvetica, sans-serif;
21 | font-size: 14px;
22 | line-height: 1.4285em;
23 | color: rgba(0, 0, 0, 0.87);
24 | font-smoothing: antialiased;
25 | }
26 | .ui.container {
27 | display: block;
28 | max-width: 100% !important;
29 | }
30 | @media only screen and (max-width: 767px) {
31 | .ui.container {
32 | width: auto !important;
33 | margin-left: 1em !important;
34 | margin-right: 1em !important;
35 | }
36 | }
37 | @media only screen and (min-width: 768px) and (max-width: 991px) {
38 | .ui.container {
39 | width: 723px;
40 | margin-left: auto !important;
41 | margin-right: auto !important;
42 | }
43 | }
44 | @media only screen and (min-width: 992px) and (max-width: 1199px) {
45 | .ui.container {
46 | width: 933px;
47 | margin-left: auto !important;
48 | margin-right: auto !important;
49 | }
50 | }
51 | @media only screen and (min-width: 1200px) {
52 | .ui.container {
53 | width: 1127px;
54 | margin-left: auto !important;
55 | margin-right: auto !important;
56 | }
57 | }
58 | .ui.segment {
59 | position: relative;
60 | background: #FFFFFF;
61 | -webkit-box-shadow: 0px 1px 2px 0 rgba(34, 36, 38, 0.15);
62 | box-shadow: 0px 1px 2px 0 rgba(34, 36, 38, 0.15);
63 | margin: 0.5rem 0em;
64 | padding: 0.5em 0.5em;
65 | border-radius: 0.28571429rem;
66 | border: 1px solid rgba(34, 36, 38, 0.15);
67 | text-align: center;
68 | }
69 | .ui.segment:first-child {
70 | margin-top: 0em;
71 | }
72 | .ui.segment:last-child {
73 | margin-bottom: 0em;
74 | }
75 | input {
76 | position: relative;
77 | font-weight: normal;
78 | font-style: normal;
79 | font-size: 12px;
80 | display: -ms-inline-flexbox;
81 | display: inline-flex;
82 | color: rgba(0, 0, 0, 0.87);
83 | padding: 9.5px 14px;
84 | width: 300px;
85 | border-color: #D8D8D8;
86 | }
87 | input[type=text]:focus {
88 | border-color: #D8D8D8;
89 | background: #FAFAFA;
90 | color: rgba(0, 0, 0, 0.87);
91 | -webkit-box-shadow: none;
92 | box-shadow: none;
93 | }
94 | label {
95 | font-size: 12px;
96 | font-weight: 500;
97 | margin-top: 6px;
98 | }
--------------------------------------------------------------------------------
/examples/erc20/DDEX/Makefile:
--------------------------------------------------------------------------------
1 | include ../../2020-06.mk
2 |
--------------------------------------------------------------------------------
/examples/erc20/DDEX/pDAI.xml:
--------------------------------------------------------------------------------
1 |
2 |
4 |
5 | ]>
6 |
14 |
15 | DDEX pDAI
16 |
17 |
18 | 0x6f9D718CaF76055E697AdfFD5E9f9f94753a7501
19 |
20 |
21 |
22 |
23 |
24 |
25 |
26 |
27 |
28 |
29 | Guide
30 |
31 |
32 | &style;
33 | &guide.en;
34 |
35 |
36 |
37 |
38 |
39 |
40 | 1.3.6.1.4.1.1466.115.121.1.26
41 |
42 |
43 |
44 |
45 |
46 |
47 |
--------------------------------------------------------------------------------
/examples/erc20/DDEX/pETH.xml:
--------------------------------------------------------------------------------
1 |
2 |
4 |
5 | ]>
6 |
14 |
15 | DDEX pETH
16 |
17 |
18 | 0x26F5f49E3bb3626b53E4573F07F8587F010019B5
19 |
20 |
21 |
22 |
23 |
24 |
25 |
26 |
27 |
28 |
29 |
30 | Guide
31 |
32 |
33 | &style;
34 | &guide.en;
35 |
36 |
37 |
38 |
39 |
40 |
41 | 1.3.6.1.4.1.1466.115.121.1.26
42 |
43 |
44 |
45 |
46 |
47 |
48 |
--------------------------------------------------------------------------------
/examples/erc20/DDEX/pUSDT.xml:
--------------------------------------------------------------------------------
1 |
2 |
4 |
5 | ]>
6 |
14 |
15 | DDEX pUSDT
16 |
17 |
18 | 0x7a6aAB486A2Bed37c7Cd523Eb60B3A42533f8906
19 |
20 |
21 |
22 |
23 |
24 |
25 |
26 |
27 |
28 |
29 | Guide
30 |
31 |
32 | &style;
33 | &guide.en;
34 |
35 |
36 |
37 |
38 |
39 |
40 | 1.3.6.1.4.1.1466.115.121.1.26
41 |
42 |
43 |
44 |
45 |
46 |
47 |
--------------------------------------------------------------------------------
/examples/erc20/DDEX/shared.css:
--------------------------------------------------------------------------------
1 | h3 { color: #111; font-family: 'Open Sans', sans-serif; font-size: 20px; font-weight: 300; line-height: 32px; }
2 |
3 | #inputBox {
4 | text-align: center;
5 | }
6 |
7 | html,
8 | body {
9 | height: 100%;
10 | }
11 | html {
12 | font-size: 14px;
13 | }
14 | body {
15 | margin: 0px;
16 | padding: 0px;
17 | overflow-x: hidden;
18 | min-width: 320px;
19 | background: #FFFFFF;
20 | font-family: 'Lato', 'Helvetica Neue', Arial, Helvetica, sans-serif;
21 | font-size: 14px;
22 | line-height: 1.4285em;
23 | color: rgba(0, 0, 0, 0.87);
24 | font-smoothing: antialiased;
25 | }
26 | .ui.container {
27 | display: block;
28 | max-width: 100% !important;
29 | }
30 | @media only screen and (max-width: 767px) {
31 | .ui.container {
32 | width: auto !important;
33 | margin-left: 1em !important;
34 | margin-right: 1em !important;
35 | }
36 | }
37 | @media only screen and (min-width: 768px) and (max-width: 991px) {
38 | .ui.container {
39 | width: 723px;
40 | margin-left: auto !important;
41 | margin-right: auto !important;
42 | }
43 | }
44 | @media only screen and (min-width: 992px) and (max-width: 1199px) {
45 | .ui.container {
46 | width: 933px;
47 | margin-left: auto !important;
48 | margin-right: auto !important;
49 | }
50 | }
51 | @media only screen and (min-width: 1200px) {
52 | .ui.container {
53 | width: 1127px;
54 | margin-left: auto !important;
55 | margin-right: auto !important;
56 | }
57 | }
58 | .ui.segment {
59 | position: relative;
60 | background: #FFFFFF;
61 | -webkit-box-shadow: 0px 1px 2px 0 rgba(34, 36, 38, 0.15);
62 | box-shadow: 0px 1px 2px 0 rgba(34, 36, 38, 0.15);
63 | margin: 0.5rem 0em;
64 | padding: 0.5em 0.5em;
65 | border-radius: 0.28571429rem;
66 | border: 1px solid rgba(34, 36, 38, 0.15);
67 | text-align: center;
68 | }
69 | .ui.segment:first-child {
70 | margin-top: 0em;
71 | }
72 | .ui.segment:last-child {
73 | margin-bottom: 0em;
74 | }
75 | input {
76 | position: relative;
77 | font-weight: normal;
78 | font-style: normal;
79 | font-size: 12px;
80 | display: -ms-inline-flexbox;
81 | display: inline-flex;
82 | color: rgba(0, 0, 0, 0.87);
83 | padding: 9.5px 14px;
84 | width: 300px;
85 | border-color: #D8D8D8;
86 | }
87 | input[type=text]:focus {
88 | border-color: #D8D8D8;
89 | background: #FAFAFA;
90 | color: rgba(0, 0, 0, 0.87);
91 | -webkit-box-shadow: none;
92 | box-shadow: none;
93 | }
94 | label {
95 | font-size: 12px;
96 | font-weight: 500;
97 | margin-top: 6px;
98 | }
--------------------------------------------------------------------------------
/examples/erc20/DeFiMoneyMarket/Makefile:
--------------------------------------------------------------------------------
1 | include ../../2020-06.mk
2 |
--------------------------------------------------------------------------------
/examples/erc20/DeFiMoneyMarket/mETH.xml:
--------------------------------------------------------------------------------
1 |
2 |
4 |
5 |
6 |
7 | ]>
8 |
16 |
17 | mETH
18 |
19 |
20 | 0xdF9307DFf0a1B57660F60f9457D32027a55ca0B2
21 |
22 |
23 | 0x4cb120dd1d33c9a3de8bc15620c7cd43418d77e2
24 |
25 |
26 |
27 |
28 |
29 |
30 |
31 |
32 | Deposit
33 |
34 |
35 | 1.3.6.1.4.1.1466.115.121.1.36
36 |
37 | Amount to supply
38 |
39 |
40 |
42 |
43 |
44 |
45 |
46 |
47 |
48 |
49 |
50 |
51 | &style;
52 | &supply.en;
53 |
54 |
55 |
56 |
57 |
58 | Withdraw
59 |
60 |
61 | 1.3.6.1.4.1.1466.115.121.1.36
62 |
63 | Amount to withdraw
64 |
65 |
66 |
67 |
68 |
69 |
70 |
71 |
72 |
73 |
74 |
75 |
76 |
77 |
78 | &style;
79 | &withdraw.en;
80 |
81 |
82 |
83 |
84 |
85 |
86 |
87 | 1.3.6.1.4.1.1466.115.121.1.36
88 |
89 |
90 |
91 |
92 | 0xdF9307DFf0a1B57660F60f9457D32027a55ca0B2
93 |
94 |
95 |
96 |
97 |
98 |
99 |
100 | 1.3.6.1.4.1.1466.115.121.1.36
101 |
102 | Balance
103 | 餘額
104 |
105 |
106 |
107 |
108 |
109 |
110 |
111 |
112 |
113 |
114 |
115 |
116 | 1.3.6.1.4.1.1466.115.121.1.36
117 |
118 | Exchange Rate
119 |
120 |
121 |
122 |
123 |
124 |
125 |
126 |
127 | 1.3.6.1.4.1.1466.115.121.1.36
128 |
129 | Token Decimals
130 |
131 |
132 |
133 |
134 |
135 |
136 |
137 |
138 | 1.3.6.1.4.1.1466.115.121.1.36
139 |
140 | Balance
141 | 餘額
142 |
143 |
144 |
145 |
146 |
147 |
148 |
149 |
150 |
151 |
152 |
153 | 1.3.6.1.4.1.1466.115.121.1.36
154 |
155 | Supply Interest Rate
156 |
157 |
158 |
159 |
160 | 0xdF9307DFf0a1B57660F60f9457D32027a55ca0B2
161 |
162 |
163 |
164 |
165 |
166 |
167 |
--------------------------------------------------------------------------------
/examples/erc20/DeFiMoneyMarket/shared.css:
--------------------------------------------------------------------------------
1 | h3 { color: #111; font-family: 'Open Sans', sans-serif; font-size: 20px; font-weight: 300; line-height: 32px; }
2 |
3 | #inputBox {
4 | text-align: center;
5 | }
6 |
7 | html,
8 | body {
9 | height: 100%;
10 | }
11 | html {
12 | font-size: 14px;
13 | }
14 | body {
15 | margin: 0px;
16 | padding: 0px;
17 | overflow-x: hidden;
18 | min-width: 320px;
19 | background: #FFFFFF;
20 | font-family: 'Lato', 'Helvetica Neue', Arial, Helvetica, sans-serif;
21 | font-size: 14px;
22 | line-height: 1.4285em;
23 | color: rgba(0, 0, 0, 0.87);
24 | font-smoothing: antialiased;
25 | }
26 | .ui.container {
27 | display: block;
28 | max-width: 100% !important;
29 | }
30 | @media only screen and (max-width: 767px) {
31 | .ui.container {
32 | width: auto !important;
33 | margin-left: 1em !important;
34 | margin-right: 1em !important;
35 | }
36 | }
37 | @media only screen and (min-width: 768px) and (max-width: 991px) {
38 | .ui.container {
39 | width: 723px;
40 | margin-left: auto !important;
41 | margin-right: auto !important;
42 | }
43 | }
44 | @media only screen and (min-width: 992px) and (max-width: 1199px) {
45 | .ui.container {
46 | width: 933px;
47 | margin-left: auto !important;
48 | margin-right: auto !important;
49 | }
50 | }
51 | @media only screen and (min-width: 1200px) {
52 | .ui.container {
53 | width: 1127px;
54 | margin-left: auto !important;
55 | margin-right: auto !important;
56 | }
57 | }
58 | .ui.segment {
59 | position: relative;
60 | background: #FFFFFF;
61 | -webkit-box-shadow: 0px 1px 2px 0 rgba(34, 36, 38, 0.15);
62 | box-shadow: 0px 1px 2px 0 rgba(34, 36, 38, 0.15);
63 | margin: 0.5rem 0em;
64 | padding: 0.5em 0.5em;
65 | border-radius: 0.28571429rem;
66 | border: 1px solid rgba(34, 36, 38, 0.15);
67 | text-align: center;
68 | }
69 | .ui.segment:first-child {
70 | margin-top: 0em;
71 | }
72 | .ui.segment:last-child {
73 | margin-bottom: 0em;
74 | }
75 | input {
76 | position: relative;
77 | font-weight: normal;
78 | font-style: normal;
79 | font-size: 12px;
80 | display: -ms-inline-flexbox;
81 | display: inline-flex;
82 | color: rgba(0, 0, 0, 0.87);
83 | padding: 9.5px 14px;
84 | width: 300px;
85 | border-color: #D8D8D8;
86 | }
87 | input[type=text]:focus {
88 | border-color: #D8D8D8;
89 | background: #FAFAFA;
90 | color: rgba(0, 0, 0, 0.87);
91 | -webkit-box-shadow: none;
92 | box-shadow: none;
93 | }
94 | label {
95 | font-size: 12px;
96 | font-weight: 500;
97 | margin-top: 6px;
98 | }
99 |
--------------------------------------------------------------------------------
/examples/erc20/NEST/Makefile:
--------------------------------------------------------------------------------
1 | include ../../2020-06.mk
2 |
--------------------------------------------------------------------------------
/examples/erc20/NEST/deposit.en.js:
--------------------------------------------------------------------------------
1 | //
12 |
13 |
14 |
${message}
15 |
16 |
17 |
18 |
for more information about NEST visit https://nestprotocol.org/
19 |
20 |
21 | `;
22 | }
23 | }
24 |
25 | web3.tokens.dataChanged = (oldTokens, updatedTokens, tokenIdCard) => {
26 | const currentTokenInstance = web3.tokens.data.currentInstance;
27 | document.getElementById(tokenIdCard).innerHTML = new Token(currentTokenInstance).render();
28 | };
29 | //]]>
30 |
--------------------------------------------------------------------------------
/examples/erc20/NEST/dividend.en.js:
--------------------------------------------------------------------------------
1 | //= nextTime.sub(timeLimit) && nowTime <= nextTime.sub(timeLimit).add(getAbonusTimeLimit));
17 | render() {
18 | let message = "";
19 | let now = Date.now() / 1000;
20 | let claimPeriod = parseInt(this.props.nextTime) - parseInt(this.props.timeLimit);
21 | let bonusTimePeriod = parseInt(this.props.nextTime) - parseInt(this.props.timeLimit) + parseInt(this.props.checkGetAbonusTimeLimit);
22 | let NESTTotalCirculation = 10000000000000000000000000000 - this.props.NESTLockedForMining
23 | if(now >= claimPeriod && now <= bonusTimePeriod) {
24 | message = "This week's total dividend is " + (this.props.TotalDividend / 1e18).toFixed(2) + " ETH." + " Your estimate income is " + ((this.props.TotalDividend / 1e18) * (this.props.withdrawable / NESTTotalCirculation)).toFixed(2) + " Your NEST dividend is claimable now until " + this.formatTimeStamp(bonusTimePeriod);
25 | window.onConfirm = null;
26 | } else {
27 | message = "This week's total dividend is " + (this.props.TotalDividend / 1e18).toFixed(2) + " ETH." + " Your estimate income is " + ((this.props.TotalDividend / 1e18) * (this.props.withdrawable / NESTTotalCirculation)).toFixed(2) + " ETH." + " Your NEST dividend is claimable on " + this.formatTimeStamp(parseInt(this.props.nextTime)) + " please come back later";
28 | window.onConfirm = function() { window.close() };
29 | }
30 | return`
31 |
32 |
33 |
34 |
${message}
35 |
36 |
37 |
for more information about NEST visit https://nestprotocol.org/
38 |
39 |
40 | `;
41 | }
42 | }
43 |
44 | web3.tokens.dataChanged = (oldTokens, updatedTokens, tokenIdCard) => {
45 | const currentTokenInstance = web3.tokens.data.currentInstance;
46 | document.getElementById(tokenIdCard).innerHTML = new Token(currentTokenInstance).render();
47 | };
48 | //]]>
49 |
--------------------------------------------------------------------------------
/examples/erc20/NEST/enable.en.js:
--------------------------------------------------------------------------------
1 | //
12 |
13 |
14 |
${message}
15 |
16 |
17 |
for more information about NEST visit https://nestprotocol.org/
18 |
19 |
20 | `;
21 | }
22 | }
23 |
24 | web3.tokens.dataChanged = (oldTokens, updatedTokens, tokenIdCard) => {
25 | const currentTokenInstance = web3.tokens.data.currentInstance;
26 | document.getElementById(tokenIdCard).innerHTML = new Token(currentTokenInstance).render();
27 | };
28 | //]]>
29 |
--------------------------------------------------------------------------------
/examples/erc20/NEST/shared.css:
--------------------------------------------------------------------------------
1 | h3 { color: #111; font-family: 'Open Sans', sans-serif; font-size: 20px; font-weight: 300; line-height: 32px; }
2 |
3 | #inputBox {
4 | text-align: center;
5 | }
6 |
7 | html,
8 | body {
9 | height: 100%;
10 | }
11 | html {
12 | font-size: 14px;
13 | }
14 | body {
15 | margin: 0px;
16 | padding: 0px;
17 | overflow-x: hidden;
18 | min-width: 320px;
19 | background: #FFFFFF;
20 | font-family: 'Lato', 'Helvetica Neue', Arial, Helvetica, sans-serif;
21 | font-size: 14px;
22 | line-height: 1.4285em;
23 | color: rgba(0, 0, 0, 0.87);
24 | font-smoothing: antialiased;
25 | }
26 | .ui.container {
27 | display: block;
28 | max-width: 100% !important;
29 | }
30 | @media only screen and (max-width: 767px) {
31 | .ui.container {
32 | width: auto !important;
33 | margin-left: 1em !important;
34 | margin-right: 1em !important;
35 | }
36 | }
37 | @media only screen and (min-width: 768px) and (max-width: 991px) {
38 | .ui.container {
39 | width: 723px;
40 | margin-left: auto !important;
41 | margin-right: auto !important;
42 | }
43 | }
44 | @media only screen and (min-width: 992px) and (max-width: 1199px) {
45 | .ui.container {
46 | width: 933px;
47 | margin-left: auto !important;
48 | margin-right: auto !important;
49 | }
50 | }
51 | @media only screen and (min-width: 1200px) {
52 | .ui.container {
53 | width: 1127px;
54 | margin-left: auto !important;
55 | margin-right: auto !important;
56 | }
57 | }
58 | .ui.segment {
59 | position: relative;
60 | background: #FFFFFF;
61 | -webkit-box-shadow: 0px 1px 2px 0 rgba(34, 36, 38, 0.15);
62 | box-shadow: 0px 1px 2px 0 rgba(34, 36, 38, 0.15);
63 | margin: 0.5rem 0em;
64 | padding: 0.5em 0.5em;
65 | border-radius: 0.28571429rem;
66 | border: 1px solid rgba(34, 36, 38, 0.15);
67 | text-align: center;
68 | }
69 | .ui.segment:first-child {
70 | margin-top: 0em;
71 | }
72 | .ui.segment:last-child {
73 | margin-bottom: 0em;
74 | }
75 | input {
76 | position: relative;
77 | font-weight: normal;
78 | font-style: normal;
79 | font-size: 12px;
80 | display: -ms-inline-flexbox;
81 | display: inline-flex;
82 | color: rgba(0, 0, 0, 0.87);
83 | padding: 9.5px 14px;
84 | width: 300px;
85 | border-color: #D8D8D8;
86 | }
87 | input[type=text]:focus {
88 | border-color: #D8D8D8;
89 | background: #FAFAFA;
90 | color: rgba(0, 0, 0, 0.87);
91 | -webkit-box-shadow: none;
92 | box-shadow: none;
93 | }
94 | label {
95 | font-size: 12px;
96 | font-weight: 500;
97 | margin-top: 6px;
98 | }
--------------------------------------------------------------------------------
/examples/erc20/NEST/withdraw.en.js:
--------------------------------------------------------------------------------
1 | //
20 |
21 |
22 |
${message}
23 |
24 |
25 |
26 |
for more information about NEST visit https://nestprotocol.org/
27 |
28 |
29 | `;
30 | }
31 | }
32 |
33 | web3.tokens.dataChanged = (oldTokens, updatedTokens, tokenIdCard) => {
34 | const currentTokenInstance = web3.tokens.data.currentInstance;
35 | document.getElementById(tokenIdCard).innerHTML = new Token(currentTokenInstance).render();
36 | };
37 | //]]>
38 |
--------------------------------------------------------------------------------
/examples/erc20/SAI/Makefile:
--------------------------------------------------------------------------------
1 | include ../../2020-06.mk
2 |
--------------------------------------------------------------------------------
/examples/erc20/SAI/SAI.xml:
--------------------------------------------------------------------------------
1 |
2 |
4 |
5 | ]>
6 |
14 |
15 | SAI
16 |
17 |
18 | 0x89d24a6b4ccb1b6faa2625fe562bdd9a23260359
19 |
20 |
21 |
22 |
23 |
24 |
25 |
26 | Important!
27 |
28 |
29 | &style;
30 | &important.en;
31 |
32 |
33 |
34 |
35 | 1.3.6.1.4.1.1466.115.121.1.36
36 |
37 |
38 |
39 |
40 | 0xc73e0383f3aff3215e6f04b0331d58cecf0ab849
41 |
42 |
43 |
44 |
45 |
46 |
--------------------------------------------------------------------------------
/examples/erc20/SAI/important.en.js:
--------------------------------------------------------------------------------
1 | // You may be able to exchange it on Uniswap" +
11 | " by opening this website in the AlphaWallet browser https://uniswap.exchange/swap?use=v1 ";
12 | return`
13 |
14 |
15 | ${message}
16 |
17 |
18 | `;
19 | }
20 | }
21 |
22 | web3.tokens.dataChanged = (oldTokens, updatedTokens, tokenCardId) => {
23 | const currentTokenInstance = updatedTokens.currentInstance;
24 | document.getElementById(tokenCardId).innerHTML = new Token(currentTokenInstance).render();
25 | };
26 | //]]>
27 |
--------------------------------------------------------------------------------
/examples/erc20/SAI/shared.css:
--------------------------------------------------------------------------------
1 | h3 { color: #111; font-family: 'Open Sans', sans-serif; font-size: 20px; font-weight: 300; line-height: 32px; }
2 |
3 | #inputBox {
4 | text-align: center;
5 | }
6 |
7 | html,
8 | body {
9 | height: 100%;
10 | }
11 | html {
12 | font-size: 14px;
13 | }
14 | body {
15 | margin: 0px;
16 | padding: 0px;
17 | overflow-x: hidden;
18 | min-width: 320px;
19 | background: #FFFFFF;
20 | font-family: 'Lato', 'Helvetica Neue', Arial, Helvetica, sans-serif;
21 | font-size: 14px;
22 | line-height: 1.4285em;
23 | color: rgba(0, 0, 0, 0.87);
24 | font-smoothing: antialiased;
25 | }
26 | .ui.container {
27 | display: block;
28 | max-width: 100% !important;
29 | }
30 | @media only screen and (max-width: 767px) {
31 | .ui.container {
32 | width: auto !important;
33 | margin-left: 1em !important;
34 | margin-right: 1em !important;
35 | }
36 | }
37 | @media only screen and (min-width: 768px) and (max-width: 991px) {
38 | .ui.container {
39 | width: 723px;
40 | margin-left: auto !important;
41 | margin-right: auto !important;
42 | }
43 | }
44 | @media only screen and (min-width: 992px) and (max-width: 1199px) {
45 | .ui.container {
46 | width: 933px;
47 | margin-left: auto !important;
48 | margin-right: auto !important;
49 | }
50 | }
51 | @media only screen and (min-width: 1200px) {
52 | .ui.container {
53 | width: 1127px;
54 | margin-left: auto !important;
55 | margin-right: auto !important;
56 | }
57 | }
58 | .ui.segment {
59 | position: relative;
60 | background: #FFFFFF;
61 | -webkit-box-shadow: 0px 1px 2px 0 rgba(34, 36, 38, 0.15);
62 | box-shadow: 0px 1px 2px 0 rgba(34, 36, 38, 0.15);
63 | margin: 0.5rem 0em;
64 | padding: 0.5em 0.5em;
65 | border-radius: 0.28571429rem;
66 | border: 1px solid rgba(34, 36, 38, 0.15);
67 | text-align: center;
68 | }
69 | .ui.segment:first-child {
70 | margin-top: 0em;
71 | }
72 | .ui.segment:last-child {
73 | margin-bottom: 0em;
74 | }
75 | input {
76 | position: relative;
77 | font-weight: normal;
78 | font-style: normal;
79 | font-size: 12px;
80 | display: -ms-inline-flexbox;
81 | display: inline-flex;
82 | color: rgba(0, 0, 0, 0.87);
83 | padding: 9.5px 14px;
84 | width: 300px;
85 | border-color: #D8D8D8;
86 | }
87 | input[type=text]:focus {
88 | border-color: #D8D8D8;
89 | background: #FAFAFA;
90 | color: rgba(0, 0, 0, 0.87);
91 | -webkit-box-shadow: none;
92 | box-shadow: none;
93 | }
94 | label {
95 | font-size: 12px;
96 | font-weight: 500;
97 | margin-top: 6px;
98 | }
--------------------------------------------------------------------------------
/examples/erc20/USDC/Makefile:
--------------------------------------------------------------------------------
1 | include ../../2020-06.mk
2 |
--------------------------------------------------------------------------------
/examples/erc20/USDC/USDC.xml:
--------------------------------------------------------------------------------
1 |
2 |
4 |
5 | ]>
6 |
14 |
15 | USDC
16 |
17 |
18 | 0xa0b86991c6218b36c1d19d4a2e9eb0ce3606eb48
19 |
20 |
21 |
22 |
23 |
24 |
25 |
26 | Best Rates
27 |
28 |
29 | &style;
30 | &bestRates.en;
31 |
32 |
33 |
34 |
35 | 1.3.6.1.4.1.1466.115.121.1.36
36 |
37 | USDC-Balance
38 |
39 |
40 |
41 |
42 |
43 |
44 |
45 |
46 |
47 |
48 |
--------------------------------------------------------------------------------
/examples/erc20/Uniswap/Makefile:
--------------------------------------------------------------------------------
1 | include ../../2020-06.mk
2 |
--------------------------------------------------------------------------------
/examples/erc20/Uniswap/daiPool.xml:
--------------------------------------------------------------------------------
1 |
2 |
4 |
5 | ]>
6 |
14 |
15 | Uniswap DAI V1
16 |
17 |
18 | 0x2a1530C4C41db0B0b2bB646CB5Eb1A67b7158667
19 |
20 |
21 |
22 |
23 |
24 |
25 |
26 |
27 |
28 |
29 | About
30 |
31 |
32 |
33 | &about.en;
34 |
35 |
36 |
37 |
38 |
39 | 1.3.6.1.4.1.1466.115.121.1.26
40 |
41 |
42 |
43 |
44 |
45 |
46 |
--------------------------------------------------------------------------------
/examples/erc20/Uniswap/saiPool.xml:
--------------------------------------------------------------------------------
1 |
2 |
4 |
5 | ]>
6 |
14 |
15 | Uniswap SAI V1
16 |
17 |
18 | 0x09cabEC1eAd1c0Ba254B09efb3EE13841712bE14
19 |
20 |
21 |
22 |
23 |
24 |
25 |
26 |
27 |
28 |
29 | About
30 |
31 |
32 |
33 | &about.en;
34 |
35 |
36 |
37 |
38 |
39 | 1.3.6.1.4.1.1466.115.121.1.26
40 |
41 |
42 |
43 |
44 |
45 |
46 |
--------------------------------------------------------------------------------
/examples/erc20/Uniswap/sethPool.xml:
--------------------------------------------------------------------------------
1 |
2 |
4 |
5 | ]>
6 |
14 |
15 | Uniswap sETH V1
16 |
17 |
18 | 0x4740C758859D4651061CC9CDEFdBa92BDc3a845d
19 |
20 |
21 |
22 |
23 |
24 |
25 |
26 |
27 |
28 |
29 | About
30 |
31 |
32 |
33 | &about.en;
34 |
35 |
36 |
37 |
38 |
39 | 1.3.6.1.4.1.1466.115.121.1.26
40 |
41 |
42 |
43 |
44 |
45 |
46 |
--------------------------------------------------------------------------------
/examples/erc20/Uniswap/shared.css:
--------------------------------------------------------------------------------
1 | h3 { color: #111; font-family: 'Open Sans', sans-serif; font-size: 20px; font-weight: 300; line-height: 32px; }
2 |
3 | #inputBox {
4 | text-align: center;
5 | }
6 |
7 | html,
8 | body {
9 | height: 100%;
10 | }
11 | html {
12 | font-size: 14px;
13 | }
14 | body {
15 | margin: 0px;
16 | padding: 0px;
17 | overflow-x: hidden;
18 | min-width: 320px;
19 | background: #FFFFFF;
20 | font-family: 'Lato', 'Helvetica Neue', Arial, Helvetica, sans-serif;
21 | font-size: 14px;
22 | line-height: 1.4285em;
23 | color: rgba(0, 0, 0, 0.87);
24 | font-smoothing: antialiased;
25 | }
26 | .ui.container {
27 | display: block;
28 | max-width: 100% !important;
29 | }
30 | @media only screen and (max-width: 767px) {
31 | .ui.container {
32 | width: auto !important;
33 | margin-left: 1em !important;
34 | margin-right: 1em !important;
35 | }
36 | }
37 | @media only screen and (min-width: 768px) and (max-width: 991px) {
38 | .ui.container {
39 | width: 723px;
40 | margin-left: auto !important;
41 | margin-right: auto !important;
42 | }
43 | }
44 | @media only screen and (min-width: 992px) and (max-width: 1199px) {
45 | .ui.container {
46 | width: 933px;
47 | margin-left: auto !important;
48 | margin-right: auto !important;
49 | }
50 | }
51 | @media only screen and (min-width: 1200px) {
52 | .ui.container {
53 | width: 1127px;
54 | margin-left: auto !important;
55 | margin-right: auto !important;
56 | }
57 | }
58 | .ui.segment {
59 | position: relative;
60 | background: #FFFFFF;
61 | -webkit-box-shadow: 0px 1px 2px 0 rgba(34, 36, 38, 0.15);
62 | box-shadow: 0px 1px 2px 0 rgba(34, 36, 38, 0.15);
63 | margin: 0.5rem 0em;
64 | padding: 0.5em 0.5em;
65 | border-radius: 0.28571429rem;
66 | border: 1px solid rgba(34, 36, 38, 0.15);
67 | text-align: center;
68 | }
69 | .ui.segment:first-child {
70 | margin-top: 0em;
71 | }
72 | .ui.segment:last-child {
73 | margin-bottom: 0em;
74 | }
75 | input {
76 | position: relative;
77 | font-weight: normal;
78 | font-style: normal;
79 | font-size: 12px;
80 | display: -ms-inline-flexbox;
81 | display: inline-flex;
82 | color: rgba(0, 0, 0, 0.87);
83 | padding: 9.5px 14px;
84 | width: 300px;
85 | border-color: #D8D8D8;
86 | }
87 | input[type=text]:focus {
88 | border-color: #D8D8D8;
89 | background: #FAFAFA;
90 | color: rgba(0, 0, 0, 0.87);
91 | -webkit-box-shadow: none;
92 | box-shadow: none;
93 | }
94 | label {
95 | font-size: 12px;
96 | font-weight: 500;
97 | margin-top: 6px;
98 | }
--------------------------------------------------------------------------------
/examples/erc20/Uniswap/usdcPool.xml:
--------------------------------------------------------------------------------
1 |
2 |
4 |
5 | ]>
6 |
14 |
15 | Uniswap USDC V1
16 |
17 |
18 | 0x97dec872013f6b5fb443861090ad931542878126
19 |
20 |
21 |
22 |
23 |
24 |
25 |
26 |
27 |
28 |
29 | About
30 |
31 |
32 |
33 | &about.en;
34 |
35 |
36 |
37 |
38 |
39 | 1.3.6.1.4.1.1466.115.121.1.26
40 |
41 |
42 |
43 |
44 |
45 |
46 |
--------------------------------------------------------------------------------
/examples/erc20/Uniswap/wbtcPool.xml:
--------------------------------------------------------------------------------
1 |
2 |
4 |
5 | ]>
6 |
14 |
15 | Uniswap WBTC V1
16 |
17 |
18 | 0x4d2f5cfba55ae412221182d8475bc85799a5644b
19 |
20 |
21 |
22 |
23 |
24 |
25 |
26 |
27 |
28 |
29 | About
30 |
31 |
32 |
33 | &about.en;
34 |
35 |
36 |
37 |
38 |
39 | 1.3.6.1.4.1.1466.115.121.1.26
40 |
41 |
42 |
43 |
44 |
45 |
46 |
--------------------------------------------------------------------------------
/examples/erc20/Uniswap/wethPool.xml:
--------------------------------------------------------------------------------
1 |
2 |
4 |
5 | ]>
6 |
14 |
15 | Uniswap WETH V1
16 |
17 |
18 | 0xA2881A90Bf33F03E7a3f803765Cd2ED5c8928dFb
19 |
20 |
21 |
22 |
23 |
24 |
25 |
26 |
27 |
28 |
29 | About
30 |
31 |
32 |
33 | &about.en;
34 |
35 |
36 |
37 |
38 |
39 | 1.3.6.1.4.1.1466.115.121.1.26
40 |
41 |
42 |
43 |
44 |
45 |
46 |
--------------------------------------------------------------------------------
/examples/erc20/WETH/Makefile:
--------------------------------------------------------------------------------
1 | include ../../2020-06.mk
2 |
--------------------------------------------------------------------------------
/examples/erc20/WETH/WETH.xml:
--------------------------------------------------------------------------------
1 |
2 |
4 |
5 |
6 |
7 | ]>
8 |
16 |
17 | WETH
18 |
19 |
20 | 0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2
21 |
22 |
23 |
24 |
25 |
26 |
27 |
28 | Wrap
29 |
30 |
31 | 1.3.6.1.4.1.1466.115.121.1.36
32 |
33 | Amount in WETH
34 |
35 |
36 |
38 |
39 |
40 |
41 |
42 |
43 |
44 |
45 |
46 |
47 | &style;
48 | &wrap.en;
49 |
50 |
51 |
52 |
53 | Unwrap
54 |
55 |
56 | 1.3.6.1.4.1.1466.115.121.1.36
57 |
58 | Amount in WETH
59 |
60 |
61 |
63 |
64 |
65 |
66 |
67 |
68 |
69 |
70 |
71 |
72 |
73 |
74 | &style;
75 | &unwrap.en;
76 |
77 |
78 |
79 |
80 | Best Rates
81 |
82 |
83 | &style;
84 | &bestRates.en;
85 |
86 |
87 |
88 |
89 | 1.3.6.1.4.1.1466.115.121.1.36
90 |
91 | WETH-Balance
92 |
93 |
94 |
95 |
96 |
97 |
98 |
99 |
100 |
101 |
102 |
--------------------------------------------------------------------------------
/examples/erc20/WETH/shared.css:
--------------------------------------------------------------------------------
1 | h3 { color: #111; font-family: 'Open Sans', sans-serif; font-size: 20px; font-weight: 300; line-height: 32px; }
2 |
3 | #inputBox {
4 | text-align: center;
5 | }
6 |
7 | html,
8 | body {
9 | height: 100%;
10 | }
11 | html {
12 | font-size: 14px;
13 | }
14 | body {
15 | margin: 0px;
16 | padding: 0px;
17 | overflow-x: hidden;
18 | min-width: 320px;
19 | background: #FFFFFF;
20 | font-family: 'Lato', 'Helvetica Neue', Arial, Helvetica, sans-serif;
21 | font-size: 14px;
22 | line-height: 1.4285em;
23 | color: rgba(0, 0, 0, 0.87);
24 | font-smoothing: antialiased;
25 | }
26 | .ui.container {
27 | display: block;
28 | max-width: 100% !important;
29 | }
30 | @media only screen and (max-width: 767px) {
31 | .ui.container {
32 | width: auto !important;
33 | margin-left: 1em !important;
34 | margin-right: 1em !important;
35 | }
36 | }
37 | @media only screen and (min-width: 768px) and (max-width: 991px) {
38 | .ui.container {
39 | width: 723px;
40 | margin-left: auto !important;
41 | margin-right: auto !important;
42 | }
43 | }
44 | @media only screen and (min-width: 992px) and (max-width: 1199px) {
45 | .ui.container {
46 | width: 933px;
47 | margin-left: auto !important;
48 | margin-right: auto !important;
49 | }
50 | }
51 | @media only screen and (min-width: 1200px) {
52 | .ui.container {
53 | width: 1127px;
54 | margin-left: auto !important;
55 | margin-right: auto !important;
56 | }
57 | }
58 | .ui.segment {
59 | position: relative;
60 | background: #FFFFFF;
61 | -webkit-box-shadow: 0px 1px 2px 0 rgba(34, 36, 38, 0.15);
62 | box-shadow: 0px 1px 2px 0 rgba(34, 36, 38, 0.15);
63 | margin: 0.5rem 0em;
64 | padding: 0.5em 0.5em;
65 | border-radius: 0.28571429rem;
66 | border: 1px solid rgba(34, 36, 38, 0.15);
67 | text-align: center;
68 | }
69 | .ui.segment:first-child {
70 | margin-top: 0em;
71 | }
72 | .ui.segment:last-child {
73 | margin-bottom: 0em;
74 | }
75 | input {
76 | position: relative;
77 | font-weight: normal;
78 | font-style: normal;
79 | font-size: 12px;
80 | display: -ms-inline-flexbox;
81 | display: inline-flex;
82 | color: rgba(0, 0, 0, 0.87);
83 | padding: 9.5px 14px;
84 | width: 300px;
85 | border-color: #D8D8D8;
86 | }
87 | input[type=text]:focus {
88 | border-color: #D8D8D8;
89 | background: #FAFAFA;
90 | color: rgba(0, 0, 0, 0.87);
91 | -webkit-box-shadow: none;
92 | box-shadow: none;
93 | }
94 | label {
95 | font-size: 12px;
96 | font-weight: 500;
97 | margin-top: 6px;
98 | }
--------------------------------------------------------------------------------
/examples/erc20/dForce/Makefile:
--------------------------------------------------------------------------------
1 | include ../../2020-06.mk
2 |
--------------------------------------------------------------------------------
/examples/erc20/dForce/USDx.xml:
--------------------------------------------------------------------------------
1 |
2 |
4 |
5 |
6 | ]>
7 |
15 |
16 | dForce USDx
17 |
18 |
19 | 0xeb269732ab75A6fD61Ea60b06fE994cD32a83549
20 |
21 |
22 |
23 |
24 |
25 |
26 |
27 |
28 |
29 |
30 | Guide
31 |
32 |
33 | &style;
34 | &guide.en;
35 |
36 |
37 |
38 |
39 |
40 | More info
41 |
42 |
43 | &style;
44 | &moreInfo.en;
45 |
46 |
47 |
48 |
49 |
50 |
51 | 1.3.6.1.4.1.1466.115.121.1.26
52 |
53 |
54 |
55 |
56 |
57 |
58 |
--------------------------------------------------------------------------------
/examples/erc20/dForce/shared.css:
--------------------------------------------------------------------------------
1 | h3 { color: #111; font-family: 'Open Sans', sans-serif; font-size: 20px; font-weight: 300; line-height: 32px; }
2 |
3 | #inputBox {
4 | text-align: center;
5 | }
6 |
7 | html,
8 | body {
9 | height: 100%;
10 | }
11 | html {
12 | font-size: 14px;
13 | }
14 | body {
15 | margin: 0px;
16 | padding: 0px;
17 | overflow-x: hidden;
18 | min-width: 320px;
19 | background: #FFFFFF;
20 | font-family: 'Lato', 'Helvetica Neue', Arial, Helvetica, sans-serif;
21 | font-size: 14px;
22 | line-height: 1.4285em;
23 | color: rgba(0, 0, 0, 0.87);
24 | font-smoothing: antialiased;
25 | }
26 | .ui.container {
27 | display: block;
28 | max-width: 100% !important;
29 | }
30 | @media only screen and (max-width: 767px) {
31 | .ui.container {
32 | width: auto !important;
33 | margin-left: 1em !important;
34 | margin-right: 1em !important;
35 | }
36 | }
37 | @media only screen and (min-width: 768px) and (max-width: 991px) {
38 | .ui.container {
39 | width: 723px;
40 | margin-left: auto !important;
41 | margin-right: auto !important;
42 | }
43 | }
44 | @media only screen and (min-width: 992px) and (max-width: 1199px) {
45 | .ui.container {
46 | width: 933px;
47 | margin-left: auto !important;
48 | margin-right: auto !important;
49 | }
50 | }
51 | @media only screen and (min-width: 1200px) {
52 | .ui.container {
53 | width: 1127px;
54 | margin-left: auto !important;
55 | margin-right: auto !important;
56 | }
57 | }
58 | .ui.segment {
59 | position: relative;
60 | background: #FFFFFF;
61 | -webkit-box-shadow: 0px 1px 2px 0 rgba(34, 36, 38, 0.15);
62 | box-shadow: 0px 1px 2px 0 rgba(34, 36, 38, 0.15);
63 | margin: 0.5rem 0em;
64 | padding: 0.5em 0.5em;
65 | border-radius: 0.28571429rem;
66 | border: 1px solid rgba(34, 36, 38, 0.15);
67 | text-align: center;
68 | }
69 | .ui.segment:first-child {
70 | margin-top: 0em;
71 | }
72 | .ui.segment:last-child {
73 | margin-bottom: 0em;
74 | }
75 | input {
76 | position: relative;
77 | font-weight: normal;
78 | font-style: normal;
79 | font-size: 12px;
80 | display: -ms-inline-flexbox;
81 | display: inline-flex;
82 | color: rgba(0, 0, 0, 0.87);
83 | padding: 9.5px 14px;
84 | width: 300px;
85 | border-color: #D8D8D8;
86 | }
87 | input[type=text]:focus {
88 | border-color: #D8D8D8;
89 | background: #FAFAFA;
90 | color: rgba(0, 0, 0, 0.87);
91 | -webkit-box-shadow: none;
92 | box-shadow: none;
93 | }
94 | label {
95 | font-size: 12px;
96 | font-weight: 500;
97 | margin-top: 6px;
98 | }
--------------------------------------------------------------------------------
/examples/fifa/Makefile:
--------------------------------------------------------------------------------
1 | include ../2020-06.mk
2 |
--------------------------------------------------------------------------------
/examples/fifa/fifa.en.js:
--------------------------------------------------------------------------------
1 | //
111 |
112 |
113 |
114 | ${this.props.numero}x ${this.props.countryA} vs ${this.props.countryB}
115 |
116 |
117 |
118 | ${date} | ${time}
119 |
120 |
121 |
122 | ${this.props.venue} | ${this.props.locality}
123 |
124 |
125 |
126 | ${this.props.category}, M${this.props.match}
127 |
128 |
129 |
130 |
131 | `;
132 | }
133 | }
134 |
135 | web3.tokens.dataChanged = (oldTokens, updatedTokens, tokenCardId) => {
136 | const currentTokenInstance = updatedTokens.currentInstance;
137 | document.getElementById(tokenCardId).innerHTML = new Token(currentTokenInstance).render();
138 | };
139 | //]]>
140 |
--------------------------------------------------------------------------------
/examples/validate.sh:
--------------------------------------------------------------------------------
1 | #!/bin/sh
2 |
3 | if [ $# -eq 0 ]; then
4 | echo Usage:
5 | echo ' $ ./validate.sh directory/filename.xml'
6 | echo which validates the said XML file - a TokenScript file
7 | echo ' '
8 | echo You can do a blanket test of all xml files by:
9 | echo ' $ ./validate.sh */*.xml */*/*.xml'
10 | echo ' '
11 | echo 'You can specify a schema file (with absolute path)'
12 | echo ' $ TOKENSCRIPT_SCHEMA=/home/james/TokenScript-Repo/www/2020/03/tokenscript/tokenscript.xsd ./validate.sh */*.xml */*/*.xml'
13 | fi
14 |
15 | CWD=${PWD}
16 | PASS=TRUE
17 | for i in "$@"
18 | do
19 | # ignore all folders with space in it
20 | echo "$i" | grep ' ' && continue
21 |
22 | if [ -f "${i%.xml}.canonicalized.xml" ]; then
23 | rm "${i%.xml}.canonicalized.xml"
24 | fi
25 |
26 | if [ ${i##*.} != "xml" ]; then
27 | echo "Only accepts .xml file."
28 | exit
29 | fi
30 |
31 | BN=`basename "$i" .xml`
32 |
33 | cd "${i%/*.xml}"
34 |
35 | if make "${BN}.canonicalized.xml" > /dev/null; then
36 | echo "[Valid] : $i"
37 | else
38 | PASS=FALSE
39 | fi
40 |
41 | cd $CWD
42 | ## the following is very important to prevent these XML files being picked up in the next run
43 | if [ -f "${i%.xml}.canonicalized.xml" ]; then
44 | rm "${i%.xml}.canonicalized.xml"
45 | fi
46 | done;
47 | if [ $PASS = FALSE ] ; then exit 1; fi
48 |
--------------------------------------------------------------------------------
/img/readme/tokenscript-examples.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/SmartTokenLabs/TokenScript-Examples/ddfe8425b5d27277aed3f4a15594b23da8caf416/img/readme/tokenscript-examples.jpg
--------------------------------------------------------------------------------
/resources/fast-token-onboarding/README.md:
--------------------------------------------------------------------------------
1 | # AlphaWallet
2 | Verifying your tokens for TokenScript, and thus recognition in AlphaWallet.
3 |
4 | # xmlsectool - xml signing tool
5 | Signing of xml requires xmlsectool:
6 | - Mac: brew install xmlsectool
7 | - Linux/Windows: https://wiki.shibboleth.net/confluence/display/XSTJ2/xmlsectool+V2+Home#xmlsectoolV2Home-ObtainingandUsingxmlsectool
8 |
9 | # TokenScript
10 | Open the relevant erc20 or erc721 canonicalized.xml file, and modify the parameters accordingly:
11 | - Name as it will appear to users (eg CryptoKitty / CryptoKitties):
12 | - `Singular Name `
13 | - `Plural Name `
14 | - Token Name (eg CryptoKitties): ``
15 | - Smart Contract address: `0xYOUR_CONTRACT_ADDRESS_HERE `
16 | - Contract Name (eg CryptoKitties): ` `
17 |
18 | # Signing
19 | A script has been provided for convenience (sign.sh), please open and modify parameters accordingly:
20 | - `NAME='YOUR COMPANY NAME'`
21 | - `KEYSTORE_FILE=./YOUR_KEY_FILE.p12 # of your domain`
22 | - `TOKEN_FILE=erc20.canonicalized.xml # or erc721.canonicalized.xml`
23 | - keyPassword `"YOUR .P12 PASSWORD"`
24 |
25 | # Testing your .tsml
26 | Command: `curl -X POST -F file=@"/full/path/YOUR_TSML_FILE.tsml" https://aw.app/api/v1/verifyXMLDSig`
27 | Success: `{"result":"pass", ...}`
28 |
29 | # You're in!
30 | Please send the resulting .tsml file (signed/certified xml), or get in touch if you have any questions/comments.
31 |
32 | We look forward to sharing your token with our users!
33 | The AlphaWallet Team
34 |
--------------------------------------------------------------------------------
/resources/fast-token-onboarding/erc20.canonicalized.xml:
--------------------------------------------------------------------------------
1 |
8 |
9 |
10 | Token
11 | Tokens
12 |
13 |
17 |
18 |
19 | 0xYOUR_CONTRACT_ADDRESS_HERE
20 |
21 |
22 |
23 |
24 |
25 |
26 |
27 |
28 |
29 |
30 |
31 |
32 |
33 |
34 |
35 |
36 |
37 |
38 |
39 |
40 |
--------------------------------------------------------------------------------
/resources/fast-token-onboarding/erc721.canonicalized.xml:
--------------------------------------------------------------------------------
1 |
8 |
9 |
10 | Token
11 | Tokens
12 |
13 |
17 |
18 |
19 | 0xYOUR_CONTRACT_ADDRESS_HERE
20 |
21 |
22 |
23 |
24 |
25 |
26 |
27 |
28 |
29 |
30 |
31 |
32 |
33 |
34 |
35 |
36 |
37 |
38 |
39 |
40 |
--------------------------------------------------------------------------------
/resources/fast-token-onboarding/sign.sh:
--------------------------------------------------------------------------------
1 | #!/bin/bash
2 | NAME='YOUR COMPANY NAME'
3 | KEYSTORE_FILE=./YOUR_KEY_FILE.p12 # of your domain
4 | # set .p12 password in last line of xmlsectool command below
5 |
6 | TOKEN_FILE=USDx.xml # or erc721.canonicalized.xml
7 | SIGNATURE_ALGORITHM=rsa-sha256 # or ecdsa-sha256
8 |
9 | echo "Signing xml with $KEYSTORE_FILE..."
10 | xmlsectool --sign --keyInfoKeyName "$NAME" --digest SHA-256 \
11 | --signatureAlgorithm http://www.w3.org/2001/04/xmldsig-more#$SIGNATURE_ALGORITHM \
12 | --inFile $TOKEN_FILE --outFile "$NAME".tsml --keystore $KEYSTORE_FILE --keystoreType PKCS12 \
13 | --key 1 --keyPassword "YOUR .P12 PASSWORD" --signaturePosition LAST
14 |
--------------------------------------------------------------------------------
/tutorial/img/QR_EntryToken_ETH_address.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/SmartTokenLabs/TokenScript-Examples/ddfe8425b5d27277aed3f4a15594b23da8caf416/tutorial/img/QR_EntryToken_ETH_address.png
--------------------------------------------------------------------------------
/tutorial/step-1-forming-the-layout.md:
--------------------------------------------------------------------------------
1 | ## Forming the layout in TokenScript
2 |
3 | ### Resources
4 | All the files to complete this tutorial are contained in the example nft directory [here](https://github.com/AlphaWallet/TokenScript-Examples/tree/master/examples/EntryToken).
5 |
6 | ### Adding your layout
7 | Since TokenScript is essentially an XML dialect, it is possible to plug in your existing layout files in HTML, CSS and JS. To begin, simply clone this repo and take a look at the token.en.shtml and enter.en.shtml files inside the example NFT directory.
8 |
9 | $ git clone https://github.com/AlphaWallet/TokenScript-Examples && cd TokenScript-Examples/examples/EntryToken
10 |
11 | This demo will go through an example token which allows you to enter fake Satoshi's house with an NFT token and a challenge response off chain.
12 |
13 | ## View iconified and regular layout
14 | In our wallet, you can render both an iconified and regular view. The iconified view is shown
15 | in the wallet token card and gives a summary of all the tokens you have within a contract.
16 |
17 | It looks something like this:
18 |
19 | [ ](https://github.com/AlphaWallet/TokenScript/blob/master/doc/img/iconified-view.jpeg)
20 |
21 |
22 |
23 | The regular view is displayed after a user clicks on a particular token and it shows all the
24 | functions available to the user as well as a more in depth view of the token. It looks something like this:
25 |
26 | [ ](https://github.com/AlphaWallet/TokenScript/blob/master/doc/img/regular-view.jpeg)
27 |
--------------------------------------------------------------------------------
/tutorial/step-2-assembling-the-XML-file.md:
--------------------------------------------------------------------------------
1 | ## Assembling the XML File
2 |
3 | So, now that you have your token.en.shtml, enter.en.shtml and shared.css file, we are now ready to continue on to the XML file. This file will define the function calls, how we define the meaning of our tokens, off chain functionality of the token (in our example, it would be entering a building with a token via a challenge response) and plugging in the layout.
4 |
5 | Since NFTs can encode information inside their 32 bytes such as genes or what time the event is supposed to be held, we can use TokenScript to interpret the meaning of such tokens so that the user is given context. Furthermore, it is also possible to define logic which queries the smart contract for additional information, within the context of the token id itself.
6 |
7 | To inspect the example EntryToken.xml file we have for you, simply:
8 |
9 | $ cd examples/EntryToken && cat EntryToken.xml
10 |
11 | We have set up contracts on mainnet, ropsten, kovan & rinkeby that will always return a balance of two NFTs. You can use these to test against the sample TokenScript provided in the tutorial examples.
12 |
13 | ### Creating your own XML file or editing ours
14 |
15 | You can make your own changes to the sample XML file in the examples directory and change it to match whatever you like. Once you drag and drop it in the next step, you will be able to see the changes reload and since there is a hardcoded balance of two NFTs, you will be able to play around with it.
16 |
--------------------------------------------------------------------------------
/tutorial/step-3-debugging-and-testing.md:
--------------------------------------------------------------------------------
1 | ## Debugging and testing on iOS and Android
2 | So you now have your completed .xml and .shtml files, excellent! You can now merge the files together and drop them for testing in AlphaWallet iOS and Android. To merge the files together run 'make EntryToken.canonicalized.xml' which will validate the files and put them all together. Since we have hardcoded the balances for this contract, you will be able to see them immediately in your wallet after you add them by clicking the + button in the top-right of the wallet tab, and entering the contract address.
3 |
4 | For Ethereum mainnet:
5 |
6 | 
7 | '0x63cCEF733a093E5Bd773b41C96D3eCE361464942'
8 |
9 | Or your choice of testnet (see the `ts:address` tag in EntryToken.xml for each available network's address).
10 |
11 | ** We have uploaded this example xml file to our repo server, this means you do not have to drag and drop it to the device unless you are planning to edit it or create your own **
12 |
13 | ### Get AlphaWallet iOS or Android
14 | [ ](https://itunes.apple.com/us/app/alphawallet/id1358230430?ls=1&mt=8) [ ](https://play.google.com/store/apps/details?id=io.stormbird.wallet&hl=en_US)
15 |
16 | ### Clone the source
17 | Go to either [iOS](https://github.com/AlphaWallet/alpha-wallet-ios) or [Android](https://github.com/AlphaWallet/alpha-wallet-android) source repo
18 |
19 | ### Debugging on iOS
20 | After cloning the source code you can run it with either the emulator or your own phone via xcode or AppCode. If you are using the emulator, simply copy the path it prints when loading up in xcode and cd into it. Once there you shoud see a directory called 'assetDefinitionsOverrides', simply drop the file into this directory.
21 |
22 | If you are using your real device, simply airdrop the canonicalized.xml file or drop the xml file with its three layout files (shared.css, enter.en.shtml & token.en.shtml).
23 |
24 | ### Debugging on Android
25 | As with iOS you can either use your own device or the emulator. Run on Android Studio/Intellij and use your device or the emulator. In the AlphaWallet settings choose 'enable dev override', allow the app access to file structure then drag and drop the file into the AlphaWallet directory at root or upload to sdcard/AlphaWallet using the Device File Explorer. If the 'enable dev override' is not chosen inside the app, it will not be able to pick up files in this directory.
26 |
27 |
--------------------------------------------------------------------------------
/tutorial/step-4-signing-and-publishing.md:
--------------------------------------------------------------------------------
1 | ## Signing and publishing your TokenScript file
2 |
3 | To publish your Tokenscript, it has to be signed.
4 |
5 | Currently, a TokenScript is signed by an SSL key. For example, a TokenScript signed by the SSL key for the domain name shong.wang is displayed as "reputation relies on shong.wang" when rendered. To make your first signing easy, we provided both the signing key and needed SSL certificates.
6 |
7 | ** Dapps like DAI will have a signature from MakerDAO.com's SSL certificate; this gives the user peace of mind that the TokenScript is actually intended by the issuer. The file includes all the relevant code and therefore cannot be tampered with, as that would break the signature verification. **
8 |
9 | ### Install the tools
10 |
11 | All XML signing tools should work, but we will we demonstrate here with xmlsectool.
12 |
13 | First, check that you have the right tool installed. Say, in OS X with brew installed:
14 |
15 | $ brew install xmlsectool
16 |
17 | If your package manager doesn't provide xmlsectool, you can download from its [home page](https://wiki.shibboleth.net/confluence/display/XSTJ2/xmlsectool+V2+Home) and install it manually.
18 |
19 | From here I'll assume your system supports make. If not, it's easier to wait for the tutorial on how to sign with GUI, which we will produce based on [Oxygen's document](https://www.oxygenxml.com/doc/versions/21.0/ug-editor/topics/signing-files.html#signing-files) by late 2019.
20 |
21 | If you installed xmlsectool manually, for example to `/opt/xmlsectool-2.0.0/`, you will need to change the first line of the MakeFile to this:
22 |
23 | XMLSECTOOL=/opt/xmlsectool-2.0.0/xmlsectool.sh
24 |
25 | Having that sorted out, please also install xmlstarlet and xmllint
26 |
27 | $ brew install xmlstarlet xmllint
28 |
29 | Now we have all the tools ready.
30 |
31 | ### Validate the test TokenScript
32 |
33 | Do a `make`. It will validate EntryToken.xml. It should pass if you haven't changed it.
34 |
35 | $ make EntryToken.canonicalized.xml
36 | # XML Canonicalization
37 | xmlstarlet c14n EntryToken.xml > EntryToken.canonicalized.xml
38 | # XML Validation
39 | -xmlstarlet val --xsd http://tokenscript.org/2019/10/tokenscript/tokenscript.xsd $@ || (mv $@ $@.INVALID; xmllint --noout --schema http://tokenscript.org/2019/10/tokenscript/tokenscript.xsd $@.INVALID)
40 |
41 | ** If the file has errors, it will produce a file named EntryToken.canonicalized.xml.FAILED which you can use for debugging **
42 |
43 | ### Using your SSL key
44 | To sign a TokenScript file you must retrieve the relevant SSL key that corresponds to the Token you are making a TokenScript for. e.g. `cdp.makerdao.com` for DAI related TokenScripts.
45 |
46 | This file must be converted to .p12 for signing and since most services will give you your file in .pem, here are the steps using OpenSSL to convert it from pem to p12.
47 |
48 | $ openssl pkcs12 -export -out keystore.p12 -inkey pathToYourPrivateKey.pem -in pathToYourCert.pem -certfile pathToYourChain.pem
49 |
50 | This command will ask for you to provide a password to encrypt the .p12, you will need to use this password again for the step below. The output of this command will be `keystore.p12`.
51 |
52 | If you do not want to use your own key for this tutorial, simply skip this step and go to the next which uses the sample key `shong.wang`.
53 |
54 | ### Sign the test TokenScript
55 |
56 | We prepared the signing key and SSL certificates in ssl directory. If you use yours, remember to replace their references in the Makefile or use the command below with your encrypted .p12.
57 |
58 | Run `make` with `EntryToken.tsml`
59 |
60 | $ make EntryToken.tsml
61 | /opt/xmlsectool-2.0.0/xmlsectool.sh --sign --keyInfoKeyName 'Shong Wang' --digest SHA-256 --signatureAlgorithm http://www.w3.org/2001/04/xmldsig-more#rsa-sha256 --inFile EntryToken.canonicalized.xml --outFile EntryToken.tsml --key ssl/shong.wang.key --certificate ssl/shong.wang.certs
62 | INFO XMLSecTool - Reading XML document from file 'EntryToken.canonicalized.xml'
63 | INFO XMLSecTool - XML document parsed and is well-formed.
64 | INFO XMLSecTool - XML document successfully signed
65 | INFO XMLSecTool - XML document written to file /home/weiwu/IdeaProjects/TokenScript/examples/ticket/EntryToken.tsml
66 | # removing the canonicalized created for validation
67 | rm EntryToken.canonicalized.xml
68 |
69 | And now you get a signed TokenScript EntryToken.tsml which is ready to be published. This file can also be dropped to the iOS or Android app as described in the previous step.
70 |
71 | If you are signing with your own key from the step above, run:
72 |
73 | $ make EntryToken.tsml KEYSTORE=keystore.p12 KEYPASSWORD=YourPassword
74 |
75 | ### Publishing your TokenScript
76 |
77 | To test your current .tsml file, you can simply drop in onto your device with the instructions provided by step 3. As of now, we are serving signed tsml files from a server that the device can pull from to load into it's corresponding token card.
78 |
79 | If you would like to publish your own tsml file to run on this server, create a PR in this [repo](https://github.com/AlphaWallet/TokenScript-Repo) and we will review it.
80 |
--------------------------------------------------------------------------------
/tutorial/tutorial-files/Coin.sol:
--------------------------------------------------------------------------------
1 |
2 | // Specifies that the source code is for a version
3 | // of Solidity greater than 0.5.0
4 | pragma solidity >=0.5.0 <0.7.0;
5 |
6 | // A contract is a collection of functions and data (its state)
7 | // that resides at a specific address on the Ethereum blockchain.
8 | contract Coin {
9 | // The keyword "public" makes variables accessible from outside a contract
10 | // and creates a function that other contracts or SDKs can call to access the value
11 |
12 | string public name = "Coin"; //fancy name: eg Simon Bucks
13 | uint256 public decimals = 18; //How many decimals to show.
14 | string public symbol = "COIN"; //An identifier: eg SBX
15 |
16 | // Returns balance of an address
17 | function balanceOf(address addr) public view returns (uint) {
18 | return balances[addr];
19 | }
20 |
21 | // An address stores addresses of contracts or external (user) accounts
22 | address public minter;
23 |
24 | // A mapping lets you create complex custom data types.
25 | // This mapping assigns an unsigned integer to an address
26 | // and is also a public variable.
27 | mapping (address => uint) public balances;
28 |
29 | // Events allow Ethereum clients to react to specific
30 | // contract changes you declare.
31 | // This defines the event and it is sent later
32 | event Sent(address from, address to, uint amount);
33 |
34 | // A special function only run during the creation of the contract
35 | constructor() public {
36 | // Uses the special msg global variable to store the
37 | // address of the contract creator
38 | minter = msg.sender;
39 | }
40 |
41 | // Sends an amount of newly created coins to an address
42 | function mint(address receiver, uint amount) public {
43 | // require statements define conditions that must pass
44 | // before state is changed.
45 | // If it fails (equals false), an exception is triggered
46 | // and reverts all modifications to state from the current call
47 |
48 | // Can only be called by the contract creator
49 | require(msg.sender == minter);
50 |
51 | // Ensures a maximum amount of tokens
52 | require(amount < 1e60);
53 | balances[receiver] += amount;
54 | }
55 |
56 | // Sends an amount of existing coins
57 | // from any caller to an address
58 | function transfer(address receiver, uint amount) public {
59 | // The sender must have enough coins to send
60 | require(amount <= balances[msg.sender], "Insufficient balance.");
61 | // Adjust balances
62 | balances[msg.sender] -= amount;
63 | balances[receiver] += amount;
64 | // Emit event defined earlier
65 | emit Sent(msg.sender, receiver, amount);
66 | }
67 | }
68 |
--------------------------------------------------------------------------------
/tutorial/tutorial-files/Coin.xml:
--------------------------------------------------------------------------------
1 |
2 |
4 |
5 | ]>
6 |
13 |
14 | Coin
15 |
16 |
17 | 0x9E9002A92e91f66fe7F94D2394B3AF68eb886f39
18 |
19 |
20 |
21 |
22 |
23 |
24 |
25 | Mint
26 |
27 |
28 |
29 | Address to receive created tokens
30 |
31 |
32 |
33 |
34 |
35 |
36 |
37 | Amount to create
38 |
39 |
40 |
42 |
43 |
44 |
45 |
46 |
47 |
48 |
49 |
50 |
51 |
52 |
53 |
54 | &mint.en;
55 |
56 |
57 |
58 |
59 |
60 | Balance
61 |
62 |
63 |
64 |
65 |
66 |
67 |
68 |
69 |
70 |
71 |
72 |
--------------------------------------------------------------------------------
/tutorial/tutorial-files/Makefile:
--------------------------------------------------------------------------------
1 | ifeq ($(TOKENSCRIPT_SCHEMA),)
2 | TOKENSCRIPT_SCHEMA=http://tokenscript.org/2019/10/tokenscript/tokenscript.xsd
3 | endif
4 |
5 | ifeq ($(XMLSECTOOL),)
6 | XMLSECTOOL=xmlsectool
7 | endif
8 |
9 | ifeq ($(XMLLINT),)
10 | XMLLINT=xmllint
11 | endif
12 |
13 | ifeq ($(XMLSEC),)
14 | XMLSEC=xmlsec1 # xmlsec for Linux/Windows
15 | endif
16 |
17 |
18 | ifndef KEY
19 | KEY=1
20 | endif
21 |
22 | SIGNATURE_ALGORITHM=rsa-sha256
23 |
24 | help:
25 | # Needs a target, example: $$ make EntryToken.canonicalized.xml
26 | #
27 | # Let's say you have a TokenScript "EntryToken.xml"
28 | # - to validate and canonicalize, add 'canonicalized' in the filename
29 | @echo $$ make EntryToken.canonicalized.xml
30 | # - to sign, use tsml as file extension:
31 | @echo $$ make EntryToken.tsml
32 |
33 | %.canonicalized.xml : %.xml
34 | # XML canonicalization and validation against TS schema
35 | $(XMLLINT) --c14n $^ > $@ && \
36 | $(XMLLINT) --noout --schema $(TOKENSCRIPT_SCHEMA) $@ || \
37 | (mv $@ $@.TEST && exit 1)
38 |
39 | %.tsml: %.canonicalized.xml
40 | ifeq (,$(KEYPASSWORD))
41 | $(error KEYPASSWORD is not set)
42 | endif
43 | ifeq (,$(KEYSTORE))
44 | @echo ---------------- Keystore missing. Try this ----------------
45 | @echo $$ make KEYSTORE=shong.wang.p12 KEYPASSWORD=shong.wang KEYINFO='"Shong Wang"' $@
46 | @echo replace it with your .p12 file and your password
47 | rm $^
48 | else
49 | # Signing with xmlsec requires original .xml file to contain the Signature tag.
50 | # $(XMLSEC) sign --pkcs12:"$(KEYINFO)" $(KEYSTORE) --pwd "$(KEYPASSWORD)" --output $@ $^
51 | # For now use xmlsectool...
52 | $(XMLSECTOOL) --sign --keyInfoKeyName "$(KEYINFO)" --digest SHA-256 --signatureAlgorithm http://www.w3.org/2001/04/xmldsig-more#$(SIGNATURE_ALGORITHM) --inFile $^ --outFile $@ --keystore $(KEYSTORE) --keystoreType PKCS12 --key $(KEY) --keyPassword "$(KEYPASSWORD)" --signaturePosition LAST
53 | # removing the canonicalized created for validation
54 | rm $^
55 | endif
56 |
--------------------------------------------------------------------------------
/tutorial/tutorial-files/app.css:
--------------------------------------------------------------------------------
1 | body {
2 | background-color: #725BA4;
3 | color: #FCE8DF;
4 | font-family: 'Gill Sans', 'Gill Sans MT', Calibri, 'Trebuchet MS', sans-serif;
5 | text-align: center;
6 | }
--------------------------------------------------------------------------------
/tutorial/tutorial-files/mint.shtml:
--------------------------------------------------------------------------------
1 |
29 |
30 |
--------------------------------------------------------------------------------