|
@ -32,8 +32,9 @@ function deployProject(force) { |
|
|
deploymentDialog.open(); |
|
|
deploymentDialog.open(); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
function deployContracts() |
|
|
function deployContracts(gas, callback) |
|
|
{ |
|
|
{ |
|
|
|
|
|
deploymentGas = gas; |
|
|
var jsonRpcUrl = "http://127.0.0.1:8080"; |
|
|
var jsonRpcUrl = "http://127.0.0.1:8080"; |
|
|
console.log("Deploying to " + jsonRpcUrl); |
|
|
console.log("Deploying to " + jsonRpcUrl); |
|
|
deploymentStarted(); |
|
|
deploymentStarted(); |
|
@ -50,6 +51,8 @@ function deployContracts() |
|
|
executeTr(0, 0, state, ctrAddresses, function(){ |
|
|
executeTr(0, 0, state, ctrAddresses, function(){ |
|
|
projectModel.deploymentAddresses = ctrAddresses; |
|
|
projectModel.deploymentAddresses = ctrAddresses; |
|
|
deploymentStepChanged(qsTr("Scenario deployed. Please wait for verifications")) |
|
|
deploymentStepChanged(qsTr("Scenario deployed. Please wait for verifications")) |
|
|
|
|
|
if (callback) |
|
|
|
|
|
callback(ctrAddresses) |
|
|
}); |
|
|
}); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
@ -135,16 +138,18 @@ function getFunction(ctrName, functionId) |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
var deploymentGas |
|
|
|
|
|
var trRealIndex = -1 |
|
|
function executeTr(blockIndex, trIndex, state, ctrAddresses, callBack) |
|
|
function executeTr(blockIndex, trIndex, state, ctrAddresses, callBack) |
|
|
{ |
|
|
{ |
|
|
|
|
|
trRealIndex++; |
|
|
var tr = state.blocks.get(blockIndex).transactions.get(trIndex); |
|
|
var tr = state.blocks.get(blockIndex).transactions.get(trIndex); |
|
|
var func = getFunction(tr.contractId, tr.functionId); |
|
|
var func = getFunction(tr.contractId, tr.functionId); |
|
|
console.log(func + " " + tr.contractId + " " + tr.functionId + " ") |
|
|
|
|
|
if (!func) |
|
|
if (!func) |
|
|
executeTrNextStep(blockIndex, trIndex, state, ctrAddresses, callBack); |
|
|
executeTrNextStep(blockIndex, trIndex, state, ctrAddresses, callBack); |
|
|
else |
|
|
else |
|
|
{ |
|
|
{ |
|
|
var gasCost = clientModel.toHex(clientModel.gasCosts[trIndex]); |
|
|
var gasCost = clientModel.toHex(deploymentGas[trRealIndex]); |
|
|
var rpcParams = { "from": deploymentDialog.worker.currentAccount, "gas": "0x" + gasCost }; |
|
|
var rpcParams = { "from": deploymentDialog.worker.currentAccount, "gas": "0x" + gasCost }; |
|
|
var params = replaceParamToken(func.parameters, tr.parameters, ctrAddresses); |
|
|
var params = replaceParamToken(func.parameters, tr.parameters, ctrAddresses); |
|
|
var encodedParams = clientModel.encodeParams(params, contractFromToken(tr.contractId), tr.functionId); |
|
|
var encodedParams = clientModel.encodeParams(params, contractFromToken(tr.contractId), tr.functionId); |
|
@ -223,6 +228,15 @@ function packageDapp(addresses) |
|
|
|
|
|
|
|
|
deploymentStepChanged(qsTr("Packaging application ...")); |
|
|
deploymentStepChanged(qsTr("Packaging application ...")); |
|
|
var deploymentDir = projectPath + deploymentId + "/"; |
|
|
var deploymentDir = projectPath + deploymentId + "/"; |
|
|
|
|
|
|
|
|
|
|
|
if (deploymentDialog.packageStep.packageDir !== "") |
|
|
|
|
|
deploymentDir = deploymentDialog.packageStep.packageDir |
|
|
|
|
|
else |
|
|
|
|
|
{ |
|
|
|
|
|
deploymentDir = projectPath + "package/" |
|
|
|
|
|
fileIo.makeDir(deploymentDir); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
projectModel.deploymentDir = deploymentDir; |
|
|
projectModel.deploymentDir = deploymentDir; |
|
|
fileIo.makeDir(deploymentDir); |
|
|
fileIo.makeDir(deploymentDir); |
|
|
for (var i = 0; i < projectListModel.count; i++) { |
|
|
for (var i = 0; i < projectListModel.count; i++) { |
|
@ -263,24 +277,18 @@ function packageDapp(addresses) |
|
|
deploymentAddresses = addresses; |
|
|
deploymentAddresses = addresses; |
|
|
saveProject(); |
|
|
saveProject(); |
|
|
|
|
|
|
|
|
if (deploymentDialog.packageStep.packageDir !== "") |
|
|
|
|
|
deploymentDir = deploymentDialog.packageStep.packageDir |
|
|
|
|
|
else |
|
|
|
|
|
{ |
|
|
|
|
|
deploymentDir = projectPath + "package/" |
|
|
|
|
|
fileIo.makeDir(deploymentDir); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
var packageRet = fileIo.makePackage(deploymentDir); |
|
|
var packageRet = fileIo.makePackage(deploymentDir); |
|
|
deploymentDialog.packageStep.packageHash = packageRet[0]; |
|
|
deploymentDialog.packageStep.packageHash = packageRet[0]; |
|
|
deploymentDialog.packageStep.packageBase64 = packageRet[1]; |
|
|
deploymentDialog.packageStep.packageBase64 = packageRet[1]; |
|
|
deploymentDialog.packageStep.localPackageUrl = packageRet[2] + "?hash=" + packageRet[0]; |
|
|
deploymentDialog.packageStep.localPackageUrl = packageRet[2] + "?hash=" + packageRet[0]; |
|
|
|
|
|
deploymentDialog.packageStep.lastDeployDate = date |
|
|
deploymentComplete() |
|
|
deploymentComplete() |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
function registerDapp(callback) |
|
|
function registerDapp(callback) |
|
|
{ |
|
|
{ |
|
|
var applicationUrlEth = deploymentDialog.registerStep.applicationUrlEth; |
|
|
var applicationUrlEth = deploymentDialog.registerStep.applicationUrlEth; |
|
|
|
|
|
projectModel.deploymentEthUrl = applicationUrlEth |
|
|
applicationUrlEth = formatAppUrl(applicationUrlEth); |
|
|
applicationUrlEth = formatAppUrl(applicationUrlEth); |
|
|
deploymentStepChanged(qsTr("Registering application on the Ethereum network ...")); |
|
|
deploymentStepChanged(qsTr("Registering application on the Ethereum network ...")); |
|
|
checkEthPath(applicationUrlEth, false, function (success) { |
|
|
checkEthPath(applicationUrlEth, false, function (success) { |
|
@ -512,7 +520,7 @@ function registerContentHash(registrar, callBack) |
|
|
function registerToUrlHint(callback) |
|
|
function registerToUrlHint(callback) |
|
|
{ |
|
|
{ |
|
|
deploymentStepChanged(qsTr("Registering application Resources (" + deploymentDialog.registerStep.applicationUrlHttp) + ") ..."); |
|
|
deploymentStepChanged(qsTr("Registering application Resources (" + deploymentDialog.registerStep.applicationUrlHttp) + ") ..."); |
|
|
|
|
|
projectModel.deploymentHttpUrl = deploymentDialog.registerStep.applicationUrlHttp |
|
|
urlHintAddress(function(urlHint){ |
|
|
urlHintAddress(function(urlHint){ |
|
|
var requests = []; |
|
|
var requests = []; |
|
|
var paramUrlHttp = clientModel.encodeStringParam(deploymentDialog.registerStep.applicationUrlHttp); |
|
|
var paramUrlHttp = clientModel.encodeStringParam(deploymentDialog.registerStep.applicationUrlHttp); |
|
|