2021-06-30 02:39:00 +00:00
|
|
|
|
const CONSENSUS_TABLE = {
|
|
|
|
|
0: '无',
|
|
|
|
|
1: 'PBFT',
|
|
|
|
|
2: 'RAFT',
|
|
|
|
|
3: 'Single'
|
|
|
|
|
};
|
2021-06-15 11:56:39 +00:00
|
|
|
|
|
2021-06-30 02:39:00 +00:00
|
|
|
|
const RESPONSE_TYPE_TABLE = {
|
|
|
|
|
0: 'ALL',
|
|
|
|
|
1: 'MOST',
|
|
|
|
|
2: 'FIRST'
|
2021-06-15 11:56:39 +00:00
|
|
|
|
};
|
|
|
|
|
|
2021-06-30 02:39:00 +00:00
|
|
|
|
function loadContractInstances(event) {
|
|
|
|
|
console.log("loadContractInstances" + event);
|
|
|
|
|
listContractProcess();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function listContractProcess(event) {
|
2021-06-21 09:23:41 +00:00
|
|
|
|
console.log("listContractProcess" + event);
|
|
|
|
|
setTimeout(function () {
|
2021-06-30 02:39:00 +00:00
|
|
|
|
global.wssocket.send(JSON.stringify({
|
|
|
|
|
action: 'listContractProcess',
|
|
|
|
|
// data: event,
|
|
|
|
|
// 1 << 0: INIT, 1 << 1: RUNNING, 1 << 2: HANGED, 1 << 3: KILLED, 0: ALL
|
|
|
|
|
filters: global.myRole && global.myRole.indexOf('NodeManager') > -1 ? 0 : 7
|
|
|
|
|
}));
|
2021-06-15 11:56:39 +00:00
|
|
|
|
|
2021-06-30 02:39:00 +00:00
|
|
|
|
global.wssocket.send(JSON.stringify({
|
|
|
|
|
action: 'listLeakContractProcess'
|
|
|
|
|
}));
|
2021-06-21 09:23:41 +00:00
|
|
|
|
}, 300);
|
2021-06-30 02:39:00 +00:00
|
|
|
|
}
|
2021-06-15 11:56:39 +00:00
|
|
|
|
|
2021-06-30 02:39:00 +00:00
|
|
|
|
function onListContractProcess1(obj) {
|
|
|
|
|
console.log("+++++++++=" + obj.data.length);
|
|
|
|
|
const table = JSON.parse(obj.data);
|
2021-06-21 09:23:41 +00:00
|
|
|
|
global.contractList = table;
|
|
|
|
|
drawContractInstanceStatusPie(table);
|
|
|
|
|
// drawContractInstanceTimesPie(table);
|
|
|
|
|
drawContractInstanceTypeTimesPie(table);
|
2021-06-30 02:39:00 +00:00
|
|
|
|
drawConInfoTable(table);
|
2021-06-21 09:23:41 +00:00
|
|
|
|
console.log(table);
|
|
|
|
|
$("#selectContractInstance").html("");
|
2021-06-30 02:39:00 +00:00
|
|
|
|
const x = document.getElementById("selectContractInstance");
|
2021-06-21 09:23:41 +00:00
|
|
|
|
x.options.length = 0;
|
|
|
|
|
x.add(new Option("选择...", " "));
|
2021-06-15 11:56:39 +00:00
|
|
|
|
|
2021-06-21 09:23:41 +00:00
|
|
|
|
global.permissionNameMap = {};
|
2021-06-30 02:39:00 +00:00
|
|
|
|
for (let i = 0; i < table.length; i++) {
|
|
|
|
|
if (table[i]['contractStatus'] !== 'RUNNING') {
|
2021-06-21 09:23:41 +00:00
|
|
|
|
continue;
|
|
|
|
|
}
|
2021-06-30 02:39:00 +00:00
|
|
|
|
let option = document.createElement("option");
|
2021-06-21 09:23:41 +00:00
|
|
|
|
option.text = table[i].name;
|
|
|
|
|
console.log(table[i].name);
|
2021-06-30 02:39:00 +00:00
|
|
|
|
global.permissionNameMap[table[i].id] = table[i]['contractPermission'];
|
2021-06-21 09:23:41 +00:00
|
|
|
|
// option.value=table[i].id;
|
|
|
|
|
option.value = table[i].id;
|
|
|
|
|
x.add(option, null);
|
|
|
|
|
}
|
2021-06-30 02:39:00 +00:00
|
|
|
|
}
|
2021-06-15 11:56:39 +00:00
|
|
|
|
|
2021-06-30 02:39:00 +00:00
|
|
|
|
function drawConInfoTable(table) {
|
|
|
|
|
const ciTabDiv = $("#ciTabDiv");
|
|
|
|
|
if (ciTabDiv.css("height") === "0px") {
|
|
|
|
|
console.log("drawConInfoTabDiv: ignore");
|
2021-06-21 09:23:41 +00:00
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
var dtLang = {
|
|
|
|
|
"sProcessing": "处理中...",
|
|
|
|
|
"lengthMenu": '显示 <select>' + '<option value="10">10</option>'
|
|
|
|
|
+ '<option value="50">50</option>'
|
|
|
|
|
+ '<option value="100">100</option>'
|
|
|
|
|
+ '<option value="-1">全部</option>' + '</select> 项结果',
|
|
|
|
|
"sZeroRecords": "没有匹配结果",
|
|
|
|
|
"sInfo": "显示第 _START_ 至 _END_ 项结果,共 _TOTAL_ 项",
|
|
|
|
|
"sInfoEmpty": "显示第 0 至 0 项结果,共 0 项",
|
|
|
|
|
"sInfoFiltered": "(由 _MAX_ 项结果过滤)",
|
|
|
|
|
"sInfoPostFix": "",
|
|
|
|
|
"sSearch": "搜索:",
|
|
|
|
|
"sUrl": "",
|
|
|
|
|
"sEmptyTable": "表中数据为空",
|
|
|
|
|
"sLoadingRecords": "载入中...",
|
|
|
|
|
"sInfoThousands": ",",
|
|
|
|
|
"oPaginate": {
|
|
|
|
|
"sFirst": "首页",
|
|
|
|
|
"sPrevious": "上页",
|
|
|
|
|
"sNext": "下页",
|
|
|
|
|
"sLast": "末页"
|
|
|
|
|
},
|
|
|
|
|
"oAria": {
|
|
|
|
|
"sSortAscending": ": 以升序排列此列",
|
|
|
|
|
"sSortDescending": ": 以降序排列此列"
|
|
|
|
|
}
|
|
|
|
|
};
|
2021-06-30 02:39:00 +00:00
|
|
|
|
const tableHead = `<table id='ciTabDivTab' class='table display row-border' style='word-break:keep-all;'>
|
|
|
|
|
<thead><tr>
|
|
|
|
|
<th>序号</th>
|
|
|
|
|
<th>ID</th>
|
|
|
|
|
<th>名称</th>
|
|
|
|
|
<th>状态</th>
|
|
|
|
|
<th>端口</th>
|
|
|
|
|
<th>类型</th>
|
|
|
|
|
<th>通讯</th>
|
|
|
|
|
<th>共识</th>
|
|
|
|
|
<!--<th>返回方式</th>-->
|
|
|
|
|
<th>次数</th>
|
|
|
|
|
<th>流量</th>
|
|
|
|
|
<th>内存</th>
|
|
|
|
|
<th>管理</th>
|
|
|
|
|
</tr>
|
|
|
|
|
</thead><tbody>`;
|
|
|
|
|
const tableTail = "</tbody></table>";
|
2021-06-15 11:56:39 +00:00
|
|
|
|
|
2021-06-30 02:39:00 +00:00
|
|
|
|
console.log("drawConInfoTable");
|
|
|
|
|
let html = tableHead;
|
|
|
|
|
for (let i = 0; i < table.length; i++) {
|
|
|
|
|
html += `<tr>
|
|
|
|
|
<td>${i + 1}</td>
|
|
|
|
|
<td>${table[i].id}</td>
|
|
|
|
|
<td><a href='/client/bdwareclient.html?self=true&contract=${table[i].id}' target='_blank'>
|
|
|
|
|
${table[i].name}
|
|
|
|
|
</a></td>
|
|
|
|
|
<td>${table[i]['contractStatus']}</td>
|
|
|
|
|
<td>${table[i].port || '-'}</td>
|
|
|
|
|
<td>${table[i].type}</td>
|
|
|
|
|
<td>${table[i]['networkType'] ? "P2P" : "TCP"}</td>
|
|
|
|
|
<td>${table[i]['consensusType'] ? CONSENSUS_TABLE[table[i]['consensusType']] : '无'}</td>
|
|
|
|
|
<!--<td>${table[i].responseType ? RESPONSE_TYPE_TABLE[table[i].responseType] : '-'}</td>-->
|
|
|
|
|
<td>${table[i].times}</td>
|
|
|
|
|
<td>${table[i]['traffic'] || '-'}</td>
|
|
|
|
|
<td>${table[i].storage || '-'}</td>
|
|
|
|
|
<td style='padding:2px 12px 2px 12px'>
|
|
|
|
|
<button onclick="stopContractByID('${table[i].id}')" class="btn btn-secondary">停止</button>
|
|
|
|
|
</td>
|
|
|
|
|
</tr>`
|
2021-06-21 09:23:41 +00:00
|
|
|
|
}
|
|
|
|
|
html += tableTail;
|
|
|
|
|
html = "<h5 class='card-title'>合约实例列表</h5>" + html;
|
2021-06-30 02:39:00 +00:00
|
|
|
|
ciTabDiv.html(html);
|
2021-06-15 11:56:39 +00:00
|
|
|
|
|
2021-06-21 09:23:41 +00:00
|
|
|
|
$("#ciTabDivTab").DataTable(
|
|
|
|
|
{
|
|
|
|
|
"language": dtLang,
|
|
|
|
|
"rowCallback": function (row, data, displayNum, displayIndex,
|
|
|
|
|
dataIndex) {
|
2021-06-15 11:56:39 +00:00
|
|
|
|
|
2021-06-21 09:23:41 +00:00
|
|
|
|
},
|
2021-06-30 02:39:00 +00:00
|
|
|
|
"headerCallback": function (thead/*, data, start, end, display*/) {
|
2021-06-21 09:23:41 +00:00
|
|
|
|
$(thead).css("background", primaryColor);
|
|
|
|
|
$(thead).css("color", "white");
|
|
|
|
|
$(thead).children().css("background", primaryColor);
|
|
|
|
|
$(thead).children().css("color", "white");
|
|
|
|
|
},
|
|
|
|
|
scrollCollapse: false,
|
|
|
|
|
paging: true,
|
|
|
|
|
pageLength: 10,
|
|
|
|
|
order: [[0, 'desc']],
|
|
|
|
|
"columnDefs": [
|
|
|
|
|
{
|
|
|
|
|
"targets": 1,
|
2021-06-30 02:39:00 +00:00
|
|
|
|
"render": function (data/*, type, row, meta*/) {
|
2021-06-21 09:23:41 +00:00
|
|
|
|
if (data.length > 8)
|
|
|
|
|
return "<span title='" + data + "'>"
|
|
|
|
|
+ data.substring(0, 8)
|
|
|
|
|
+ " ...</span>";
|
|
|
|
|
else
|
|
|
|
|
return data;
|
|
|
|
|
}
|
2021-06-15 11:56:39 +00:00
|
|
|
|
|
2021-06-21 09:23:41 +00:00
|
|
|
|
},]
|
|
|
|
|
});
|
2021-06-30 02:39:00 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function stopContractByID(contractID) {
|
|
|
|
|
$("#dialogBodyDiv").html("是否停止合约,ContractID:" + contractID);
|
2021-06-21 09:23:41 +00:00
|
|
|
|
showDialog("请确认", function () {
|
2021-06-30 02:39:00 +00:00
|
|
|
|
global.wssocket.send(JSON.stringify({
|
|
|
|
|
action: 'killContractProcess',
|
|
|
|
|
requestID: new Date().getTime().toString(),
|
|
|
|
|
id: contractID
|
|
|
|
|
}));
|
2021-06-15 11:56:39 +00:00
|
|
|
|
});
|
2021-06-30 02:39:00 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function drawContractInstanceStatusPie(table) {
|
|
|
|
|
const ciStatusPieDiv = $("#ciStatusPieDiv")
|
|
|
|
|
if (ciStatusPieDiv.css("height") === "0px") {
|
2021-06-21 09:23:41 +00:00
|
|
|
|
console.log("drawContractInstanceStatusPie: ignore");
|
|
|
|
|
return;
|
|
|
|
|
}
|
2021-06-30 02:39:00 +00:00
|
|
|
|
$(ciStatusPieDiv).html(
|
|
|
|
|
"<div class='col-12' id='ciStatusPieDivCanv' style='width:100%; min-height: 150px; padding: 0;'></div>");
|
|
|
|
|
const result = {};
|
|
|
|
|
for (let i = 0; i < table.length; i++) {
|
|
|
|
|
const obj = table[i];
|
|
|
|
|
if (!result[obj['contractStatus']]) {
|
|
|
|
|
result[obj['contractStatus']] = 1;
|
2021-06-21 09:23:41 +00:00
|
|
|
|
} else
|
2021-06-30 02:39:00 +00:00
|
|
|
|
result[obj['contractStatus']]++;
|
2021-06-21 09:23:41 +00:00
|
|
|
|
}
|
|
|
|
|
global.result = result;
|
2021-06-30 02:39:00 +00:00
|
|
|
|
const dataList = [];
|
|
|
|
|
const valDataList = [];
|
|
|
|
|
for (const key in result) {
|
2021-06-21 09:23:41 +00:00
|
|
|
|
dataList.push(key);
|
2021-06-30 02:39:00 +00:00
|
|
|
|
valDataList.push({
|
|
|
|
|
name: key,
|
|
|
|
|
value: result[key]
|
|
|
|
|
});
|
2021-06-21 09:23:41 +00:00
|
|
|
|
}
|
2021-06-15 11:56:39 +00:00
|
|
|
|
|
2021-06-30 02:39:00 +00:00
|
|
|
|
const myChart = echarts.init($("#ciStatusPieDivCanv")[0], 'walden');
|
|
|
|
|
const option222 = {
|
2021-06-21 09:23:41 +00:00
|
|
|
|
tooltip: {
|
|
|
|
|
trigger: 'item',
|
|
|
|
|
formatter: '{a} <br/>{b}: {c} ({d}%)'
|
|
|
|
|
},
|
|
|
|
|
legend: {
|
|
|
|
|
orient: 'vertical',
|
|
|
|
|
left: 10,
|
|
|
|
|
data: dataList
|
|
|
|
|
},
|
|
|
|
|
series: [{
|
|
|
|
|
name: '合约实例状态',
|
|
|
|
|
type: 'pie',
|
|
|
|
|
radius: ['50%', '70%'],
|
|
|
|
|
avoidLabelOverlap: false,
|
|
|
|
|
label: {
|
|
|
|
|
normal: {
|
|
|
|
|
show: false,
|
|
|
|
|
position: 'center'
|
|
|
|
|
},
|
|
|
|
|
emphasis: {
|
|
|
|
|
show: true,
|
|
|
|
|
textStyle: {
|
|
|
|
|
fontSize: '15',
|
|
|
|
|
fontWeight: 'bold'
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
labelLine: {
|
|
|
|
|
normal: {
|
|
|
|
|
show: false
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
data: valDataList
|
|
|
|
|
}]
|
|
|
|
|
};
|
|
|
|
|
myChart.setOption(option222);
|
2021-06-30 02:39:00 +00:00
|
|
|
|
}
|
2021-06-15 11:56:39 +00:00
|
|
|
|
|
2021-06-30 02:39:00 +00:00
|
|
|
|
function drawContractInstanceTimesPie(table) {
|
|
|
|
|
const ciTimesPieDiv = $("#ciTimesPieDiv");
|
|
|
|
|
if (ciTimesPieDiv.css("height") === "0px") {
|
2021-06-21 09:23:41 +00:00
|
|
|
|
console.log("drawContractInstanceTimesPie: ignore");
|
|
|
|
|
return;
|
|
|
|
|
}
|
2021-06-30 02:39:00 +00:00
|
|
|
|
ciTimesPieDiv.html(
|
|
|
|
|
"<div class='col-12' id='ciTimesPieDivCanv' style='width:100%; min-height: 150px; padding: 0;'></div>");
|
|
|
|
|
const result = {};
|
|
|
|
|
for (let i = 0; i < table.length; i++) {
|
|
|
|
|
const obj = table[i];
|
2021-06-21 09:23:41 +00:00
|
|
|
|
result[obj.name] = obj.times;
|
|
|
|
|
}
|
|
|
|
|
global.result = result;
|
2021-06-30 02:39:00 +00:00
|
|
|
|
const dataList = [];
|
|
|
|
|
const valDataList = [];
|
|
|
|
|
for (const key in result) {
|
2021-06-21 09:23:41 +00:00
|
|
|
|
dataList.push(key);
|
2021-06-30 02:39:00 +00:00
|
|
|
|
valDataList.push({
|
|
|
|
|
name: key,
|
|
|
|
|
value: result[key]
|
|
|
|
|
});
|
2021-06-21 09:23:41 +00:00
|
|
|
|
}
|
2021-06-15 11:56:39 +00:00
|
|
|
|
|
2021-06-30 02:39:00 +00:00
|
|
|
|
const myChart = echarts.init($("#ciTimesPieDivCanv")[0], 'walden');
|
2021-06-15 11:56:39 +00:00
|
|
|
|
|
2021-06-30 02:39:00 +00:00
|
|
|
|
const option222 = {
|
2021-06-21 09:23:41 +00:00
|
|
|
|
tooltip: {
|
|
|
|
|
trigger: 'item',
|
|
|
|
|
formatter: '{a} <br/>{b}: {c} ({d}%)'
|
|
|
|
|
},
|
|
|
|
|
legend: {
|
|
|
|
|
orient: 'vertical',
|
|
|
|
|
left: 10,
|
|
|
|
|
data: dataList
|
|
|
|
|
},
|
|
|
|
|
series: [{
|
|
|
|
|
name: '实例调用次数',
|
|
|
|
|
type: 'pie',
|
|
|
|
|
radius: ['50%', '70%'],
|
|
|
|
|
avoidLabelOverlap: false,
|
|
|
|
|
label: {
|
|
|
|
|
normal: {
|
|
|
|
|
show: false,
|
|
|
|
|
position: 'center'
|
|
|
|
|
},
|
|
|
|
|
emphasis: {
|
|
|
|
|
show: true,
|
|
|
|
|
textStyle: {
|
|
|
|
|
fontSize: '15',
|
|
|
|
|
fontWeight: 'bold'
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
labelLine: {
|
|
|
|
|
normal: {
|
|
|
|
|
show: false
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
data: valDataList
|
|
|
|
|
}]
|
|
|
|
|
};
|
|
|
|
|
myChart.setOption(option222);
|
2021-06-30 02:39:00 +00:00
|
|
|
|
}
|
2021-06-15 11:56:39 +00:00
|
|
|
|
|
2021-06-30 02:39:00 +00:00
|
|
|
|
function changeContractInstance(obj) {
|
|
|
|
|
let i;
|
2021-06-21 09:23:41 +00:00
|
|
|
|
console.log(obj);
|
|
|
|
|
global.contractInstance = obj;
|
2021-06-15 11:56:39 +00:00
|
|
|
|
|
2021-06-21 09:23:41 +00:00
|
|
|
|
console.log(typeof (obj));
|
|
|
|
|
showPermissionList(global.contractInstance);
|
2021-06-15 11:56:39 +00:00
|
|
|
|
|
2021-06-30 02:39:00 +00:00
|
|
|
|
let contract;
|
|
|
|
|
for (i = 0; i < global.contractList.length; i++) {
|
|
|
|
|
if (global.contractList[i].id === obj) {
|
2021-06-21 09:23:41 +00:00
|
|
|
|
contract = global.contractList[i];
|
|
|
|
|
global.instance = contract;
|
|
|
|
|
global.instanceName = contract.name;
|
|
|
|
|
global.instanceSequencing = contract.type;
|
|
|
|
|
global.useP2P = contract.useP2P;
|
|
|
|
|
listMemoryFiles(contract.name);
|
|
|
|
|
getSyncType(contract.name);
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
2021-06-15 11:56:39 +00:00
|
|
|
|
|
2021-06-21 09:23:41 +00:00
|
|
|
|
$("#selectContractFunction").html("");
|
2021-06-30 02:39:00 +00:00
|
|
|
|
const x = document.getElementById("selectContractFunction");
|
2021-06-21 09:23:41 +00:00
|
|
|
|
x.options.length = 0;
|
|
|
|
|
x.add(new Option("选择方法...", " "));
|
|
|
|
|
console.log("contract ", contract);
|
2021-06-30 02:39:00 +00:00
|
|
|
|
for (i = 0; i < contract['exportedFunctions'].length; i++) {
|
|
|
|
|
const option = document.createElement("option");
|
|
|
|
|
option.text = contract['exportedFunctions'][i].functionName;
|
|
|
|
|
option.value = contract['exportedFunctions'][i].functionName;
|
2021-06-21 09:23:41 +00:00
|
|
|
|
x.add(option, null);
|
|
|
|
|
}
|
2021-06-30 02:39:00 +00:00
|
|
|
|
}
|
2021-06-15 11:56:39 +00:00
|
|
|
|
|
2021-06-30 02:39:00 +00:00
|
|
|
|
function changeMemoryFiles(obj) {
|
2021-06-21 09:23:41 +00:00
|
|
|
|
console.log(obj);
|
|
|
|
|
global.memoryFile = obj;
|
2021-06-30 02:39:00 +00:00
|
|
|
|
}
|
2021-06-15 11:56:39 +00:00
|
|
|
|
|
2021-06-30 02:39:00 +00:00
|
|
|
|
function executeContractWithDynamicResult() {
|
|
|
|
|
const argDiv = $("#arg")[0]
|
2021-06-21 09:23:41 +00:00
|
|
|
|
console.log("executeContractWithDynamicResult");
|
2021-06-30 02:39:00 +00:00
|
|
|
|
const request = {};
|
2021-06-21 09:23:41 +00:00
|
|
|
|
request.action = "executeContract";
|
|
|
|
|
request.requestID = new Date().getTime() + "";
|
|
|
|
|
request.contractName = global.contractInstance;
|
|
|
|
|
request.sequencing = global.instanceSequencing;
|
|
|
|
|
request.useP2P = global.useP2P;
|
|
|
|
|
request.isDebug = executeContractAsDebug.checked;
|
2021-06-30 02:39:00 +00:00
|
|
|
|
const operation = $("#selectContractFunction")[0].value;
|
|
|
|
|
if (operation === " " && !operation) {
|
2021-06-21 09:23:41 +00:00
|
|
|
|
myToast("执行合约", "请选择合约方法!");
|
|
|
|
|
return;
|
|
|
|
|
}
|
2021-06-30 02:39:00 +00:00
|
|
|
|
request.arg = `{"action":"${operation}","arg":"${argDiv.value}"}`;
|
2021-06-21 09:23:41 +00:00
|
|
|
|
request.pubkey = global.sm2Key.publicKey;
|
|
|
|
|
request.withDyanmicAnalysis = true;
|
2021-06-30 02:39:00 +00:00
|
|
|
|
request.signature = sm2.doSignature(
|
|
|
|
|
`${request.contractID}|${operation}|${argDiv.value}|${global.sm2Key.publicKey}`,
|
|
|
|
|
global.sm2Key.privateKey,
|
|
|
|
|
{hash: true, der: true});
|
2021-06-21 09:23:41 +00:00
|
|
|
|
localStorage.setItem("persisArg", JSON.stringify(request));
|
|
|
|
|
global.wssocket.send(JSON.stringify(request));
|
2021-06-30 02:39:00 +00:00
|
|
|
|
}
|
2021-06-15 11:56:39 +00:00
|
|
|
|
|
2021-06-30 02:39:00 +00:00
|
|
|
|
function executeContract() {
|
|
|
|
|
const argDiv = $('#arg')[0];
|
|
|
|
|
const request = {};
|
2021-06-21 09:23:41 +00:00
|
|
|
|
request.action = "executeContract";
|
|
|
|
|
request.requestID = new Date().getTime() + "";
|
|
|
|
|
request.contractID = global.contractInstance;
|
2021-06-30 02:39:00 +00:00
|
|
|
|
const operation = $("#selectContractFunction")[0].value;
|
|
|
|
|
if (operation === " " && !operation) {
|
2021-06-21 09:23:41 +00:00
|
|
|
|
myToast("执行合约", "请选择合约方法!");
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
request.operation = operation;
|
2021-06-30 02:39:00 +00:00
|
|
|
|
request.arg = argDiv.value;
|
2021-06-21 09:23:41 +00:00
|
|
|
|
request.pubkey = global.sm2Key.publicKey;
|
2021-06-16 04:11:09 +00:00
|
|
|
|
request.isDebug = executeContractAsDebug.checked;
|
2021-06-21 09:23:41 +00:00
|
|
|
|
console.log(request.arg);
|
2021-07-01 09:42:39 +00:00
|
|
|
|
const gasLimit = $('#gasLimit').val()/1;
|
|
|
|
|
var toSign = request.contractID + "|"
|
|
|
|
|
+ request.operation + "|" + arg ;
|
|
|
|
|
if (gasLimit>0){
|
|
|
|
|
request.gasLimit = gasLimit;
|
|
|
|
|
toSign+= "|" + gasLimit;
|
|
|
|
|
}
|
|
|
|
|
toSign+= "|" + global.sm2Key.publicKey;
|
2021-06-30 02:39:00 +00:00
|
|
|
|
request.signature = sm2.doSignature(
|
2021-07-01 09:42:39 +00:00
|
|
|
|
toSign,
|
2021-06-30 02:39:00 +00:00
|
|
|
|
global.sm2Key.privateKey,
|
|
|
|
|
{hash: true, der: true});
|
2021-06-21 09:23:41 +00:00
|
|
|
|
localStorage.setItem("persisArg", JSON.stringify(request));
|
|
|
|
|
global.wssocket.send(JSON.stringify(request));
|
2021-06-30 02:39:00 +00:00
|
|
|
|
}
|
2021-06-15 11:56:39 +00:00
|
|
|
|
|
2021-06-30 02:39:00 +00:00
|
|
|
|
function onExecuteResult(obj) {
|
2021-06-21 09:23:41 +00:00
|
|
|
|
console.log("onExecuteResult obj.data", obj.data);
|
|
|
|
|
try {
|
2021-06-30 02:39:00 +00:00
|
|
|
|
const result = obj;
|
|
|
|
|
let styleTail = "<br>字符串格式";
|
2021-06-21 09:23:41 +00:00
|
|
|
|
$("#responseStatus").html("执行状态:" + result.status);
|
2021-06-30 02:39:00 +00:00
|
|
|
|
if (result['analysis']) {
|
2021-06-21 09:23:41 +00:00
|
|
|
|
$("#responseArea")[0].value = "执行结果:" + result.result + "\n动态分析结果:"
|
2021-06-30 02:39:00 +00:00
|
|
|
|
+ result['analysis'];
|
2021-06-21 09:23:41 +00:00
|
|
|
|
} else {
|
|
|
|
|
if (result.result instanceof Object) {
|
|
|
|
|
$("#responseArea")[0].value = JSON.stringify(result.result);
|
|
|
|
|
styleTail = "<br>JSON格式";
|
|
|
|
|
} else
|
|
|
|
|
$("#responseArea")[0].value = result.result;
|
|
|
|
|
}
|
2021-06-30 02:39:00 +00:00
|
|
|
|
$("#responseID").html(`请求ID:${obj['responseID']}`);
|
2021-07-01 09:42:39 +00:00
|
|
|
|
var gasInfo="";
|
|
|
|
|
if (obj.executionGas!=undefined && obj.executionGas>0)
|
|
|
|
|
gasInfo="<br>"+obj.executionGas+"gas";
|
|
|
|
|
$("#responseTime").html(`响应时间:${obj['executeTime']}ms${gasInfo}${styleTail}`);
|
2021-06-21 09:23:41 +00:00
|
|
|
|
} catch (e) {
|
2021-06-30 02:39:00 +00:00
|
|
|
|
$("#responseStatus").html("执行状态:Failed");
|
2021-06-21 09:23:41 +00:00
|
|
|
|
$("#responseArea")[0].value = obj.data;
|
2021-06-30 02:39:00 +00:00
|
|
|
|
$("#responseID").html(`请求ID:${obj['responseID']}`);
|
|
|
|
|
$("#responseTime").html(`响应时间:${obj['executeTime']}ms`);
|
2021-06-21 09:23:41 +00:00
|
|
|
|
}
|
2021-06-30 02:39:00 +00:00
|
|
|
|
}
|
2021-06-15 11:56:39 +00:00
|
|
|
|
|
2021-06-30 02:39:00 +00:00
|
|
|
|
function onHashResult(obj) {
|
2021-06-21 09:23:41 +00:00
|
|
|
|
$("#hashResult").html("数链指纹:" + obj.data);
|
2021-06-30 02:39:00 +00:00
|
|
|
|
}
|
2021-06-15 11:56:39 +00:00
|
|
|
|
|
2021-06-30 02:39:00 +00:00
|
|
|
|
function drawCPTable(table) {
|
2021-06-15 11:56:39 +00:00
|
|
|
|
console.log("drawCPTable");
|
|
|
|
|
global.contractprocess = table.data;
|
2021-06-30 02:39:00 +00:00
|
|
|
|
if ($("#ciTabDiv").css("height") === "0px") {
|
|
|
|
|
console.log("drawCPTableDiv: ignore");
|
2021-06-21 09:23:41 +00:00
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
var dtLang = {
|
|
|
|
|
"sProcessing": "处理中...",
|
|
|
|
|
"lengthMenu": '显示 <select>' + '<option value="10">10</option>'
|
|
|
|
|
+ '<option value="50">50</option>'
|
|
|
|
|
+ '<option value="100">100</option>'
|
|
|
|
|
+ '<option value="-1">全部</option>' + '</select> 项结果',
|
|
|
|
|
"sZeroRecords": "没有匹配结果",
|
|
|
|
|
"sInfo": "显示第 _START_ 至 _END_ 项结果,共 _TOTAL_ 项",
|
|
|
|
|
"sInfoEmpty": "显示第 0 至 0 项结果,共 0 项",
|
|
|
|
|
"sInfoFiltered": "(由 _MAX_ 项结果过滤)",
|
|
|
|
|
"sInfoPostFix": "",
|
|
|
|
|
"sSearch": "搜索:",
|
|
|
|
|
"sUrl": "",
|
|
|
|
|
"sEmptyTable": "表中数据为空",
|
|
|
|
|
"sLoadingRecords": "载入中...",
|
|
|
|
|
"sInfoThousands": ",",
|
|
|
|
|
"oPaginate": {
|
|
|
|
|
"sFirst": "首页",
|
|
|
|
|
"sPrevious": "上页",
|
|
|
|
|
"sNext": "下页",
|
|
|
|
|
"sLast": "末页"
|
|
|
|
|
},
|
|
|
|
|
"oAria": {
|
|
|
|
|
"sSortAscending": ": 以升序排列此列",
|
|
|
|
|
"sSortDescending": ": 以降序排列此列"
|
|
|
|
|
}
|
|
|
|
|
};
|
2021-06-30 02:39:00 +00:00
|
|
|
|
const tableHead = `<table id='cpTabDivTab' class='table display row-border'>
|
|
|
|
|
<thead><tr>
|
|
|
|
|
<th>序号</th>
|
|
|
|
|
<th>PID</th>
|
|
|
|
|
<th>是否泄漏</th>
|
|
|
|
|
<th>启动时间</th>
|
|
|
|
|
<th>CPUUser</th>
|
|
|
|
|
<th>CPUSyss</th>
|
|
|
|
|
<th>resident</th>
|
|
|
|
|
<th>memory</th>
|
|
|
|
|
<th>管理</th>
|
|
|
|
|
</tr></thead><tbody>`;
|
|
|
|
|
const tableTail = "</tbody></table>";
|
2021-06-15 11:56:39 +00:00
|
|
|
|
table = table.data;
|
2021-06-30 02:39:00 +00:00
|
|
|
|
console.log("drawConInfoTable");
|
|
|
|
|
let html = tableHead;
|
|
|
|
|
for (let i = 0; i < table.length; i++) {
|
|
|
|
|
html += `<tr>
|
|
|
|
|
<td>${i + 1}</td>
|
|
|
|
|
<td>${table[i].pid}</td>
|
|
|
|
|
<td>${table[i]['isLeak']}</td>
|
|
|
|
|
<td>${new Date(table[i]['cpuStart']).toLocaleString()}/td>
|
|
|
|
|
<td>${table[i]['cpuTotal']}</td>
|
|
|
|
|
<td>${table[i]['cpuSys']}</td>
|
|
|
|
|
<td>${(table[i]['resident'] / (1024 * 1024)).toFixed(2)}MB</td>
|
|
|
|
|
<td>${(table[i]['memsize'] / (1024 * 1024)).toFixed(2)}MB</td>
|
|
|
|
|
<td style='padding:2px 12px 2px 12px'>
|
|
|
|
|
<button onclick="stopContractByPID('${table[i].pid}')" class='btn btn-secondary'>停止</button>
|
|
|
|
|
</td>
|
|
|
|
|
</tr>`
|
2021-06-21 09:23:41 +00:00
|
|
|
|
}
|
|
|
|
|
html += tableTail;
|
2021-06-30 02:39:00 +00:00
|
|
|
|
html = `<h5 class='card-title'>合约进程列表</h5>${html}`;
|
2021-06-21 09:23:41 +00:00
|
|
|
|
$("#cpTabDiv").html(html);
|
2021-06-15 11:56:39 +00:00
|
|
|
|
|
2021-06-21 09:23:41 +00:00
|
|
|
|
$("#cpTabDivTab").DataTable(
|
|
|
|
|
{
|
|
|
|
|
"language": dtLang,
|
|
|
|
|
"rowCallback": function (row, data, displayNum, displayIndex,
|
|
|
|
|
dataIndex) {
|
2021-06-15 11:56:39 +00:00
|
|
|
|
|
2021-06-21 09:23:41 +00:00
|
|
|
|
},
|
2021-06-30 02:39:00 +00:00
|
|
|
|
"headerCallback": function (thead/*, data, start, end, display*/) {
|
2021-06-21 09:23:41 +00:00
|
|
|
|
$(thead).css("background", primaryColor);
|
|
|
|
|
$(thead).css("color", "white");
|
|
|
|
|
$(thead).children().css("background", primaryColor);
|
|
|
|
|
$(thead).children().css("color", "white");
|
|
|
|
|
},
|
|
|
|
|
scrollCollapse: false,
|
|
|
|
|
paging: true,
|
|
|
|
|
pageLength: 10,
|
|
|
|
|
order: [[0, 'desc']],
|
|
|
|
|
"columnDefs": [
|
|
|
|
|
{
|
|
|
|
|
"targets": 1,
|
2021-06-30 02:39:00 +00:00
|
|
|
|
"render": function (data/*, type, row, meta*/) {
|
2021-06-21 09:23:41 +00:00
|
|
|
|
if (data.length > 10)
|
2021-06-15 11:56:39 +00:00
|
|
|
|
// return "<span title='" + data + "'>"
|
|
|
|
|
// + data.substring(0, 10)
|
|
|
|
|
// + " ...</span>";
|
2021-06-21 09:23:41 +00:00
|
|
|
|
return data;
|
|
|
|
|
else
|
|
|
|
|
return data;
|
|
|
|
|
}
|
2021-06-15 11:56:39 +00:00
|
|
|
|
|
2021-06-21 09:23:41 +00:00
|
|
|
|
},]
|
|
|
|
|
});
|
2021-06-30 02:39:00 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function stopContractByPID(pid) {
|
2021-06-21 09:23:41 +00:00
|
|
|
|
$("#dialogBodyDiv").html("是否停止PID:" + pid);
|
|
|
|
|
showDialog("请确认", function () {
|
2021-06-30 02:39:00 +00:00
|
|
|
|
global.wssocket.send(JSON.stringify({
|
|
|
|
|
action: 'killProcessByPID',
|
|
|
|
|
pid: pid
|
|
|
|
|
}));
|
|
|
|
|
global.wssocket.send(JSON.stringify({
|
|
|
|
|
action: 'listLeakContractProcess'
|
|
|
|
|
}));
|
2021-06-15 11:56:39 +00:00
|
|
|
|
});
|
2021-06-30 02:39:00 +00:00
|
|
|
|
}
|