blockchainethereumblockchain-walleterc20erc721walletxdaidappdecentralizederc1155erc875iosswifttokens
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
1348 lines
90 KiB
1348 lines
90 KiB
<?xml version="1.0" encoding="UTF-8" standalone="no"?><ts:token xmlns:ts="http://tokenscript.org/2020/06/tokenscript" xmlns:asnx="urn:ietf:params:xml:ns:asnx" xmlns:ethereum="urn:ethereum:constantinople" xmlns:xhtml="http://www.w3.org/1999/xhtml" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" custodian="false" xsi:schemaLocation="http://tokenscript.org/2020/06/tokenscript http://tokenscript.org/2020/06/tokenscript.xsd">
|
|
|
|
<asnx:module name="ERC20-Events">
|
|
<namedType name="MintOnDeposit">
|
|
<type>
|
|
<sequence>
|
|
<element ethereum:indexed="true" ethereum:type="address" name="_fromMinter"/>
|
|
<element ethereum:indexed="false" ethereum:type="uint256" name="_valueMinted"/>
|
|
<element ethereum:indexed="false" ethereum:type="uint256" name="_fromBalanceIncreaseMinted"/>
|
|
<element ethereum:indexed="false" ethereum:type="uint256" name="_fromIndexMinted"/>
|
|
</sequence>
|
|
</type>
|
|
</namedType>
|
|
<namedType name="Borrow">
|
|
<type>
|
|
<sequence>
|
|
<element ethereum:indexed="true" ethereum:type="address" name="_reserve"/>
|
|
<element ethereum:indexed="true" ethereum:type="address" name="_user"/>
|
|
<element ethereum:indexed="false" ethereum:type="uint256" name="_amount"/>
|
|
<element ethereum:indexed="false" ethereum:type="uint256" name="_borrowRateMode"/>
|
|
<element ethereum:indexed="false" ethereum:type="uint256" name="_borrowRate"/>
|
|
<element ethereum:indexed="false" ethereum:type="uint256" name="_originationFee"/>
|
|
<element ethereum:indexed="false" ethereum:type="uint256" name="_borrowBalanceIncrease"/>
|
|
<element ethereum:indexed="true" ethereum:type="uint16" name="_referral"/>
|
|
<element ethereum:indexed="false" ethereum:type="uint256" name="_timestamp"/>
|
|
</sequence>
|
|
</type>
|
|
</namedType>
|
|
<namedType name="Redeem">
|
|
<type>
|
|
<sequence>
|
|
<element ethereum:indexed="true" ethereum:type="address" name="_fromRedeemer"/>
|
|
<element ethereum:indexed="false" ethereum:type="uint256" name="_valueRedeemed"/>
|
|
<element ethereum:indexed="false" ethereum:type="uint256" name="_fromBalanceIncreaseRedeemed"/>
|
|
<element ethereum:indexed="false" ethereum:type="uint256" name="_fromIndexRedeemed"/>
|
|
</sequence>
|
|
</type>
|
|
</namedType>
|
|
<namedType name="Transfer">
|
|
<type>
|
|
<sequence>
|
|
<element ethereum:indexed="true" ethereum:type="address" name="from"/>
|
|
<element ethereum:indexed="true" ethereum:type="address" name="to"/>
|
|
<element ethereum:indexed="false" ethereum:type="uint256" name="amount"/>
|
|
</sequence>
|
|
</type>
|
|
</namedType>
|
|
</asnx:module>
|
|
|
|
<ts:label>
|
|
<ts:string xml:lang="en">aETH</ts:string>
|
|
</ts:label>
|
|
|
|
<ts:contract name="balance">
|
|
<ts:address network="1">0xb8c9fc923e67da6d7979bf2c290bd1df9c512bfa</ts:address>
|
|
</ts:contract>
|
|
<ts:contract name="AAVEGetters">
|
|
<ts:address network="1">0x38ba1173f498f7a89ac474edba1d587cc1ab021d</ts:address>
|
|
</ts:contract>
|
|
<ts:contract name="PriceOracle">
|
|
<ts:address network="1">0x76B47460d7F7c5222cFb6b6A75615ab10895DDe4</ts:address>
|
|
</ts:contract>
|
|
<ts:contract interface="erc20" name="aETH">
|
|
<ts:address network="1">0x3a3a65aab0dd2a17e3f1947ba16138cd37d08c04</ts:address>
|
|
</ts:contract>
|
|
<ts:contract name="LendingPoolProvider">
|
|
<ts:address network="1">0x24a42fD28C976A61Df5D00D0599C34c4f90748c8</ts:address>
|
|
</ts:contract>
|
|
<ts:contract name="AAVELendingPool">
|
|
<ts:address network="1">0x398eC7346DcD622eDc5ae82352F02bE94C62d119</ts:address>
|
|
</ts:contract>
|
|
<ts:contract name="AAVELendingPoolCore">
|
|
<ts:address network="1">0x3dfd23A6c5E8BbcFc9581d2E864a68feb6a076d3</ts:address>
|
|
</ts:contract>
|
|
|
|
<ts:origins>
|
|
<ts:ethereum contract="aETH"/>
|
|
</ts:origins>
|
|
|
|
<ts:cards>
|
|
<ts:card type="action">
|
|
<ts:label>
|
|
<ts:string xml:lang="en">Withdraw ETH from Aave</ts:string>
|
|
</ts:label>
|
|
<ts:attribute name="redeemAmount">
|
|
<ts:type><ts:syntax>1.3.6.1.4.1.1466.115.121.1.36</ts:syntax></ts:type>
|
|
<ts:label>
|
|
<ts:string xml:lang="en">Amount to withdraw</ts:string>
|
|
</ts:label>
|
|
<ts:origins>
|
|
<ts:user-entry as="e8"/>
|
|
</ts:origins>
|
|
</ts:attribute>
|
|
<ts:transaction>
|
|
<ethereum:transaction as="uint" contract="aETH" function="redeem">
|
|
<ts:data>
|
|
<ts:uint256 ref="redeemAmount"/>
|
|
</ts:data>
|
|
</ethereum:transaction>
|
|
</ts:transaction>
|
|
<ts:view xml:lang="en">
|
|
<xhtml:style type="text/css">.separator {
|
|
width: 100%;
|
|
height: 1px;
|
|
background-color: #e9e9e9;
|
|
margin-top: 7.5%;
|
|
}
|
|
|
|
.action {
|
|
height: 50px;
|
|
}
|
|
|
|
body{
|
|
margin-top: 0;
|
|
}
|
|
|
|
h1 {
|
|
margin-top: 0;
|
|
line-height: 2;
|
|
background-color: #fbfbfb;
|
|
border-bottom: thin solid rgb(235,235,235);
|
|
text-align: left;
|
|
font-variant: all-small-caps;
|
|
}
|
|
|
|
h2 {
|
|
float: left;
|
|
margin-top: 0;
|
|
margin-bottom: 0;
|
|
}
|
|
|
|
p.hint {
|
|
clear: left;
|
|
}
|
|
|
|
input {
|
|
float: right;
|
|
font-size: x-large;
|
|
border: none;
|
|
line-height: 40px;
|
|
text-align: right;
|
|
width: 5ex;
|
|
}
|
|
|
|
h2 img {
|
|
vertical-align: middle;
|
|
}
|
|
|
|
.action {
|
|
font-family: SourceSansPro, sans-serif;
|
|
}
|
|
|
|
.enable.action {
|
|
font-size: large;
|
|
text-align: center;
|
|
margin-left: 8%;
|
|
margin-right: 8%;
|
|
margin-top: 35%;
|
|
}
|
|
|
|
.enable.action img {
|
|
padding-bottom: 40px;
|
|
}
|
|
|
|
.titleAction {
|
|
width: 272px;
|
|
height: 24px;
|
|
font-size: 15px;
|
|
font-weight: 600;
|
|
font-stretch: normal;
|
|
font-style: normal;
|
|
line-height: 1.67;
|
|
letter-spacing: normal;
|
|
color: #727272;
|
|
}
|
|
|
|
.detailsTitle {
|
|
width: 246px;
|
|
height: 41px;
|
|
font-family: SourceSansPro-Semibold, sans-serif;
|
|
font-size: 24px;
|
|
font-weight: bold;
|
|
font-stretch: normal;
|
|
font-style: normal;
|
|
line-height: 1.71;
|
|
letter-spacing: normal;
|
|
color: black;
|
|
}
|
|
|
|
table {
|
|
margin-top: 1em;
|
|
width: 100%;
|
|
border-collapse: collapse;
|
|
}
|
|
|
|
table caption {
|
|
font-weight: bold;
|
|
font-size: x-large;
|
|
line-height: 2;
|
|
text-align: left;
|
|
}
|
|
|
|
table th {
|
|
font-weight: normal; /* Tomek likes to deemphasize field names */
|
|
text-align: left;
|
|
line-height: 3;
|
|
}
|
|
|
|
table td {
|
|
text-align: right;
|
|
font-weight: bold;
|
|
font-size: large;
|
|
line-height: 3;
|
|
}
|
|
|
|
table tr {
|
|
border-top: 1px solid #727272;
|
|
}
|
|
|
|
table tr:last-child {
|
|
border-bottom: 1px solid #727272;
|
|
}
|
|
</xhtml:style>
|
|
<xhtml:script type="text/javascript">//
|
|
class Token {
|
|
|
|
constructor(token, card) {
|
|
this.token = token;
|
|
this.card = card;
|
|
}
|
|
|
|
render() {
|
|
const decimals18 = 1e+18;
|
|
let aTokenBalance = (this.token.aTokenBalance / decimals18).toFixed(2);
|
|
let totalBorrows = (this.token.totalBorrows / decimals18).toFixed(2);
|
|
let withdrawable = (this.token.availableBorrowsETH / decimals18);
|
|
//if you have other assets that add to your collateral, your withdrawable could be larger than your aETH balance
|
|
if(withdrawable > aTokenBalance) {
|
|
withdrawable = aTokenBalance;
|
|
}
|
|
|
|
return `<div class="withdraw action">
|
|
<h1>Withdraw</h1>
|
|
<h2><img src=""></h2>
|
|
<input id="redeemAmount" type="number" placeholder="0">
|
|
<p class="hint">Available to withdraw ${withdrawable.toFixed(3)} ETH</p>
|
|
<table>
|
|
<caption>Deposits</caption>
|
|
<tbody>
|
|
<tr>
|
|
<th>Total Deposited + Interest </th>
|
|
<td>${aTokenBalance}</td>
|
|
</tr>
|
|
<tr>
|
|
<th>Borrowed</th>
|
|
<td>${totalBorrows} ETH</td>
|
|
</tr>
|
|
<tr>
|
|
<th>Available to withdraw</th>
|
|
<td>${withdrawable.toFixed(3)} ETH</td>
|
|
</tr>
|
|
</tbody>
|
|
</table>
|
|
</div>`;
|
|
}
|
|
}
|
|
|
|
web3.tokens.dataChanged = (oldTokens, updated, tokenIdCard) => {
|
|
document.getElementById(tokenIdCard).innerHTML = new Token(updated.token, updated.card).render();
|
|
};
|
|
|
|
//
|
|
</xhtml:script>
|
|
</ts:view>
|
|
</ts:card>
|
|
|
|
<ts:card type="action">
|
|
<ts:label>
|
|
<ts:string xml:lang="en">Borrow DAI</ts:string>
|
|
</ts:label>
|
|
<ts:attribute name="borrowAmount">
|
|
<ts:type><ts:syntax>1.3.6.1.4.1.1466.115.121.1.36</ts:syntax></ts:type>
|
|
<ts:label>
|
|
<ts:string xml:lang="en">Amount to Borrow</ts:string>
|
|
</ts:label>
|
|
<ts:origins>
|
|
<!-- e18 is a hard coded multiplier.
|
|
rationale for hardcoding: avoiding over-design -->
|
|
<ts:user-entry as="e18"/>
|
|
</ts:origins>
|
|
</ts:attribute>
|
|
<ts:transaction>
|
|
<ethereum:transaction as="uint" contract="LendingPoolProvider" function="borrow">
|
|
<ts:data>
|
|
<ts:address>0x6b175474e89094c44da98b954eedeac495271d0f</ts:address>
|
|
<ts:uint256 ref="borrowAmount"/>
|
|
<ts:uint256>2</ts:uint256> <!-- 1 is stable rate, 2 is variable rate -->
|
|
<ts:uint256>0</ts:uint256> <!-- referral code -->
|
|
</ts:data>
|
|
</ethereum:transaction>
|
|
</ts:transaction>
|
|
<ts:view xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
|
|
<xhtml:style type="text/css">.separator {
|
|
width: 100%;
|
|
height: 1px;
|
|
background-color: #e9e9e9;
|
|
margin-top: 7.5%;
|
|
}
|
|
|
|
.action {
|
|
height: 50px;
|
|
}
|
|
|
|
body{
|
|
margin-top: 0;
|
|
}
|
|
|
|
h1 {
|
|
margin-top: 0;
|
|
line-height: 2;
|
|
background-color: #fbfbfb;
|
|
border-bottom: thin solid rgb(235,235,235);
|
|
text-align: left;
|
|
font-variant: all-small-caps;
|
|
}
|
|
|
|
h2 {
|
|
float: left;
|
|
margin-top: 0;
|
|
margin-bottom: 0;
|
|
}
|
|
|
|
p.hint {
|
|
clear: left;
|
|
}
|
|
|
|
input {
|
|
float: right;
|
|
font-size: x-large;
|
|
border: none;
|
|
line-height: 40px;
|
|
text-align: right;
|
|
width: 5ex;
|
|
}
|
|
|
|
h2 img {
|
|
vertical-align: middle;
|
|
}
|
|
|
|
.action {
|
|
font-family: SourceSansPro, sans-serif;
|
|
}
|
|
|
|
.enable.action {
|
|
font-size: large;
|
|
text-align: center;
|
|
margin-left: 8%;
|
|
margin-right: 8%;
|
|
margin-top: 35%;
|
|
}
|
|
|
|
.enable.action img {
|
|
padding-bottom: 40px;
|
|
}
|
|
|
|
.titleAction {
|
|
width: 272px;
|
|
height: 24px;
|
|
font-size: 15px;
|
|
font-weight: 600;
|
|
font-stretch: normal;
|
|
font-style: normal;
|
|
line-height: 1.67;
|
|
letter-spacing: normal;
|
|
color: #727272;
|
|
}
|
|
|
|
.detailsTitle {
|
|
width: 246px;
|
|
height: 41px;
|
|
font-family: SourceSansPro-Semibold, sans-serif;
|
|
font-size: 24px;
|
|
font-weight: bold;
|
|
font-stretch: normal;
|
|
font-style: normal;
|
|
line-height: 1.71;
|
|
letter-spacing: normal;
|
|
color: black;
|
|
}
|
|
|
|
table {
|
|
margin-top: 1em;
|
|
width: 100%;
|
|
border-collapse: collapse;
|
|
}
|
|
|
|
table caption {
|
|
font-weight: bold;
|
|
font-size: x-large;
|
|
line-height: 2;
|
|
text-align: left;
|
|
}
|
|
|
|
table th {
|
|
font-weight: normal; /* Tomek likes to deemphasize field names */
|
|
text-align: left;
|
|
line-height: 3;
|
|
}
|
|
|
|
table td {
|
|
text-align: right;
|
|
font-weight: bold;
|
|
font-size: large;
|
|
line-height: 3;
|
|
}
|
|
|
|
table tr {
|
|
border-top: 1px solid #727272;
|
|
}
|
|
|
|
table tr:last-child {
|
|
border-bottom: 1px solid #727272;
|
|
}
|
|
</xhtml:style>
|
|
<xhtml:script type="text/javascript">//
|
|
class Token {
|
|
|
|
constructor(token, card) {
|
|
this.token = token;
|
|
this.card = card;
|
|
}
|
|
|
|
render() {
|
|
const decimals18 = 1e+18;
|
|
let borrowAPY = ((this.token.userInterestRateBorrow / 1e+27) * 100).toFixed(2) + "%";
|
|
if(this.token.userInterestRateBorrow === 0) {
|
|
borrowAPY = "N/A";
|
|
}
|
|
let collateralValueInEth = (this.token.totalCollateral / decimals18).toFixed(2);
|
|
|
|
return `
|
|
<div class="borrow action">
|
|
<h1>Borrow</h1>
|
|
<h2><img src=""></h2>
|
|
<input id="borrowAmount" type="number" placeholder="0">
|
|
<p class="hint">Available to borrow: ${((this.token.availableBorrowsETH / this.token.assetPriceDAI)).toFixed(2)} DAI</p>
|
|
<table>
|
|
<caption>Details</caption>
|
|
<tbody>
|
|
<tr>
|
|
<th>Variable Borrow APY </th>
|
|
<td>${borrowAPY}</td>
|
|
</tr>
|
|
<tr>
|
|
<th>Maximum you can borrow</th>
|
|
<td>${((this.token.availableBorrowsETH / this.token.assetPriceDAI)).toFixed(2)} DAI</td>
|
|
</tr>
|
|
<tr>
|
|
<th>You Already Borrowed</th>
|
|
<td>${((this.token.totalBorrows / this.token.assetPriceDAI)).toFixed(2)} DAI</td>
|
|
</tr>
|
|
<tr>
|
|
<th>New Health Factor</th>
|
|
<td>${(this.token.healthFactor / 1e+18).toFixed(2)}</td>
|
|
</tr>
|
|
<tr>
|
|
<th>Your collateral is worth</th>
|
|
<td>${collateralValueInEth} ETH (${((this.token.totalCollateral / this.token.assetPriceDAI)).toFixed(2)} DAI)</td>
|
|
</tr>
|
|
</tbody>
|
|
</table>
|
|
</div>`;
|
|
}
|
|
}
|
|
|
|
web3.tokens.dataChanged = (oldTokens, updated, tokenIdCard) => {
|
|
document.getElementById(tokenIdCard).innerHTML = new Token(updated.token, updated.card).render();
|
|
};
|
|
//
|
|
</xhtml:script>
|
|
</ts:view>
|
|
</ts:card>
|
|
|
|
|
|
<ts:card name="aETHRedeemed" type="activity">
|
|
<ts:origins>
|
|
<ethereum:event contract="aETH" filter="_fromRedeemer=${ownerAddress}" type="Redeem"/>
|
|
</ts:origins>
|
|
<ts:item-view xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
|
|
<style type="text/css">.icons {
|
|
margin-top: 10%;
|
|
}
|
|
|
|
.date {
|
|
margin-top: 2%;
|
|
justify-content: center;
|
|
}
|
|
|
|
.logo {
|
|
width: 60px;
|
|
height: 60px;
|
|
object-fit: contain;
|
|
}
|
|
|
|
.sentSolid {
|
|
width: 34px;
|
|
height: 34px;
|
|
object-fit: contain;
|
|
}
|
|
|
|
.depositContainer {
|
|
width: 375px;
|
|
height: 34px;
|
|
font-family: SourceSansPro-Semibold, sans-serif;
|
|
font-size: 20px;
|
|
font-weight: 600;
|
|
font-stretch: normal;
|
|
font-style: normal;
|
|
line-height: 1.7;
|
|
letter-spacing: normal;
|
|
text-align: center;
|
|
color: black;
|
|
}
|
|
|
|
.headerRectangle {
|
|
width: 375px;
|
|
height: 150px;
|
|
background-color: #ffffff;
|
|
margin-top: 10%;
|
|
text-align: center;
|
|
}
|
|
|
|
.date {
|
|
font-family: SourceSansPro, sans-serif;
|
|
font-size: 12px;
|
|
font-weight: normal;
|
|
font-stretch: normal;
|
|
font-style: normal;
|
|
line-height: 1.67;
|
|
letter-spacing: normal;
|
|
text-align: center;
|
|
color: #727272;
|
|
}
|
|
|
|
.separator {
|
|
width: 100%;
|
|
height: 1px;
|
|
background-color: #e9e9e9;
|
|
margin-top: 7.5%;
|
|
}
|
|
|
|
.amountBox{
|
|
width: 375px;
|
|
height: 47px;
|
|
font-family: SourceSansPro-Regular, sans-serif;
|
|
font-size: 28px;
|
|
font-weight: normal;
|
|
font-stretch: normal;
|
|
font-style: normal;
|
|
line-height: 1.68;
|
|
letter-spacing: normal;
|
|
text-align: center;
|
|
color: black;
|
|
}
|
|
|
|
.midSection {
|
|
width: 375px;
|
|
height: 81px;
|
|
background-color: white;
|
|
}
|
|
</style>
|
|
<xhtml:script type="text/javascript">//
|
|
class Token {
|
|
|
|
constructor(token, card) {
|
|
this.token = token;
|
|
this.card = card;
|
|
this.time = this.formatTimeStamp(this.card.timestamp.date);
|
|
}
|
|
|
|
formatTimeStamp(time) {
|
|
let a = new Date(time);
|
|
let hours = a.getHours();
|
|
let minutes = a.getMinutes();
|
|
let ampm = hours >= 12 ? 'pm' : 'am';
|
|
hours = hours % 12;
|
|
hours = hours ? hours : 12; // the hour '0' should be '12'
|
|
minutes = minutes < 10 ? '0' + minutes : minutes;
|
|
return hours + ':' + minutes + ' ' + ampm;
|
|
}
|
|
|
|
render() {
|
|
return`
|
|
<div>
|
|
<div class="container">
|
|
<div class="logo">
|
|
<img src="">
|
|
</div>
|
|
<div class="info">
|
|
- ${this.card._valueRedeemed / 1e+18} ETH<br/>
|
|
<div class="time">${this.time}</div>
|
|
</div>
|
|
<div class="title">
|
|
Withdrew <strong>ETH</strong>
|
|
</div>
|
|
<div class="subtitle">
|
|
from Aave
|
|
</div>
|
|
</div>
|
|
</div>
|
|
`;
|
|
}
|
|
}
|
|
|
|
web3.tokens.dataChanged = (oldTokens, updated, tokenIdCard) => {
|
|
document.getElementById(tokenIdCard).innerHTML = new Token(updated.token, updated.card).render();
|
|
};
|
|
//
|
|
</xhtml:script>
|
|
</ts:item-view>
|
|
<ts:view xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
|
|
<xhtml:style type="text/css">.icons {
|
|
margin-top: 10%;
|
|
}
|
|
|
|
.date {
|
|
margin-top: 2%;
|
|
justify-content: center;
|
|
}
|
|
|
|
.logo {
|
|
width: 60px;
|
|
height: 60px;
|
|
object-fit: contain;
|
|
}
|
|
|
|
.sentSolid {
|
|
width: 34px;
|
|
height: 34px;
|
|
object-fit: contain;
|
|
}
|
|
|
|
.depositContainer {
|
|
width: 375px;
|
|
height: 34px;
|
|
font-family: SourceSansPro-Semibold, sans-serif;
|
|
font-size: 20px;
|
|
font-weight: 600;
|
|
font-stretch: normal;
|
|
font-style: normal;
|
|
line-height: 1.7;
|
|
letter-spacing: normal;
|
|
text-align: center;
|
|
color: black;
|
|
}
|
|
|
|
.headerRectangle {
|
|
width: 375px;
|
|
height: 150px;
|
|
background-color: #ffffff;
|
|
margin-top: 10%;
|
|
text-align: center;
|
|
}
|
|
|
|
.date {
|
|
font-family: SourceSansPro, sans-serif;
|
|
font-size: 12px;
|
|
font-weight: normal;
|
|
font-stretch: normal;
|
|
font-style: normal;
|
|
line-height: 1.67;
|
|
letter-spacing: normal;
|
|
text-align: center;
|
|
color: #727272;
|
|
}
|
|
|
|
.separator {
|
|
width: 100%;
|
|
height: 1px;
|
|
background-color: #e9e9e9;
|
|
margin-top: 7.5%;
|
|
}
|
|
|
|
.amountBox{
|
|
width: 375px;
|
|
height: 47px;
|
|
font-family: SourceSansPro-Regular, sans-serif;
|
|
font-size: 28px;
|
|
font-weight: normal;
|
|
font-stretch: normal;
|
|
font-style: normal;
|
|
line-height: 1.68;
|
|
letter-spacing: normal;
|
|
text-align: center;
|
|
color: black;
|
|
}
|
|
|
|
.midSection {
|
|
width: 375px;
|
|
height: 81px;
|
|
background-color: white;
|
|
}
|
|
</xhtml:style>
|
|
<xhtml:script type="text/javascript">//
|
|
class Token {
|
|
|
|
constructor(token, card) {
|
|
this.token = token;
|
|
this.card = card;
|
|
this.time = this.formatTimeStampTodayTime(this.card.timestamp.date) + " | " + this.formatTimeStamp(this.card.timestamp.date);
|
|
}
|
|
|
|
formatTimeStampTodayTime(time) {
|
|
let a = new Date(time);
|
|
let hours = a.getHours();
|
|
let minutes = a.getMinutes();
|
|
let ampm = hours >= 12 ? 'pm' : 'am';
|
|
hours = hours % 12;
|
|
hours = hours ? hours : 12; // the hour '0' should be '12'
|
|
minutes = minutes < 10 ? '0' + minutes : minutes;
|
|
return hours + ':' + minutes + ' ' + ampm;
|
|
}
|
|
|
|
formatTimeStamp(time) {
|
|
let a = new Date(time);
|
|
let months = ['Jan','Feb','Mar','Apr','May','Jun','Jul','Aug','Sep','Oct','Nov','Dec'];
|
|
let year = a.getFullYear();
|
|
let month = months[a.getMonth()];
|
|
let date = a.getDate();
|
|
return date + ' ' + month + ' ' + year;
|
|
}
|
|
|
|
render() {
|
|
return`
|
|
<div>
|
|
<div class="headerRectangle">
|
|
<div class="date">
|
|
<p>${this.time}</p>
|
|
</div>
|
|
|
|
<div class="icons">
|
|
<img class="logo" src="">
|
|
</div>
|
|
|
|
<div class="depositContainer">
|
|
<p>Withdrew ETH</p>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="separator"></div>
|
|
|
|
<div class="amountBox">
|
|
<p>- ${this.card._valueRedeemed} ETH</p>
|
|
</div>
|
|
</div>
|
|
`;
|
|
}
|
|
}
|
|
|
|
web3.tokens.dataChanged = (oldTokens, updated, tokenIdCard) => {
|
|
document.getElementById(tokenIdCard).innerHTML = new Token(updated.token, updated.card).render();
|
|
};
|
|
//
|
|
</xhtml:script>
|
|
</ts:view>
|
|
</ts:card>
|
|
|
|
<ts:card name="aETHBorrowed" type="activity">
|
|
<ts:origins>
|
|
<ethereum:event contract="aETH" filter="_user=${ownerAddress}" type="Borrow"/>
|
|
</ts:origins>
|
|
<ts:item-view xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
|
|
<xhtml:style type="text/css">.icons {
|
|
margin-top: 10%;
|
|
}
|
|
|
|
.date {
|
|
margin-top: 2%;
|
|
justify-content: center;
|
|
}
|
|
|
|
.logo {
|
|
width: 60px;
|
|
height: 60px;
|
|
object-fit: contain;
|
|
}
|
|
|
|
.sentSolid {
|
|
width: 34px;
|
|
height: 34px;
|
|
object-fit: contain;
|
|
}
|
|
|
|
.depositContainer {
|
|
width: 375px;
|
|
height: 34px;
|
|
font-family: SourceSansPro-Semibold, sans-serif;
|
|
font-size: 20px;
|
|
font-weight: 600;
|
|
font-stretch: normal;
|
|
font-style: normal;
|
|
line-height: 1.7;
|
|
letter-spacing: normal;
|
|
text-align: center;
|
|
color: black;
|
|
}
|
|
|
|
.headerRectangle {
|
|
width: 375px;
|
|
height: 150px;
|
|
background-color: #ffffff;
|
|
margin-top: 10%;
|
|
text-align: center;
|
|
}
|
|
|
|
.date {
|
|
font-family: SourceSansPro, sans-serif;
|
|
font-size: 12px;
|
|
font-weight: normal;
|
|
font-stretch: normal;
|
|
font-style: normal;
|
|
line-height: 1.67;
|
|
letter-spacing: normal;
|
|
text-align: center;
|
|
color: #727272;
|
|
}
|
|
|
|
.separator {
|
|
width: 100%;
|
|
height: 1px;
|
|
background-color: #e9e9e9;
|
|
margin-top: 7.5%;
|
|
}
|
|
|
|
.amountBox{
|
|
width: 375px;
|
|
height: 47px;
|
|
font-family: SourceSansPro-Regular, sans-serif;
|
|
font-size: 28px;
|
|
font-weight: normal;
|
|
font-stretch: normal;
|
|
font-style: normal;
|
|
line-height: 1.68;
|
|
letter-spacing: normal;
|
|
text-align: center;
|
|
color: black;
|
|
}
|
|
|
|
.midSection {
|
|
width: 375px;
|
|
height: 81px;
|
|
background-color: white;
|
|
}
|
|
</xhtml:style>
|
|
<xhtml:script type="text/javascript">//
|
|
class Token {
|
|
|
|
constructor(token, card) {
|
|
this.token = token;
|
|
this.card = card;
|
|
this.time = this.formatTimeStamp(this.card.timestamp.date);
|
|
}
|
|
|
|
formatTimeStamp(time) {
|
|
let a = new Date(time);
|
|
let hours = a.getHours();
|
|
let minutes = a.getMinutes();
|
|
let ampm = hours >= 12 ? 'pm' : 'am';
|
|
hours = hours % 12;
|
|
hours = hours ? hours : 12; // the hour '0' should be '12'
|
|
minutes = minutes < 10 ? '0' + minutes : minutes;
|
|
return hours + ':' + minutes + ' ' + ampm;
|
|
}
|
|
|
|
render() {
|
|
return`
|
|
<div>
|
|
<div class="container">
|
|
<div class="logo">
|
|
<img src="">
|
|
</div>
|
|
<div class="info">
|
|
+ ${this.card._amount / 1e+18} DAI<br/>
|
|
<div class="time">${this.time}</div>
|
|
</div>
|
|
<div class="title">
|
|
Borrowing <strong>DAI</strong>
|
|
</div>
|
|
<div class="subtitle">
|
|
from Aave
|
|
</div>
|
|
</div>
|
|
</div>
|
|
`;
|
|
}
|
|
}
|
|
|
|
web3.tokens.dataChanged = (oldTokens, updated, tokenIdCard) => {
|
|
document.getElementById(tokenIdCard).innerHTML = new Token(updated.token, updated.card).render();
|
|
};
|
|
//
|
|
</xhtml:script>
|
|
</ts:item-view>
|
|
<ts:view xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
|
|
<xhtml:style type="text/css">.icons {
|
|
margin-top: 10%;
|
|
}
|
|
|
|
.date {
|
|
margin-top: 2%;
|
|
justify-content: center;
|
|
}
|
|
|
|
.logo {
|
|
width: 60px;
|
|
height: 60px;
|
|
object-fit: contain;
|
|
}
|
|
|
|
.sentSolid {
|
|
width: 34px;
|
|
height: 34px;
|
|
object-fit: contain;
|
|
}
|
|
|
|
.depositContainer {
|
|
width: 375px;
|
|
height: 34px;
|
|
font-family: SourceSansPro-Semibold, sans-serif;
|
|
font-size: 20px;
|
|
font-weight: 600;
|
|
font-stretch: normal;
|
|
font-style: normal;
|
|
line-height: 1.7;
|
|
letter-spacing: normal;
|
|
text-align: center;
|
|
color: black;
|
|
}
|
|
|
|
.headerRectangle {
|
|
width: 375px;
|
|
height: 150px;
|
|
background-color: #ffffff;
|
|
margin-top: 10%;
|
|
text-align: center;
|
|
}
|
|
|
|
.date {
|
|
font-family: SourceSansPro, sans-serif;
|
|
font-size: 12px;
|
|
font-weight: normal;
|
|
font-stretch: normal;
|
|
font-style: normal;
|
|
line-height: 1.67;
|
|
letter-spacing: normal;
|
|
text-align: center;
|
|
color: #727272;
|
|
}
|
|
|
|
.separator {
|
|
width: 100%;
|
|
height: 1px;
|
|
background-color: #e9e9e9;
|
|
margin-top: 7.5%;
|
|
}
|
|
|
|
.amountBox{
|
|
width: 375px;
|
|
height: 47px;
|
|
font-family: SourceSansPro-Regular, sans-serif;
|
|
font-size: 28px;
|
|
font-weight: normal;
|
|
font-stretch: normal;
|
|
font-style: normal;
|
|
line-height: 1.68;
|
|
letter-spacing: normal;
|
|
text-align: center;
|
|
color: black;
|
|
}
|
|
|
|
.midSection {
|
|
width: 375px;
|
|
height: 81px;
|
|
background-color: white;
|
|
}
|
|
</xhtml:style>
|
|
<xhtml:script type="text/javascript">//
|
|
class Token {
|
|
|
|
constructor(token, card) {
|
|
this.token = token;
|
|
this.card = card;
|
|
this.time = this.formatTimeStampTodayTime(this.card.timestamp.date) + " | " + this.formatTimeStamp(this.card.timestamp.date);
|
|
}
|
|
|
|
formatTimeStampTodayTime(time) {
|
|
let a = new Date(time);
|
|
let hours = a.getHours();
|
|
let minutes = a.getMinutes();
|
|
let ampm = hours >= 12 ? 'pm' : 'am';
|
|
hours = hours % 12;
|
|
hours = hours ? hours : 12; // the hour '0' should be '12'
|
|
minutes = minutes < 10 ? '0' + minutes : minutes;
|
|
return hours + ':' + minutes + ' ' + ampm;
|
|
}
|
|
|
|
formatTimeStamp(time) {
|
|
let a = new Date(time);
|
|
let months = ['Jan','Feb','Mar','Apr','May','Jun','Jul','Aug','Sep','Oct','Nov','Dec'];
|
|
let year = a.getFullYear();
|
|
let month = months[a.getMonth()];
|
|
let date = a.getDate();
|
|
return date + ' ' + month + ' ' + year;
|
|
}
|
|
|
|
render() {
|
|
return`
|
|
<div>
|
|
<div class="headerRectangle">
|
|
<div class="date">
|
|
<p>${this.time}</p>
|
|
</div>
|
|
|
|
<div class="icons">
|
|
<img class="logo" src="">
|
|
</div>
|
|
|
|
<div class="depositContainer">
|
|
<p>Borrowing DAI</p>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="separator"></div>
|
|
|
|
<div class="amountBox">
|
|
<p>+ ${this.card._amount} DAI</p>
|
|
</div>
|
|
</div>
|
|
`;
|
|
}
|
|
}
|
|
|
|
web3.tokens.dataChanged = (oldTokens, updated, tokenIdCard) => {
|
|
document.getElementById(tokenIdCard).innerHTML = new Token(updated.token, updated.card).render();
|
|
};
|
|
//
|
|
</xhtml:script>
|
|
</ts:view>
|
|
</ts:card>
|
|
|
|
</ts:cards>
|
|
|
|
<!-- your balance in ETH -->
|
|
<ts:attribute name="tokenBalance">
|
|
<ts:type><ts:syntax>1.3.6.1.4.1.1466.115.121.1.36</ts:syntax></ts:type>
|
|
<ts:label>
|
|
<ts:string xml:lang="en">Balance</ts:string>
|
|
<ts:string xml:lang="zh">餘額</ts:string>
|
|
</ts:label>
|
|
<ts:origins>
|
|
<ethereum:call as="uint" contract="balance" function="balanceOf">
|
|
<ts:data>
|
|
<ts:address ref="ownerAddress"/>
|
|
</ts:data>
|
|
</ethereum:call>
|
|
</ts:origins>
|
|
</ts:attribute>
|
|
|
|
<ts:attribute name="lendingPoolAddress">
|
|
<ts:type><ts:syntax>1.3.6.1.4.1.1466.115.121.1.15</ts:syntax></ts:type>
|
|
<ts:origins>
|
|
<ethereum:call as="address" contract="LendingPoolProvider" function="getLendingPool">
|
|
</ethereum:call>
|
|
</ts:origins>
|
|
</ts:attribute>
|
|
|
|
<ts:attribute name="allowance">
|
|
<ts:type><ts:syntax>1.3.6.1.4.1.1466.115.121.1.36</ts:syntax></ts:type>
|
|
<ts:origins>
|
|
<ethereum:call as="uint" contract="aETH" function="allowance">
|
|
<ts:data>
|
|
<ts:address ref="ownerAddress"/>
|
|
<ts:address>0x3a3a65aab0dd2a17e3f1947ba16138cd37d08c04</ts:address>
|
|
</ts:data>
|
|
</ethereum:call>
|
|
</ts:origins>
|
|
</ts:attribute>
|
|
|
|
<ts:attribute name="aTokenBalance">
|
|
<ts:type><ts:syntax>1.3.6.1.4.1.1466.115.121.1.36</ts:syntax></ts:type>
|
|
<ts:label>
|
|
<ts:string xml:lang="en">Balance</ts:string>
|
|
<ts:string xml:lang="zh">餘額</ts:string>
|
|
</ts:label>
|
|
<ts:origins>
|
|
<ethereum:call as="uint" contract="aETH" function="balanceOf">
|
|
<ts:data>
|
|
<ts:address ref="ownerAddress"/>
|
|
</ts:data>
|
|
</ethereum:call>
|
|
</ts:origins>
|
|
</ts:attribute>
|
|
|
|
<ts:attribute name="userInterestRateBorrow">
|
|
<ts:type><ts:syntax>1.3.6.1.4.1.1466.115.121.1.36</ts:syntax></ts:type>
|
|
<ts:label>
|
|
<ts:string xml:lang="en">Variable interest rate borrow</ts:string>
|
|
</ts:label>
|
|
<ts:origins>
|
|
<ethereum:call as="uint" contract="AAVEGetters" function="getBorrowRate">
|
|
<ts:data>
|
|
<ts:address>0x6b175474e89094c44da98b954eedeac495271d0f</ts:address>
|
|
<ts:address ref="ownerAddress"/>
|
|
</ts:data>
|
|
</ethereum:call>
|
|
</ts:origins>
|
|
</ts:attribute>
|
|
|
|
<ts:attribute name="interestRateSupply">
|
|
<ts:type><ts:syntax>1.3.6.1.4.1.1466.115.121.1.36</ts:syntax></ts:type>
|
|
<ts:label>
|
|
<ts:string xml:lang="en">interest rate supply</ts:string>
|
|
</ts:label>
|
|
<ts:origins>
|
|
<ethereum:call as="uint" contract="AAVEGetters" function="getLiquidityRate">
|
|
<ts:data>
|
|
<ts:address>0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE</ts:address>
|
|
<ts:address ref="ownerAddress"/>
|
|
</ts:data>
|
|
</ethereum:call>
|
|
</ts:origins>
|
|
</ts:attribute>
|
|
|
|
<ts:attribute name="aTokenPrincipleBalance">
|
|
<ts:type><ts:syntax>1.3.6.1.4.1.1466.115.121.1.36</ts:syntax></ts:type>
|
|
<ts:label>
|
|
<ts:string xml:lang="en">Principal Balance</ts:string>
|
|
<ts:string xml:lang="zh">餘額</ts:string>
|
|
</ts:label>
|
|
<ts:origins>
|
|
<ethereum:call as="uint" contract="aETH" function="principalBalanceOf">
|
|
<ts:data>
|
|
<ts:address ref="ownerAddress"/>
|
|
</ts:data>
|
|
</ethereum:call>
|
|
</ts:origins>
|
|
</ts:attribute>
|
|
|
|
<ts:attribute name="enabledForBorrowing">
|
|
<ts:type><ts:syntax>1.3.6.1.4.1.1466.115.121.1.36</ts:syntax></ts:type>
|
|
<ts:label>
|
|
<ts:string xml:lang="en">enabled for borrowing</ts:string>
|
|
</ts:label>
|
|
<ts:origins>
|
|
<ethereum:call as="bool" contract="LendingPoolProvider" function="isUserUseReserveAsCollateralEnabled">
|
|
<ts:data>
|
|
<ts:address>0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE</ts:address>
|
|
<ts:address ref="ownerAddress"/>
|
|
</ts:data>
|
|
</ethereum:call>
|
|
</ts:origins>
|
|
</ts:attribute>
|
|
|
|
<ts:attribute name="loanToValue">
|
|
<ts:type><ts:syntax>1.3.6.1.4.1.1466.115.121.1.36</ts:syntax></ts:type>
|
|
<ts:label>
|
|
<ts:string xml:lang="en">LTV</ts:string>
|
|
</ts:label>
|
|
<ts:origins>
|
|
<ethereum:call as="uint" contract="AAVEGetters" function="getLTV">
|
|
<ts:data>
|
|
<ts:address ref="ownerAddress"/>
|
|
</ts:data>
|
|
</ethereum:call>
|
|
</ts:origins>
|
|
</ts:attribute>
|
|
|
|
<ts:attribute name="availableBorrowsETH">
|
|
<ts:type><ts:syntax>1.3.6.1.4.1.1466.115.121.1.36</ts:syntax></ts:type>
|
|
<ts:label>
|
|
<ts:string xml:lang="en">borrowable</ts:string>
|
|
</ts:label>
|
|
<ts:origins>
|
|
<ethereum:call as="uint" contract="AAVEGetters" function="getAvailableBorrowsETH">
|
|
<ts:data>
|
|
<ts:address ref="ownerAddress"/>
|
|
</ts:data>
|
|
</ethereum:call>
|
|
</ts:origins>
|
|
</ts:attribute>
|
|
|
|
<ts:attribute name="healthFactor">
|
|
<ts:type><ts:syntax>1.3.6.1.4.1.1466.115.121.1.36</ts:syntax></ts:type>
|
|
<ts:label>
|
|
<ts:string xml:lang="en">health factor</ts:string>
|
|
</ts:label>
|
|
<ts:origins>
|
|
<ethereum:call as="uint" contract="AAVEGetters" function="getHealthFactor">
|
|
<ts:data>
|
|
<ts:address ref="ownerAddress"/>
|
|
</ts:data>
|
|
</ethereum:call>
|
|
</ts:origins>
|
|
</ts:attribute>
|
|
|
|
<ts:attribute name="totalCollateral">
|
|
<ts:type><ts:syntax>1.3.6.1.4.1.1466.115.121.1.36</ts:syntax></ts:type>
|
|
<ts:label>
|
|
<ts:string xml:lang="en">total collateral in ETH</ts:string>
|
|
</ts:label>
|
|
<ts:origins>
|
|
<ethereum:call as="uint" contract="AAVEGetters" function="getTotalCollateralETH">
|
|
<ts:data>
|
|
<ts:address ref="ownerAddress"/>
|
|
</ts:data>
|
|
</ethereum:call>
|
|
</ts:origins>
|
|
</ts:attribute>
|
|
|
|
<ts:attribute name="totalBorrows">
|
|
<ts:type><ts:syntax>1.3.6.1.4.1.1466.115.121.1.36</ts:syntax></ts:type>
|
|
<ts:label>
|
|
<ts:string xml:lang="en">total borrows in ETH</ts:string>
|
|
</ts:label>
|
|
<ts:origins>
|
|
<ethereum:call as="uint" contract="AAVEGetters" function="getTotalBorrowsETH">
|
|
<ts:data>
|
|
<ts:address ref="ownerAddress"/>
|
|
</ts:data>
|
|
</ethereum:call>
|
|
</ts:origins>
|
|
</ts:attribute>
|
|
|
|
<ts:attribute name="liquidationThreshold">
|
|
<ts:type><ts:syntax>1.3.6.1.4.1.1466.115.121.1.36</ts:syntax></ts:type>
|
|
<ts:label>
|
|
<ts:string xml:lang="en">liquidation threshold</ts:string>
|
|
</ts:label>
|
|
<ts:origins>
|
|
<ethereum:call as="uint" contract="AAVEGetters" function="getCurrentLiquidationThreshold">
|
|
<ts:data>
|
|
<ts:address ref="ownerAddress"/>
|
|
</ts:data>
|
|
</ethereum:call>
|
|
</ts:origins>
|
|
</ts:attribute>
|
|
|
|
<ts:attribute name="assetPriceDAI">
|
|
<ts:type><ts:syntax>1.3.6.1.4.1.1466.115.121.1.36</ts:syntax></ts:type>
|
|
<ts:label>
|
|
<ts:string xml:lang="en">asset price</ts:string>
|
|
</ts:label>
|
|
<ts:origins>
|
|
<ethereum:call as="uint" contract="PriceOracle" function="getAssetPrice">
|
|
<ts:data>
|
|
<ts:address>0x6B175474E89094C44Da98b954EedeAC495271d0F</ts:address>
|
|
</ts:data>
|
|
</ethereum:call>
|
|
</ts:origins>
|
|
</ts:attribute>
|
|
|
|
<ds:Signature xmlns:ds="http://www.w3.org/2000/09/xmldsig#">
|
|
<ds:SignedInfo>
|
|
<ds:CanonicalizationMethod Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/>
|
|
<ds:SignatureMethod Algorithm="http://www.w3.org/2001/04/xmldsig-more#rsa-sha256"/>
|
|
<ds:Reference URI="">
|
|
<ds:Transforms>
|
|
<ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/>
|
|
<ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/>
|
|
</ds:Transforms>
|
|
<ds:DigestMethod Algorithm="http://www.w3.org/2001/04/xmlenc#sha256"/>
|
|
<ds:DigestValue>Mpu/KHXZdpCQM4wmFK3I2yl9pxBkSH3bXv59D+Gnpvw=</ds:DigestValue>
|
|
</ds:Reference>
|
|
</ds:SignedInfo>
|
|
<ds:SignatureValue>
|
|
kAVDItZy174O8SgRo6xq4BP66mzyaWQA6hB5w6L34pClOkrxe5TwBIdoyaIHW9bxxgzt9CczqoSF
|
|
gdeW9IDsC3nJ8UbJOnCUkcLnQXqOdCDmlwj6h4dhqtSbgPbfVmng1Anf3ll6j9b8hM1Deb0C9Iga
|
|
yj1A++dnjWuBx9Lfeh/aGoxknF8eOiA+GWbfxHwNUwVaahr6MHLhsTgQdv0emISrt0Hx3EeSD5lw
|
|
0zLP19ppj0rxTdWaV240mPBy3uZCBkdjIfL9gDK9hkVHVJUvEHNCU/mUlAxEAovUSXoHiySWWkjl
|
|
d+ph70jOnt018YbCz2g4ifid9cn2BzyZjcY0dg==
|
|
</ds:SignatureValue>
|
|
<ds:KeyInfo>
|
|
<ds:KeyName>AlphaWallet</ds:KeyName>
|
|
<ds:KeyValue>
|
|
<ds:RSAKeyValue>
|
|
<ds:Modulus>
|
|
tDHBH8jKLPEjpXsy/V9/XsXBYmc64SXx6IWG9CdJzm+iSrk3Od2ZZTS3DsR5+hp9hk6UwRyb1XKG
|
|
+TMrBODfxIIWricmnhxYMqiyvwDhecm4RU4YFteekBFAsuhEGCJBtmJSrle5G3iE/9FwvTfw/cxo
|
|
yAydv85OWc4UkxkfjzaXVqGGKCzSFhRm48HwG51/1nmC1mmPh070EMY4Km4N/ieJZ8egLjDAIZEI
|
|
EY5Cj7ig9PPnGf2pF21/z7vm3zQViXi6XJIBn1E5CTXzDW1y1BYe0QI+dxxY0o+97mwisZu7fVfB
|
|
/rJJm3g7Ye4/lITkZeRMP+OLYyG1pathItlrVQ==
|
|
</ds:Modulus>
|
|
<ds:Exponent>AQAB</ds:Exponent>
|
|
</ds:RSAKeyValue>
|
|
</ds:KeyValue>
|
|
<ds:X509Data>
|
|
<ds:X509Certificate>
|
|
MIIFUDCCBDigAwIBAgISAy095xt55U0Cc0++zYon7TT0MA0GCSqGSIb3DQEBCwUAMEoxCzAJBgNV
|
|
BAYTAlVTMRYwFAYDVQQKEw1MZXQncyBFbmNyeXB0MSMwIQYDVQQDExpMZXQncyBFbmNyeXB0IEF1
|
|
dGhvcml0eSBYMzAeFw0xOTA5MjQxMTA1MTdaFw0xOTEyMjMxMTA1MTdaMBMxETAPBgNVBAMMCCou
|
|
YXcuYXBwMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAtDHBH8jKLPEjpXsy/V9/XsXB
|
|
Ymc64SXx6IWG9CdJzm+iSrk3Od2ZZTS3DsR5+hp9hk6UwRyb1XKG+TMrBODfxIIWricmnhxYMqiy
|
|
vwDhecm4RU4YFteekBFAsuhEGCJBtmJSrle5G3iE/9FwvTfw/cxoyAydv85OWc4UkxkfjzaXVqGG
|
|
KCzSFhRm48HwG51/1nmC1mmPh070EMY4Km4N/ieJZ8egLjDAIZEIEY5Cj7ig9PPnGf2pF21/z7vm
|
|
3zQViXi6XJIBn1E5CTXzDW1y1BYe0QI+dxxY0o+97mwisZu7fVfB/rJJm3g7Ye4/lITkZeRMP+OL
|
|
YyG1pathItlrVQIDAQABo4ICZTCCAmEwDgYDVR0PAQH/BAQDAgWgMB0GA1UdJQQWMBQGCCsGAQUF
|
|
BwMBBggrBgEFBQcDAjAMBgNVHRMBAf8EAjAAMB0GA1UdDgQWBBRaKDKFkPztPgQee3418kofZddy
|
|
MTAfBgNVHSMEGDAWgBSoSmpjBH3duubRObemRWXv86jsoTBvBggrBgEFBQcBAQRjMGEwLgYIKwYB
|
|
BQUHMAGGImh0dHA6Ly9vY3NwLmludC14My5sZXRzZW5jcnlwdC5vcmcwLwYIKwYBBQUHMAKGI2h0
|
|
dHA6Ly9jZXJ0LmludC14My5sZXRzZW5jcnlwdC5vcmcvMBsGA1UdEQQUMBKCCCouYXcuYXBwggZh
|
|
dy5hcHAwTAYDVR0gBEUwQzAIBgZngQwBAgEwNwYLKwYBBAGC3xMBAQEwKDAmBggrBgEFBQcCARYa
|
|
aHR0cDovL2Nwcy5sZXRzZW5jcnlwdC5vcmcwggEEBgorBgEEAdZ5AgQCBIH1BIHyAPAAdwB0ftqD
|
|
Ma0zEJEhnM4lT0Jwwr/9XkIgCMY3NXnmEHvMVgAAAW1jKVxwAAAEAwBIMEYCIQCHuWOuAiqXC7Bn
|
|
nYLS4BDrOrVeObYC7zcQvru7Aqx5DAIhAP9ukUp9nnQBWgAgTdfK+GdhHxboIaxJz7456ws6myft
|
|
AHUAY/Lbzeg7zCzPC3KEJ1drM6SNYXePvXWmOLHHaFRL2I0AAAFtYyladwAABAMARjBEAiBaxydV
|
|
JMY5/hQyrjaMMonJgQBhEKBHvv4FbthX+lZfpAIga4sB0hDaoT4knZfVhVP/u/Uv47t6z1+TEWnL
|
|
/TresTwwDQYJKoZIhvcNAQELBQADggEBAGSPK0ivDprmvO72TVLZsuk/JDhCmXQcYe6cRGPiX7WL
|
|
c0B6wfLaxb0rrQdmGpTiTEHS6wEa6tOMEsfxutPWeOxlqFPU97QHhLrdBlf4IDfk8i1Em3rpPPQu
|
|
3M2u5nfeRXvsIxyB5vLQvuR/NwCQqA2bwkCrlLz7dr1iGem35DGI0ikIkdODTPI+RpwHK8b2iApA
|
|
w6XaVGA99eCJS2dHqeyHPAc1Yf+Klv+z0FyM38ZUfazRRIQ17LtolM1U/9Ynld20SXtCrIFbcmbo
|
|
w3piXuHLlDRcRxWqdL33yPoTEbPuLtS6vqDXefYP0RiYpQHHwJz4E6q5VCbK6LgILnIyX+M=
|
|
</ds:X509Certificate>
|
|
<ds:X509Certificate>
|
|
MIIEkjCCA3qgAwIBAgIQCgFBQgAAAVOFc2oLheynCDANBgkqhkiG9w0BAQsFADA/MSQwIgYDVQQK
|
|
ExtEaWdpdGFsIFNpZ25hdHVyZSBUcnVzdCBDby4xFzAVBgNVBAMTDkRTVCBSb290IENBIFgzMB4X
|
|
DTE2MDMxNzE2NDA0NloXDTIxMDMxNzE2NDA0NlowSjELMAkGA1UEBhMCVVMxFjAUBgNVBAoTDUxl
|
|
dCdzIEVuY3J5cHQxIzAhBgNVBAMTGkxldCdzIEVuY3J5cHQgQXV0aG9yaXR5IFgzMIIBIjANBgkq
|
|
hkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAnNMM8FrlLke3cl03g7NoYzDq1zUmGSXhvb418XCSL7e4
|
|
S0EFq6meNQhY7LEqxGiHC6PjdeTm86dicbp5gWAf15Gan/PQeGdxyGkOlZHP/uaZ6WA8SMx+yk13
|
|
EiSdRxta67nsHjcAHJyse6cF6s5K671B5TaYucv9bTyWaN8jKkKQDIZ0Z8h/pZq4UmEUEz9l6YKH
|
|
y9v6Dlb2honzhT+Xhq+w3Brvaw2VFn3EK6BlspkENnWAa6xK8xuQSXgvopZPKiAlKQTGdMDQMc2P
|
|
MTiVFrqoM7hD8bEfwzB/onkxEz0tNvjj/PIzark5McWvxI0NHWQWM6r6hCm21AvA2H3DkwIDAQAB
|
|
o4IBfTCCAXkwEgYDVR0TAQH/BAgwBgEB/wIBADAOBgNVHQ8BAf8EBAMCAYYwfwYIKwYBBQUHAQEE
|
|
czBxMDIGCCsGAQUFBzABhiZodHRwOi8vaXNyZy50cnVzdGlkLm9jc3AuaWRlbnRydXN0LmNvbTA7
|
|
BggrBgEFBQcwAoYvaHR0cDovL2FwcHMuaWRlbnRydXN0LmNvbS9yb290cy9kc3Ryb290Y2F4My5w
|
|
N2MwHwYDVR0jBBgwFoAUxKexpHsscfrb4UuQdf/EFWCFiRAwVAYDVR0gBE0wSzAIBgZngQwBAgEw
|
|
PwYLKwYBBAGC3xMBAQEwMDAuBggrBgEFBQcCARYiaHR0cDovL2Nwcy5yb290LXgxLmxldHNlbmNy
|
|
eXB0Lm9yZzA8BgNVHR8ENTAzMDGgL6AthitodHRwOi8vY3JsLmlkZW50cnVzdC5jb20vRFNUUk9P
|
|
VENBWDNDUkwuY3JsMB0GA1UdDgQWBBSoSmpjBH3duubRObemRWXv86jsoTANBgkqhkiG9w0BAQsF
|
|
AAOCAQEA3TPXEfNjWDjdGBX7CVW+dla5cEilaUcne8IkCJLxWh9KEik3JHRRHGJouM2VcGfl96S8
|
|
TihRzZvoroed6ti6WqEBmtzw3Wodatg+VyOeph4EYpr/1wXKtx8/wApIvJSwtmVi4MFU5aMqrSDE
|
|
6ea73Mj2tcMyo5jMd6jmeWUHK8so/joWUoHOUgwuX4Po1QYz+3dszkDqMp4fklxBwXRsW10KXzPM
|
|
TZ+sOPAveyxindmjkW8lGy+QsRlGPfZ+G6Z6h7mjem0Y+iWlkYcV4PIWL1iwBi8saCbGS5jN2p8M
|
|
+X+Q7UNKEkROb3N6KOqkqm57TH2H3eDJAkSnh6/DNFu0Qg==
|
|
</ds:X509Certificate>
|
|
</ds:X509Data>
|
|
</ds:KeyInfo>
|
|
</ds:Signature></ts:token>
|
|
|