diff --git a/go.mod b/go.mod index 78db02e..1b355c9 100644 --- a/go.mod +++ b/go.mod @@ -1,12 +1,19 @@ module github.com/xyield/xumm-go-client -go 1.16 +go 1.18 require ( github.com/gorilla/websocket v1.4.2 github.com/json-iterator/go v1.1.12 - github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd // indirect github.com/stretchr/testify v1.7.0 github.com/ugorji/go/codec v1.2.7 github.com/xyield/xumm-user-device v0.0.0-20220315190815-aed3ae39e4ab ) + +require ( + github.com/davecgh/go-spew v1.1.1 // indirect + github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd // indirect + github.com/modern-go/reflect2 v1.0.2 // indirect + github.com/pmezard/go-difflib v1.0.0 // indirect + gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c // indirect +) diff --git a/go.sum b/go.sum index 1b2d83f..1cd3c21 100644 --- a/go.sum +++ b/go.sum @@ -4,13 +4,11 @@ github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSs github.com/google/gofuzz v1.0.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg= github.com/gorilla/websocket v1.4.2 h1:+/TMaTYc4QFitKJxsQ7Yye35DkWvkdLcvGKqM+x0Ufc= github.com/gorilla/websocket v1.4.2/go.mod h1:YR8l580nyteQvAITg2hZ9XVh4b55+EU/adAjf1fMHhE= -github.com/json-iterator/go v1.1.11/go.mod h1:KdQUCv79m/52Kvf8AW2vK1V8akMuk1QjK/uOdHXbAo4= github.com/json-iterator/go v1.1.12 h1:PV8peI4a0ysnczrg+LtxykD8LfKY9ML6u2jnxaEnrnM= github.com/json-iterator/go v1.1.12/go.mod h1:e30LSqwooZae/UwlEbR2852Gd8hjQvJoHmT4TnhNGBo= github.com/modern-go/concurrent v0.0.0-20180228061459-e0a39a4cb421/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q= github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd h1:TRLaZ9cD/w8PVh93nsPXa1VrQ6jlwL5oN8l14QlcNfg= github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q= -github.com/modern-go/reflect2 v0.0.0-20180701023420-4b7aa43c6742/go.mod h1:bx2lNnkwVCuqBIxFjflWJWanXIb3RllmbCylyMrvgv0= github.com/modern-go/reflect2 v1.0.2 h1:xBagoLtFs94CBntxluKeaWgTMpvLxC4ur3nMaC9Gz0M= github.com/modern-go/reflect2 v1.0.2/go.mod h1:yWuevngMOJpCy52FWWMvUC8ws7m/LJsjYzDa0/r8luk= github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM= @@ -19,13 +17,9 @@ github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+ github.com/stretchr/testify v1.3.0/go.mod h1:M5WIy9Dh21IEIfnGCwXGc5bZfKNJtfHm1UVUgZn+9EI= github.com/stretchr/testify v1.7.0 h1:nwc3DEeHmmLAfoZucVR881uASk0Mfjw8xYJ99tb5CcY= github.com/stretchr/testify v1.7.0/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg= -github.com/ugorji/go v1.2.6/go.mod h1:anCg0y61KIhDlPZmnH+so+RQbysYVyDko0IMgJv0Nn0= -github.com/ugorji/go v1.2.7 h1:qYhyWUUd6WbiM+C6JZAUkIJt/1WrjzNHY9+KCIjVqTo= github.com/ugorji/go v1.2.7/go.mod h1:nF9osbDWLy6bDVv/Rtoh6QgnvNDpmCalQV5urGCCS6M= -github.com/ugorji/go/codec v1.2.6/go.mod h1:V6TCNZ4PHqoHGFZuSG1W8nrCzzdgA2DozYxWFFpvxTw= github.com/ugorji/go/codec v1.2.7 h1:YPXUKf7fYbp/y8xloBqZOw2qaVggbfwMlI8WM3wZUJ0= github.com/ugorji/go/codec v1.2.7/go.mod h1:WGN1fab3R1fzQlVQTkfxVtIBhWDRqOviHU95kRgeqEY= -github.com/xyield/xumm-go-client v0.0.0-20220310192812-590915fe9937/go.mod h1:0LoPhdN9OpjWZJaZ86y1sz/oc57PbuAIB5ORwSX5kyc= github.com/xyield/xumm-user-device v0.0.0-20220315190815-aed3ae39e4ab h1:8tFBu+hvANduwkQutWsFDWVR60bXdZ1uoyA7nJgG6FE= github.com/xyield/xumm-user-device v0.0.0-20220315190815-aed3ae39e4ab/go.mod h1:VwNyuWpcqbDmKq6IvvXTDJAFf+skL6M9/pDgQYNyYRk= gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405 h1:yhCVgyC4o1eVCa2tZl7eS0r+SDo693bJlVdllGtEeKM= diff --git a/go.work.sum b/go.work.sum new file mode 100644 index 0000000..0132959 --- /dev/null +++ b/go.work.sum @@ -0,0 +1 @@ +github.com/ugorji/go v1.2.7 h1:qYhyWUUd6WbiM+C6JZAUkIJt/1WrjzNHY9+KCIjVqTo= diff --git a/xumm-go-client b/xumm-go-client new file mode 160000 index 0000000..96aadd7 --- /dev/null +++ b/xumm-go-client @@ -0,0 +1 @@ +Subproject commit 96aadd7f8061ea2f1b4afb6580c3bfb0e1a02b11 diff --git a/xumm/jwt/jwt.go b/xumm/jwt/jwt.go index 8d84031..a66d49a 100644 --- a/xumm/jwt/jwt.go +++ b/xumm/jwt/jwt.go @@ -13,7 +13,7 @@ type JwtInterface interface { GetPayloadByCustomId(customId string, jwt ...string) (*models.XummPayload, error) GetRatesForCurrency(cur string, jwt ...string) (*models.RatesCurrencyResponse, error) PostPayload(body models.XummPostPayload, jwt ...string) (*models.CreatedPayload, error) - Ping(Jwt ...string) (*models.Pong, error) + Ping(Jwt ...string) (*models.JwtPong, error) } type Jwt struct { diff --git a/xumm/jwt/jwt_ping.go b/xumm/jwt/jwt_ping.go index c311bc5..272eacd 100644 --- a/xumm/jwt/jwt_ping.go +++ b/xumm/jwt/jwt_ping.go @@ -14,7 +14,7 @@ const ( ) // Ping method tests connectivity to XUMM api. -func (j *Jwt) Ping(jwt ...string) (*models.Pong, error) { +func (j *Jwt) Ping(jwt ...string) (*models.JwtPong, error) { req, err := http.NewRequest(http.MethodGet, j.Cfg.BaseURL+JWTPINGENDPOINT, nil) if jwt == nil { @@ -36,7 +36,7 @@ func (j *Jwt) Ping(jwt ...string) (*models.Pong, error) { log.Println(err) return nil, err } - var p models.Pong + var p models.JwtPong _, err = utils.DeserialiseRequest(&p, res.Body) if err != nil { return nil, err diff --git a/xumm/meta/get_account_meta_integration_test.go b/xumm/meta/get_account_meta_integration_test.go new file mode 100644 index 0000000..530b2df --- /dev/null +++ b/xumm/meta/get_account_meta_integration_test.go @@ -0,0 +1,24 @@ +package meta + +import ( + "testing" + + "github.com/stretchr/testify/assert" + "github.com/xyield/xumm-go-client/xumm" + statictestdata "github.com/xyield/xumm-go-client/xumm/meta/static-test-data" +) + +func TestGetAccountMetaIntegrationTest(t *testing.T) { + + cfg, err := xumm.NewConfig() + assert.NoError(t, err) + m := &Meta{ + Cfg: cfg, + } + + am, err := m.GetAccountMeta(statictestdata.AccountMetaTestResult.Account) + + assert.NoError(t, err) + assert.NotEmpty(t, am) + assert.Equal(t, statictestdata.AccountMetaTestResult, am) +} diff --git a/xumm/meta/get_account_meta_test.go b/xumm/meta/get_account_meta_test.go new file mode 100644 index 0000000..5984144 --- /dev/null +++ b/xumm/meta/get_account_meta_test.go @@ -0,0 +1,91 @@ +package meta + +import ( + "net/http" + "testing" + + "github.com/stretchr/testify/assert" + testutils "github.com/xyield/xumm-go-client/utils/test-utils" + "github.com/xyield/xumm-go-client/xumm" + statictestdata "github.com/xyield/xumm-go-client/xumm/meta/static-test-data" + "github.com/xyield/xumm-go-client/xumm/models" +) + +func TestGetAccountMeta(t *testing.T) { + + jsonResponse := `{ + "account": "rwietsevLFg8XSmG3bEZzFein1g8RBqWDZ", + "kycApproved": true, + "xummPro": true, + "blocked": false, + "force_dtag": false, + "avatar": "https://xumm.app/avatar/rwietsevLFg8XSmG3bEZzFein1g8RBqWDZ.png", + "xummProfile": { + "accountAlias": "XRPL Labs - Wietse Wind", + "ownerAlias": "Wietse Wind", + "slug": "wietsewind", + "profileUrl": "https://xumm.me/wietsewind", + "accountSlug": null, + "payString": "wietsewind$xumm.me" + }, + "thirdPartyProfiles": [ + { + "accountAlias": "Wietse Wind", + "source": "xumm.app" + }, + { + "accountAlias": "wietse.com", + "source": "xrpl" + }, + { + "accountAlias": "XRPL-Labs", + "source": "bithomp.com" + } + ], + "globalid": { + "linked": "2021-06-29T10:22:25.000Z", + "profileUrl": "https://app.global.id/u/wietse", + "sufficientTrust": true + } + }` + + tests := []struct { + testName string + inputValue string + expectedOutput *models.AccountMetaResponse + expectedError error + httpStatusCode int + }{ + {testName: "correctData", inputValue: jsonResponse, expectedOutput: statictestdata.AccountMetaTestResult, expectedError: nil, httpStatusCode: 200}, + } + + for _, tt := range tests { + + t.Run(tt.testName, func(t *testing.T) { + m := &testutils.MockClient{} + m.DoFunc = testutils.MockResponse(tt.inputValue, tt.httpStatusCode, m) + cfg, err := xumm.NewConfig(xumm.WithHttpClient(m), xumm.WithAuth("testApiKey", "testApiSecret")) + assert.NoError(t, err) + meta := &Meta{ + Cfg: cfg, + } + ca, err := meta.GetAccountMeta(statictestdata.AccountMetaTestResult.Account) + + if tt.expectedError != nil { + assert.Nil(t, ca) + assert.Error(t, err) + assert.EqualError(t, err, tt.expectedError.Error()) + } else { + assert.Equal(t, http.Header{ + "X-API-Key": {"testApiKey"}, + "X-API-Secret": {"testApiSecret"}, + "Content-Type": {"application/json"}, + }, m.Spy.Header) + assert.NoError(t, err) + assert.Equal(t, tt.expectedOutput, ca) + } + }) + + } + +} diff --git a/xumm/meta/get_curated_assets_integration_test.go b/xumm/meta/get_curated_assets_integration_test.go index 2a46856..82b8553 100644 --- a/xumm/meta/get_curated_assets_integration_test.go +++ b/xumm/meta/get_curated_assets_integration_test.go @@ -33,7 +33,7 @@ func TestCuratedAssetsIntegration(t *testing.T) { Id: 185, Name: "Bitstamp", Domain: "bitstamp.net", - Avatar: "https://xumm.app/assets/icons/currencies/ex-bitstamp.png", + Avatar: "https://xumm.app/cdn-cgi/image/width=250,height=250,quality=75,fit=crop/assets/icons/currencies/ex-bitstamp.png", Currencies: map[string]models.CurrencyInfo{ "BTC": { Id: 492, @@ -41,7 +41,23 @@ func TestCuratedAssetsIntegration(t *testing.T) { Issuer: "rvYAfWj5gh67oV6fW32ZzP3Aw4Eubs59B", Currency: "BTC", Name: "Bitcoin", - Avatar: "https://xumm.app/assets/icons/currencies/crypto-btc.png", + Avatar: "https://xumm.app/cdn-cgi/image/width=250,height=250,quality=75,fit=crop/assets/icons/currencies/crypto-btc.png", + }, + "EUR": { + Id: 13854758, + IssuerId: 185, + Issuer: "rvYAfWj5gh67oV6fW32ZzP3Aw4Eubs59B", + Currency: "EUR", + Name: "Euro", + Avatar: "https://xumm.app/cdn-cgi/image/width=250,height=250,quality=75,fit=crop/assets/icons/currencies/fiat-euro.png", + }, + "GBP": { + Id: 13854774, + IssuerId: 185, + Issuer: "rvYAfWj5gh67oV6fW32ZzP3Aw4Eubs59B", + Currency: "GBP", + Name: "British Pound", + Avatar: "https://cdn.xumm.pro/cdn-cgi/image/width=250,height=250,quality=75,fit=crop/currencies-tokens/fiat-brpnd.png", }, "USD": { Id: 178, @@ -49,7 +65,7 @@ func TestCuratedAssetsIntegration(t *testing.T) { Issuer: "rvYAfWj5gh67oV6fW32ZzP3Aw4Eubs59B", Currency: "USD", Name: "US Dollar", - Avatar: "https://xumm.app/assets/icons/currencies/fiat-dollar.png", + Avatar: "https://xumm.app/cdn-cgi/image/width=250,height=250,quality=75,fit=crop/assets/icons/currencies/fiat-dollar.png", }, }, }, bitstamp) diff --git a/xumm/meta/get_hookhash.go b/xumm/meta/get_hookhash.go index 56e103f..ae0f052 100644 --- a/xumm/meta/get_hookhash.go +++ b/xumm/meta/get_hookhash.go @@ -1,6 +1,8 @@ package meta import ( + "encoding/hex" + "fmt" "net/http" "github.com/xyield/xumm-go-client/utils" @@ -12,7 +14,28 @@ const ( HOOKHASHENDPOINT = "/platform/hookhash/" ) -func (m *Meta) GetHookhash(h string) (*models.HookHashResponse, error) { +type EmptyHookHash struct{} + +func (e *EmptyHookHash) Error() string { + return fmt.Sprintln("No hookhash provided") +} + +type InvalidHookHash struct{} + +func (e *InvalidHookHash) Error() string { + return fmt.Sprintln("Invalid hookhash provided, must be 64 hexadecimal characters") +} + +func (m *Meta) GetHookHash(h string) (*models.HookHashResponse, error) { + + if len(h) != 64 { + return nil, &InvalidHookHash{} + } + + _, err := hex.DecodeString(h) + if err != nil { + return nil, &InvalidHookHash{} + } req, err := http.NewRequest(http.MethodGet, m.Cfg.BaseURL+HOOKHASHENDPOINT+h, nil) if err != nil { diff --git a/xumm/meta/get_hookhash_integration_test.go b/xumm/meta/get_hookhash_integration_test.go new file mode 100644 index 0000000..027da10 --- /dev/null +++ b/xumm/meta/get_hookhash_integration_test.go @@ -0,0 +1,30 @@ +//go:build integration +// +build integration + +package meta + +import ( + "testing" + + "github.com/stretchr/testify/assert" + "github.com/xyield/xumm-go-client/xumm" + "github.com/xyield/xumm-go-client/xumm/models" +) + +func TestGetHookHashIntegrationTest(t *testing.T) { + + cfg, err := xumm.NewConfig() + assert.NoError(t, err) + m := &Meta{ + Cfg: cfg, + } + + hookHash := "31C3EC186C367DA66DFBD0E576D6170A2C1AB846BFC35FC0B49D202F2A8CDFD8" + + hh, err := m.GetHookHash(hookHash) + + assert.NoError(t, err) + assert.IsType(t, &models.HookHashResponse{}, hh) + assert.NotEmpty(t, hh.Name) + assert.NotEmpty(t, hh.Description) +} diff --git a/xumm/meta/get_hookhash_test.go b/xumm/meta/get_hookhash_test.go new file mode 100644 index 0000000..e315cb6 --- /dev/null +++ b/xumm/meta/get_hookhash_test.go @@ -0,0 +1,108 @@ +//go:build unit +// +build unit + +package meta + +import ( + "net/http" + "testing" + + "github.com/stretchr/testify/assert" + testutils "github.com/xyield/xumm-go-client/utils/test-utils" + "github.com/xyield/xumm-go-client/xumm" + "github.com/xyield/xumm-go-client/xumm/models" +) + +func TestGetHookhash(t *testing.T) { + + c := &models.HookHashResponse{ + Name: "testhookhash", + Description: "atesthookhash", + Creator: models.HookHashCreator{ + Name: "joebloggs", + Mail: "jb@gfail.com", + Site: "test.com", + }, + Xapp: "testXapp", + AppUUID: "testUUID", + Icon: "testIcon", + VerifiedAccounts: []string{"testva"}, + Audits: []string{"testaudits"}, + } + + validJson := `{ + "name": "testhookhash", + "description": "atesthookhash", + "creator": { + "name": "joebloggs", + "mail": "jb@gfail.com", + "site": "test.com" + }, + "xapp": "testXapp", + "appuuid": "testUUID", + "icon": "testIcon", + "verifiedaccounts": ["testva"], + "audits": ["testaudits"] + }` + + errorJson := `{ + "error": { + "reference": "3a04c7d3-94aa-4d8d-9559-62bb5e8a653c", + "code": 400 + "message": "Invalid hookhash provided, must be 64 hexadecimal characters" + } + }` + + var tests = []struct { + testName string + testValue string + inputValue string + expectedOutput *models.HookHashResponse + expectedError error + httpStatusCode int + }{ + { + testName: "GetHookhash - success", + testValue: "A17E4DEAD62BF705D9B73B4EAD2832F1C55C6C5A0067327A45E497FD8D31C0E3", + inputValue: validJson, + expectedOutput: c, + expectedError: nil, + httpStatusCode: http.StatusOK, + }, + { + testName: "GetHookhash - error response", + testValue: "invalidhookhash", + inputValue: errorJson, + expectedOutput: nil, + expectedError: &InvalidHookHash{}, + httpStatusCode: 400, + }, + } + for _, tt := range tests { + + t.Run(tt.testName, func(t *testing.T) { + m := &testutils.MockClient{} + m.DoFunc = testutils.MockResponse(tt.inputValue, tt.httpStatusCode, m) + cfg, err := xumm.NewConfig(xumm.WithHttpClient(m), xumm.WithAuth("testApiKey", "testApiSecret")) + assert.NoError(t, err) + meta := &Meta{ + Cfg: cfg, + } + ca, err := meta.GetHookHash(tt.testValue) + + if tt.expectedError != nil { + assert.Nil(t, ca) + assert.Error(t, err) + assert.EqualError(t, err, tt.expectedError.Error()) + } else { + assert.NoError(t, err) + assert.Equal(t, tt.expectedOutput, ca) + assert.Equal(t, http.Header{ + "X-API-Key": {"testApiKey"}, + "X-API-Secret": {"testApiSecret"}, + "Content-Type": {"application/json"}, + }, m.Spy.Header) + } + }) + } +} diff --git a/xumm/meta/get_hookhashes.go b/xumm/meta/get_hookhashes.go new file mode 100644 index 0000000..728e827 --- /dev/null +++ b/xumm/meta/get_hookhashes.go @@ -0,0 +1,33 @@ +package meta + +import ( + "net/http" + + "github.com/xyield/xumm-go-client/utils" + "github.com/xyield/xumm-go-client/xumm" + "github.com/xyield/xumm-go-client/xumm/models" +) + +func (m *Meta) GetHookHashes() (*models.HookHashesResponse, error) { + + req, err := http.NewRequest(http.MethodGet, m.Cfg.BaseURL+HOOKHASHENDPOINT, nil) + if err != nil { + return nil, err + } + req.Header = m.Cfg.GetHeaders() + res, err := m.Cfg.HTTPClient.Do(req) + if err != nil { + return nil, err + } + err = xumm.CheckForErrorResponse(res) + if err != nil { + return nil, err + } + var hh models.HookHashesResponse + _, err = utils.DeserialiseRequest(&hh, res.Body) + if err != nil { + return nil, err + } + + return &hh, nil +} diff --git a/xumm/meta/get_hookhashes_integration_test.go b/xumm/meta/get_hookhashes_integration_test.go new file mode 100644 index 0000000..d4c707f --- /dev/null +++ b/xumm/meta/get_hookhashes_integration_test.go @@ -0,0 +1,33 @@ +//go:build integration +// +build integration + +package meta + +import ( + "testing" + + "github.com/stretchr/testify/assert" + "github.com/xyield/xumm-go-client/xumm" + "github.com/xyield/xumm-go-client/xumm/models" +) + +func TestGetHookHashesIntegrationTest(t *testing.T) { + + cfg, err := xumm.NewConfig() + assert.NoError(t, err) + m := &Meta{ + Cfg: cfg, + } + + hh, err := m.GetHookHashes() + + assert.NoError(t, err) + assert.IsType(t, &models.HookHashesResponse{}, hh) + assert.NotEmpty(t, hh) + + for _, hookHash := range *hh { + assert.NotEmpty(t, hookHash.Name) + assert.NotEmpty(t, hookHash.Description) + } + +} diff --git a/xumm/meta/get_hookhashes_test.go b/xumm/meta/get_hookhashes_test.go new file mode 100644 index 0000000..3c93b56 --- /dev/null +++ b/xumm/meta/get_hookhashes_test.go @@ -0,0 +1,208 @@ +//go:build unit +// +build unit + +package meta + +import ( + "net/http" + "testing" + + "github.com/stretchr/testify/assert" + testutils "github.com/xyield/xumm-go-client/utils/test-utils" + "github.com/xyield/xumm-go-client/xumm" + "github.com/xyield/xumm-go-client/xumm/models" +) + +func TestGetHookHashes(t *testing.T) { + + noHookHash := `{ + "31C3EC186C367DA66DFBD0E576D6170A2C1AB846BFC35FC0B49D202F2A8CDFD8": { + "name": "Savings", + "description": "Efficiently manage your finances with the savings hook by automatically transferring a percentage of your transaction amount to a separate savings account to prevent accidental spending", + "creator": { + "name": "XRPL Labs", + "mail": "support@xrpl-labs.com", + "site": "xrpl-labs.com" + }, + "xapp": "hooks.savings", + "appuuid": "d21fe83d-64b9-4aef-8908-9a4952d8922c", + "icon": "https://cdn.xumm.pro/cdn-cgi/image/width=500,height=500,quality=75,fit=crop/app-logo/1857a4e1-6711-4c37-bb54-7664e129e9bf.png", + "verifiedAccounts": [], + "audits": [] + }, + "FCEA17EB0A771899227CD1C22CD1BFC9C9B78017E6EAE0F576C6E78BAE9D57D4": { + "name": "Firewall", + "description": "Select which type of transactions you allow into and out of your account.", + "creator": { + "name": "XRPL Labs", + "mail": "support@xrpl-labs.com", + "site": "xrpl-labs.com" + }, + "xapp": "hooks.firewall", + "appuuid": "26447750-0063-4f81-9de4-c7a9bb8fe935", + "icon": "https://cdn.xumm.pro/cdn-cgi/image/width=500,height=500,quality=75,fit=crop/app-logo/9a1800d8-d2a3-4bbb-9cdd-e8e47850d65c.png", + "verifiedAccounts": [], + "audits": [] + }, + "C08FF0A3849F7D4A2F346DDB69282487BA320557516DC954C91CA81F05F478BB": { + "name": "Direct Debit", + "description": "Allow trusted third parties to pull funds from your account up to a limit you set. For example your power company can bill you and your account can automatically pay that bill.", + "creator": { + "name": "XRPL Labs", + "mail": "support@xrpl-labs.com", + "site": "xrpl-labs.com" + }, + "xapp": "hooks.directdebit", + "appuuid": "6df15d3e-7c6e-49a5-aceb-63df92e92fc2", + "icon": "https://cdn.xumm.pro/cdn-cgi/image/width=500,height=500,quality=75,fit=crop/app-logo/24738ef6-df4b-464c-9a07-5c9f01c76f00.png", + "verifiedAccounts": [], + "audits": [] + }, + "9B11CAAF4F87D2638CE86D3E82FE4A1464D95693B4C440B9048DCC5EFD91862B": { + "name": "Payment Watchdog", + "description": "When sending high value transactions out of your account, require first a notification that a high valued payment will be made, followed by a time delay, followed by the high value transaction itself. This prevents accidental high value sends, adding an additional layer of security to your account.", + "creator": { + "name": "XRPL Labs", + "mail": "support@xrpl-labs.com", + "site": "xrpl-labs.com" + }, + "xapp": "hooks.highvalueprotect", + "appuuid": "dcfe584f-8158-49ec-840a-3aea8819ce72", + "icon": "https://cdn.xumm.pro/cdn-cgi/image/width=500,height=500,quality=75,fit=crop/app-logo/1857a4e1-6711-4c37-bb54-7664e129e9bf.png", + "verifiedAccounts": [], + "audits": [] + }, + "???": { + "name": "Balance Adjustment", + "description": "Claim Xahau Balance Adjustment.", + "creator": { + "name": "Xahau", + "mail": "mail@xahau.network", + "site": "xahau.network" + }, + "xapp": "xahau.balanceadjustment", + "appuuid": "3b58aa5d-5263-4252-b230-f81ab0db9a7a", + "icon": "https://cdn.xumm.pro/cdn-cgi/image/width=500,height=500,quality=75,fit=crop/app-logo/3b1fd165-1923-4ed2-a48c-80709cd6a127.png", + "verifiedAccounts": [], + "audits": [] + } + }` + + hookhashresp := models.HookHashesResponse{ + "31C3EC186C367DA66DFBD0E576D6170A2C1AB846BFC35FC0B49D202F2A8CDFD8": models.HookHashResponse{ + Name: "Savings", + Description: "Efficiently manage your finances with the savings hook by automatically transferring a percentage of your transaction amount to a separate savings account to prevent accidental spending", + Creator: models.HookHashCreator{ + Name: "XRPL Labs", + Mail: "support@xrpl-labs.com", + Site: "xrpl-labs.com", + }, + Xapp: "hooks.savings", + AppUUID: "d21fe83d-64b9-4aef-8908-9a4952d8922c", + Icon: "https://cdn.xumm.pro/cdn-cgi/image/width=500,height=500,quality=75,fit=crop/app-logo/1857a4e1-6711-4c37-bb54-7664e129e9bf.png", + VerifiedAccounts: []string{}, + Audits: []string{}, + }, + "FCEA17EB0A771899227CD1C22CD1BFC9C9B78017E6EAE0F576C6E78BAE9D57D4": models.HookHashResponse{ + Name: "Firewall", + Description: "Select which type of transactions you allow into and out of your account.", + Creator: models.HookHashCreator{ + Name: "XRPL Labs", + Mail: "support@xrpl-labs.com", + Site: "xrpl-labs.com", + }, + Xapp: "hooks.firewall", + AppUUID: "26447750-0063-4f81-9de4-c7a9bb8fe935", + Icon: "https://cdn.xumm.pro/cdn-cgi/image/width=500,height=500,quality=75,fit=crop/app-logo/9a1800d8-d2a3-4bbb-9cdd-e8e47850d65c.png", + VerifiedAccounts: []string{}, + Audits: []string{}, + }, + "C08FF0A3849F7D4A2F346DDB69282487BA320557516DC954C91CA81F05F478BB": models.HookHashResponse{ + Name: "Direct Debit", + Description: "Allow trusted third parties to pull funds from your account up to a limit you set. For example your power company can bill you and your account can automatically pay that bill.", + Creator: models.HookHashCreator{ + Name: "XRPL Labs", + Mail: "support@xrpl-labs.com", + Site: "xrpl-labs.com", + }, + Xapp: "hooks.directdebit", + AppUUID: "6df15d3e-7c6e-49a5-aceb-63df92e92fc2", + Icon: "https://cdn.xumm.pro/cdn-cgi/image/width=500,height=500,quality=75,fit=crop/app-logo/24738ef6-df4b-464c-9a07-5c9f01c76f00.png", + VerifiedAccounts: []string{}, + Audits: []string{}, + }, + "9B11CAAF4F87D2638CE86D3E82FE4A1464D95693B4C440B9048DCC5EFD91862B": models.HookHashResponse{ + Name: "Payment Watchdog", + Description: "When sending high value transactions out of your account, require first a notification that a high valued payment will be made, followed by a time delay, followed by the high value transaction itself. This prevents accidental high value sends, adding an additional layer of security to your account.", + Creator: models.HookHashCreator{ + Name: "XRPL Labs", + Mail: "support@xrpl-labs.com", + Site: "xrpl-labs.com", + }, + Xapp: "hooks.highvalueprotect", + AppUUID: "dcfe584f-8158-49ec-840a-3aea8819ce72", + Icon: "https://cdn.xumm.pro/cdn-cgi/image/width=500,height=500,quality=75,fit=crop/app-logo/1857a4e1-6711-4c37-bb54-7664e129e9bf.png", + VerifiedAccounts: []string{}, + Audits: []string{}, + }, + "???": models.HookHashResponse{ + Name: "Balance Adjustment", + Description: "Claim Xahau Balance Adjustment.", + Creator: models.HookHashCreator{ + Name: "Xahau", + Mail: "mail@xahau.network", + Site: "xahau.network", + }, + Xapp: "xahau.balanceadjustment", + AppUUID: "3b58aa5d-5263-4252-b230-f81ab0db9a7a", + Icon: "https://cdn.xumm.pro/cdn-cgi/image/width=500,height=500,quality=75,fit=crop/app-logo/3b1fd165-1923-4ed2-a48c-80709cd6a127.png", + VerifiedAccounts: []string{}, + Audits: []string{}, + }, + } + + var tests = []struct { + testName string + inputValue string + expectedOutput *models.HookHashesResponse + expectedError error + httpStatusCode int + }{ + { + testName: "GetHookHashes - success", + inputValue: noHookHash, + expectedOutput: &hookhashresp, + expectedError: nil, + httpStatusCode: http.StatusOK, + }, + } + + for _, tt := range tests { + + t.Run(tt.testName, func(t *testing.T) { + m := &testutils.MockClient{} + m.DoFunc = testutils.MockResponse(tt.inputValue, tt.httpStatusCode, m) + cfg, err := xumm.NewConfig(xumm.WithHttpClient(m), xumm.WithAuth("testApiKey", "testApiSecret")) + assert.NoError(t, err) + meta := &Meta{ + Cfg: cfg, + } + ca, err := meta.GetHookHashes() + + if tt.expectedError != nil { + assert.Nil(t, ca) + assert.Error(t, err) + assert.EqualError(t, err, tt.expectedError.Error()) + } else { + assert.NoError(t, err) + assert.Equal(t, tt.expectedOutput, ca) + assert.Equal(t, http.Header{ + "X-API-Key": {"testApiKey"}, + "X-API-Secret": {"testApiSecret"}, + "Content-Type": {"application/json"}, + }, m.Spy.Header) + } + }) + } + +} diff --git a/xumm/meta/get_rails_integration_test.go b/xumm/meta/get_rails_integration_test.go new file mode 100644 index 0000000..6069241 --- /dev/null +++ b/xumm/meta/get_rails_integration_test.go @@ -0,0 +1,29 @@ +//go:build integration +// +build integration + +package meta + +import ( + "testing" + + "github.com/stretchr/testify/assert" + "github.com/xyield/xumm-go-client/xumm" + statictestdata "github.com/xyield/xumm-go-client/xumm/meta/static-test-data" + "github.com/xyield/xumm-go-client/xumm/models" +) + +func TestGetRailsIntegrationTest(t *testing.T) { + + cfg, err := xumm.NewConfig() + assert.NoError(t, err) + m := &Meta{ + Cfg: cfg, + } + + r, err := m.GetRails() + assert.NoError(t, err) + assert.NotEmpty(t, r) + assert.IsType(t, &models.RailsResponse{}, r) + assert.Equal(t, statictestdata.RailsResponseResult, r) + +} diff --git a/xumm/meta/get_rails_test.go b/xumm/meta/get_rails_test.go new file mode 100644 index 0000000..325b229 --- /dev/null +++ b/xumm/meta/get_rails_test.go @@ -0,0 +1,255 @@ +//go:build unit +// +build unit + +package meta + +import ( + "net/http" + "testing" + + "github.com/stretchr/testify/assert" + testutils "github.com/xyield/xumm-go-client/utils/test-utils" + "github.com/xyield/xumm-go-client/xumm" + statictestdata "github.com/xyield/xumm-go-client/xumm/meta/static-test-data" + "github.com/xyield/xumm-go-client/xumm/models" +) + +func TestGetRails(t *testing.T) { + railsJson := `{ + "MAINNET": { + "chain_id": 0, + "color": "#4CA1F8", + "name": "XRPL Mainnet", + "is_livenet": true, + "native_asset": "XRP", + "endpoints": [ + { + "name": "XRPLCluster.com (XRPLF)", + "url": "wss://xrplcluster.com" + }, + { + "name": "Ripple S2 (Ripple)", + "url": "wss://s2.ripple.com" + }, + { + "name": "xrpl.link (XRPLF, fallback)", + "url": "wss://xrpl.link" + } + ], + "explorers": [ + { + "name": "Bithomp Explorer", + "url_tx": "https://bithomp.com/explorer/", + "url_ctid": "https://bithomp.com/explorer/", + "url_account": "https://bithomp.com/explorer/" + }, + { + "name": "XRP Scan", + "url_tx": "https://xrpscan.com/tx/", + "url_account": "https://xrpscan.com/account/" + }, + { + "name": "XRPL.org Livenet Explorer", + "url_tx": "https://livenet.xrpl.org/transactions/", + "url_account": "https://livenet.xrpl.org/accounts/" + }, + { + "name": "XRPLF Technical Explorer", + "url_tx": "https://explorer.xrplf.org/tx/", + "url_ctid": "https://explorer.xrplf.org/", + "url_account": "https://explorer.xrplf.org/" + } + ], + "rpc": "https://xrplcluster.com", + "definitions": "default", + "icons": { + "icon_square": "", + "icon_asset": "" + } + }, + "TESTNET": { + "chain_id": 1, + "color": "#FF6719", + "name": "XRPL Testnet", + "is_livenet": false, + "native_asset": "XRP", + "faucet": "https://faucet.altnet.rippletest.net/accounts", + "xpop_endpoints": [ + "https://testnet.xrpl-labs.com/xpop/" + ], + "endpoints": [ + { + "name": "XRPL Labs Testnet", + "url": "wss://testnet.xrpl-labs.com" + }, + { + "name": "Ripple XRPL Testnet", + "url": "wss://s.altnet.rippletest.net:51233" + } + ], + "explorers": [ + { + "name": "Bithomp Testnet Explorer", + "url_tx": "https://test.bithomp.com/explorer/", + "url_ctid": "https://test.bithomp.com/explorer/", + "url_account": "https://test.bithomp.com/explorer/" + }, + { + "name": "XRPL.org Testnet Explorer", + "url_tx": "https://testnet.xrpl.org/transactions/", + "url_account": "https://testnet.xrpl.org/accounts/" + }, + { + "name": "XRPLF Technical Explorer", + "url_tx": "https://explorer-testnet.xrplf.org/tx/", + "url_account": "https://explorer-testnet.xrplf.org/", + "url_ctid": "https://explorer-testnet.xrplf.org/" + } + ], + "rpc": "https://testnet.xrpl-labs.com", + "definitions": "default", + "icons": { + "icon_square": "", + "icon_asset": "" + } + }, + "DEVNET": { + "chain_id": 2, + "color": "#B480FF", + "name": "XRPL Devnet", + "is_livenet": false, + "native_asset": "XRP", + "faucet": "https://faucet.devnet.rippletest.net/accounts", + "endpoints": [ + { + "name": "Ripple XRPL Devnet", + "url": "wss://s.devnet.rippletest.net:51233" + } + ], + "explorers": [ + { + "name": "XRPL.org Devnet Explorer", + "url_tx": "https://devnet.xrpl.org/transactions/", + "url_account": "https://devnet.xrpl.org/accounts/" + } + ], + "rpc": "https://s.devnet.rippletest.net:51234", + "definitions": "default", + "icons": { + "icon_square": "", + "icon_asset": "" + } + }, + "XAHAU": { + "chain_id": 21337, + "color": "#0E0143", + "name": "Xahau Mainnet", + "is_livenet": true, + "native_asset": "XAH", + "endpoints": [ + { + "name": "Xahau Nodes (XRPL Labs)", + "url": "wss://xahau.network" + } + ], + "explorers": [ + { + "name": "Bithomp Explorer", + "url_tx": "https://xahau.bithomp.com/explorer/", + "url_ctid": "https://xahau.bithomp.com/explorer/", + "url_account": "https://xahau.bithomp.com/explorer/" + }, + { + "name": "XRPLF Technical Explorer", + "url_tx": "https://hooks-testnet-v3-explorer.xrpl-labs.com/", + "url_account": "https://hooks-testnet-v3-explorer.xrpl-labs.com/", + "_url_account": "https://explorer.xahau.network/" + } + ], + "rpc": "https://xahau.network", + "definitions": "xahau", + "icons": { + "icon_square": "", + "icon_asset": "" + } + }, + "XAHAUTESTNET": { + "chain_id": 21338, + "color": "#C0E12B", + "name": "Xahau Testnet", + "is_livenet": false, + "native_asset": "XAH", + "faucet": "https://xahau-test.net/accounts", + "endpoints": [ + { + "name": "Xahau Nodes (XRPL Labs)", + "url": "wss://xahau-test.net" + } + ], + "explorers": [ + { + "name": "Bithomp Explorer", + "url_tx": "https://test.xahauexplorer.com/explorer/", + "url_ctid": "https://test.xahauexplorer.com/explorer/", + "url_account": "https://test.xahauexplorer.com/explorer/" + }, + { + "name": "XRPLF Technical Explorer", + "url_tx": "https://explorer.xahau-test.net/tx/", + "url_account": "https://explorer.xahau-test.net/", + "url_ctid": "https://explorer.xahau-test.net/" + } + ], + "rpc": "https://xahau-test.net/", + "definitions": "xahau", + "icons": { + "icon_square": "", + "icon_asset": "" + } + } +}` + + var tests = []struct { + testName string + inputValue string + expectedOutput *models.RailsResponse + expectedError error + httpStatusCode int + }{ + { + testName: "GetHookHashes - success", + inputValue: railsJson, + expectedOutput: statictestdata.RailsResponseResult, + expectedError: nil, + httpStatusCode: http.StatusOK, + }, + } + + for _, tt := range tests { + + t.Run(tt.testName, func(t *testing.T) { + m := &testutils.MockClient{} + m.DoFunc = testutils.MockResponse(tt.inputValue, tt.httpStatusCode, m) + cfg, err := xumm.NewConfig(xumm.WithHttpClient(m), xumm.WithAuth("testApiKey", "testApiSecret")) + assert.NoError(t, err) + meta := &Meta{ + Cfg: cfg, + } + ca, err := meta.GetRails() + + if tt.expectedError != nil { + assert.Nil(t, ca) + assert.Error(t, err) + assert.EqualError(t, err, tt.expectedError.Error()) + } else { + assert.NoError(t, err) + assert.Equal(t, tt.expectedOutput, ca) + assert.Equal(t, http.Header{ + "X-API-Key": {"testApiKey"}, + "X-API-Secret": {"testApiSecret"}, + "Content-Type": {"application/json"}, + }, m.Spy.Header) + } + }) + } +} diff --git a/xumm/meta/meta.go b/xumm/meta/meta.go index 8caa832..f0ede3d 100644 --- a/xumm/meta/meta.go +++ b/xumm/meta/meta.go @@ -13,7 +13,8 @@ type MetaInterface interface { GetRatesForCurrency(cur string) (*models.RatesCurrencyResponse, error) GetXrplTransaction(txid string) (*models.XrpTxResponse, error) GetAccountMeta(a string) (*models.AccountMetaResponse, error) - GetHookhash(h string) (*models.HookHashResponse, error) + GetHookHash(h string) (*models.HookHashResponse, error) + GetHookHashes() (*models.HookHashesResponse, error) GetRails() (*models.RailsResponse, error) VerifyUserToken(t string) (*models.UserTokenResponse, error) VerifyUserTokens(uts ...string) (*models.UserTokenResponse, error) diff --git a/xumm/meta/ping_integration_test.go b/xumm/meta/ping_integration_test.go index 01d0cd0..de69e40 100644 --- a/xumm/meta/ping_integration_test.go +++ b/xumm/meta/ping_integration_test.go @@ -23,9 +23,10 @@ func TestPingIntegration(t *testing.T) { assert.NoError(t, err) assert.Equal(t, models.Application{ - UUIDV4: "eda1fbb4-8641-47bd-91c8-3adca27cd6e3", - Name: "Test Xumm App", - Disabled: 0, + UUIDV4: "eda1fbb4-8641-47bd-91c8-3adca27cd6e3", + Name: "Test Xumm App", + WebhookUrl: "https://32fc-115-189-103-75.ngrok-free.app/webhook", + Disabled: 0, }, pong.Auth.Application) assert.True(t, pong.Pong) assert.True(t, testutils.IsValidUUID(pong.Auth.Call.UUIDV4)) diff --git a/xumm/meta/static-test-data/account_meta_result.go b/xumm/meta/static-test-data/account_meta_result.go new file mode 100644 index 0000000..6c1c052 --- /dev/null +++ b/xumm/meta/static-test-data/account_meta_result.go @@ -0,0 +1,39 @@ +package statictestdata + +import "github.com/xyield/xumm-go-client/xumm/models" + +var AccountMetaTestResult = &models.AccountMetaResponse{ + Account: "rwietsevLFg8XSmG3bEZzFein1g8RBqWDZ", + KycApproved: true, + XummPro: true, + Blocked: false, + ForceDtag: false, + Avatar: "https://xumm.app/avatar/rwietsevLFg8XSmG3bEZzFein1g8RBqWDZ.png", + XummProfile: models.XummProfile{ + AccountAlias: "XRPL Labs - Wietse Wind", + OwnerAlias: "Wietse Wind", + Slug: "wietsewind", + ProfileURL: "https://xumm.me/wietsewind", + AccountSlug: "", + PayString: "wietsewind$xumm.me", + }, + ThirdPartyProfiles: []models.ThirdPartyProfile{ + { + AccountAlias: "Wietse Wind", + Source: "xumm.app", + }, + { + AccountAlias: "wietse.com", + Source: "xrpl", + }, + { + AccountAlias: "XRPL-Labs", + Source: "bithomp.com", + }, + }, + GlobalID: models.GlobalID{ + Linked: "2021-06-29T10:22:25.000Z", + ProfileURL: "https://app.global.id/u/wietse", + SufficientTrust: true, + }, +} diff --git a/xumm/meta/static-test-data/rails_result.go b/xumm/meta/static-test-data/rails_result.go new file mode 100644 index 0000000..71943b5 --- /dev/null +++ b/xumm/meta/static-test-data/rails_result.go @@ -0,0 +1,198 @@ +package statictestdata + +import "github.com/xyield/xumm-go-client/xumm/models" + +var RailsResponseResult = &models.RailsResponse{ + models.MAINNET: models.Rail{ + ChainID: models.MainnetChainID, + Color: models.MainnetColor, + Name: models.MainnetName, + IsLivenet: models.MainnetIsLivenet, + NativeAsset: models.MainnetNativeAsset, + Endpoints: []models.RailsEndpoint{ + { + Name: models.MainnetEndpointsXRPLClusterName, + Url: models.MainnetEndpointsXRPLClusterUrl, + }, + { + Name: models.MainnetEndpointsRippleS2Name, + Url: models.MainnetEndpointsRippleS2Url, + }, + { + Name: models.MainnetEndpointsXRPLFallbackName, + Url: models.MainnetEndpointsXRPLFallbackUrl, + }, + }, + Explorers: []models.RailsExplorer{ + { + Name: models.MainnetExplorersBithompName, + URLTx: models.MainnetExplorersBithompURLTx, + URLCTID: models.MainnetExplorersBithompURLCTID, + URLAccount: models.MainnetExplorersBithompURLAccount, + }, + { + Name: models.MainnetExplorersXRPScanName, + URLTx: models.MainnetExplorersXRPScanURLTx, + URLAccount: models.MainnetExplorersXRPScanURLAccount, + }, + { + Name: models.MainnetExplorersXRPLOrgName, + URLTx: models.MainnetExplorersXRPLOrgURLTx, + URLAccount: models.MainnetExplorersXRPLOrgURLAccount, + }, + { + Name: models.MainnetExplorersXRPLFTechnicalName, + URLTx: models.MainnetExplorersXRPLFTechnicalURLTx, + URLCTID: models.MainnetExplorersXRPLFTechnicalCTID, + URLAccount: models.MainnetExplorersXRPLFTechnicalURLAccount, + }, + }, + RPC: models.MainnetRPC, + Definitions: models.MainnetDefinitions, + Icons: models.RailsIcon{ + IconSquare: models.MainnetIconSquare, + IconAsset: models.MainnetIconAsset, + }, + }, + models.TESTNET: models.Rail{ + ChainID: models.TestnetChainID, + Color: models.TestnetColor, + Name: models.TestnetName, + IsLivenet: models.TestnetIsLivenet, + NativeAsset: models.TestnetNativeAsset, + Faucet: models.TestnetFaucet, + XpopEndpoints: []models.XpopEndpoints{ + models.TestnetXpopEndpointXRPLLabs, + }, + Endpoints: []models.RailsEndpoint{ + { + Name: models.TestnetEndpointsXRPLLabsTestnetName, + Url: models.TestnetEndpointsXRPLLabsTestnetUrl, + }, + { + Name: models.TestnetEndpointsRippleXRPLTestnetName, + Url: models.TestnetEndpointsRippleXRPLTestnetUrl, + }, + }, + Explorers: []models.RailsExplorer{ + { + Name: models.TestnetExplorersBithompName, + URLTx: models.TestnetExplorersBithompURLTx, + URLCTID: models.TestnetExplorersBithompURLCTID, + URLAccount: models.TestnetExplorersBithompURLAccount, + }, + { + Name: models.TestnetExplorersXRPLOrgName, + URLTx: models.TestnetExplorersXRPLOrgURLTx, + URLAccount: models.TestnetExplorersXRPLOrgURLAccount, + }, + { + Name: models.TestnetExplorersXRPLFTechnicalName, + URLTx: models.TestnetExplorersXRPLFTechnicalURLTx, + URLAccount: models.TestnetExplorersXRPLFTechnicalURLAccount, + URLCTID: models.TestnetExplorersXRPLFTechnicalURLCTID, + }, + }, + RPC: models.TestnetRPC, + Definitions: models.TestnetDefinitions, + Icons: models.RailsIcon{ + IconSquare: models.TestnetIconSquare, + IconAsset: models.TestnetIconAsset, + }, + }, + models.DEVNET: models.Rail{ + ChainID: models.DevnetChainID, + Color: models.DevnetColor, + Name: models.DevnetName, + IsLivenet: models.DevnetIsLivenet, + NativeAsset: models.DevnetNativeAsset, + Faucet: models.DevnetFaucet, + Endpoints: []models.RailsEndpoint{ + { + Name: models.DevnetEndpointsRippleXRPLDevnetName, + Url: models.DevnetEndpointsRippleXRPLDevnetUrl, + }, + }, + Explorers: []models.RailsExplorer{ + { + Name: models.DevnetExplorersXRPLOrgName, + URLTx: models.DevnetExplorersXRPLOrgURLTx, + URLAccount: models.DevnetExplorersXRPLOrgURLAccount, + }, + }, + RPC: models.DevnetRPC, + Definitions: models.DevnetDefinitions, + Icons: models.RailsIcon{ + IconSquare: models.DevnetIconSquare, + IconAsset: models.DevnetIconAsset, + }, + }, + models.XAHAU: models.Rail{ + ChainID: models.XahauChainID, + Color: models.XahauColor, + Name: models.XahauName, + IsLivenet: models.XahauIsLivenet, + NativeAsset: models.XahauNativeAsset, + Endpoints: []models.RailsEndpoint{ + { + Name: models.XahauEndpointsXahauNetworkName, + Url: models.XahauEndpointsXahauNetworkUrl, + }, + }, + Explorers: []models.RailsExplorer{ + { + Name: models.XahauExplorersBithompName, + URLTx: models.XahauExplorersBithompURLTx, + URLCTID: models.XahauExplorersBithompURLCTID, + URLAccount: models.XahauExplorersBithompURLAccount, + }, + { + Name: models.XahauExplorersXRPLFTechnicalName, + URLTx: models.XahauExplorersXRPLFTechnicalURLTx, + URLAccount: models.XahauExplorersXRPLFTechnicalURLAccount, + URLAccountNonExp: models.XahauExplorersXRPLFTechnicalURLAccountNonExp, + }, + }, + RPC: models.XahauRPC, + Definitions: models.XahauDefinitions, + Icons: models.RailsIcon{ + IconSquare: models.XahauIconSquare, + IconAsset: models.XahauIconAsset, + }, + }, + models.XAHAUTESTNET: models.Rail{ + ChainID: models.XahauTestnetChainID, + Color: models.XahauTestnetColor, + Name: models.XahauTestnetName, + IsLivenet: models.XahauTestnetIsLivenet, + NativeAsset: models.XahauTestnetNativeAsset, + Faucet: models.XahauTestnetFaucet, + Endpoints: []models.RailsEndpoint{ + { + Name: models.XahauTestnetEndpointsXahauTestnetName, + Url: models.XahauTestnetEndpointsXahauTestnetUrl, + }, + }, + Explorers: []models.RailsExplorer{ + { + Name: models.XahauTestnetExplorersBithompName, + URLTx: models.XahauTestnetExplorersBithompURLTx, + URLCTID: models.XahauTestnetExplorersBithompURLCTID, + URLAccount: models.XahauTestnetExplorersBithompURLAccount, + }, + { + Name: models.XahauTestnetExplorersXRPLFTechnicalName, + URLTx: models.XahauTestnetExplorersXRPLFTechnicalURLTx, + URLAccount: models.XahauTestnetExplorersXRPLFTechnicalURLAccount, + URLCTID: models.XahauTestnetExplorersXRPLFTechnicalURLCTID, + }, + }, + + RPC: models.XahauTestnetRPC, + Definitions: models.XahauTestnetDefinitions, + Icons: models.RailsIcon{ + IconSquare: models.XahauTestnetIconSquare, + IconAsset: models.XahauTestnetIconAsset, + }, + }, +} diff --git a/xumm/models/account_meta.go b/xumm/models/account_meta.go index 1803a13..5782190 100644 --- a/xumm/models/account_meta.go +++ b/xumm/models/account_meta.go @@ -1,6 +1,11 @@ package models type AccountMetaResponse struct { + Account string `json:"account"` + KycApproved bool `json:"kycApproved"` + XummPro bool `json:"xummPro"` + Blocked bool `json:"blocked"` + ForceDtag bool `json:"force_dtag"` Avatar string `json:"avatar,omitempty"` XummProfile XummProfile `json:"xummProfile,omitempty"` ThirdPartyProfiles []ThirdPartyProfile `json:"thirdPartyProfiles,omitempty"` @@ -10,6 +15,10 @@ type AccountMetaResponse struct { type XummProfile struct { AccountAlias string `json:"accountAlias,omitempty"` OwnerAlias string `json:"ownerAlias,omitempty"` + Slug string `json:"slug,omitempty"` + ProfileURL string `json:"profileUrl,omitempty"` + AccountSlug string `json:"accountSlug,omitempty"` + PayString string `json:"payString,omitempty"` } type ThirdPartyProfile struct { @@ -18,6 +27,7 @@ type ThirdPartyProfile struct { } type GlobalID struct { - Linked string `json:"linked,omitempty"` - ProfileURL string `json:"profileUrl,omitempty"` + Linked string `json:"linked,omitempty"` + ProfileURL string `json:"profileUrl,omitempty"` + SufficientTrust bool `json:"sufficientTrust"` } diff --git a/xumm/models/application.go b/xumm/models/application.go index 7e1714d..b6a6cd5 100644 --- a/xumm/models/application.go +++ b/xumm/models/application.go @@ -6,3 +6,17 @@ type Application struct { WebhookUrl string `json:"webhookurl,omitempty"` Disabled int `json:"disabled,omitempty"` } + +type ApplicationDetails struct { + Quota map[string]interface{} `json:"quota,omitempty"` + Application Application `json:"application"` + Call Call `json:"call,omitempty"` + JwtData JwtPong `json:"jwtData,omitempty"` +} + +type AppDetails struct { + UUIDv4 string `json:"uuidv4"` + Name string `json:"name"` + WebhookURL *string `json:"webhookurl,omitempty"` + Disabled *int `json:"disabled,omitempty"` +} diff --git a/xumm/models/curated_assets_response.go b/xumm/models/curated_assets_response.go index 64d40c6..1520c47 100644 --- a/xumm/models/curated_assets_response.go +++ b/xumm/models/curated_assets_response.go @@ -11,14 +11,16 @@ type Issuer struct { Name string `json:"name"` Domain string `json:"domain,omitempty"` Avatar string `json:"avatar,omitempty"` + Shortlist int `json:"shortlist"` Currencies map[string]CurrencyInfo `json:"currencies"` } type CurrencyInfo struct { - Id int64 `json:"id"` - IssuerId int64 `json:"issuer_id"` - Issuer string `json:"issuer"` - Currency string `json:"currency"` - Name string `json:"name"` - Avatar string `json:"avatar,omitempty"` + Id int64 `json:"id"` + IssuerId int64 `json:"issuer_id"` + Issuer string `json:"issuer"` + Currency string `json:"currency"` + Name string `json:"name"` + Avatar string `json:"avatar,omitempty"` + Shortlist int `json:"shortlist"` } diff --git a/xumm/models/hookhash_response.go b/xumm/models/hookhash_response.go index e4063b6..b3f3c74 100644 --- a/xumm/models/hookhash_response.go +++ b/xumm/models/hookhash_response.go @@ -1,8 +1,8 @@ package models type HookHashResponse struct { - Name string `json:"name,omitempty"` - Description string `json:"description,omitempty"` + Name string `json:"name"` + Description string `json:"description"` Creator HookHashCreator `json:"creator,omitempty"` Xapp string `json:"xapp,omitempty"` AppUUID string `json:"appuuid,omitempty"` diff --git a/xumm/models/hookhashes_response.go b/xumm/models/hookhashes_response.go new file mode 100644 index 0000000..bcf91b6 --- /dev/null +++ b/xumm/models/hookhashes_response.go @@ -0,0 +1,3 @@ +package models + +type HookHashesResponse map[string]HookHashResponse diff --git a/xumm/models/jwt_pong.go b/xumm/models/jwt_pong.go new file mode 100644 index 0000000..39f9cde --- /dev/null +++ b/xumm/models/jwt_pong.go @@ -0,0 +1,18 @@ +package models + +type JwtPong struct { + Pong bool `json:"pong"` + ClientID string `json:"client_id"` + State string `json:"state,omitempty"` + Scope string `json:"scope,omitempty"` + Nonce string `json:"nonce,omitempty"` + Aud string `json:"aud"` + Sub string `json:"sub"` + AppUUIDv4 string `json:"app_uuidv4"` + AppName string `json:"app_name"` + PayloadUUIDv4 string `json:"payload_uuidv4"` + UserTokenUUIDv4 string `json:"usertoken_uuidv4"` + Iat int `json:"iat"` + Exp int `json:"exp"` + Iss string `json:"iss"` +} diff --git a/xumm/models/kyc_account_status.go b/xumm/models/kyc_info_response.go similarity index 100% rename from xumm/models/kyc_account_status.go rename to xumm/models/kyc_info_response.go diff --git a/xumm/models/kyc_status_state_request.go b/xumm/models/kyc_status_request.go similarity index 100% rename from xumm/models/kyc_status_state_request.go rename to xumm/models/kyc_status_request.go diff --git a/xumm/models/kyc_status_state_response.go b/xumm/models/kyc_status_response.go similarity index 100% rename from xumm/models/kyc_status_state_response.go rename to xumm/models/kyc_status_response.go diff --git a/xumm/models/nftoken_detail.go b/xumm/models/nftoken_detail.go new file mode 100644 index 0000000..ff9c320 --- /dev/null +++ b/xumm/models/nftoken_detail.go @@ -0,0 +1,9 @@ +package models + +type NftokenDetail struct { + Issuer string `json:"issuer,omitempty"` + Token string `json:"token,omitempty"` + Owner string `json:"owner,omitempty"` + Name string `json:"name,omitempty"` + Image string `json:"image,omitempty"` +} diff --git a/xumm/models/pong.go b/xumm/models/pong.go index 72ebeb3..60a460a 100644 --- a/xumm/models/pong.go +++ b/xumm/models/pong.go @@ -5,12 +5,6 @@ type Pong struct { Auth ApplicationDetails `json:"auth"` } -type ApplicationDetails struct { - Quota map[string]interface{} `json:"quota"` - Application Application `json:"application"` - Call Call `json:"call"` -} - type Call struct { UUIDV4 string `json:"uuidv4"` } diff --git a/xumm/models/rails_response.go b/xumm/models/rails_response.go index 803ac0a..5970de5 100644 --- a/xumm/models/rails_response.go +++ b/xumm/models/rails_response.go @@ -1,36 +1,184 @@ package models -type RailsResponse struct { -} +const ( + MAINNET = "MAINNET" + TESTNET = "TESTNET" + DEVNET = "DEVNET" + XAHAU = "XAHAU" + XAHAUTESTNET = "XAHAUTESTNET" + + MainnetChainID = 0 + TestnetChainID = 1 + DevnetChainID = 2 + XahauChainID = 21337 + XahauTestnetChainID = 21338 + + MainnetColor = "#4CA1F8" + TestnetColor = "#FF6719" + DevnetColor = "#B480FF" + XahauColor = "#0E0143" + XahauTestnetColor = "#C0E12B" + + MainnetName = "XRPL Mainnet" + TestnetName = "XRPL Testnet" + DevnetName = "XRPL Devnet" + XahauName = "Xahau Mainnet" + XahauTestnetName = "Xahau Testnet" + + MainnetIsLivenet = true + TestnetIsLivenet = false + DevnetIsLivenet = false + XahauIsLivenet = true + XahauTestnetIsLivenet = false + + MainnetNativeAsset = "XRP" + TestnetNativeAsset = "XRP" + DevnetNativeAsset = "XRP" + XahauNativeAsset = "XAH" + XahauTestnetNativeAsset = "XAH" + + MainnetFaucet = "" + TestnetFaucet = "https://faucet.altnet.rippletest.net/accounts" + DevnetFaucet = "https://faucet.devnet.rippletest.net/accounts" + XahauFaucet = "" + XahauTestnetFaucet = "https://xahau-test.net/accounts" + + TestnetXpopEndpointXRPLLabs = "https://testnet.xrpl-labs.com/xpop/" + + MainnetEndpointsXRPLClusterName = "XRPLCluster.com (XRPLF)" + MainnetEndpointsXRPLClusterUrl = "wss://xrplcluster.com" + MainnetEndpointsRippleS2Name = "Ripple S2 (Ripple)" + MainnetEndpointsRippleS2Url = "wss://s2.ripple.com" + MainnetEndpointsXRPLFallbackName = "xrpl.link (XRPLF, fallback)" + MainnetEndpointsXRPLFallbackUrl = "wss://xrpl.link" + + TestnetEndpointsXRPLLabsTestnetName = "XRPL Labs Testnet" + TestnetEndpointsXRPLLabsTestnetUrl = "wss://testnet.xrpl-labs.com" + TestnetEndpointsRippleXRPLTestnetName = "Ripple XRPL Testnet" + TestnetEndpointsRippleXRPLTestnetUrl = "wss://s.altnet.rippletest.net:51233" + + DevnetEndpointsRippleXRPLDevnetName = "Ripple XRPL Devnet" + DevnetEndpointsRippleXRPLDevnetUrl = "wss://s.devnet.rippletest.net:51233" + + XahauEndpointsXahauNetworkName = "Xahau Nodes (XRPL Labs)" + XahauEndpointsXahauNetworkUrl = "wss://xahau.network" + + XahauTestnetEndpointsXahauTestnetName = "Xahau Nodes (XRPL Labs)" + XahauTestnetEndpointsXahauTestnetUrl = "wss://xahau-test.net" + + MainnetExplorersBithompName = "Bithomp Explorer" + MainnetExplorersBithompURLTx = "https://bithomp.com/explorer/" + MainnetExplorersBithompURLCTID = "https://bithomp.com/explorer/" + MainnetExplorersBithompURLAccount = "https://bithomp.com/explorer/" + + MainnetExplorersXRPScanName = "XRP Scan" + MainnetExplorersXRPScanURLTx = "https://xrpscan.com/tx/" + MainnetExplorersXRPScanURLAccount = "https://xrpscan.com/account/" + + MainnetExplorersXRPLOrgName = "XRPL.org Livenet Explorer" + MainnetExplorersXRPLOrgURLTx = "https://livenet.xrpl.org/transactions/" + MainnetExplorersXRPLOrgURLAccount = "https://livenet.xrpl.org/accounts/" + + MainnetExplorersXRPLFTechnicalName = "XRPLF Technical Explorer" + MainnetExplorersXRPLFTechnicalURLTx = "https://explorer.xrplf.org/tx/" + MainnetExplorersXRPLFTechnicalCTID = "https://explorer.xrplf.org/" + MainnetExplorersXRPLFTechnicalURLAccount = "https://explorer.xrplf.org/" + + TestnetExplorersBithompName = "Bithomp Testnet Explorer" + TestnetExplorersBithompURLTx = "https://test.bithomp.com/explorer/" + TestnetExplorersBithompURLCTID = "https://test.bithomp.com/explorer/" + TestnetExplorersBithompURLAccount = "https://test.bithomp.com/explorer/" + + TestnetExplorersXRPLOrgName = "XRPL.org Testnet Explorer" + TestnetExplorersXRPLOrgURLTx = "https://testnet.xrpl.org/transactions/" + TestnetExplorersXRPLOrgURLAccount = "https://testnet.xrpl.org/accounts/" + + TestnetExplorersXRPLFTechnicalName = "XRPLF Technical Explorer" + TestnetExplorersXRPLFTechnicalURLTx = "https://explorer-testnet.xrplf.org/tx/" + TestnetExplorersXRPLFTechnicalURLAccount = "https://explorer-testnet.xrplf.org/" + TestnetExplorersXRPLFTechnicalURLCTID = "https://explorer-testnet.xrplf.org/" + + DevnetExplorersXRPLOrgName = "XRPL.org Devnet Explorer" + DevnetExplorersXRPLOrgURLTx = "https://devnet.xrpl.org/transactions/" + DevnetExplorersXRPLOrgURLAccount = "https://devnet.xrpl.org/accounts/" + + XahauExplorersBithompName = "Bithomp Explorer" + XahauExplorersBithompURLTx = "https://xahau.bithomp.com/explorer/" + XahauExplorersBithompURLCTID = "https://xahau.bithomp.com/explorer/" + XahauExplorersBithompURLAccount = "https://xahau.bithomp.com/explorer/" + + XahauExplorersXRPLFTechnicalName = "XRPLF Technical Explorer" + XahauExplorersXRPLFTechnicalURLTx = "https://hooks-testnet-v3-explorer.xrpl-labs.com/" + XahauExplorersXRPLFTechnicalURLAccount = "https://hooks-testnet-v3-explorer.xrpl-labs.com/" + XahauExplorersXRPLFTechnicalURLAccountNonExp = "https://explorer.xahau.network/" + + XahauTestnetExplorersBithompName = "Bithomp Explorer" + XahauTestnetExplorersBithompURLTx = "https://test.xahauexplorer.com/explorer/" + XahauTestnetExplorersBithompURLCTID = "https://test.xahauexplorer.com/explorer/" + XahauTestnetExplorersBithompURLAccount = "https://test.xahauexplorer.com/explorer/" + + XahauTestnetExplorersXRPLFTechnicalName = "XRPLF Technical Explorer" + XahauTestnetExplorersXRPLFTechnicalURLTx = "https://explorer.xahau-test.net/tx/" + XahauTestnetExplorersXRPLFTechnicalURLAccount = "https://explorer.xahau-test.net/" + XahauTestnetExplorersXRPLFTechnicalURLCTID = "https://explorer.xahau-test.net/" + + MainnetRPC = "https://xrplcluster.com" + TestnetRPC = "https://testnet.xrpl-labs.com" + DevnetRPC = "https://s.devnet.rippletest.net:51234" + XahauRPC = "https://xahau.network" + XahauTestnetRPC = "https://xahau-test.net/" + + MainnetDefinitions = "default" + TestnetDefinitions = "default" + DevnetDefinitions = "default" + XahauDefinitions = "xahau" + XahauTestnetDefinitions = "xahau" + + MainnetIconSquare = "" + MainnetIconAsset = "" + TestnetIconSquare = "" + TestnetIconAsset = "" + DevnetIconSquare = "" + DevnetIconAsset = "" + XahauIconSquare = "" + XahauIconAsset = "" + XahauTestnetIconSquare = "" + XahauTestnetIconAsset = "" +) + +type RailsResponse map[string]Rail type Rail struct { - ChainID int `json:"chain_id,omitempty"` - Color string `json:"color,omitempty"` - Name string `json:"name,omitempty"` - IsLivenet bool `json:"is_livenet,omitempty"` - NativeAsset string `json:"native_asset,omitempty"` - Faucet string `json:"faucet,omitempty"` - Endpoints []RailsEndpoint `json:"endpoints,omitempty"` - Explorers []RailsExplorer `json:"explorers,omitempty"` - RPC string `json:"rpc,omitempty"` - Definitions string `json:"definitions,omitempty"` - Icons RailsIcon `json:"icons,omitempty"` + ChainID int `json:"chain_id"` + Color string `json:"color"` + Name string `json:"name"` + IsLivenet bool `json:"is_livenet"` + NativeAsset string `json:"native_asset"` + Faucet string `json:"faucet"` + XpopEndpoints []XpopEndpoints `json:"xpop_endpoints,omitempty"` + Endpoints []RailsEndpoint `json:"endpoints"` + Explorers []RailsExplorer `json:"explorers"` + RPC string `json:"rpc,omitempty"` + Definitions string `json:"definitions,omitempty"` + Icons RailsIcon `json:"icons"` } type RailsEndpoint struct { - Name string `json:"name,omitempty"` - Url string `json:"url,omitempty"` + Name string `json:"name"` + Url string `json:"url"` } type RailsExplorer struct { - Name string `json:"name,omitempty"` - URLTx string `json:"url_tx,omitempty"` - URLCTID string `json:"url_ctid,omitempty"` - URLAccount string `json:"url_account,omitempty"` - _URLAccount string `json:"_url_account,omitempty"` + Name string `json:"name"` + URLTx string `json:"url_tx"` + URLCTID string `json:"url_ctid,omitempty"` + URLAccount string `json:"url_account,omitempty"` + URLAccountNonExp string `json:"_url_account,omitempty"` } type RailsIcon struct { - IconSquare string `json:"icon_square,omitempty"` - IconAsset string `json:"icon_asset,omitempty"` + IconSquare string `json:"icon_square"` + IconAsset string `json:"icon_asset"` } + +type XpopEndpoints string diff --git a/xumm/models/rates_currency_reponse.go b/xumm/models/rates_currency_reponse.go index c8b64ac..59197d3 100644 --- a/xumm/models/rates_currency_reponse.go +++ b/xumm/models/rates_currency_reponse.go @@ -13,5 +13,5 @@ type Meta struct { type Currency struct { En string `json:"en"` Code string `json:"code"` - Symbol string `json:"symbol"` + Symbol string `json:"symbol,omitempty"` } diff --git a/xumm/models/user_token_validity.go b/xumm/models/user_token_validity.go index aa4ce4c..fd0f48c 100644 --- a/xumm/models/user_token_validity.go +++ b/xumm/models/user_token_validity.go @@ -3,8 +3,8 @@ package models type UserTokenValidity struct { UserToken string `json:"user_token"` Active bool `json:"active"` - Issued int64 `json:"issued"` - Expires int64 `json:"expires"` + Issued int64 `json:"issued,omitempty"` + Expires int64 `json:"expires,omitempty"` } type UserTokenResponse struct { diff --git a/xumm/payload/delete_payload_test.go b/xumm/payload/delete_payload_test.go index 167be63..ecfe1cc 100644 --- a/xumm/payload/delete_payload_test.go +++ b/xumm/payload/delete_payload_test.go @@ -123,9 +123,6 @@ func TestCancelPayloadByUuid(t *testing.T) { AppOpened: false, ReturnURLApp: "", ReturnURLWeb: "", - CustomIdentifier: "some_identifier_1337", - CustomBlob: anyjson.AnyJson{}, - CustomInstruction: "Hey ❤️ ...", }, }, statusCode: 200, diff --git a/xumm/payload/get_payload_custom_id_test.go b/xumm/payload/get_payload_custom_id_test.go index 7c81309..93e4cb2 100644 --- a/xumm/payload/get_payload_custom_id_test.go +++ b/xumm/payload/get_payload_custom_id_test.go @@ -8,7 +8,6 @@ import ( "testing" "github.com/stretchr/testify/assert" - anyjson "github.com/xyield/xumm-go-client/utils/json" testutils "github.com/xyield/xumm-go-client/utils/test-utils" "github.com/xyield/xumm-go-client/xumm" "github.com/xyield/xumm-go-client/xumm/models" @@ -59,9 +58,8 @@ func TestGetPayloadCustomId(t *testing.T) { TxType: "SignIn", TxDestination: "", TxDestinationTag: 0, - RequestJSON: anyjson.AnyJson{ - "TransactionType": "SignIn", - "SignIn": true, + RequestJSON: models.PayloadRequestJsonObject{ + TransactionType: "SignIn", }, Origintype: "test", Signmethod: "test", diff --git a/xumm/payload/get_payload_uuid_test.go b/xumm/payload/get_payload_uuid_test.go index 94f6e5c..e1780ba 100644 --- a/xumm/payload/get_payload_uuid_test.go +++ b/xumm/payload/get_payload_uuid_test.go @@ -8,7 +8,6 @@ import ( "testing" "github.com/stretchr/testify/assert" - anyjson "github.com/xyield/xumm-go-client/utils/json" testutils "github.com/xyield/xumm-go-client/utils/test-utils" "github.com/xyield/xumm-go-client/xumm" "github.com/xyield/xumm-go-client/xumm/models" @@ -59,9 +58,8 @@ func TestGetPayloadUuid(t *testing.T) { TxType: "SignIn", TxDestination: "", TxDestinationTag: 0, - RequestJSON: anyjson.AnyJson{ - "TransactionType": "SignIn", - "SignIn": true, + RequestJSON: models.PayloadRequestJsonObject{ + TransactionType: "SignIn", }, Origintype: "test", Signmethod: "test", diff --git a/xumm/payload/subscribe_payload_test.go b/xumm/payload/subscribe_payload_test.go index 0e9b79f..ef799ae 100644 --- a/xumm/payload/subscribe_payload_test.go +++ b/xumm/payload/subscribe_payload_test.go @@ -70,9 +70,8 @@ func TestSubscribe(t *testing.T) { TxType: "SignIn", TxDestination: "", TxDestinationTag: 0, - RequestJSON: anyjson.AnyJson{ - "TransactionType": "SignIn", - "SignIn": true, + RequestJSON: models.PayloadRequestJsonObject{ + TransactionType: "SignIn", }, Origintype: "test", Signmethod: "test", @@ -289,9 +288,8 @@ func TestCreateAndSubscribe(t *testing.T) { TxType: "SignIn", TxDestination: "", TxDestinationTag: 0, - RequestJSON: anyjson.AnyJson{ - "TransactionType": "SignIn", - "SignIn": true, + RequestJSON: models.PayloadRequestJsonObject{ + TransactionType: "SignIn", }, Origintype: "test", Signmethod: "test",