2021-07-09 15:19:33 +02:00
|
|
|
package node
|
2018-04-12 18:17:10 +02:00
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2022-03-23 18:47:00 +00:00
|
|
|
"database/sql"
|
|
|
|
"io/ioutil"
|
|
|
|
"os"
|
2021-07-09 15:19:33 +02:00
|
|
|
"strings"
|
2018-04-12 18:17:10 +02:00
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
|
2022-03-23 18:47:00 +00:00
|
|
|
"github.com/status-im/status-go/appdatabase"
|
|
|
|
"github.com/status-im/status-go/multiaccounts"
|
2018-06-08 13:29:50 +02:00
|
|
|
"github.com/status-im/status-go/params"
|
2022-09-27 16:27:20 -04:00
|
|
|
"github.com/status-im/status-go/sqlite"
|
2018-04-12 18:17:10 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
type TestServiceAPI struct{}
|
|
|
|
|
|
|
|
func (api *TestServiceAPI) SomeMethod(_ context.Context) (string, error) {
|
|
|
|
return "some method result", nil
|
|
|
|
}
|
|
|
|
|
2022-03-23 18:47:00 +00:00
|
|
|
func setupTestDB() (*sql.DB, func() error, error) {
|
|
|
|
tmpfile, err := ioutil.TempFile("", "tests")
|
|
|
|
if err != nil {
|
|
|
|
return nil, nil, err
|
|
|
|
}
|
2022-09-27 16:27:20 -04:00
|
|
|
db, err := appdatabase.InitializeDB(tmpfile.Name(), "tests", sqlite.ReducedKDFIterationsNumber)
|
2022-03-23 18:47:00 +00:00
|
|
|
if err != nil {
|
|
|
|
return nil, nil, err
|
|
|
|
}
|
|
|
|
return db, func() error {
|
|
|
|
err := db.Close()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
return os.Remove(tmpfile.Name())
|
|
|
|
}, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func setupTestMultiDB() (*multiaccounts.Database, func() error, error) {
|
|
|
|
tmpfile, err := ioutil.TempFile("", "tests")
|
|
|
|
if err != nil {
|
|
|
|
return nil, nil, err
|
|
|
|
}
|
|
|
|
db, err := multiaccounts.InitializeDB(tmpfile.Name())
|
|
|
|
if err != nil {
|
|
|
|
return nil, nil, err
|
|
|
|
}
|
|
|
|
return db, func() error {
|
|
|
|
err := db.Close()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
return os.Remove(tmpfile.Name())
|
|
|
|
}, nil
|
|
|
|
}
|
|
|
|
|
2021-07-09 15:19:33 +02:00
|
|
|
func createAndStartStatusNode(config *params.NodeConfig) (*StatusNode, error) {
|
2021-12-21 15:44:37 +00:00
|
|
|
statusNode := New(nil)
|
2022-03-23 18:47:00 +00:00
|
|
|
|
|
|
|
db, stop, err := setupTestDB()
|
|
|
|
defer func() {
|
|
|
|
err := stop()
|
|
|
|
if err != nil {
|
|
|
|
statusNode.log.Error("stopping db", err)
|
|
|
|
}
|
|
|
|
}()
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
statusNode.appDB = db
|
|
|
|
|
|
|
|
ma, stop2, err := setupTestMultiDB()
|
|
|
|
defer func() {
|
|
|
|
err := stop2()
|
|
|
|
if err != nil {
|
|
|
|
statusNode.log.Error("stopping multiaccount db", err)
|
|
|
|
}
|
|
|
|
}()
|
2021-07-09 15:19:33 +02:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
2018-04-12 18:17:10 +02:00
|
|
|
}
|
2022-03-23 18:47:00 +00:00
|
|
|
statusNode.multiaccountsDB = ma
|
|
|
|
|
|
|
|
err = statusNode.Start(config, nil)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
2021-07-09 15:19:33 +02:00
|
|
|
return statusNode, nil
|
2018-04-12 18:17:10 +02:00
|
|
|
}
|
|
|
|
|
2023-03-27 16:33:00 +02:00
|
|
|
func createStatusNode() (*StatusNode, func() error, func() error, error) {
|
|
|
|
db, stop1, err := setupTestDB()
|
|
|
|
if err != nil {
|
|
|
|
return nil, nil, nil, err
|
|
|
|
}
|
|
|
|
statusNode := New(nil)
|
|
|
|
statusNode.SetAppDB(db)
|
|
|
|
|
|
|
|
ma, stop2, err := setupTestMultiDB()
|
|
|
|
statusNode.SetMultiaccountsDB(ma)
|
|
|
|
|
|
|
|
return statusNode, stop1, stop2, err
|
|
|
|
}
|
|
|
|
|
2018-04-12 18:17:10 +02:00
|
|
|
func TestNodeRPCClientCallOnlyPublicAPIs(t *testing.T) {
|
|
|
|
var err error
|
|
|
|
|
2018-04-16 14:36:09 +02:00
|
|
|
statusNode, err := createAndStartStatusNode(¶ms.NodeConfig{
|
|
|
|
APIModules: "", // no whitelisted API modules; use only public APIs
|
2021-07-09 15:19:33 +02:00
|
|
|
UpstreamConfig: params.UpstreamRPCConfig{
|
|
|
|
URL: "https://infura.io",
|
|
|
|
Enabled: true},
|
|
|
|
WakuConfig: params.WakuConfig{
|
|
|
|
Enabled: true,
|
|
|
|
},
|
2018-04-16 14:36:09 +02:00
|
|
|
})
|
2018-04-12 18:17:10 +02:00
|
|
|
require.NoError(t, err)
|
|
|
|
defer func() {
|
|
|
|
err := statusNode.Stop()
|
|
|
|
require.NoError(t, err)
|
|
|
|
}()
|
|
|
|
|
|
|
|
client := statusNode.RPCClient()
|
|
|
|
require.NotNil(t, client)
|
|
|
|
|
2021-07-09 15:19:33 +02:00
|
|
|
// call public API with public RPC Client
|
|
|
|
result, err := statusNode.CallRPC(`{"jsonrpc": "2.0", "id": 1, "method": "eth_uninstallFilter", "params": ["id"]}`)
|
2018-04-12 18:17:10 +02:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
2021-07-09 15:19:33 +02:00
|
|
|
// the call is successful
|
|
|
|
require.False(t, strings.Contains(result, "error"))
|
2018-04-12 18:17:10 +02:00
|
|
|
|
2021-07-09 15:19:33 +02:00
|
|
|
result, err = statusNode.CallRPC(`{"jsonrpc": "2.0", "id": 1, "method": "waku_info"}`)
|
2018-04-12 18:17:10 +02:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
2021-07-09 15:19:33 +02:00
|
|
|
// call private API with public RPC client
|
|
|
|
require.Equal(t, ErrRPCMethodUnavailable, result)
|
2018-04-12 18:17:10 +02:00
|
|
|
|
|
|
|
}
|
2018-04-16 10:01:37 +02:00
|
|
|
|
|
|
|
func TestNodeRPCPrivateClientCallPrivateService(t *testing.T) {
|
|
|
|
var err error
|
|
|
|
|
2021-07-12 16:16:33 +02:00
|
|
|
statusNode, err := createAndStartStatusNode(¶ms.NodeConfig{
|
|
|
|
WakuConfig: params.WakuConfig{
|
|
|
|
Enabled: true,
|
|
|
|
},
|
|
|
|
})
|
2018-04-16 10:01:37 +02:00
|
|
|
require.NoError(t, err)
|
|
|
|
defer func() {
|
|
|
|
err := statusNode.Stop()
|
|
|
|
require.NoError(t, err)
|
|
|
|
}()
|
|
|
|
|
2021-07-09 15:19:33 +02:00
|
|
|
result, err := statusNode.CallPrivateRPC(`{"jsonrpc": "2.0", "id": 1, "method": "waku_info"}`)
|
2018-04-16 10:01:37 +02:00
|
|
|
require.NoError(t, err)
|
2021-07-09 15:19:33 +02:00
|
|
|
|
|
|
|
// the call is successful
|
|
|
|
require.False(t, strings.Contains(result, "error"))
|
2022-03-23 18:47:00 +00:00
|
|
|
|
|
|
|
_, err = statusNode.CallPrivateRPC(`{"jsonrpc": "2.0", "id": 1, "method": "settings_getSettings"}`)
|
|
|
|
require.NoError(t, err)
|
2018-04-16 10:01:37 +02:00
|
|
|
}
|