From f44e4bda3706a8454eaf882f8969c3abe50f8413 Mon Sep 17 00:00:00 2001 From: Srinivas Baride Date: Wed, 13 Jan 2021 11:44:55 +0530 Subject: [PATCH] Fix query and incorrect host IP issues --- Dockerfile | 2 +- lite/query.go | 21 +++++++++++---------- rest/session/handlers.go | 2 +- 3 files changed, 13 insertions(+), 12 deletions(-) diff --git a/Dockerfile b/Dockerfile index 39844ea..6ac1c41 100644 --- a/Dockerfile +++ b/Dockerfile @@ -7,7 +7,7 @@ RUN apk add git gcc linux-headers make musl-dev && \ make install --jobs=$(nproc) RUN cd /root/ && \ - apk add autoconf automake g++ git libtool make unbound-dev && \ + apk add autoconf automake file g++ git libtool make unbound-dev && \ git clone https://github.com/handshake-org/hnsd.git --branch=v1.0.0 --depth=1 && \ cd /root/hnsd/ && \ bash autogen.sh && sh configure && make --jobs=$(nproc) diff --git a/lite/query.go b/lite/query.go index debd415..3c988c8 100644 --- a/lite/query.go +++ b/lite/query.go @@ -13,21 +13,21 @@ import ( "github.com/sentinel-official/hub/x/vpn" ) -func (c *Client) Query(path string, params, result interface{}) error { +func (c *Client) Query(path string, params, result interface{}) (bool, error) { bytes, err := c.ctx.Codec.MarshalJSON(params) if err != nil { - return err + return false, err } res, _, err := c.ctx.QueryWithData(path, bytes) if err != nil { - return err + return false, err } if res == nil { - return nil + return false, nil } - return c.ctx.Codec.UnmarshalJSON(res, result) + return true, c.ctx.Codec.UnmarshalJSON(res, result) } func (c *Client) QueryAccount(address sdk.AccAddress) (exported.Account, error) { @@ -36,7 +36,7 @@ func (c *Client) QueryAccount(address sdk.AccAddress) (exported.Account, error) path = fmt.Sprintf("custom/%s/%s", auth.QuerierRoute, auth.QueryAccount) ) - if err := c.Query(path, auth.NewQueryAccountParams(address), &result); err != nil { + if ok, err := c.Query(path, auth.NewQueryAccountParams(address), &result); !ok { return nil, err } @@ -49,7 +49,7 @@ func (c *Client) QueryNode(address hub.NodeAddress) (*node.Node, error) { path = fmt.Sprintf("custom/%s/%s/%s", vpn.StoreKey, node.QuerierRoute, node.QueryNode) ) - if err := c.Query(path, node.NewQueryNodeParams(address), &result); err != nil { + if ok, err := c.Query(path, node.NewQueryNodeParams(address), &result); !ok { return nil, err } @@ -62,7 +62,7 @@ func (c *Client) QuerySubscription(id uint64) (*subscription.Subscription, error path = fmt.Sprintf("custom/%s/%s/%s", vpn.StoreKey, subscription.QuerierRoute, subscription.QuerySubscription) ) - if err := c.Query(path, subscription.NewQuerySubscriptionParams(id), &result); err != nil { + if ok, err := c.Query(path, subscription.NewQuerySubscriptionParams(id), &result); !ok { return nil, err } @@ -75,7 +75,7 @@ func (c *Client) QueryQuota(id uint64, address sdk.AccAddress) (*subscription.Qu path = fmt.Sprintf("custom/%s/%s/%s", vpn.StoreKey, subscription.QuerierRoute, subscription.QueryQuota) ) - if err := c.Query(path, subscription.NewQueryQuotaParams(id, address), &result); err != nil { + if ok, err := c.Query(path, subscription.NewQueryQuotaParams(id, address), &result); !ok { return nil, err } @@ -83,7 +83,8 @@ func (c *Client) QueryQuota(id uint64, address sdk.AccAddress) (*subscription.Qu } func (c *Client) HasNodeForPlan(id uint64, address hub.NodeAddress) (bool, error) { - res, _, err := c.ctx.QueryStore(plan.NodeForPlanKey(id, address), vpn.ModuleName) + res, _, err := c.ctx.QueryStore(plan.NodeForPlanKey(id, address), + fmt.Sprintf("%s/%s", vpn.ModuleName, plan.ModuleName)) if err != nil { return false, err } diff --git a/rest/session/handlers.go b/rest/session/handlers.go index 07aca66..1f3aa9d 100644 --- a/rest/session/handlers.go +++ b/rest/session/handlers.go @@ -111,7 +111,7 @@ func HandlerAddSession(ctx *context.Context) http.HandlerFunc { return } - result = append(result, net.ParseIP(ctx.Location().IP)...) + result = append(result, net.ParseIP(ctx.Location().IP).To4()...) result = append(result, ctx.Service().Info()...) utils.WriteResultToResponse(w, http.StatusCreated, result) }