DERO-HE STARGATE Testnet Release12
This commit is contained in:
parent
e39e06b2df
commit
75ca9971c9
@ -530,7 +530,7 @@ func (chain *Blockchain) Add_Complete_Block(cbl *block.Complete_Block) (err erro
|
|||||||
// always check whether the coin base tx is okay
|
// always check whether the coin base tx is okay
|
||||||
if bl.Height != 0 {
|
if bl.Height != 0 {
|
||||||
if err = chain.Verify_Transaction_Coinbase(cbl, &bl.Miner_TX); err != nil { // if miner address is not registered give error
|
if err = chain.Verify_Transaction_Coinbase(cbl, &bl.Miner_TX); err != nil { // if miner address is not registered give error
|
||||||
block_logger.Warnf("Error verifying coinbase tx, err :'%s'", err)
|
//block_logger.Warnf("Error verifying coinbase tx, err :'%s'", err)
|
||||||
return err, false
|
return err, false
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -200,89 +200,92 @@ func (chain *Blockchain) process_transaction_sc(cache map[crypto.Hash]*graviton.
|
|||||||
}
|
}
|
||||||
}()
|
}()
|
||||||
|
|
||||||
if tx.SCDATA.Has(rpc.SCACTION, rpc.DataUint64) { // but only it is present
|
if !tx.SCDATA.Has(rpc.SCACTION, rpc.DataUint64) { // tx doesn't have sc action
|
||||||
action_code := rpc.SC_ACTION(tx.SCDATA.Value(rpc.SCACTION, rpc.DataUint64).(uint64))
|
//err = fmt.Errorf("no scid provided")
|
||||||
|
return tx.Fees(), nil
|
||||||
|
}
|
||||||
|
|
||||||
switch action_code {
|
action_code := rpc.SC_ACTION(tx.SCDATA.Value(rpc.SCACTION, rpc.DataUint64).(uint64))
|
||||||
case rpc.SC_INSTALL: // request to install an SC
|
|
||||||
if !tx.SCDATA.Has(rpc.SCCODE, rpc.DataString) { // but only it is present
|
|
||||||
break
|
|
||||||
}
|
|
||||||
sc_code := tx.SCDATA.Value(rpc.SCCODE, rpc.DataString).(string)
|
|
||||||
if sc_code == "" { // no code provided nothing to do
|
|
||||||
err = fmt.Errorf("no code provided")
|
|
||||||
break
|
|
||||||
}
|
|
||||||
|
|
||||||
// check whether sc can be parsed
|
switch action_code {
|
||||||
//var sc_parsed dvm.SmartContract
|
case rpc.SC_INSTALL: // request to install an SC
|
||||||
pos := ""
|
if !tx.SCDATA.Has(rpc.SCCODE, rpc.DataString) { // but only it is present
|
||||||
var sc dvm.SmartContract
|
break
|
||||||
|
}
|
||||||
|
sc_code := tx.SCDATA.Value(rpc.SCCODE, rpc.DataString).(string)
|
||||||
|
if sc_code == "" { // no code provided nothing to do
|
||||||
|
err = fmt.Errorf("no code provided")
|
||||||
|
break
|
||||||
|
}
|
||||||
|
|
||||||
sc, pos, err = dvm.ParseSmartContract(sc_code)
|
// check whether sc can be parsed
|
||||||
if err != nil {
|
//var sc_parsed dvm.SmartContract
|
||||||
rlog.Warnf("error Parsing sc txid %s err %s pos %s\n", txhash, err, pos)
|
pos := ""
|
||||||
break
|
var sc dvm.SmartContract
|
||||||
}
|
|
||||||
|
|
||||||
meta := SC_META_DATA{Balance: tx.Value}
|
sc, pos, err = dvm.ParseSmartContract(sc_code)
|
||||||
|
if err != nil {
|
||||||
|
rlog.Warnf("error Parsing sc txid %s err %s pos %s\n", txhash, err, pos)
|
||||||
|
break
|
||||||
|
}
|
||||||
|
|
||||||
if _, ok := sc.Functions["InitializePrivate"]; ok {
|
meta := SC_META_DATA{Balance: tx.Value}
|
||||||
meta.Type = 1
|
|
||||||
}
|
|
||||||
if sc_data_tree, err = ss.GetTree(string(scid[:])); err != nil {
|
|
||||||
break
|
|
||||||
} else {
|
|
||||||
w_sc_data_tree = &Tree_Wrapper{tree: sc_data_tree, entries: map[string][]byte{}}
|
|
||||||
}
|
|
||||||
|
|
||||||
// install SC, should we check for sanity now, why or why not
|
if _, ok := sc.Functions["InitializePrivate"]; ok {
|
||||||
w_sc_data_tree.Put(SC_Code_Key(scid), dvm.Variable{Type: dvm.String, Value: sc_code}.MarshalBinaryPanic())
|
meta.Type = 1
|
||||||
|
}
|
||||||
|
if sc_data_tree, err = ss.GetTree(string(scid[:])); err != nil {
|
||||||
|
break
|
||||||
|
} else {
|
||||||
|
w_sc_data_tree = &Tree_Wrapper{tree: sc_data_tree, entries: map[string][]byte{}}
|
||||||
|
}
|
||||||
|
|
||||||
w_sc_tree.Put(SC_Meta_Key(scid), meta.MarshalBinary())
|
// install SC, should we check for sanity now, why or why not
|
||||||
|
w_sc_data_tree.Put(SC_Code_Key(scid), dvm.Variable{Type: dvm.String, Value: sc_code}.MarshalBinaryPanic())
|
||||||
|
|
||||||
// at this point we must trigger the initialize call in the DVM
|
w_sc_tree.Put(SC_Meta_Key(scid), meta.MarshalBinary())
|
||||||
//fmt.Printf("We must call the SC initialize function\n")
|
|
||||||
|
|
||||||
if meta.Type == 1 { // if its a a private SC
|
// at this point we must trigger the initialize call in the DVM
|
||||||
gas, err = chain.execute_sc_function(w_sc_tree, w_sc_data_tree, scid, bl_height, bl_topoheight, blid, tx, "InitializePrivate", 1)
|
//fmt.Printf("We must call the SC initialize function\n")
|
||||||
} else {
|
|
||||||
gas, err = chain.execute_sc_function(w_sc_tree, w_sc_data_tree, scid, bl_height, bl_topoheight, blid, tx, "Initialize", 1)
|
|
||||||
}
|
|
||||||
|
|
||||||
case rpc.SC_CALL: // trigger a CALL
|
if meta.Type == 1 { // if its a a private SC
|
||||||
if !tx.SCDATA.Has(rpc.SCID, rpc.DataHash) { // but only it is present
|
gas, err = chain.execute_sc_function(w_sc_tree, w_sc_data_tree, scid, bl_height, bl_topoheight, blid, tx, "InitializePrivate", 1)
|
||||||
err = fmt.Errorf("no scid provided")
|
} else {
|
||||||
break
|
gas, err = chain.execute_sc_function(w_sc_tree, w_sc_data_tree, scid, bl_height, bl_topoheight, blid, tx, "Initialize", 1)
|
||||||
}
|
}
|
||||||
if !tx.SCDATA.Has("entrypoint", rpc.DataString) { // but only it is present
|
|
||||||
err = fmt.Errorf("no entrypoint provided")
|
|
||||||
break
|
|
||||||
}
|
|
||||||
|
|
||||||
scid = tx.SCDATA.Value(rpc.SCID, rpc.DataHash).(crypto.Hash)
|
case rpc.SC_CALL: // trigger a CALL
|
||||||
|
if !tx.SCDATA.Has(rpc.SCID, rpc.DataHash) { // but only it is present
|
||||||
|
err = fmt.Errorf("no scid provided")
|
||||||
|
break
|
||||||
|
}
|
||||||
|
if !tx.SCDATA.Has("entrypoint", rpc.DataString) { // but only it is present
|
||||||
|
err = fmt.Errorf("no entrypoint provided")
|
||||||
|
break
|
||||||
|
}
|
||||||
|
|
||||||
if _, err = w_sc_tree.Get(SC_Meta_Key(scid)); err != nil {
|
scid = tx.SCDATA.Value(rpc.SCID, rpc.DataHash).(crypto.Hash)
|
||||||
err = fmt.Errorf("scid %s not installed", scid)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
if sc_data_tree, err = ss.GetTree(string(scid[:])); err != nil {
|
if _, err = w_sc_tree.Get(SC_Meta_Key(scid)); err != nil {
|
||||||
|
err = fmt.Errorf("scid %s not installed", scid)
|
||||||
return
|
|
||||||
} else {
|
|
||||||
w_sc_data_tree = &Tree_Wrapper{tree: sc_data_tree, entries: map[string][]byte{}}
|
|
||||||
}
|
|
||||||
|
|
||||||
entrypoint := tx.SCDATA.Value("entrypoint", rpc.DataString).(string)
|
|
||||||
//fmt.Printf("We must call the SC %s function\n", entrypoint)
|
|
||||||
|
|
||||||
gas, err = chain.execute_sc_function(w_sc_tree, w_sc_data_tree, scid, bl_height, bl_topoheight, blid, tx, entrypoint, 1)
|
|
||||||
|
|
||||||
default: // unknown what to do
|
|
||||||
err = fmt.Errorf("unknown action what to do", scid)
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if sc_data_tree, err = ss.GetTree(string(scid[:])); err != nil {
|
||||||
|
|
||||||
|
return
|
||||||
|
} else {
|
||||||
|
w_sc_data_tree = &Tree_Wrapper{tree: sc_data_tree, entries: map[string][]byte{}}
|
||||||
|
}
|
||||||
|
|
||||||
|
entrypoint := tx.SCDATA.Value("entrypoint", rpc.DataString).(string)
|
||||||
|
//fmt.Printf("We must call the SC %s function\n", entrypoint)
|
||||||
|
|
||||||
|
gas, err = chain.execute_sc_function(w_sc_tree, w_sc_data_tree, scid, bl_height, bl_topoheight, blid, tx, entrypoint, 1)
|
||||||
|
|
||||||
|
default: // unknown what to do
|
||||||
|
err = fmt.Errorf("unknown action what to do", scid)
|
||||||
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
if err == nil { // we must commit the changes
|
if err == nil { // we must commit the changes
|
||||||
@ -323,11 +326,12 @@ func (chain *Blockchain) process_transaction_sc(cache map[crypto.Hash]*graviton.
|
|||||||
//fmt.Printf("SC %s balance %d\n", scid, w_sc_data_tree.leftover_balance)
|
//fmt.Printf("SC %s balance %d\n", scid, w_sc_data_tree.leftover_balance)
|
||||||
sc_tree.Put(SC_Meta_Key(scid), meta.MarshalBinary())
|
sc_tree.Put(SC_Meta_Key(scid), meta.MarshalBinary())
|
||||||
|
|
||||||
for _, transfer := range w_sc_data_tree.transfere { // give devs reward
|
for i, transfer := range w_sc_data_tree.transfere { // give devs reward
|
||||||
var balance_serialized []byte
|
var balance_serialized []byte
|
||||||
addr_bytes := []byte(transfer.Address)
|
addr_bytes := []byte(transfer.Address)
|
||||||
balance_serialized, err = balance_tree.Get(addr_bytes)
|
balance_serialized, err = balance_tree.Get(addr_bytes)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
fmt.Printf("%s %d could not transfer %d %+v\n", scid, i, transfer.Amount, addr_bytes)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
balance := new(crypto.ElGamal).Deserialize(balance_serialized)
|
balance := new(crypto.ElGamal).Deserialize(balance_serialized)
|
||||||
|
@ -82,7 +82,7 @@ func (chain *Blockchain) Verify_Transaction_Coinbase(cbl *block.Complete_Block,
|
|||||||
_, topos := chain.Store.Topo_store.binarySearchHeight(int64(cbl.Bl.Height - 1))
|
_, topos := chain.Store.Topo_store.binarySearchHeight(int64(cbl.Bl.Height - 1))
|
||||||
// load all db versions one by one and check whether the root hash matches the one mentioned in the tx
|
// load all db versions one by one and check whether the root hash matches the one mentioned in the tx
|
||||||
if len(topos) < 1 {
|
if len(topos) < 1 {
|
||||||
return fmt.Errorf("could not find previous height blocks")
|
return fmt.Errorf("could not find previous height blocks %d", cbl.Bl.Height-1)
|
||||||
}
|
}
|
||||||
|
|
||||||
var balance_tree *graviton.Tree
|
var balance_tree *graviton.Tree
|
||||||
|
@ -53,7 +53,7 @@ func (DERO_RPC_APIS) GetRandomAddress(ctx context.Context, p rpc.GetRandomAddres
|
|||||||
}
|
}
|
||||||
|
|
||||||
treename := config.BALANCE_TREE
|
treename := config.BALANCE_TREE
|
||||||
if p.SCID.IsZero() {
|
if !p.SCID.IsZero() {
|
||||||
treename = string(p.SCID[:])
|
treename = string(p.SCID[:])
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -289,7 +289,7 @@ type txinfo struct {
|
|||||||
}
|
}
|
||||||
|
|
||||||
type Asset struct {
|
type Asset struct {
|
||||||
SCID crypto.Hash
|
SCID string
|
||||||
Fees string
|
Fees string
|
||||||
Burn string
|
Burn string
|
||||||
Ring []string
|
Ring []string
|
||||||
@ -561,9 +561,14 @@ func load_tx_from_rpc(info *txinfo, txhash string) (err error) {
|
|||||||
|
|
||||||
for t := range tx.Payloads {
|
for t := range tx.Payloads {
|
||||||
var a Asset
|
var a Asset
|
||||||
a.SCID = tx.Payloads[t].SCID
|
a.SCID = tx.Payloads[t].SCID.String()
|
||||||
a.Fees = fmt.Sprintf("%.05f", float64(tx.Payloads[t].Statement.Fees)/100000)
|
a.Fees = fmt.Sprintf("%.05f", float64(tx.Payloads[t].Statement.Fees)/100000)
|
||||||
a.Burn = fmt.Sprintf("%.05f", float64(tx.Payloads[t].BurnValue)/100000)
|
a.Burn = fmt.Sprintf("%.05f", float64(tx.Payloads[t].BurnValue)/100000)
|
||||||
|
|
||||||
|
if len(tx_result.Txs[0].Ring) == 0 {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
a.Ring_size = len(tx_result.Txs[0].Ring[t])
|
a.Ring_size = len(tx_result.Txs[0].Ring[t])
|
||||||
|
|
||||||
for i := range tx_result.Txs[0].Ring[t] {
|
for i := range tx_result.Txs[0].Ring[t] {
|
||||||
@ -772,7 +777,7 @@ func show_page(w http.ResponseWriter, page int) {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fmt.Printf("page %+v\n", data)
|
//fmt.Printf("page %+v\n", data)
|
||||||
|
|
||||||
err = t.ExecuteTemplate(w, "main", data)
|
err = t.ExecuteTemplate(w, "main", data)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -365,8 +365,26 @@ var tx_template string = `{{define "tx"}}
|
|||||||
</table>
|
</table>
|
||||||
|
|
||||||
{{range $ii, $ee := .info.Assets}}
|
{{range $ii, $ee := .info.Assets}}
|
||||||
<H5>SCID: {{$ee.SCID}} {{$ee.Ring_size}} inputs/outputs (RING size) Fees {{$ee.Fees}} Burned {{$ee.Burn}}</H5>
|
{{if eq $ee.SCID "0000000000000000000000000000000000000000000000000000000000000000" }}
|
||||||
|
<H5>DERO : {{$ee.Ring_size}} inputs/outputs (RING size) Fees {{$ee.Fees}}
|
||||||
|
|
||||||
|
{{if eq $.info.TransactionType "SC"}}
|
||||||
|
Deposited to SC {{$ee.Burn}}
|
||||||
|
{{else}}
|
||||||
|
Burned {{$ee.Burn}}
|
||||||
|
{{end}}
|
||||||
|
|
||||||
|
</H5>
|
||||||
|
|
||||||
|
{{else}}
|
||||||
|
<H5>SCID: {{$ee.SCID}} {{$ee.Ring_size}} inputs/outputs (RING size) Fees {{$ee.Fees}} {{if eq $.info.TransactionType "SC"}}
|
||||||
|
Deposited Tokens to SC {{$ee.Burn}}
|
||||||
|
{{else}}
|
||||||
|
Burned {{$ee.Burn}}
|
||||||
|
{{end}}
|
||||||
|
|
||||||
|
</H5>
|
||||||
|
{{end}}
|
||||||
<div class="center">
|
<div class="center">
|
||||||
<table class="center">
|
<table class="center">
|
||||||
<tr>
|
<tr>
|
||||||
|
@ -20,4 +20,4 @@ import "github.com/blang/semver"
|
|||||||
|
|
||||||
// right now it has to be manually changed
|
// right now it has to be manually changed
|
||||||
// do we need to include git commitsha??
|
// do we need to include git commitsha??
|
||||||
var Version = semver.MustParse("3.2.0-16.DEROHE.STARGATE+23022021")
|
var Version = semver.MustParse("3.2.12-1.DEROHE.STARGATE+27022021")
|
||||||
|
@ -412,12 +412,12 @@ func process_connection(conn net.Conn, remote_addr *net.TCPAddr, incoming, sync_
|
|||||||
}
|
}
|
||||||
go func() {
|
go func() {
|
||||||
//defer globals.Recover()
|
//defer globals.Recover()
|
||||||
defer func() {
|
defer func() {
|
||||||
if r := recover(); r != nil {
|
if r := recover(); r != nil {
|
||||||
rlog.Warnf("Recovered while handling connection, Stack trace below", r)
|
rlog.Warnf("Recovered while handling connection, Stack trace below", r)
|
||||||
rlog.Warnf("Stack trace \n%s", debug.Stack())
|
rlog.Warnf("Stack trace \n%s", debug.Stack())
|
||||||
}
|
}
|
||||||
}()
|
}()
|
||||||
//RPCSERVER.ServeConn(rconn.ServerConn) // start single threaded rpc server with GOB encoding
|
//RPCSERVER.ServeConn(rconn.ServerConn) // start single threaded rpc server with GOB encoding
|
||||||
RPCSERVER.ServeCodec(NewCBORServerCodec(rconn.ServerConn)) // use CBOR encoding on rpc
|
RPCSERVER.ServeCodec(NewCBORServerCodec(rconn.ServerConn)) // use CBOR encoding on rpc
|
||||||
}()
|
}()
|
||||||
|
@ -34,8 +34,8 @@ func (connection *Connection) GetObject(request ObjectList, response *Objects) e
|
|||||||
for i := range request.Block_list { // find the block
|
for i := range request.Block_list { // find the block
|
||||||
var cbl Complete_Block
|
var cbl Complete_Block
|
||||||
bl, err := chain.Load_BL_FROM_ID(request.Block_list[i])
|
bl, err := chain.Load_BL_FROM_ID(request.Block_list[i])
|
||||||
if err != nil{
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
cbl.Block = bl.Serialize()
|
cbl.Block = bl.Serialize()
|
||||||
for j := range bl.Tx_hashes {
|
for j := range bl.Tx_hashes {
|
||||||
|
@ -205,6 +205,15 @@ type (
|
|||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
|
||||||
|
type (
|
||||||
|
SC_Invoke_Params struct {
|
||||||
|
SC_ID string `json:"scid"`
|
||||||
|
SC_RPC Arguments `json:"sc_rpc"`
|
||||||
|
SC_DERO_Deposit uint64 `json:"sc_dero_deposit"`
|
||||||
|
SC_TOKEN_Deposit uint64 `json:"sc_token_deposit"`
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
type (
|
type (
|
||||||
Get_Transfers_Params struct {
|
Get_Transfers_Params struct {
|
||||||
Coinbase bool `json:"coinbase"`
|
Coinbase bool `json:"coinbase"`
|
||||||
|
70
walletapi/rpcserver/rpc_scinvoke.go
Normal file
70
walletapi/rpcserver/rpc_scinvoke.go
Normal file
@ -0,0 +1,70 @@
|
|||||||
|
// Copyright 2017-2021 DERO Project. All rights reserved.
|
||||||
|
// Use of this source code in any form is governed by RESEARCH license.
|
||||||
|
// license can be found in the LICENSE file.
|
||||||
|
// GPG: 0F39 E425 8C65 3947 702A 8234 08B2 0360 A03A 9DE8
|
||||||
|
//
|
||||||
|
//
|
||||||
|
// 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.
|
||||||
|
|
||||||
|
package rpcserver
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
import "context"
|
||||||
|
import "runtime/debug"
|
||||||
|
import "github.com/romana/rlog"
|
||||||
|
import "github.com/deroproject/derohe/rpc"
|
||||||
|
import "github.com/deroproject/derohe/cryptography/crypto"
|
||||||
|
|
||||||
|
func (w *WALLET_RPC_APIS) ScInvoke(ctx context.Context, p rpc.SC_Invoke_Params) (err error) {
|
||||||
|
defer func() { // safety so if anything wrong happens, we return error
|
||||||
|
if r := recover(); r != nil {
|
||||||
|
err = fmt.Errorf("panic occured. stack trace %s", debug.Stack())
|
||||||
|
}
|
||||||
|
}()
|
||||||
|
|
||||||
|
rlog.Debugf("ScInvoke handler")
|
||||||
|
defer rlog.Debugf("ScInvoke handler finished")
|
||||||
|
|
||||||
|
if !w.wallet.GetMode() { // if wallet is in online mode, use the fees, provided by the daemon, else we need to use what is provided by the user
|
||||||
|
return fmt.Errorf("Wallet is in offline mode")
|
||||||
|
}
|
||||||
|
|
||||||
|
// translate rpc to arguments
|
||||||
|
|
||||||
|
//fmt.Printf("incoming transfer params %+v\n", p)
|
||||||
|
|
||||||
|
if p.SC_ID == "" {
|
||||||
|
return fmt.Errorf("SCID cannot be empty")
|
||||||
|
}
|
||||||
|
|
||||||
|
// if destination is "", we will choose a random address automatically
|
||||||
|
|
||||||
|
var tp rpc.Transfer_Params
|
||||||
|
tp.Transfers = append(tp.Transfers, rpc.Transfer{Destination: "deto1qxsplx7vzgydacczw6vnrtfh3fxqcjevyxcvlvl82fs8uykjkmaxgfgulfha5", Amount: 0, Burn: p.SC_DERO_Deposit})
|
||||||
|
|
||||||
|
// we must burn this much tokens
|
||||||
|
if p.SC_TOKEN_Deposit >= 1 {
|
||||||
|
scid := crypto.HashHexToHash(p.SC_ID)
|
||||||
|
tp.Transfers = append(tp.Transfers, rpc.Transfer{SCID: scid, Amount: 0, Burn: p.SC_TOKEN_Deposit})
|
||||||
|
}
|
||||||
|
tp.SC_RPC = p.SC_RPC
|
||||||
|
tp.SC_ID = p.SC_ID
|
||||||
|
|
||||||
|
//fmt.Printf("transfers %+v\n", tp)
|
||||||
|
|
||||||
|
err = wallet_apis.Transfer(context.Background(), tp)
|
||||||
|
|
||||||
|
//fmt.Printf("err transfer %s\n", err)
|
||||||
|
|
||||||
|
return err
|
||||||
|
|
||||||
|
}
|
@ -148,7 +148,7 @@ func (r *RPCServer) Run(wallet *walletapi.Wallet_Disk) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
p.SC_Code = string(b) // encode as base64
|
p.SC_Code = string(b) // encode as base64
|
||||||
p.Transfers = append(p.Transfers, rpc.Transfer{Destination: "deto1qxsplx7vzgydacczw6vnrtfh3fxqcjevyxcvlvl82fs8uykjkmaxgfgulfha5", Amount: 1})
|
p.Transfers = append(p.Transfers, rpc.Transfer{Destination: "deto1qxsplx7vzgydacczw6vnrtfh3fxqcjevyxcvlvl82fs8uykjkmaxgfgulfha5", Amount: 0})
|
||||||
if err := wallet_apis.Transfer(context.Background(), p); err != nil {
|
if err := wallet_apis.Transfer(context.Background(), p); err != nil {
|
||||||
fmt.Fprintf(w, err.Error())
|
fmt.Fprintf(w, err.Error())
|
||||||
return
|
return
|
||||||
@ -281,6 +281,7 @@ var historical_apis = handler.Map{
|
|||||||
"transfer": handler.New(wallet_apis.Transfer),
|
"transfer": handler.New(wallet_apis.Transfer),
|
||||||
"Transfer": handler.New(wallet_apis.Transfer),
|
"Transfer": handler.New(wallet_apis.Transfer),
|
||||||
"transfer_split": handler.New(wallet_apis.Transfer),
|
"transfer_split": handler.New(wallet_apis.Transfer),
|
||||||
|
"scinvoke": handler.New(wallet_apis.ScInvoke),
|
||||||
}
|
}
|
||||||
|
|
||||||
func translate_http_to_jsonrpc_and_vice_versa(w http.ResponseWriter, r *http.Request) {
|
func translate_http_to_jsonrpc_and_vice_versa(w http.ResponseWriter, r *http.Request) {
|
||||||
|
@ -113,10 +113,12 @@ func (w *Wallet_Memory) BuildTransaction(transfers []rpc.Transfer, emap map[stri
|
|||||||
asset.SCID = transfers[t].SCID
|
asset.SCID = transfers[t].SCID
|
||||||
asset.BurnValue = transfers[t].Burn
|
asset.BurnValue = transfers[t].Burn
|
||||||
|
|
||||||
fees := uint64(1)
|
fees := uint64(0)
|
||||||
value := transfers[t].Amount
|
value := transfers[t].Amount
|
||||||
burn_value := transfers[t].Burn
|
burn_value := transfers[t].Burn
|
||||||
|
if asset.SCID.IsZero() && (value+burn_value) == 0 {
|
||||||
|
fees = 1
|
||||||
|
}
|
||||||
for i := range publickeylist { // setup commitments
|
for i := range publickeylist { // setup commitments
|
||||||
var x bn256.G1
|
var x bn256.G1
|
||||||
switch {
|
switch {
|
||||||
|
@ -79,6 +79,9 @@ func (w Wallet_Pool_Entry) DeepCopy() (r Wallet_Pool_Entry) {
|
|||||||
func (w Wallet_Pool_Entry) Amount() (v uint64) {
|
func (w Wallet_Pool_Entry) Amount() (v uint64) {
|
||||||
for i := range w.Transfers {
|
for i := range w.Transfers {
|
||||||
v += w.Transfers[i].Amount
|
v += w.Transfers[i].Amount
|
||||||
|
if w.Transfers[i].SCID.IsZero() {
|
||||||
|
v += w.Transfers[i].Burn
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return v
|
return v
|
||||||
@ -127,13 +130,16 @@ func (w *Wallet_Memory) PoolTransfer(transfers []rpc.Transfer, scdata rpc.Argume
|
|||||||
}
|
}
|
||||||
|
|
||||||
// total which is pending to be sent
|
// total which is pending to be sent
|
||||||
|
// what about SCID, how to show their balance
|
||||||
func (w *Wallet_Memory) PoolBalance() (balance uint64) {
|
func (w *Wallet_Memory) PoolBalance() (balance uint64) {
|
||||||
w.account.Lock()
|
w.account.Lock()
|
||||||
defer w.account.Unlock()
|
defer w.account.Unlock()
|
||||||
|
|
||||||
for i := range w.account.Pool {
|
for i := range w.account.Pool {
|
||||||
for j := range w.account.Pool[i].Transfers {
|
for j := range w.account.Pool[i].Transfers {
|
||||||
balance += w.account.Pool[i].Transfers[j].Amount //+ w.account.Pool[i].Burn
|
if w.account.Pool[i].Transfers[j].SCID.IsZero() {
|
||||||
|
balance += w.account.Pool[i].Transfers[j].Amount + w.account.Pool[i].Transfers[j].Burn
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return
|
return
|
||||||
|
@ -111,8 +111,36 @@ func (w *Wallet_Memory) TransferPayload0(transfers []rpc.Transfer, transfer_all
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
for i := range transfers {
|
for t := range transfers {
|
||||||
if _, err = rpc.NewAddress(transfers[i].Destination); err != nil {
|
saddress := transfers[t].Destination
|
||||||
|
|
||||||
|
if saddress == "" { // user skipped destination
|
||||||
|
if transfers[t].SCID.IsZero() {
|
||||||
|
err = fmt.Errorf("Main Destination cannot be empty")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
// we will try 5 times, to get a random ring ring member other than us, if ok, we move ahead
|
||||||
|
for i := 0; i < 5; i++ {
|
||||||
|
for _, k := range w.random_ring_members(transfers[t].SCID) {
|
||||||
|
|
||||||
|
//fmt.Printf("%d ring %d '%s'\n",i,j,k)
|
||||||
|
if k != w.GetAddress().String() {
|
||||||
|
saddress = k
|
||||||
|
transfers[t].Destination = k
|
||||||
|
i = 1000 // break outer loop also
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if saddress == "" {
|
||||||
|
err = fmt.Errorf("could not obtain random ring member for scid %s", transfers[t].SCID)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if _, err = rpc.NewAddress(saddress); err != nil {
|
||||||
|
fmt.Printf("err processing address '%s' err '%s'\n", saddress, err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -174,6 +202,7 @@ func (w *Wallet_Memory) TransferPayload0(transfers []rpc.Transfer, transfer_all
|
|||||||
var dest_e *crypto.ElGamal
|
var dest_e *crypto.ElGamal
|
||||||
bits_needed[1], dest_e, err = w.GetEncryptedBalanceAtTopoHeight(transfers[t].SCID, -1, addr.String())
|
bits_needed[1], dest_e, err = w.GetEncryptedBalanceAtTopoHeight(transfers[t].SCID, -1, addr.String())
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
fmt.Printf(" t %d unregistered1 '%s' %s\n", t, addr, err)
|
||||||
return
|
return
|
||||||
} else {
|
} else {
|
||||||
emap[string(transfers[t].SCID.String())][addr.PublicKey.G1().String()] = dest_e.Serialize()
|
emap[string(transfers[t].SCID.String())][addr.PublicKey.G1().String()] = dest_e.Serialize()
|
||||||
|
Loading…
x
Reference in New Issue
Block a user