/* * Copyright (c) 2015 Cryptonomex, Inc., and contributors. * All rights reserved. * * Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met: * * 1. Any modified source or binaries are used only with the BitShares network. * * 2. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer. * * 3. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * */ #include "GrapheneApplication.hpp" #include "ChainDataModel.hpp" #include "Wallet.hpp" #include "Operations.hpp" #include "Transaction.hpp" #include #include #include using graphene::app::login_api; using graphene::app::database_api; GrapheneApplication::GrapheneApplication(QObject* parent) :QObject(parent),m_thread("app") { connect(this, &GrapheneApplication::queueExecute, this, &GrapheneApplication::execute); m_model = new ChainDataModel(m_thread, this); m_operationBuilder = new OperationBuilder(*m_model, this); m_wallet = new Wallet(this); connect(m_model, &ChainDataModel::queueExecute, this, &GrapheneApplication::execute); connect(m_model, &ChainDataModel::exceptionThrown, this, &GrapheneApplication::exceptionThrown); } GrapheneApplication::~GrapheneApplication() { } void GrapheneApplication::setIsConnected(bool v) { if (v != m_isConnected) { m_isConnected = v; Q_EMIT isConnectedChanged(m_isConnected); } } void GrapheneApplication::start(QString apiurl, QString user, QString pass) { if (!m_thread.is_current()) { m_done = m_thread.async([=](){ return start(apiurl, user, pass); }); return; } try { m_client = std::make_shared(); ilog("connecting...${s}", ("s",apiurl.toStdString())); auto con = m_client->connect(apiurl.toStdString()); m_connectionClosed = con->closed.connect([this]{queueExecute([this]{setIsConnected(false);});}); auto apic = std::make_shared(*con); auto remote_api = apic->get_remote_api(1); auto db_api = apic->get_remote_api(0); if (!remote_api->login(user.toStdString(), pass.toStdString())) { elog("login failed"); Q_EMIT loginFailed(); return; } auto net_api = remote_api->network_broadcast(); ilog("connecting..."); queueExecute([=](){ m_model->setDatabaseAPI(db_api); m_model->setNetworkAPI(net_api); }); queueExecute([=](){ setIsConnected(true); }); } catch (const fc::exception& e) { Q_EMIT exceptionThrown(QString::fromStdString(e.to_string())); } } QString GrapheneApplication::defaultDataPath() { return QStandardPaths::writableLocation(QStandardPaths::AppDataLocation); } Transaction* GrapheneApplication::createTransaction() const { return new Transaction; } void GrapheneApplication::signTransaction(Transaction* transaction) const { if (transaction == nullptr) return; auto getActiveAuth = [this](graphene::chain::account_id_type id) { return &model()->getAccount(id.instance.value)->accountObject().active; }; auto getOwnerAuth = [this](graphene::chain::account_id_type id) { return &model()->getAccount(id.instance.value)->accountObject().owner; }; auto& chainId = model()->chain_properties().chain_id; auto& trx = transaction->internalTransaction(); trx.set_reference_block(model()->dynamic_global_properties().head_block_id); flat_set pubKeys = wallet()->getAvailablePrivateKeys(); auto requiredKeys = trx.get_required_signatures(chainId, pubKeys, getActiveAuth, getOwnerAuth); trx.signatures = wallet()->signDigest(trx.digest(), requiredKeys); idump((trx)); } Q_SLOT void GrapheneApplication::execute(const std::function& func)const { func(); }