123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537 |
- @page "/blockchains"
- @page "/blockchains/{Smart}"
- @using System.Text.RegularExpressions;
- @using Console = HyperCube.Utils.AdvConsole;
- @inject NavigationManager NavigationManager
- @inject IJSRuntime JsRuntime
- @using HyperCube.Models
- @using Microsoft.AspNetCore.Identity;
- @inject AuthenticationStateProvider AuthenticationStateProvider
- @inject UserManager<IdentityUser> UserManager
- @attribute [Authorize]
- <div class="tabs__content">
- <div class="tabs__controls">
- @if (account.Roles.Contains(Role.Admin) || account.Roles.Contains(Role.Initiator))
- {
- <a href="DocEdit" class="tabs__btn">Загрузка материалов</a>
- }
- @if (account.Roles.Contains(Role.Admin) || account.Roles.Contains(Role.Verifier))
- {
- <a href="Verifying" class="tabs__btn">Верификация</a>
- }
- <a class="tabs__btn">Библиотеки</a>
- @if (account.Roles.Contains(Role.Admin) || account.Roles.Contains(Role.Requester))
- {
- <a class="tabs__btn">Заказы</a>
- }
- </div>
- </div>
- <br>
- @*<h1>Blazor is @Smart!</h1>*@
- @code
- {
- string hidecontr = "visible";
- string hidereceipt = "hidden";
- string result = "";
- string qrr = "";
- string newcode = "";
- string newname = "";
- string balance = "";
- string sha3 = "";
- string function1 = "";
- string function_processed = "";
- string contractAddDisabled = "";
- string tokenContract = "0xe5D682717955d6C35d465A3485625C64655a04f4";
- string tokenName
- {
- get { return Blockchain.tokenName; }
- set { }
- }
- string tokenSymbol
- {
- get { return Blockchain.symbol; }
- set { }
- }
- string tokenDecimals
- {
- get { return Blockchain.decimals; }
- set { }
- }
- string tokenBalance
- {
- get { return Blockchain.tokenBalance; }
- set { }
- }
- string tokenAmount;
- string addressTo;
- SmartContract ctrSelected = new SmartContract();
- int ct;
-
- string accountSelected;
- int contrtest
- {
- get
- {
- return ct;
- }
- set
- {
- ct = value;
- Console.WriteLine("ch contrtest val " + value);
- var ctr = GetContract(value);
- if (ctr != null)
- {
- Console.WriteLine("ctr found " + ctr.Name);
- ctrSelected = ctr;
- }
- }
- }
- }
- @if (Blockchain.blockChainsInitialized)
- {
- <select @bind="AccountModel.GetCurrent().blockchain_selected" style="color:green">
- <option value=0>Ethereum Dev Network</option>
- <option value=1>Ethereum Test Network</option>
- </select>
- <p><b>@Blockchain.GetMain().url:@Blockchain.GetMain().port </b><br /> <b>Address:</b> @Blockchain.GetMain().address<br /> <b>Balance:</b> @Blockchain.GetMain().balance</p>
- @*@foreach(var bc in Blockchain.loaded.Values)
- {
- <p>
- <b>
- @bc.url:@bc.port
- </b>, address: @bc.address
- </p>
- }*@
- @*<p>@AccountModel.GetCurrent().blockchain_selected</p>*@
- <br>
- <p></p>
- <p style="visibility:@hidecontr">
- Add smart contract:
- <p><input id="newname" @bind="newname" placeholder="Имя нового контракта" /></p>
- <p><input id="newcode" size="100" @bind="newcode" name="code" type="text" placeholder="Исходный код" /></p>
- <p><input id="bytecode" size="100" @bind="bytecode" name="bytecode" type="text" placeholder="Байткод" @bind:event="oninput" /></p>
- <p><input id="function1" size="100" @bind="function1" name="function1" type="text" placeholder="Функция №1 - Объявление" /></p>
- <p><input disabled id="function_processed" size="100" @bind="function_processed" name="function_processed" type="text" placeholder="Функция" /></p>
- <button @onclick="checkCode">checkCode</button>
- <div style="visibility: @contractAddDisabled">
- <button @onclick="AddContract">Add</button>
- </div>
- @*<div>
- <button @onclick="TestHTTP">TestHTTP</button>
- </div>*@
- <p><input id="getsha3" size="100" @bind="sha3" name="getsha3" type="text" placeholder="SHA3" @bind:event="oninput" /></p>
- @*<button @onclick="GetSHA3_2">GetSHA3</button>*@
- @*<p>
- 0x60806040526000805534801561001457600080fd5b50610101806100246000396000f3006080604052600436106053576000357c0100000000000000000000000000000000000000000000000000000000900463ffffffff1680635b34b966146058578063a87d942c14606c578063f5c5ad83146094575b600080fd5b348015606357600080fd5b50606a60a8565b005b348015607757600080fd5b50607e60ba565b6040518082815260200191505060405180910390f35b348015609f57600080fd5b5060a660c3565b005b60016000808282540192505081905550565b60008054905090565b600160008082825403925050819055505600a165627a7a723058207815571f5c1d82bff3c0512a4cbc7a1f1c2063fa9a0de61913b76925f041e9ed0029
- </p>*@
- <br />
- </p>
- <div>
- <button @onclick="ImportERC20">ImportERC20</button>
- <p><input id="tc" size="100" @bind="tokenContract" name="code" type="text" placeholder="Адрес контракта токена" /></p>
- <p><input id="tn" size="100" @bind="tokenName" name="code" type="text" placeholder="" /></p>
- <p><input id="ts" size="100" @bind="tokenSymbol" name="code" type="text" placeholder="" /></p>
- <p><input id="td" size="100" @bind="tokenDecimals" name="code" type="text" placeholder="" /></p>
- <p><input id="tb" size="100" @bind="tokenBalance" name="code" type="text" placeholder="" /></p>
- </div>
- <div>
- <button @onclick="TransferToken">Transfer</button>
- <p><input id="tc" size="100" @bind="tokenAmount" name="code" type="text" placeholder="Количество" /></p>
- <p><input id="tn" size="100" @bind="addressTo" name="code" type="text" placeholder="Адрес получателя" /></p>
- </div>
- @*<p style="visibility:@hidereceipt">
- Get smart contract address:
- <button @onclick="GetReceipt">Check transaction receipt</button>
- <input id="bytecode" size="100" @bind="bytecode" name="bytecode" type="text" placeholder="Transaction address" @bind:event="oninput">
- <br />
- </p>*@
- <p>
- <select @bind="contrtest">
- <option value="0">[Select Contract]</option>
- @if (Blockchain.loaded.Count > 0)
- {
- result = Blockchain.loaded.Count.ToString();
- if (Blockchain.GetMain().contracts.Count > 0)
- {
- @foreach (var c in Blockchain.GetMain().contracts.Values)
- {
- <option value="@c.ID">
- [@c.ID] @c.Name [@c.Address]
- </option>
- }
- }
- }
- </select>
- <button @onclick="deleteContract">Удалить контракт</button>
- <p>
- @ctrSelected.Code
- </p>
- @ctrSelected.Name
- <br>
- @Blockchain.GetMain().id;
- <br />
- </p>
- <p>
- <select @bind="accountSelected">
- <option value="0">[Select Account]</option>
- @if (Blockchain.loaded.Count > 0)
- {
- @foreach (var acc in AccountModel.Loaded.Values)
- {
- <option value="@acc.UUID">
- [@acc.Email] @acc.Name
- </option>
- }
- }
- </select>
- @*<button @onclick="CreateBlockchainAccount">CreateBlockchainAccount for @accountSelected</button>*@
- <button @onclick="GetBalance">GetBalance</button> Balance: @balance
- <button @onclick="Transfer50">Transfer 50</button>
- <button @onclick="Unlock">Unlock</button>
- <div>Wallet:@myWallet</div>
- <div>Token balance:@balanceHCB</div>
- <br><br>
- @*<button @onclick="TransferContract">Transfer 10 by Contract</button>*@
- @*<button @onclick="EstimateGas">EstimateGas</button>*@
- @*<button onclick="window.location.href='@mypath'">Download 1</button>*@
- <p>Export address:</p>
- <button id="btn" @onclick="DloadJSON">Download JSON file</button>
- <button id="btn" @onclick="ExportPrivateKey">Private Key</button>
- <button id="btn" @onclick="PrivateKeyQR">QR code</button>
- </p>
- <br>
- <br>
- <div>@((MarkupString)qrr)</div>
- @*<p>Result: @result, gas: @gas</p>*@
- }
- @code
- {
- AccountModel account;
- private Random r = new Random();
- private string bcURL = Blockchain.URLdefault;
- private int bcport = Blockchain.defaultPort;
- private string bytecode = "";
- private string error = "";
- string lastTransAddr = "";
- string contractAddress = "";
- int focus = 0;
- string gas = "";
- async Task<string> PrivateKeyQR()
- {
- var code = await ExportPrivateKey();
- code = HyperCube.Models.Blockchain.QRtest(code);
- qrr = $"<img src=\"data: image / png; base64, {code}\"/>";
- return "";
- }
- async Task<string> ExportPrivateKey()
- {
- var wallet = await GetWallet();
- if (wallet != null)
- {
- var acc = AccountModel.Find(accountSelected);
- string text = getFiles(wallet, "key", acc.PWDHash);
- qrr = $"<p>{text}</p>";
- return text;
-
- }
- return "";
- }
- async Task<string> DloadJSON()
- {
- var wallet = await GetWallet();
- if (wallet != null)
- {
- string text = getFiles(wallet, "json");
- qrr = $"<p>{text}</p>";
- return await JsRuntime.InvokeAsync<string>("test", text);
- }
- return "";
- }
- async Task<string> GetWallet()
- {
- if (accountSelected != "" && accountSelected != null && accountSelected != "0")
- {
- var acc = AccountModel.Find(accountSelected);
- if (acc != null)
- {
- myWallet = await acc.GetOrCreateActualAddress(Blockchain.GetMain());
- return myWallet;
- }
- }
- return null;
- }
-
-
-
- async Task<string> Unlock()
- {
- var bc = Blockchain.GetMain();
- var ret = await bc.RunFunction("personal_unlockAccount", $"\"{bc.address}\",\"test_Password_212\",0");
-
-
- return ret;
- }
- async Task ImportERC20()
- {
- await Blockchain.GetMain().ImportERC20(tokenContract, myWallet);
-
- }
- async Task TransferToken()
- {
- await Blockchain.GetMain().TransferToken(Blockchain.GetMain().address, tokenContract, addressTo, tokenAmount);
- }
- async Task EstimateGas()
- {
- gas = await Blockchain.GetMain().GetEstimatedGasContractAdd(ctrSelected.ByteCode);
- }
- async Task deleteContract()
- {
- var main = Blockchain.GetMain();
- if (main != null)
- {
- main.contracts.Remove(ctrSelected.ID);
- main.contractNames.Remove(ctrSelected.Name);
- MySQLConnector.Instance().SQLInsert($"delete from smart_contracts where id ={ctrSelected.ID}");
- MySQLConnector.Instance().SQLInsert($"delete from functions where contract_id ={ctrSelected.ID}");
- ctrSelected = null;
- }
- }
- async Task checkCode()
- {
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- function_processed = await Blockchain.GetMain().compileFunction(function1, false);
- if (function1 != "()" && function1 != "")
- contractAddDisabled = "";
- else
- contractAddDisabled = "visible";
- }
- async Task<string> GetSHA3(string code)
- {
- var res = await Blockchain.GetMain().GetSHA3(code);
- Console.WriteLine($"GetSHA3 {code} {res}");
- var ret = res.Substring(2, 8);
- return ret;
- }
- async Task<string> GetSHA3_2()
- {
- var res = await Blockchain.GetMain().GetSHA3(sha3);
- Console.WriteLine($"GetSHA3 {res}");
- var ret = res.Substring(2, 8);
- return ret;
- }
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- private async Task Transfer50()
- {
- var acc = AccountModel.Find(accountSelected);
- var bc = Blockchain.GetMain();
- var addr = await acc.GetOrCreateActualAddress(bc);
- var res = await bc.SendTransaction(Blockchain.GetMain().address, addr, 50);
- }
- private async Task GetBalance()
- {
- Console.WriteLine("accountSelected " + accountSelected);
- if (accountSelected != "" && accountSelected != null && accountSelected != "0")
- {
- var acc = AccountModel.Find(accountSelected);
- if (acc != null)
- {
- myWallet = await acc.GetOrCreateActualAddress(Blockchain.GetMain());
- balance = await acc.GetBalance();
- }
- }
- else
- {
- myWallet = Blockchain.GetMain().address;
- balance = await Blockchain.GetMain().GetBalance();
- }
- await Blockchain.GetMain().GetBalanceToken("0xe5D682717955d6C35d465A3485625C64655a04f4", myWallet);
- }
-
-
-
-
-
-
-
-
- private async Task ChangeContract()
- {
- Console.WriteLine("ChangeContract " + contrtest);
-
-
- }
- private async Task RunContract()
- {
-
- }
- private async Task AddContract()
- {
- if (Blockchain.loaded.Count > 0)
- {
- var taddr = await Blockchain.GetMain().AddContract(newname, newcode, bytecode);
- if (taddr.Length > 0 && taddr[0] != "")
- {
- result = taddr[0].ToString();
-
- var caddr = await Blockchain.GetMain().GetReceipt(result, true);
- if (caddr != "")
- {
- result = "contractAddress: " + caddr;
- contractAddress = caddr;
-
- var smc = taddr[1] as SmartContract;
- smc.Address = contractAddress;
- MySQLConnector.Instance().SQLInsert($"update smart_contracts set address='{contractAddress}' where id= {smc.ID}");
-
-
- smc.AddFunction(function_processed, sha3);
- }
- }
- }
-
- }
- SmartContract GetContract(int id)
- {
- if (Blockchain.GetMain().contracts.ContainsKey(id))
- return Blockchain.GetMain().contracts[id];
- else
- return null;
- }
- protected override async Task OnInitializedAsync()
- {
-
- account = AccountModel.Current;
- Console.WriteLine($"Blockchains OnInitializedAsync");
- await GetBalance();
- }
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- }
|