Merge pull request #2548 from karalabe/surface-rpc-endpoint
cmd/geth, internal/web3ext, rpc: surface rpc module, fix shh, fix miner
This commit is contained in:
commit
5a901bb555
|
@ -199,7 +199,7 @@ func (js *jsre) apiBindings() error {
|
||||||
// load only supported API's in javascript runtime
|
// load only supported API's in javascript runtime
|
||||||
shortcuts := "var eth = web3.eth; var personal = web3.personal; "
|
shortcuts := "var eth = web3.eth; var personal = web3.personal; "
|
||||||
for _, apiName := range apiNames {
|
for _, apiName := range apiNames {
|
||||||
if apiName == "web3" || apiName == "rpc" {
|
if apiName == "web3" {
|
||||||
continue // manually mapped or ignore
|
continue // manually mapped or ignore
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -18,44 +18,17 @@
|
||||||
package web3ext
|
package web3ext
|
||||||
|
|
||||||
var Modules = map[string]string{
|
var Modules = map[string]string{
|
||||||
"txpool": TxPool_JS,
|
|
||||||
"admin": Admin_JS,
|
"admin": Admin_JS,
|
||||||
"personal": Personal_JS,
|
"debug": Debug_JS,
|
||||||
"eth": Eth_JS,
|
"eth": Eth_JS,
|
||||||
"miner": Miner_JS,
|
"miner": Miner_JS,
|
||||||
"debug": Debug_JS,
|
|
||||||
"net": Net_JS,
|
"net": Net_JS,
|
||||||
|
"personal": Personal_JS,
|
||||||
|
"rpc": RPC_JS,
|
||||||
|
"shh": Shh_JS,
|
||||||
|
"txpool": TxPool_JS,
|
||||||
}
|
}
|
||||||
|
|
||||||
const TxPool_JS = `
|
|
||||||
web3._extend({
|
|
||||||
property: 'txpool',
|
|
||||||
methods:
|
|
||||||
[
|
|
||||||
],
|
|
||||||
properties:
|
|
||||||
[
|
|
||||||
new web3._extend.Property({
|
|
||||||
name: 'content',
|
|
||||||
getter: 'txpool_content'
|
|
||||||
}),
|
|
||||||
new web3._extend.Property({
|
|
||||||
name: 'inspect',
|
|
||||||
getter: 'txpool_inspect'
|
|
||||||
}),
|
|
||||||
new web3._extend.Property({
|
|
||||||
name: 'status',
|
|
||||||
getter: 'txpool_status',
|
|
||||||
outputFormatter: function(status) {
|
|
||||||
status.pending = web3._extend.utils.toDecimal(status.pending);
|
|
||||||
status.queued = web3._extend.utils.toDecimal(status.queued);
|
|
||||||
return status;
|
|
||||||
}
|
|
||||||
})
|
|
||||||
]
|
|
||||||
});
|
|
||||||
`
|
|
||||||
|
|
||||||
const Admin_JS = `
|
const Admin_JS = `
|
||||||
web3._extend({
|
web3._extend({
|
||||||
property: 'admin',
|
property: 'admin',
|
||||||
|
@ -176,88 +149,6 @@ web3._extend({
|
||||||
});
|
});
|
||||||
`
|
`
|
||||||
|
|
||||||
const Personal_JS = `
|
|
||||||
web3._extend({
|
|
||||||
property: 'personal',
|
|
||||||
methods:
|
|
||||||
[
|
|
||||||
new web3._extend.Method({
|
|
||||||
name: 'importRawKey',
|
|
||||||
call: 'personal_importRawKey',
|
|
||||||
params: 2
|
|
||||||
})
|
|
||||||
]
|
|
||||||
});
|
|
||||||
`
|
|
||||||
|
|
||||||
const Eth_JS = `
|
|
||||||
web3._extend({
|
|
||||||
property: 'eth',
|
|
||||||
methods:
|
|
||||||
[
|
|
||||||
new web3._extend.Method({
|
|
||||||
name: 'sign',
|
|
||||||
call: 'eth_sign',
|
|
||||||
params: 2,
|
|
||||||
inputFormatter: [web3._extend.formatters.inputAddressFormatter, null]
|
|
||||||
}),
|
|
||||||
new web3._extend.Method({
|
|
||||||
name: 'resend',
|
|
||||||
call: 'eth_resend',
|
|
||||||
params: 3,
|
|
||||||
inputFormatter: [web3._extend.formatters.inputTransactionFormatter, web3._extend.utils.fromDecimal, web3._extend.utils.fromDecimal]
|
|
||||||
}),
|
|
||||||
new web3._extend.Method({
|
|
||||||
name: 'getNatSpec',
|
|
||||||
call: 'eth_getNatSpec',
|
|
||||||
params: 1,
|
|
||||||
inputFormatter: [web3._extend.formatters.inputTransactionFormatter]
|
|
||||||
}),
|
|
||||||
new web3._extend.Method({
|
|
||||||
name: 'signTransaction',
|
|
||||||
call: 'eth_signTransaction',
|
|
||||||
params: 1,
|
|
||||||
inputFormatter: [web3._extend.formatters.inputTransactionFormatter]
|
|
||||||
}),
|
|
||||||
new web3._extend.Method({
|
|
||||||
name: 'submitTransaction',
|
|
||||||
call: 'eth_submitTransaction',
|
|
||||||
params: 1,
|
|
||||||
inputFormatter: [web3._extend.formatters.inputTransactionFormatter]
|
|
||||||
})
|
|
||||||
],
|
|
||||||
properties:
|
|
||||||
[
|
|
||||||
new web3._extend.Property({
|
|
||||||
name: 'pendingTransactions',
|
|
||||||
getter: 'eth_pendingTransactions',
|
|
||||||
outputFormatter: function(txs) {
|
|
||||||
var formatted = [];
|
|
||||||
for (var i = 0; i < txs.length; i++) {
|
|
||||||
formatted.push(web3._extend.formatters.outputTransactionFormatter(txs[i]));
|
|
||||||
formatted[i].blockHash = null;
|
|
||||||
}
|
|
||||||
return formatted;
|
|
||||||
}
|
|
||||||
})
|
|
||||||
]
|
|
||||||
});
|
|
||||||
`
|
|
||||||
|
|
||||||
const Net_JS = `
|
|
||||||
web3._extend({
|
|
||||||
property: 'net',
|
|
||||||
methods: [],
|
|
||||||
properties:
|
|
||||||
[
|
|
||||||
new web3._extend.Property({
|
|
||||||
name: 'version',
|
|
||||||
getter: 'net_version'
|
|
||||||
})
|
|
||||||
]
|
|
||||||
});
|
|
||||||
`
|
|
||||||
|
|
||||||
const Debug_JS = `
|
const Debug_JS = `
|
||||||
web3._extend({
|
web3._extend({
|
||||||
property: 'debug',
|
property: 'debug',
|
||||||
|
@ -410,6 +301,60 @@ web3._extend({
|
||||||
});
|
});
|
||||||
`
|
`
|
||||||
|
|
||||||
|
const Eth_JS = `
|
||||||
|
web3._extend({
|
||||||
|
property: 'eth',
|
||||||
|
methods:
|
||||||
|
[
|
||||||
|
new web3._extend.Method({
|
||||||
|
name: 'sign',
|
||||||
|
call: 'eth_sign',
|
||||||
|
params: 2,
|
||||||
|
inputFormatter: [web3._extend.formatters.inputAddressFormatter, null]
|
||||||
|
}),
|
||||||
|
new web3._extend.Method({
|
||||||
|
name: 'resend',
|
||||||
|
call: 'eth_resend',
|
||||||
|
params: 3,
|
||||||
|
inputFormatter: [web3._extend.formatters.inputTransactionFormatter, web3._extend.utils.fromDecimal, web3._extend.utils.fromDecimal]
|
||||||
|
}),
|
||||||
|
new web3._extend.Method({
|
||||||
|
name: 'getNatSpec',
|
||||||
|
call: 'eth_getNatSpec',
|
||||||
|
params: 1,
|
||||||
|
inputFormatter: [web3._extend.formatters.inputTransactionFormatter]
|
||||||
|
}),
|
||||||
|
new web3._extend.Method({
|
||||||
|
name: 'signTransaction',
|
||||||
|
call: 'eth_signTransaction',
|
||||||
|
params: 1,
|
||||||
|
inputFormatter: [web3._extend.formatters.inputTransactionFormatter]
|
||||||
|
}),
|
||||||
|
new web3._extend.Method({
|
||||||
|
name: 'submitTransaction',
|
||||||
|
call: 'eth_submitTransaction',
|
||||||
|
params: 1,
|
||||||
|
inputFormatter: [web3._extend.formatters.inputTransactionFormatter]
|
||||||
|
})
|
||||||
|
],
|
||||||
|
properties:
|
||||||
|
[
|
||||||
|
new web3._extend.Property({
|
||||||
|
name: 'pendingTransactions',
|
||||||
|
getter: 'eth_pendingTransactions',
|
||||||
|
outputFormatter: function(txs) {
|
||||||
|
var formatted = [];
|
||||||
|
for (var i = 0; i < txs.length; i++) {
|
||||||
|
formatted.push(web3._extend.formatters.outputTransactionFormatter(txs[i]));
|
||||||
|
formatted[i].blockHash = null;
|
||||||
|
}
|
||||||
|
return formatted;
|
||||||
|
}
|
||||||
|
})
|
||||||
|
]
|
||||||
|
});
|
||||||
|
`
|
||||||
|
|
||||||
const Miner_JS = `
|
const Miner_JS = `
|
||||||
web3._extend({
|
web3._extend({
|
||||||
property: 'miner',
|
property: 'miner',
|
||||||
|
@ -440,7 +385,7 @@ web3._extend({
|
||||||
name: 'setGasPrice',
|
name: 'setGasPrice',
|
||||||
call: 'miner_setGasPrice',
|
call: 'miner_setGasPrice',
|
||||||
params: 1,
|
params: 1,
|
||||||
inputFormatter: [web3._extend.utils.fromDecial]
|
inputFormatter: [web3._extend.utils.fromDecimal]
|
||||||
}),
|
}),
|
||||||
new web3._extend.Method({
|
new web3._extend.Method({
|
||||||
name: 'startAutoDAG',
|
name: 'startAutoDAG',
|
||||||
|
@ -463,6 +408,48 @@ web3._extend({
|
||||||
});
|
});
|
||||||
`
|
`
|
||||||
|
|
||||||
|
const Net_JS = `
|
||||||
|
web3._extend({
|
||||||
|
property: 'net',
|
||||||
|
methods: [],
|
||||||
|
properties:
|
||||||
|
[
|
||||||
|
new web3._extend.Property({
|
||||||
|
name: 'version',
|
||||||
|
getter: 'net_version'
|
||||||
|
})
|
||||||
|
]
|
||||||
|
});
|
||||||
|
`
|
||||||
|
|
||||||
|
const Personal_JS = `
|
||||||
|
web3._extend({
|
||||||
|
property: 'personal',
|
||||||
|
methods:
|
||||||
|
[
|
||||||
|
new web3._extend.Method({
|
||||||
|
name: 'importRawKey',
|
||||||
|
call: 'personal_importRawKey',
|
||||||
|
params: 2
|
||||||
|
})
|
||||||
|
]
|
||||||
|
});
|
||||||
|
`
|
||||||
|
|
||||||
|
const RPC_JS = `
|
||||||
|
web3._extend({
|
||||||
|
property: 'rpc',
|
||||||
|
methods: [],
|
||||||
|
properties:
|
||||||
|
[
|
||||||
|
new web3._extend.Property({
|
||||||
|
name: 'modules',
|
||||||
|
getter: 'rpc_modules'
|
||||||
|
})
|
||||||
|
]
|
||||||
|
});
|
||||||
|
`
|
||||||
|
|
||||||
const Shh_JS = `
|
const Shh_JS = `
|
||||||
web3._extend({
|
web3._extend({
|
||||||
property: 'shh',
|
property: 'shh',
|
||||||
|
@ -471,7 +458,35 @@ web3._extend({
|
||||||
[
|
[
|
||||||
new web3._extend.Property({
|
new web3._extend.Property({
|
||||||
name: 'version',
|
name: 'version',
|
||||||
getter: 'shh_version'
|
getter: 'shh_version',
|
||||||
|
outputFormatter: web3._extend.utils.toDecimal
|
||||||
|
})
|
||||||
|
]
|
||||||
|
});
|
||||||
|
`
|
||||||
|
|
||||||
|
const TxPool_JS = `
|
||||||
|
web3._extend({
|
||||||
|
property: 'txpool',
|
||||||
|
methods: [],
|
||||||
|
properties:
|
||||||
|
[
|
||||||
|
new web3._extend.Property({
|
||||||
|
name: 'content',
|
||||||
|
getter: 'txpool_content'
|
||||||
|
}),
|
||||||
|
new web3._extend.Property({
|
||||||
|
name: 'inspect',
|
||||||
|
getter: 'txpool_inspect'
|
||||||
|
}),
|
||||||
|
new web3._extend.Property({
|
||||||
|
name: 'status',
|
||||||
|
getter: 'txpool_status',
|
||||||
|
outputFormatter: function(status) {
|
||||||
|
status.pending = web3._extend.utils.toDecimal(status.pending);
|
||||||
|
status.queued = web3._extend.utils.toDecimal(status.queued);
|
||||||
|
return status;
|
||||||
|
}
|
||||||
})
|
})
|
||||||
]
|
]
|
||||||
});
|
});
|
||||||
|
|
|
@ -34,7 +34,8 @@ const (
|
||||||
|
|
||||||
notificationBufferSize = 10000 // max buffered notifications before codec is closed
|
notificationBufferSize = 10000 // max buffered notifications before codec is closed
|
||||||
|
|
||||||
DefaultIPCApis = "admin,eth,debug,miner,net,shh,txpool,personal,web3"
|
MetadataApi = "rpc"
|
||||||
|
DefaultIPCApis = "admin,debug,eth,miner,net,personal,shh,txpool,web3"
|
||||||
DefaultHTTPApis = "eth,net,web3"
|
DefaultHTTPApis = "eth,net,web3"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -61,7 +62,7 @@ func NewServer() *Server {
|
||||||
// register a default service which will provide meta information about the RPC service such as the services and
|
// register a default service which will provide meta information about the RPC service such as the services and
|
||||||
// methods it offers.
|
// methods it offers.
|
||||||
rpcService := &RPCService{server}
|
rpcService := &RPCService{server}
|
||||||
server.RegisterName("rpc", rpcService)
|
server.RegisterName(MetadataApi, rpcService)
|
||||||
|
|
||||||
return server
|
return server
|
||||||
}
|
}
|
||||||
|
|
|
@ -234,7 +234,7 @@ func SupportedModules(client Client) (map[string]string, error) {
|
||||||
req := JSONRequest{
|
req := JSONRequest{
|
||||||
Id: []byte("1"),
|
Id: []byte("1"),
|
||||||
Version: "2.0",
|
Version: "2.0",
|
||||||
Method: "rpc_modules",
|
Method: MetadataApi + "_modules",
|
||||||
}
|
}
|
||||||
if err := client.Send(req); err != nil {
|
if err := client.Send(req); err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
|
|
Loading…
Reference in New Issue