Browse Source

Merge pull request #2543 from yann300/deploydialog

Mix - Deploydialog ui changes
cl-refactor
Arkadiy Paronyan 10 years ago
parent
commit
e8afa0b120
  1. 2
      mix/QBigInt.h
  2. 2
      mix/QFunctionDefinition.h
  3. 1
      mix/qml/Block.qml
  4. 54
      mix/qml/BlockChain.qml
  5. 198
      mix/qml/DeployContractStep.qml
  6. 21
      mix/qml/DeploymentDialog.qml
  7. 170
      mix/qml/DeploymentDialogSteps.qml
  8. 6
      mix/qml/DeploymentWorker.qml
  9. 55
      mix/qml/KeyValuePanel.qml
  10. 2
      mix/qml/PackagingStep.qml
  11. 20
      mix/qml/ProjectModel.qml
  12. 74
      mix/qml/RegisteringStep.qml
  13. 4
      mix/qml/ScenarioLoader.qml
  14. 2
      mix/qml/StatusPane.qml
  15. 3
      mix/qml/WebPreview.qml
  16. 39
      mix/qml/js/NetworkDeployment.js
  17. 3
      mix/qml/js/TransactionHelper.js

2
mix/QBigInt.h

@ -82,6 +82,8 @@ public:
BigIntVariant internalValue() const { return m_internalValue; } BigIntVariant internalValue() const { return m_internalValue; }
/// @returns a string representation of the big integer used. Invokable from QML. /// @returns a string representation of the big integer used. Invokable from QML.
Q_INVOKABLE QString value() const; Q_INVOKABLE QString value() const;
/// hex value.
Q_INVOKABLE QString hexValue() const { return QString::fromStdString(dev::toHex(dev::u256(value().toStdString()))); }
/// Set the value of the BigInteger used. Will use u256 type. Invokable from QML. /// Set the value of the BigInteger used. Will use u256 type. Invokable from QML.
Q_INVOKABLE void setValue(QString const& _value) { m_internalValue = dev::jsToU256(_value.toStdString()); } Q_INVOKABLE void setValue(QString const& _value) { m_internalValue = dev::jsToU256(_value.toStdString()); }
Q_INVOKABLE void setBigInt(QString const& _value) { m_internalValue = bigint(_value.toStdString()); } Q_INVOKABLE void setBigInt(QString const& _value) { m_internalValue = bigint(_value.toStdString()); }

2
mix/QFunctionDefinition.h

@ -55,6 +55,8 @@ public:
FixedHash<4> hash() const { return m_hash; } FixedHash<4> hash() const { return m_hash; }
/// Get the full hash of this function declaration on the contract ABI. /// Get the full hash of this function declaration on the contract ABI.
FixedHash<32> fullHash() const { return m_fullHash; } FixedHash<32> fullHash() const { return m_fullHash; }
/// Get the hash of this function declaration on the contract ABI. returns QString
Q_INVOKABLE QString qhash() const { return QString::fromStdString(m_hash.hex()); }
private: private:
int m_index; int m_index;

1
mix/qml/Block.qml

@ -105,6 +105,7 @@ ColumnLayout
anchors.verticalCenter: parent.verticalCenter anchors.verticalCenter: parent.verticalCenter
anchors.right: parent.right anchors.right: parent.right
anchors.rightMargin: 14 anchors.rightMargin: 14
visible: false
MouseArea MouseArea
{ {
anchors.fill: parent anchors.fill: parent

54
mix/qml/BlockChain.qml

@ -117,47 +117,7 @@ ColumnLayout {
RowLayout RowLayout
{ {
id: header Layout.preferredHeight: 10
spacing: 0
Layout.preferredHeight: 24
Rectangle
{
Layout.preferredWidth: statusWidth
Layout.preferredHeight: parent.height
color: "transparent"
Image {
id: debugImage
anchors.verticalCenter: parent.verticalCenter
anchors.horizontalCenter: parent.horizontalCenter
source: "qrc:/qml/img/recycleicon@2x.png"
width: statusWidth + 10
fillMode: Image.PreserveAspectFit
}
}
Rectangle
{
anchors.verticalCenter: parent.verticalCenter
Layout.preferredWidth: fromWidth
Label
{
anchors.verticalCenter: parent.verticalCenter
text: "From"
anchors.left: parent.left
anchors.leftMargin: horizontalMargin
}
}
Label
{
text: "To"
anchors.verticalCenter: parent.verticalCenter
Layout.preferredWidth: toWidth + cellSpacing
}
Label
{
text: ""
anchors.verticalCenter: parent.verticalCenter
Layout.preferredWidth: debugActionWidth
}
} }
Rectangle Rectangle
@ -178,18 +138,6 @@ ColumnLayout {
width: parent.width width: parent.width
spacing: 20 spacing: 20
Block
{
scenario: blockChainPanel.model
Layout.preferredWidth: blockChainScrollView.width
Layout.preferredHeight: 60
blockIndex: -1
transactions: []
status: ""
number: -2
trHeight: 60
}
Repeater // List of blocks Repeater // List of blocks
{ {
id: blockChainRepeater id: blockChainRepeater

198
mix/qml/DeployContractStep.qml

@ -12,12 +12,15 @@ Rectangle {
property variant paramsModel: [] property variant paramsModel: []
property variant worker property variant worker
property variant gas: [] property variant gas: []
property alias gasPrice: gasPriceInput
color: "#E3E3E3E3" color: "#E3E3E3E3"
signal deployed
anchors.fill: parent anchors.fill: parent
id: root id: root
property int labelWidth: 150 property int labelWidth: 150
function show() function show()
{ {
visible = true visible = true
@ -25,12 +28,13 @@ Rectangle {
contractList.change() contractList.change()
accountsModel.clear() accountsModel.clear()
for (var k in worker.accounts) for (var k in worker.accounts)
{
accountsModel.append(worker.accounts[k]) accountsModel.append(worker.accounts[k])
}
if (worker.accounts.length > 0) if (worker.currentAccount === "" && worker.accounts.length > 0)
{
worker.currentAccount = worker.accounts[0].id worker.currentAccount = worker.accounts[0].id
accountsList.currentIndex = 0
}
if (projectModel.deployBlockNumber !== -1) if (projectModel.deployBlockNumber !== -1)
{ {
@ -45,13 +49,28 @@ Rectangle {
function updateVerification(blockNumber, trLost) function updateVerification(blockNumber, trLost)
{ {
verificationLabel.text = blockNumber - projectModel.deployBlockNumber var nb = parseInt(blockNumber - projectModel.deployBlockNumber)
if (trLost.length > 0) verificationTextArea.visible = false
verificationLabel.visible = true
if (nb >= 10)
{ {
verificationLabel.text += "\n" + qsTr("Transactions lost") + "\n" verificationLabel.text = qsTr("contracts deployment verified")
for (var k in trLost) verificationLabel.color = "green"
}
else
{
verificationLabel.text = nb
if (trLost.length > 0)
{ {
verificationLabel.text += trLost[k] + "\n" verificationTextArea.visible = true
verificationLabel.visible = false
deploymentStepChanged("following transactions are invalidated:")
verificationTextArea.text += "\n" + qsTr("Transactions lost") + "\n"
for (var k in trLost)
{
deploymentStepChanged(trLost[k])
verificationTextArea.text += trLost[k] + "\n"
}
} }
} }
} }
@ -250,7 +269,6 @@ Rectangle {
{ {
worker.currentAccount = currentText worker.currentAccount = currentText
accountBalance.text = worker.balance(currentText).format() accountBalance.text = worker.balance(currentText).format()
console.log(worker.balance(currentText).format())
} }
} }
@ -280,6 +298,11 @@ Rectangle {
displayUnitSelection: true displayUnitSelection: true
displayFormattedValue: true displayFormattedValue: true
edit: true edit: true
function toHexWei()
{
return "0x" + gasPriceInput.value.toWei().hexValue()
}
} }
Connections Connections
@ -329,9 +352,7 @@ Rectangle {
root.gas = gas root.gas = gas
cost = 0 cost = 0
for (var k in gas) for (var k in gas)
{
cost += gas[k] cost += gas[k]
}
setCost() setCost()
} }
}); });
@ -349,7 +370,7 @@ Rectangle {
width: labelWidth width: labelWidth
Label Label
{ {
text: qsTr("Cost Estimate") text: qsTr("Deployment Cost")
anchors.right: parent.right anchors.right: parent.right
anchors.verticalCenter: parent.verticalCenter anchors.verticalCenter: parent.verticalCenter
} }
@ -365,92 +386,87 @@ Rectangle {
} }
} }
RowLayout Rectangle
{ {
id: deployedRow border.color: "#cccccc"
border.width: 2
Layout.fillWidth: true Layout.fillWidth: true
Rectangle Layout.preferredHeight: parent.height + 25
color: "transparent"
id: rectDeploymentVariable
ScrollView
{ {
width: labelWidth anchors.fill: parent
Label anchors.topMargin: 4
anchors.bottomMargin: 4
ColumnLayout
{ {
id: labelAddresses RowLayout
text: qsTr("Deployed Contracts")
anchors.right: parent.right
anchors.verticalCenter: parent.verticalCenter
}
}
ColumnLayout
{
anchors.top: parent.top
anchors.topMargin: 1
ListModel
{
id: deployedAddrModel
}
Repeater
{
id: deployedAddresses
model: deployedAddrModel
function refresh()
{ {
deployedAddrModel.clear() id: deployedRow
deployedRow.visible = Object.keys(projectModel.deploymentAddresses).length > 0 Layout.fillWidth: true
for (var k in projectModel.deploymentAddresses) Rectangle
{ {
if (k.indexOf("-") !== -1) // this is an contract instance. ctr without - are the last deployed (to support old project) width: labelWidth
deployedAddrModel.append({ id: k, value: projectModel.deploymentAddresses[k]}) Label
{
id: labelAddresses
text: qsTr("Deployed Contracts")
anchors.right: parent.right
anchors.verticalCenter: parent.verticalCenter
}
}
ColumnLayout
{
anchors.top: parent.top
anchors.topMargin: 1
width: parent.width
id: deployedAddresses
function refresh()
{
textAddresses.text = ""
deployedRow.visible = Object.keys(projectModel.deploymentAddresses).length > 0
textAddresses.text = JSON.stringify(projectModel.deploymentAddresses, null, ' ')
}
TextArea
{
anchors.fill: parent
id: textAddresses
}
} }
} }
Rectangle RowLayout
{ {
Layout.preferredHeight: 20 id: verificationRow
Layout.preferredWidth: 235 Layout.fillWidth: true
color: "transparent" visible: Object.keys(projectModel.deploymentAddresses).length > 0
Label Rectangle
{ {
id: labelContract width: labelWidth
width: 112 Label
elide: Text.ElideRight {
text: index > -1 ? deployedAddrModel.get(index).id : "" text: qsTr("Verifications")
anchors.right: parent.right
anchors.verticalCenter: parent.verticalCenter
}
} }
TextField TextArea
{ {
width: 123 id: verificationTextArea
anchors.verticalCenter: parent.verticalCenter visible: false
anchors.left: labelContract.right
text: index > - 1 ? deployedAddrModel.get(index).value : ""
} }
}
}
}
}
RowLayout Label
{ {
id: verificationRow id: verificationLabel
Layout.fillWidth: true visible: true
visible: Object.keys(projectModel.deploymentAddresses).length > 0 }
Rectangle }
{
width: labelWidth
Label
{
text: qsTr("Verifications")
anchors.right: parent.right
anchors.verticalCenter: parent.verticalCenter
} }
} }
Label
{
id: verificationLabel
maximumLineCount: 20
}
} }
} }
@ -460,12 +476,31 @@ Rectangle {
Layout.alignment: Qt.BottomEdge Layout.alignment: Qt.BottomEdge
Button Button
{ {
Layout.preferredHeight: 22
anchors.right: deployBtn.left
text: qsTr("Reset")
action: clearDeployAction
}
Action {
id: clearDeployAction
onTriggered: {
worker.forceStopPooling()
fileIo.deleteDir(projectModel.deploymentDir)
projectModel.cleanDeploymentStatus()
deploymentDialog.steps.reset()
}
}
Button
{
id: deployBtn
anchors.right: parent.right anchors.right: parent.right
text: qsTr("Deploy Contracts") text: qsTr("Deploy Contracts")
onClicked: onClicked:
{ {
projectModel.deployedScenarioIndex = contractList.currentIndex projectModel.deployedScenarioIndex = contractList.currentIndex
NetworkDeploymentCode.deployContracts(root.gas, function(addresses, trHashes) NetworkDeploymentCode.deployContracts(root.gas, gasPriceInput.toHexWei(), function(addresses, trHashes)
{ {
projectModel.deploymentTrHashes = trHashes projectModel.deploymentTrHashes = trHashes
worker.verifyHashes(trHashes, function (nb, trLost) worker.verifyHashes(trHashes, function (nb, trLost)
@ -473,6 +508,7 @@ Rectangle {
projectModel.deployBlockNumber = nb projectModel.deployBlockNumber = nb
projectModel.saveProject() projectModel.saveProject()
root.updateVerification(nb, trLost) root.updateVerification(nb, trLost)
root.deployed()
}) })
projectModel.deploymentAddresses = addresses projectModel.deploymentAddresses = addresses
projectModel.saveProject() projectModel.saveProject()

21
mix/qml/DeploymentDialog.qml

@ -22,6 +22,7 @@ Dialog {
property alias packageStep: packageStep property alias packageStep: packageStep
property alias registerStep: registerStep property alias registerStep: registerStep
property alias worker: worker property alias worker: worker
property alias steps: steps
function close() function close()
{ {
@ -52,15 +53,31 @@ Dialog {
anchors.fill: parent anchors.fill: parent
anchors.margins: 10 anchors.margins: 10
RowLayout Rectangle
{ {
id: explanation id: explanation
Layout.preferredWidth: parent.width - 50 Layout.preferredWidth: parent.width - 50
Layout.preferredHeight: 50 Layout.preferredHeight: 50
color: "transparent"
Label Label
{ {
id: info
anchors.centerIn: parent anchors.centerIn: parent
text: qsTr("Putting your dapp live is a multi step process. You can read more about it on the 'guide to uploading'.") text: qsTr("Putting your dapp live is a multi step process. You can read more about it on the")
}
Text {
anchors.left: info.right
anchors.leftMargin: 7
id: linkText
text: '<html><style type="text/css"></style><a href="https://github.com/ethereum/wiki/wiki/Mix:-The-DApp-IDE#deployment-to-network">guide to uploading</a></html>'
onLinkActivated: Qt.openUrlExternally("https://github.com/ethereum/wiki/wiki/Mix:-The-DApp-IDE#deployment-to-network")
anchors.verticalCenter: parent.verticalCenter
MouseArea
{
anchors.fill: parent
cursorShape: Qt.PointingHandCursor
}
} }
} }

170
mix/qml/DeploymentDialogSteps.qml

@ -26,13 +26,55 @@ Rectangle {
selected(step) selected(step)
} }
function reset()
{
for (var k in deployLogs.logs)
{
deployLogs.logs[k] = ""
}
deployLogs.switchLogs()
refreshCurrent()
}
border.color: "#cccccc" border.color: "#cccccc"
border.width: 1 border.width: 1
Connections
{
id: deployStatus
target: deploymentDialog.deployStep
onDeployed:
{
console.log("deployed")
}
}
Connections
{
id: packagedStatus
target: deploymentDialog.packageStep
onPackaged:
{
console.log("packaged")
}
}
Connections
{
id: registerStatus
target: deploymentDialog.registerStep
onRegistered:
{
console.log("registered")
}
}
ColumnLayout ColumnLayout
{ {
anchors.fill: parent anchors.fill: parent
anchors.margins: 1 anchors.margins: 1
spacing: 0
Repeater Repeater
{ {
id: menu id: menu
@ -45,7 +87,7 @@ Rectangle {
{ {
step: 2, step: 2,
type:"package", type:"package",
label: qsTr("Package files") label: qsTr("Package Dapp")
}, },
{ {
step: 3, step: 3,
@ -70,6 +112,7 @@ Rectangle {
labelContainer.state = "selected" labelContainer.state = "selected"
sel = index sel = index
itemClicked(menu.model[index].type) itemClicked(menu.model[index].type)
deployLogs.switchLogs()
} }
function unselect() function unselect()
@ -136,62 +179,60 @@ Rectangle {
} }
Connections { Connections {
target: projectModel property var logs: ({})
onDeploymentStarted: log.text = log.text + qsTr("Running deployment...") + "\n" id: deployLogs
onDeploymentError: log.text = log.text + error + "\n"
onDeploymentComplete: log.text = log.text + qsTr("Deployment complete") + "\n"
onDeploymentStepChanged: log.text = log.text + message + "\n"
}
Rectangle function switchLogs()
{ {
Layout.fillWidth: true if (root.sel)
Layout.preferredHeight: 1 {
color: "#cccccc" if (!logs[root.sel])
} logs[root.sel] = ""
log.text = logs[root.sel]
}
}
RowLayout target: projectModel
{ onDeploymentStarted:
anchors.horizontalCenter: parent.horizontalCenter
Layout.preferredHeight: 20
anchors.left: parent.left
anchors.leftMargin: 2
Button
{ {
Layout.preferredHeight: 22 if (!logs[root.sel])
Layout.preferredWidth: 22 logs[root.sel] = ""
action: clearAction logs[root.sel] = logs[root.sel] + qsTr("Running deployment...") + "\n"
iconSource: "qrc:/qml/img/cleariconactive.png" log.text = logs[root.sel]
} }
Action { onDeploymentError:
id: clearAction {
enabled: log.text !== "" if (!logs[root.sel])
tooltip: qsTr("Clear") logs[root.sel] = ""
onTriggered: { logs[root.sel] = logs[root.sel] + error + "\n"
log.text = "" log.text = logs[root.sel]
}
} }
Button onDeploymentComplete:
{ {
Layout.preferredHeight: 22 if (!logs[root.sel])
text: qsTr("Clear Deployment") logs[root.sel] = ""
action: clearDeployAction logs[root.sel] = logs[root.sel] + qsTr("Deployment complete") + "\n"
log.text = logs[root.sel]
} }
Action { onDeploymentStepChanged:
id: clearDeployAction {
onTriggered: { if (!logs[root.sel])
worker.forceStopPooling() logs[root.sel] = ""
fileIo.deleteDir(projectModel.deploymentDir) logs[root.sel] = logs[root.sel] + message + "\n"
projectModel.cleanDeploymentStatus() log.text = logs[root.sel]
root.refreshCurrent()
log.text = ""
}
} }
} }
Rectangle
{
Layout.fillWidth: true
Layout.preferredHeight: 2
color: "#cccccc"
}
ScrollView ScrollView
{ {
Layout.fillHeight: true Layout.fillHeight: true
@ -205,6 +246,47 @@ Rectangle {
id: log id: log
} }
} }
Rectangle
{
Layout.preferredHeight: 20
Layout.fillWidth: true
color: "#cccccc"
LogsPaneStyle
{
id: style
}
Label
{
anchors.horizontalCenter: parent.horizontalCenter
anchors.verticalCenter: parent.verticalCenter
text: qsTr("Logs")
font.italic: true
font.pointSize: style.absoluteSize(-1)
}
Button
{
height: 20
width: 20
anchors.right: parent.right
action: clearAction
iconSource: "qrc:/qml/img/cleariconactive.png"
tooltip: qsTr("Clear Messages")
}
Action {
id: clearAction
enabled: log.text !== ""
tooltip: qsTr("Clear")
onTriggered: {
deployLogs.logs[root.sel] = ""
log.text = deployLogs.logs[root.sel]
}
}
}
} }
} }

6
mix/qml/DeploymentWorker.qml

@ -38,6 +38,7 @@ Item
var ids = JSON.parse(arg2)[0].result; var ids = JSON.parse(arg2)[0].result;
requests = []; requests = [];
accounts = []
for (var k in ids) for (var k in ids)
{ {
requests.push({ requests.push({
@ -52,6 +53,7 @@ Item
TransactionHelper.rpcCall(requests, function (request, response){ TransactionHelper.rpcCall(requests, function (request, response){
var balanceRet = JSON.parse(response); var balanceRet = JSON.parse(response);
balances = {}
for (var k in balanceRet) for (var k in balanceRet)
{ {
var ether = QEtherHelper.createEther(balanceRet[k].result, QEther.Wei); var ether = QEtherHelper.createEther(balanceRet[k].result, QEther.Wei);
@ -206,7 +208,7 @@ Item
property var callBack property var callBack
property int elapsed property int elapsed
property string hash property string hash
interval: 500 interval: 2000
running: false running: false
repeat: true repeat: true
onTriggered: { onTriggered: {
@ -227,7 +229,7 @@ Item
stop(); stop();
callBack(1, receipt); callBack(1, receipt);
} }
else if (elapsed > 250000) else if (elapsed > 2500000)
{ {
stop(); stop();
callBack(-1, null); callBack(-1, null);

55
mix/qml/KeyValuePanel.qml

@ -82,45 +82,44 @@ ColumnLayout {
clip: true clip: true
ColumnLayout ColumnLayout
{ {
anchors.margins: 10 spacing: 0
id: colValue
anchors.top: parent.top
anchors.topMargin: 5
Repeater Repeater
{ {
id: repeaterKeyValue id: repeaterKeyValue
model: modelKeyValue model: modelKeyValue
RowLayout Row
{ {
Layout.fillWidth: true
Layout.preferredHeight: 30 Layout.preferredHeight: 30
spacing: 0 spacing: 5
Rectangle anchors.left: colValue.left
anchors.leftMargin: 5
Label
{ {
Layout.preferredWidth: columnValues.width / 2 maximumLineCount: 1
Label text: {
{ if (index >= 0 && repeaterKeyValue.model.get(index).key !== undefined)
anchors.left: parent.left return repeaterKeyValue.model.get(index).key
anchors.leftMargin: 10 else
text: { return ""
if (index >= 0 && repeaterKeyValue.model.get(index).key !== undefined)
return repeaterKeyValue.model.get(index).key
else
return ""
}
} }
} }
Rectangle Label
{ {
Layout.preferredWidth: columnValues.width / 2 - 10 text: "="
Label }
{
anchors.right: parent.right Label
anchors.rightMargin: 10 {
text: { maximumLineCount: 1
if (index >= 0 && repeaterKeyValue.model.get(index).value !== undefined) text: {
return repeaterKeyValue.model.get(index).value if (index >= 0 && repeaterKeyValue.model.get(index).value !== undefined)
else return repeaterKeyValue.model.get(index).value
return "" else
} return ""
} }
} }
} }

2
mix/qml/PackagingStep.qml

@ -20,6 +20,7 @@ Rectangle {
property alias lastDeployDate: lastDeployLabel.text property alias lastDeployDate: lastDeployLabel.text
property string deploymentId property string deploymentId
property string packageDir property string packageDir
signal packaged
function show() function show()
{ {
@ -107,6 +108,7 @@ Rectangle {
{ {
NetworkDeploymentCode.packageDapp(projectModel.deploymentAddresses); NetworkDeploymentCode.packageDapp(projectModel.deploymentAddresses);
projectModel.saveProject() projectModel.saveProject()
root.packaged()
} }
} }

20
mix/qml/ProjectModel.qml

@ -80,20 +80,14 @@ Item {
function getDocumentIndex(documentId) { return ProjectModelCode.getDocumentIndex(documentId); } function getDocumentIndex(documentId) { return ProjectModelCode.getDocumentIndex(documentId); }
function addExistingFiles(paths) { ProjectModelCode.doAddExistingFiles(paths); } function addExistingFiles(paths) { ProjectModelCode.doAddExistingFiles(paths); }
function deployProject() { NetworkDeploymentCode.deployProject(false); } function deployProject() { NetworkDeploymentCode.deployProject(false); }
function registerToUrlHint(url, callback) { NetworkDeploymentCode.registerToUrlHint(url, callback); } function registerToUrlHint(url, gasPrice, callback) { NetworkDeploymentCode.registerToUrlHint(url, gasPrice, callback); }
function formatAppUrl() { NetworkDeploymentCode.formatAppUrl(url); } function formatAppUrl() { NetworkDeploymentCode.formatAppUrl(url); }
function cleanDeploymentStatus() function cleanDeploymentStatus()
{ {
deployedScenarioIndex = 0 deployedScenarioIndex = 0
applicationUrlEth = ""
applicationUrlHttp = ""
deployBlockNumber = "" deployBlockNumber = ""
deploymentTrHashes = {} deploymentTrHashes = {}
registerContentHashTrHash = ""
registerUrlTrHash = ""
registerContentHashBlockNumber = -1
registerUrlBlockNumber = -1
deploymentAddresses = {} deploymentAddresses = {}
deploymentDir = "" deploymentDir = ""
deploymentDialog.packageStep.packageHash = "" deploymentDialog.packageStep.packageHash = ""
@ -102,6 +96,18 @@ Item {
deploymentDialog.packageStep.lastDeployDate = "" deploymentDialog.packageStep.lastDeployDate = ""
deploymentDialog.packageStep.localPackageUrl = "" deploymentDialog.packageStep.localPackageUrl = ""
saveProject() saveProject()
cleanRegisteringStatus()
}
function cleanRegisteringStatus()
{
applicationUrlEth = ""
applicationUrlHttp = ""
registerContentHashTrHash = ""
registerUrlTrHash = ""
registerContentHashBlockNumber = -1
registerUrlBlockNumber = -1
saveProject()
} }
Connections { Connections {

74
mix/qml/RegisteringStep.qml

@ -19,42 +19,58 @@ Rectangle {
id: root id: root
color: "#E3E3E3E3" color: "#E3E3E3E3"
anchors.fill: parent anchors.fill: parent
signal registered
function show() function show()
{ {
ctrRegisterLabel.calculateRegisterGas() ctrRegisterLabel.calculateRegisterGas()
applicationUrlEthCtrl.text = projectModel.applicationUrlEth if (applicationUrlHttpCtrl.text === "")
applicationUrlHttpCtrl.text = projectModel.applicationUrlHttp applicationUrlHttpCtrl.text = projectModel.applicationUrlHttp
if (applicationUrlEthCtrl.text === "")
applicationUrlEthCtrl.text = projectModel.applicationUrlEth
visible = true visible = true
verificationEthUrl.text = "" verificationEthUrl.text = ""
if (projectModel.registerContentHashTrHash !== "") if (projectModel.registerContentHashTrHash !== "" && projectModel.registerContentHashBlockNumber !== -1)
{ {
worker.verifyHash("registerHash", projectModel.registerContentHashTrHash, function(bn, trLost) worker.verifyHash("registerHash", projectModel.registerContentHashTrHash, function(bn, trLost)
{ {
updateVerification(projectModel.registerContentHashBlockNumber, bn, trLost, verificationEthUrl) updateVerification(projectModel.registerContentHashBlockNumber, bn, trLost, verificationEthUrl, "registerHash")
}); });
} }
else if (projectModel.registerContentHashTrHash !== "" && projectModel.registerContentHashBlockNumber === -1)
verificationEthUrl.text = qsTr("waiting verifications")
verificationUrl.text = "" verificationUrl.text = ""
if (projectModel.registerUrlTrHash !== "") if (projectModel.registerUrlTrHash !== "" && projectModel.registerUrlBlockNumber !== -1)
{ {
worker.verifyHash("registerUrl", projectModel.registerUrlTrHash, function(bn, trLost) worker.verifyHash("registerUrl", projectModel.registerUrlTrHash, function(bn, trLost)
{ {
updateVerification(projectModel.registerUrlBlockNumber, bn, trLost, verificationUrl) updateVerification(projectModel.registerUrlBlockNumber, bn, trLost, verificationUrl, "registerUrl")
}); });
} }
else if (projectModel.registerUrlTrHash !== "" && projectModel.registerUrlBlockNumber === -1)
verificationUrl.text = qsTr("waiting verifications")
} }
function updateVerification(originbn, bn, trLost, ctrl) function updateVerification(originbn, bn, trLost, ctrl, trContext)
{ {
if (trLost.length === 0) if (trLost.length === 0)
{ {
ctrl.text = bn - originbn ctrl.text = bn - originbn
ctrl.text += qsTr(" verifications") if (parseInt(bn - originbn) >= 10)
{
ctrl.color= "green"
ctrl.text= qsTr("verified")
}
else
ctrl.text += qsTr(" verifications")
} }
else else
{ {
deploymentStepChanged(trContext + qsTr(" has been invalidated.") + trLost[0] + " " + qsTr("no longer present") )
ctrl.text = qsTr("invalidated") ctrl.text = qsTr("invalidated")
} }
} }
@ -124,6 +140,7 @@ Rectangle {
{ {
id: verificationUrl id: verificationUrl
anchors.verticalCenter: parent.verticalCenter anchors.verticalCenter: parent.verticalCenter
font.italic: true
} }
} }
@ -136,7 +153,7 @@ Rectangle {
Layout.preferredWidth: col.width / 2 Layout.preferredWidth: col.width / 2
Label Label
{ {
text: qsTr("Gas to use for dapp registration") text: qsTr("Registration Cost")
anchors.right: parent.right anchors.right: parent.right
anchors.verticalCenter: parent.verticalCenter anchors.verticalCenter: parent.verticalCenter
id: ctrRegisterLabel id: ctrRegisterLabel
@ -148,9 +165,12 @@ Rectangle {
NetworkDeploymentCode.checkPathCreationCost(applicationUrlEthCtrl.text, function(pathCreationCost) NetworkDeploymentCode.checkPathCreationCost(applicationUrlEthCtrl.text, function(pathCreationCost)
{ {
var ether = QEtherHelper.createBigInt(pathCreationCost); var ether = QEtherHelper.createBigInt(pathCreationCost);
var gasTotal = ether.multiply(worker.gasPriceInt); if (deploymentDialog.deployStep.gasPrice.value)
gasToUseDeployInput.value = QEtherHelper.createEther(gasTotal.value(), QEther.Wei, parent); {
gasToUseDeployInput.update(); var gasTotal = ether.multiply(deploymentDialog.deployStep.gasPrice.value.toWei());
gasToUseDeployInput.value = QEtherHelper.createEther(gasTotal.value(), QEther.Wei, parent);
gasToUseDeployInput.update();
}
}); });
} }
} }
@ -159,9 +179,9 @@ Rectangle {
Ether Ether
{ {
id: gasToUseDeployInput id: gasToUseDeployInput
displayUnitSelection: true displayUnitSelection: false
displayFormattedValue: true displayFormattedValue: true
edit: true edit: false
Layout.preferredWidth: 235 Layout.preferredWidth: 235
} }
} }
@ -224,6 +244,10 @@ Rectangle {
Label Label
{ {
id: verificationEthUrl id: verificationEthUrl
anchors.verticalCenter: parent.verticalCenter;
anchors.topMargin: 10
font.italic: true
font.pointSize: appStyle.absoluteSize(-1)
} }
} }
} }
@ -234,7 +258,7 @@ Rectangle {
anchors.bottomMargin: 10 anchors.bottomMargin: 10
width: parent.width width: parent.width
function registerHash(callback) function registerHash(gasPrice, callback)
{ {
var inError = []; var inError = [];
var ethUrl = NetworkDeploymentCode.formatAppUrl(applicationUrlEthCtrl.text); var ethUrl = NetworkDeploymentCode.formatAppUrl(applicationUrlEthCtrl.text);
@ -244,10 +268,11 @@ Rectangle {
inError.push(qsTr("Member too long: " + ethUrl[k]) + "\n"); inError.push(qsTr("Member too long: " + ethUrl[k]) + "\n");
} }
if (!worker.stopForInputError(inError)) if (!worker.stopForInputError(inError))
{ {
NetworkDeploymentCode.registerDapp(ethUrl, function(){ NetworkDeploymentCode.registerDapp(ethUrl, gasPrice, function(){
projectModel.applicationUrlEth = applicationUrlEthCtrl.text projectModel.applicationUrlEth = applicationUrlEthCtrl.text
projectModel.saveProject() projectModel.saveProject()
verificationEthUrl.text = qsTr("waiting verifications")
worker.waitForTrReceipt(projectModel.registerContentHashTrHash, function(status, receipt) worker.waitForTrReceipt(projectModel.registerContentHashTrHash, function(status, receipt)
{ {
worker.verifyHash("registerHash", projectModel.registerContentHashTrHash, function(bn, trLost) worker.verifyHash("registerHash", projectModel.registerContentHashTrHash, function(bn, trLost)
@ -262,7 +287,7 @@ Rectangle {
} }
} }
function registerUrl() function registerUrl(gasPrice, callback)
{ {
if (applicationUrlHttp.text === "" || deploymentDialog.packageHash === "") if (applicationUrlHttp.text === "" || deploymentDialog.packageHash === "")
{ {
@ -276,9 +301,10 @@ Rectangle {
inError.push(qsTr(applicationUrlHttpCtrl.text)); inError.push(qsTr(applicationUrlHttpCtrl.text));
if (!worker.stopForInputError(inError)) if (!worker.stopForInputError(inError))
{ {
registerToUrlHint(applicationUrlHttpCtrl.text, function(){ registerToUrlHint(applicationUrlHttpCtrl.text, gasPrice, function(){
projectModel.applicationUrlHttp = applicationUrlHttpCtrl.text projectModel.applicationUrlHttp = applicationUrlHttpCtrl.text
projectModel.saveProject() projectModel.saveProject()
verificationUrl.text = qsTr("waiting verifications")
worker.waitForTrReceipt(projectModel.registerUrlTrHash, function(status, receipt) worker.waitForTrReceipt(projectModel.registerUrlTrHash, function(status, receipt)
{ {
worker.verifyHash("registerUrl", projectModel.registerUrlTrHash, function(bn, trLost) worker.verifyHash("registerUrl", projectModel.registerUrlTrHash, function(bn, trLost)
@ -286,6 +312,8 @@ Rectangle {
projectModel.registerUrlBlockNumber = bn projectModel.registerUrlBlockNumber = bn
projectModel.saveProject() projectModel.saveProject()
root.updateVerification(bn, bn, trLost, verificationUrl) root.updateVerification(bn, bn, trLost, verificationUrl)
root.registered()
callback()
}); });
}) })
}) })
@ -300,8 +328,12 @@ Rectangle {
width: 30 width: 30
onClicked: onClicked:
{ {
parent.registerHash(function(){ verificationEthUrl.text = ""
parent.registerUrl() verificationUrl.text = ""
projectModel.cleanRegisteringStatus()
var gasPrice = deploymentDialog.deployStep.gasPrice.toHexWei()
parent.registerHash(gasPrice, function(){
parent.registerUrl(gasPrice, function(){})
}) })
} }
} }

4
mix/qml/ScenarioLoader.qml

@ -35,7 +35,7 @@ ColumnLayout
{ {
Layout.preferredWidth: 560 Layout.preferredWidth: 560
anchors.horizontalCenter: parent.horizontalCenter anchors.horizontalCenter: parent.horizontalCenter
Layout.preferredHeight: 60 Layout.preferredHeight: 75
spacing: 0 spacing: 0
anchors.top: parent.top anchors.top: parent.top
anchors.topMargin: 10 anchors.topMargin: 10
@ -88,7 +88,7 @@ ColumnLayout
color: "#cccccc" color: "#cccccc"
id: deleteImg id: deleteImg
anchors.top: parent.top anchors.top: parent.top
anchors.topMargin: 6 anchors.topMargin: 7
visible: projectModel.stateListModel.count > 1 visible: projectModel.stateListModel.count > 1
MouseArea MouseArea
{ {

2
mix/qml/StatusPane.qml

@ -179,7 +179,7 @@ Rectangle {
function updateWidth() function updateWidth()
{ {
if (text.length > 80) if (text.length > 100)
width = parent.width - 10 width = parent.width - 10
else else
width = undefined width = undefined

3
mix/qml/WebPreview.qml

@ -272,7 +272,8 @@ Item {
Button Button
{ {
height: 28 height: 22
width: 22
anchors.verticalCenter: parent.verticalCenter anchors.verticalCenter: parent.verticalCenter
action: expressionAction action: expressionAction
iconSource: "qrc:/qml/img/console.png" iconSource: "qrc:/qml/img/console.png"

39
mix/qml/js/NetworkDeployment.js

@ -32,11 +32,10 @@ function deployProject(force) {
deploymentDialog.open(); deploymentDialog.open();
} }
function deployContracts(gas, callback) function deployContracts(gas, gasPrice, callback)
{ {
deploymentGas = gas; deploymentGas = gas;
var jsonRpcUrl = "http://127.0.0.1:8080"; deploymentGasPrice = gasPrice
console.log("Deploying to " + jsonRpcUrl);
deploymentStarted(); deploymentStarted();
var ctrAddresses = {}; var ctrAddresses = {};
@ -79,10 +78,7 @@ function checkPathCreationCost(ethUrl, callBack)
} }
} }
else else
{
deploymentStepChanged(qsTr("Your Dapp can be registered here."));
callBack((dappUrl.length - 1) * (deploymentDialog.registerStep.ownedRegistrarDeployGas + deploymentDialog.registerStep.ownedRegistrarSetSubRegistrarGas) + deploymentDialog.registerStep.ownedRegistrarSetContentHashGas); callBack((dappUrl.length - 1) * (deploymentDialog.registerStep.ownedRegistrarDeployGas + deploymentDialog.registerStep.ownedRegistrarSetSubRegistrarGas) + deploymentDialog.registerStep.ownedRegistrarSetContentHashGas);
}
}); });
} }
@ -140,6 +136,7 @@ function getFunction(ctrName, functionId)
} }
var deploymentGas var deploymentGas
var deploymentGasPrice
var trRealIndex = -1 var trRealIndex = -1
function executeTr(blockIndex, trIndex, state, ctrAddresses, trHashes, callBack) function executeTr(blockIndex, trIndex, state, ctrAddresses, trHashes, callBack)
{ {
@ -153,14 +150,14 @@ function executeTr(blockIndex, trIndex, state, ctrAddresses, trHashes, callBack)
else else
{ {
var gasCost = clientModel.toHex(deploymentGas[trRealIndex]); var gasCost = clientModel.toHex(deploymentGas[trRealIndex]);
var rpcParams = { "from": deploymentDialog.worker.currentAccount, "gas": "0x" + gasCost }; var rpcParams = { "from": deploymentDialog.worker.currentAccount, "gas": "0x" + gasCost, "gasPrice": deploymentGasPrice };
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);
if (tr.contractId === tr.functionId) if (tr.contractId === tr.functionId)
rpcParams.code = codeModel.contracts[tr.contractId].codeHex + encodedParams.join(""); rpcParams.code = codeModel.contracts[tr.contractId].codeHex + encodedParams.join("");
else else
rpcParams.data = func.hash + encodedParams.join(""); rpcParams.data = "0x" + func.qhash() + encodedParams.join("");
var requests = [{ var requests = [{
jsonrpc: "2.0", jsonrpc: "2.0",
@ -214,13 +211,9 @@ function executeTrNextStep(blockIndex, trIndex, state, ctrAddresses, trHashes, c
{ {
blockIndex++ blockIndex++
if (blockIndex < state.blocks.count) if (blockIndex < state.blocks.count)
{
executeTr(blockIndex, 0, state, ctrAddresses, trHashes, callBack); executeTr(blockIndex, 0, state, ctrAddresses, trHashes, callBack);
}
else else
{
callBack(); callBack();
}
} }
} }
@ -298,16 +291,17 @@ function packageDapp(addresses)
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 deploymentDialog.packageStep.lastDeployDate = date
deploymentComplete() deploymentStepChanged(qsTr("Dapp is Packaged"))
} }
function registerDapp(url, callback) function registerDapp(url, gasPrice, callback)
{ {
deploymentGasPrice = gasPrice
deploymentStepChanged(qsTr("Registering application on the Ethereum network ...")); deploymentStepChanged(qsTr("Registering application on the Ethereum network ..."));
checkEthPath(url, false, function (success) { checkEthPath(url, false, function (success) {
if (!success) if (!success)
return; return;
deploymentComplete(); deploymentStepChanged(qsTr("Dapp has been registered. Please wait for verifications."));
if (callback) if (callback)
callback() callback()
}); });
@ -446,7 +440,7 @@ function continueRegistration(dappUrl, addr, callBack, checkOnly)
requests.push({ requests.push({
jsonrpc: "2.0", jsonrpc: "2.0",
method: "eth_sendTransaction", method: "eth_sendTransaction",
params: [ { "from": deploymentDialog.worker.currentAccount, "gas": "0x" + gasCost, "code": "0x600080547fffffffffffffffffffffffff000000000000000000000000000000000000000016331781556105cd90819061003990396000f3007c010000000000000000000000000000000000000000000000000000000060003504630198489281146100b257806321f8a721146100e45780632dff6941146100ee5780633b3b57de1461010e5780635a3a05bd1461013e5780635fd4b08a146101715780637dd564111461017d57806389a69c0e14610187578063b387ef92146101bb578063b5c645bd146101f4578063be99a98014610270578063c3d014d6146102a8578063d93e7573146102dc57005b73ffffffffffffffffffffffffffffffffffffffff600435166000908152600160205260409020548060005260206000f35b6000808052602081f35b600435600090815260026020819052604090912001548060005260206000f35b600435600090815260026020908152604082205473ffffffffffffffffffffffffffffffffffffffff1680835291f35b600435600090815260026020908152604082206001015473ffffffffffffffffffffffffffffffffffffffff1680835291f35b60008060005260206000f35b6000808052602081f35b60005461030c9060043590602435903373ffffffffffffffffffffffffffffffffffffffff908116911614610569576105c9565b60005473ffffffffffffffffffffffffffffffffffffffff168073ffffffffffffffffffffffffffffffffffffffff1660005260206000f35b600435600090815260026020819052604090912080546001820154919092015473ffffffffffffffffffffffffffffffffffffffff9283169291909116908273ffffffffffffffffffffffffffffffffffffffff166000528173ffffffffffffffffffffffffffffffffffffffff166020528060405260606000f35b600054610312906004359060243590604435903373ffffffffffffffffffffffffffffffffffffffff90811691161461045457610523565b6000546103189060043590602435903373ffffffffffffffffffffffffffffffffffffffff90811691161461052857610565565b60005461031e90600435903373ffffffffffffffffffffffffffffffffffffffff90811691161461032457610451565b60006000f35b60006000f35b60006000f35b60006000f35b60008181526002602090815260408083205473ffffffffffffffffffffffffffffffffffffffff16835260019091529020548114610361576103e1565b6000818152600260205260408082205473ffffffffffffffffffffffffffffffffffffffff169183917ff63780e752c6a54a94fc52715dbc5518a3b4c3c2833d301a204226548a2a85459190a360008181526002602090815260408083205473ffffffffffffffffffffffffffffffffffffffff16835260019091528120555b600081815260026020819052604080832080547fffffffffffffffffffffffff00000000000000000000000000000000000000009081168255600182018054909116905590910182905582917fa6697e974e6a320f454390be03f74955e8978f1a6971ea6730542e37b66179bc91a25b50565b600083815260026020526040902080547fffffffffffffffffffffffff00000000000000000000000000000000000000001683179055806104bb57827fa6697e974e6a320f454390be03f74955e8978f1a6971ea6730542e37b66179bc60006040a2610522565b73ffffffffffffffffffffffffffffffffffffffff8216837ff63780e752c6a54a94fc52715dbc5518a3b4c3c2833d301a204226548a2a854560006040a373ffffffffffffffffffffffffffffffffffffffff821660009081526001602052604090208390555b5b505050565b600082815260026020819052604080832090910183905583917fa6697e974e6a320f454390be03f74955e8978f1a6971ea6730542e37b66179bc91a25b5050565b60008281526002602052604080822060010180547fffffffffffffffffffffffff0000000000000000000000000000000000000000168417905583917fa6697e974e6a320f454390be03f74955e8978f1a6971ea6730542e37b66179bc91a25b505056" } ], params: [ { "from": deploymentDialog.worker.currentAccount, "gasPrice": deploymentGasPrice, "gas": "0x" + gasCost, "code": "0x600080547fffffffffffffffffffffffff000000000000000000000000000000000000000016331781556105cd90819061003990396000f3007c010000000000000000000000000000000000000000000000000000000060003504630198489281146100b257806321f8a721146100e45780632dff6941146100ee5780633b3b57de1461010e5780635a3a05bd1461013e5780635fd4b08a146101715780637dd564111461017d57806389a69c0e14610187578063b387ef92146101bb578063b5c645bd146101f4578063be99a98014610270578063c3d014d6146102a8578063d93e7573146102dc57005b73ffffffffffffffffffffffffffffffffffffffff600435166000908152600160205260409020548060005260206000f35b6000808052602081f35b600435600090815260026020819052604090912001548060005260206000f35b600435600090815260026020908152604082205473ffffffffffffffffffffffffffffffffffffffff1680835291f35b600435600090815260026020908152604082206001015473ffffffffffffffffffffffffffffffffffffffff1680835291f35b60008060005260206000f35b6000808052602081f35b60005461030c9060043590602435903373ffffffffffffffffffffffffffffffffffffffff908116911614610569576105c9565b60005473ffffffffffffffffffffffffffffffffffffffff168073ffffffffffffffffffffffffffffffffffffffff1660005260206000f35b600435600090815260026020819052604090912080546001820154919092015473ffffffffffffffffffffffffffffffffffffffff9283169291909116908273ffffffffffffffffffffffffffffffffffffffff166000528173ffffffffffffffffffffffffffffffffffffffff166020528060405260606000f35b600054610312906004359060243590604435903373ffffffffffffffffffffffffffffffffffffffff90811691161461045457610523565b6000546103189060043590602435903373ffffffffffffffffffffffffffffffffffffffff90811691161461052857610565565b60005461031e90600435903373ffffffffffffffffffffffffffffffffffffffff90811691161461032457610451565b60006000f35b60006000f35b60006000f35b60006000f35b60008181526002602090815260408083205473ffffffffffffffffffffffffffffffffffffffff16835260019091529020548114610361576103e1565b6000818152600260205260408082205473ffffffffffffffffffffffffffffffffffffffff169183917ff63780e752c6a54a94fc52715dbc5518a3b4c3c2833d301a204226548a2a85459190a360008181526002602090815260408083205473ffffffffffffffffffffffffffffffffffffffff16835260019091528120555b600081815260026020819052604080832080547fffffffffffffffffffffffff00000000000000000000000000000000000000009081168255600182018054909116905590910182905582917fa6697e974e6a320f454390be03f74955e8978f1a6971ea6730542e37b66179bc91a25b50565b600083815260026020526040902080547fffffffffffffffffffffffff00000000000000000000000000000000000000001683179055806104bb57827fa6697e974e6a320f454390be03f74955e8978f1a6971ea6730542e37b66179bc60006040a2610522565b73ffffffffffffffffffffffffffffffffffffffff8216837ff63780e752c6a54a94fc52715dbc5518a3b4c3c2833d301a204226548a2a854560006040a373ffffffffffffffffffffffffffffffffffffffff821660009081526001602052604090208390555b5b505050565b600082815260026020819052604080832090910183905583917fa6697e974e6a320f454390be03f74955e8978f1a6971ea6730542e37b66179bc91a25b5050565b60008281526002602052604080822060010180547fffffffffffffffffffffffff0000000000000000000000000000000000000000168417905583917fa6697e974e6a320f454390be03f74955e8978f1a6971ea6730542e37b66179bc91a25b505056" } ],
id: jsonRpcRequestId++ id: jsonRpcRequestId++
}); });
@ -468,7 +462,7 @@ function continueRegistration(dappUrl, addr, callBack, checkOnly)
//setRegister() //setRegister()
jsonrpc: "2.0", jsonrpc: "2.0",
method: "eth_sendTransaction", method: "eth_sendTransaction",
params: [ { "from": deploymentDialog.worker.currentAccount, "gas": "0x" + gasCost, "to": '0x' + addr, "data": "0x89a69c0e" + crLevel + newCtrAddress } ], params: [ { "from": deploymentDialog.worker.currentAccount, "gasPrice": deploymentGasPrice, "gas": "0x" + gasCost, "to": '0x' + addr, "data": "0x89a69c0e" + crLevel + newCtrAddress } ],
id: jsonRpcRequestId++ id: jsonRpcRequestId++
}); });
@ -501,7 +495,7 @@ function reserve(registrar, callBack)
//reserve() //reserve()
jsonrpc: "2.0", jsonrpc: "2.0",
method: "eth_sendTransaction", method: "eth_sendTransaction",
params: [ { "from": deploymentDialog.worker.currentAccount, "gas": "0xfffff", "to": '0x' + registrar, "data": "0x432ced04" + paramTitle } ], params: [ { "from": deploymentDialog.worker.currentAccount, "gasPrice": deploymentGasPrice, "gas": "0xfffff", "to": '0x' + registrar, "data": "0x432ced04" + paramTitle } ],
id: jsonRpcRequestId++ id: jsonRpcRequestId++
}); });
rpcCall(requests, function (httpRequest, response) { rpcCall(requests, function (httpRequest, response) {
@ -524,7 +518,7 @@ function registerContentHash(registrar, callBack)
//setContent() //setContent()
jsonrpc: "2.0", jsonrpc: "2.0",
method: "eth_sendTransaction", method: "eth_sendTransaction",
params: [ { "from": deploymentDialog.worker.currentAccount, "gas": "0x" + gasCost, "to": '0x' + registrar, "data": "0xc3d014d6" + paramTitle + deploymentDialog.packageStep.packageHash } ], params: [ { "from": deploymentDialog.worker.currentAccount, "gasPrice": deploymentGasPrice, "gas": "0x" + gasCost, "to": '0x' + registrar, "data": "0xc3d014d6" + paramTitle + deploymentDialog.packageStep.packageHash } ],
id: jsonRpcRequestId++ id: jsonRpcRequestId++
}); });
rpcCall(requests, function (httpRequest, response) { rpcCall(requests, function (httpRequest, response) {
@ -533,9 +527,10 @@ function registerContentHash(registrar, callBack)
}); });
} }
function registerToUrlHint(url, callback) function registerToUrlHint(url, gasPrice, callback)
{ {
console.log("register url " + deploymentDialog.packageStep.packageHash + " " + url) console.log("register url " + deploymentDialog.packageStep.packageHash + " " + url)
deploymentGasPrice = gasPrice
deploymentStepChanged(qsTr("Registering application Resources...")) deploymentStepChanged(qsTr("Registering application Resources..."))
urlHintAddress(function(urlHint){ urlHintAddress(function(urlHint){
var requests = []; var requests = [];
@ -545,13 +540,13 @@ function registerToUrlHint(url, callback)
//urlHint => suggestUrl //urlHint => suggestUrl
jsonrpc: "2.0", jsonrpc: "2.0",
method: "eth_sendTransaction", method: "eth_sendTransaction",
params: [ { "to": '0x' + urlHint, "from": deploymentDialog.worker.currentAccount, "gas": "0x" + gasCost, "data": "0x584e86ad" + deploymentDialog.packageStep.packageHash + paramUrlHttp } ], params: [ { "to": '0x' + urlHint, "gasPrice": deploymentGasPrice, "from": deploymentDialog.worker.currentAccount, "gas": "0x" + gasCost, "data": "0x584e86ad" + deploymentDialog.packageStep.packageHash + paramUrlHttp } ],
id: jsonRpcRequestId++ id: jsonRpcRequestId++
}); });
rpcCall(requests, function (httpRequest, response) { rpcCall(requests, function (httpRequest, response) {
projectModel.registerUrlTrHash = JSON.parse(response)[0].result projectModel.registerUrlTrHash = JSON.parse(response)[0].result
deploymentComplete(); deploymentStepChanged(qsTr("Dapp resources has been registered. Please wait for verifications."));
if (callback) if (callback)
callback() callback()
}); });

3
mix/qml/js/TransactionHelper.js

@ -33,7 +33,8 @@ function rpcCall(requests, callBack, error)
{ {
var errorText = qsTr("Unable to initiate request to the live network. Please verify your ethereum node is up.") + qsTr(" Error status: ") + httpRequest.status; var errorText = qsTr("Unable to initiate request to the live network. Please verify your ethereum node is up.") + qsTr(" Error status: ") + httpRequest.status;
console.log(errorText); console.log(errorText);
error(errorText); if (error)
error(errorText);
} }
else else
{ {

Loading…
Cancel
Save