-
Notifications
You must be signed in to change notification settings - Fork 71
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #275 from AlphaWallet/UEFA
first sprint of UEFA tsml ticket
- Loading branch information
Showing
4 changed files
with
461 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,38 @@ | ||
XMLSECTOOL=xmlsectool | ||
KEYSTORE= | ||
KEY=1 | ||
KEYPASSWORD= | ||
SIGNATURE_ALGORITHM=rsa-sha256 | ||
|
||
help: | ||
# Needs a target, example: $$ make EntryToken.canonicalized.xml | ||
# | ||
# Let's say you have a TokenScript "EntryToken.xml" | ||
#- to validate and canonicalize, add 'canonicalized' in the filename | ||
@echo $$ make EntryToken.canonicalized.xml | ||
# - to sign, use tsml as file extension: | ||
@echo $$ make EntryToken.tsml | ||
|
||
%.canonicalized.xml : %.xml | ||
# xmlsectool canonicalises automatically when needed, but leaving an xml:base attribute which creates trouble later. | ||
# xmlstarlet does it neatly | ||
# XML Canonicalization | ||
xmlstarlet c14n $^ > $@ | ||
# xmlsectool validates too, albeit adding xml:base with breaks schema. Example: | ||
# JVMOPTS=-Djavax.xml.accessExternalDTD=all /opt/xmlsectool-2.0.0/xmlsectool.sh --validateSchema --xsd --schemaDirectory ../../schema --inFile $^ | ||
# XML Validation | ||
# if INVALID, run validation again with xmllint to get meaningful error | ||
# then delete the canonicalized file | ||
-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) | ||
|
||
%.tsml: %.canonicalized.xml | ||
ifeq (,$(KEYSTORE)) | ||
@echo ---------------- Keystore missing. Try this ---------------- | ||
@echo $$ make KEYSTORE=shong.wang.p12 KEYPASSWORD=shong.wang $@ | ||
@echo replace it with your .p12 file and your password | ||
rm $^ | ||
else | ||
$(XMLSECTOOL) --sign --keyInfoKeyName 'Shong Wang' --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 | ||
# removing the canonicalized created for validation | ||
rm $^ | ||
endif |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,147 @@ | ||
<script type="text/javascript"> | ||
(function() { | ||
'use strict' | ||
|
||
function GeneralizedTime(generalizedTime) { | ||
this.rawData = generalizedTime; | ||
} | ||
|
||
GeneralizedTime.prototype.getYear = function () { | ||
return parseInt(this.rawData.substring(0, 4), 10); | ||
} | ||
|
||
GeneralizedTime.prototype.getMonth = function () { | ||
return parseInt(this.rawData.substring(4, 6), 10) - 1; | ||
} | ||
|
||
GeneralizedTime.prototype.getDay = function () { | ||
return parseInt(this.rawData.substring(6, 8), 10) | ||
}, | ||
|
||
GeneralizedTime.prototype.getHours = function () { | ||
return parseInt(this.rawData.substring(8, 10), 10) | ||
}, | ||
|
||
GeneralizedTime.prototype.getMinutes = function () { | ||
var minutes = parseInt(this.rawData.substring(10, 12), 10) | ||
if (minutes) return minutes | ||
return 0 | ||
}, | ||
|
||
GeneralizedTime.prototype.getSeconds = function () { | ||
var seconds = parseInt(this.rawData.substring(12, 14), 10) | ||
if (seconds) return seconds | ||
return 0 | ||
}, | ||
|
||
GeneralizedTime.prototype.getMilliseconds = function () { | ||
var startIdx | ||
if (time.indexOf('.') !== -1) { | ||
startIdx = this.rawData.indexOf('.') + 1 | ||
} else if (time.indexOf(',') !== -1) { | ||
startIdx = this.rawData.indexOf(',') + 1 | ||
} else { | ||
return 0 | ||
} | ||
|
||
var stopIdx = time.length - 1 | ||
var fraction = '0' + '.' + time.substring(startIdx, stopIdx) | ||
var ms = parseFloat(fraction) * 1000 | ||
return ms | ||
}, | ||
|
||
GeneralizedTime.prototype.getTimeZone = function () { | ||
let time = this.rawData; | ||
var length = time.length | ||
var symbolIdx | ||
if (time.charAt(length - 1 ) === 'Z') return 0 | ||
if (time.indexOf('+') !== -1) { | ||
symbolIdx = time.indexOf('+') | ||
} else if (time.indexOf('-') !== -1) { | ||
symbolIdx = time.indexOf('-') | ||
} else { | ||
return NaN | ||
} | ||
|
||
var minutes = time.substring(symbolIdx + 2) | ||
var hours = time.substring(symbolIdx + 1, symbolIdx + 2) | ||
var one = (time.charAt(symbolIdx) === '+') ? 1 : -1 | ||
|
||
var intHr = one * parseInt(hours, 10) * 60 * 60 * 1000 | ||
var intMin = one * parseInt(minutes, 10) * 60 * 1000 | ||
var ms = minutes ? intHr + intMin : intHr | ||
return ms | ||
} | ||
|
||
if (typeof exports === 'object') { | ||
module.exports = GeneralizedTime | ||
} else if (typeof define === 'function' && define.amd) { | ||
define(GeneralizedTime) | ||
} else { | ||
window.GeneralizedTime = GeneralizedTime | ||
} | ||
}()) | ||
</script> | ||
<script type="text/javascript"><![CDATA[ | ||
class Token { | ||
constructor(tokenInstance) { | ||
this.props = tokenInstance | ||
} | ||
|
||
formatGeneralizedTimeToDate(str) { | ||
const d = new GeneralizedTime(str) | ||
return new Date(d.getYear(), d.getMonth(), d.getDay(), d.getHours(), d.getMinutes(), d.getSeconds()).toLocaleDateString() | ||
} | ||
formatGeneralizedTimeToTime(str) { | ||
const d = new GeneralizedTime(str) | ||
return new Date(d.getYear(), d.getMonth(), d.getDay(), d.getHours(), d.getMinutes(), d.getSeconds()).toLocaleTimeString([], {hour: '2-digit', minute:'2-digit'}) | ||
} | ||
|
||
render() { | ||
let time; | ||
let date; | ||
if (this.props.time == null) { | ||
time = "" | ||
date = "" | ||
} else { | ||
time = this.formatGeneralizedTimeToTime(this.props.time.generalizedTime) | ||
date = this.props.time == null ? "": this.formatGeneralizedTimeToDate(this.props.time.generalizedTime) | ||
} | ||
let redeemedMessage = "(Not redeemed)" | ||
if(this.props.redeemed) { | ||
redeemedMessage = "(Redeemed)" | ||
} | ||
return `<div> | ||
<div> | ||
<span class="tbml-count">x${this.props._count}</span> | ||
<span class="tbml-category">${this.props.category}</span> | ||
<span class="tbml-category">${redeemedMessage}</span> | ||
</div> | ||
<div> | ||
<span class="tbml-venue">${this.props.venue}</span> | ||
</div> | ||
<div style="margin: 0px; padding:0px; clear: both; height: 6px"> | ||
| ||
</div> | ||
<div> | ||
<img src="" class="data-icon"/> | ||
<span class="tbml-date">${date}</span> | ||
<img src="" class="data-icon"/> | ||
<span class="tbml-date">${this.props.countryA}-${this.props.countryB}</span> | ||
<img src="" class="data-icon"/> | ||
<span class="tbml-date">M${this.props.match}</span> | ||
</div> | ||
<div> | ||
<span class="tbml-time">${time}, ${this.props.locality}</span> | ||
</div> | ||
</div>`; | ||
} | ||
} | ||
|
||
web3.tokens.dataChanged = (oldTokens, updatedTokens) => { | ||
const currentTokenInstance = web3.tokens.data.currentInstance; | ||
const domHtml = new Token(currentTokenInstance).render(); | ||
document.getElementById('root').innerHTML = domHtml | ||
}; | ||
]]></script> | ||
<div id="root"></div> |
Oops, something went wrong.