lash/export-to-term #157
| @ -2,6 +2,7 @@ package common | |||||||
| 
 | 
 | ||||||
| import ( | import ( | ||||||
| 	"encoding/hex" | 	"encoding/hex" | ||||||
|  | 	"strings" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| func NormalizeHex(s string) (string, error) { | func NormalizeHex(s string) (string, error) { | ||||||
| @ -16,3 +17,15 @@ func NormalizeHex(s string) (string, error) { | |||||||
| 	} | 	} | ||||||
| 	return hex.EncodeToString(r), nil | 	return hex.EncodeToString(r), nil | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | func IsSameHex(left string, right string) bool { | ||||||
|  | 	bl, err := NormalizeHex(left) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return false | ||||||
|  | 	} | ||||||
|  | 	br, err := NormalizeHex(left) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return false | ||||||
|  | 	} | ||||||
|  | 	return strings.Compare(bl, br) == 0 | ||||||
|  | } | ||||||
|  | |||||||
| @ -10,6 +10,7 @@ import ( | |||||||
| 	"git.defalsify.org/vise.git/resource" | 	"git.defalsify.org/vise.git/resource" | ||||||
| 
 | 
 | ||||||
| 	"git.grassecon.net/urdt/ussd/internal/handlers/ussd" | 	"git.grassecon.net/urdt/ussd/internal/handlers/ussd" | ||||||
|  | 	"git.grassecon.net/urdt/ussd/internal/utils" | ||||||
| 	"git.grassecon.net/urdt/ussd/remote" | 	"git.grassecon.net/urdt/ussd/remote" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -233,11 +233,11 @@ func (h *Handlers) CheckPinMisMatch(ctx context.Context, sym string, input []byt | |||||||
| 		return res, fmt.Errorf("missing session") | 		return res, fmt.Errorf("missing session") | ||||||
| 	} | 	} | ||||||
| 	store := h.userdataStore | 	store := h.userdataStore | ||||||
| 	blockedNumber, err := store.ReadEntry(ctx, sessionId, utils.DATA_BLOCKED_NUMBER) | 	blockedNumber, err := store.ReadEntry(ctx, sessionId, common.DATA_BLOCKED_NUMBER) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return res, err | 		return res, err | ||||||
| 	} | 	} | ||||||
| 	temporaryPin, err := store.ReadEntry(ctx, string(blockedNumber), utils.DATA_TEMPORARY_VALUE) | 	temporaryPin, err := store.ReadEntry(ctx, string(blockedNumber), common.DATA_TEMPORARY_VALUE) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return res, err | 		return res, err | ||||||
| 	} | 	} | ||||||
| @ -307,12 +307,12 @@ func (h *Handlers) SaveOthersTemporaryPin(ctx context.Context, sym string, input | |||||||
| 		return res, fmt.Errorf("missing session") | 		return res, fmt.Errorf("missing session") | ||||||
| 	} | 	} | ||||||
| 	temporaryPin := string(input) | 	temporaryPin := string(input) | ||||||
| 	blockedNumber, err := store.ReadEntry(ctx, sessionId, utils.DATA_BLOCKED_NUMBER) | 	blockedNumber, err := store.ReadEntry(ctx, sessionId, common.DATA_BLOCKED_NUMBER) | ||||||
| 
 | 
 | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return res, err | 		return res, err | ||||||
| 	} | 	} | ||||||
| 	err = store.WriteEntry(ctx, string(blockedNumber), utils.DATA_TEMPORARY_VALUE, []byte(temporaryPin)) | 	err = store.WriteEntry(ctx, string(blockedNumber), common.DATA_TEMPORARY_VALUE, []byte(temporaryPin)) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return res, err | 		return res, err | ||||||
| 	} | 	} | ||||||
| @ -841,15 +841,15 @@ func (h *Handlers) ResetOthersPin(ctx context.Context, sym string, input []byte) | |||||||
| 	if !ok { | 	if !ok { | ||||||
| 		return res, fmt.Errorf("missing session") | 		return res, fmt.Errorf("missing session") | ||||||
| 	} | 	} | ||||||
| 	blockedPhonenumber, err := store.ReadEntry(ctx, sessionId, utils.DATA_BLOCKED_NUMBER) | 	blockedPhonenumber, err := store.ReadEntry(ctx, sessionId, common.DATA_BLOCKED_NUMBER) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return res, err | 		return res, err | ||||||
| 	} | 	} | ||||||
| 	temporaryPin, err := store.ReadEntry(ctx, string(blockedPhonenumber), utils.DATA_TEMPORARY_VALUE) | 	temporaryPin, err := store.ReadEntry(ctx, string(blockedPhonenumber), common.DATA_TEMPORARY_VALUE) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return res, err | 		return res, err | ||||||
| 	} | 	} | ||||||
| 	err = store.WriteEntry(ctx, string(blockedPhonenumber), utils.DATA_ACCOUNT_PIN, []byte(temporaryPin)) | 	err = store.WriteEntry(ctx, string(blockedPhonenumber), common.DATA_ACCOUNT_PIN, []byte(temporaryPin)) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return res, nil | 		return res, nil | ||||||
| 	} | 	} | ||||||
| @ -874,7 +874,7 @@ func (h *Handlers) ValidateBlockedNumber(ctx context.Context, sym string, input | |||||||
| 		return res, fmt.Errorf("missing session") | 		return res, fmt.Errorf("missing session") | ||||||
| 	} | 	} | ||||||
| 	blockedNumber := string(input) | 	blockedNumber := string(input) | ||||||
| 	_, err = store.ReadEntry(ctx, blockedNumber, utils.DATA_PUBLIC_KEY) | 	_, err = store.ReadEntry(ctx, blockedNumber, common.DATA_PUBLIC_KEY) | ||||||
| 	if !isValidPhoneNumber(blockedNumber) { | 	if !isValidPhoneNumber(blockedNumber) { | ||||||
| 		res.FlagSet = append(res.FlagSet, flag_unregistered_number) | 		res.FlagSet = append(res.FlagSet, flag_unregistered_number) | ||||||
| 		return res, nil | 		return res, nil | ||||||
| @ -888,7 +888,7 @@ func (h *Handlers) ValidateBlockedNumber(ctx context.Context, sym string, input | |||||||
| 			return res, err | 			return res, err | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 	err = store.WriteEntry(ctx, sessionId, utils.DATA_BLOCKED_NUMBER, []byte(blockedNumber)) | 	err = store.WriteEntry(ctx, sessionId, common.DATA_BLOCKED_NUMBER, []byte(blockedNumber)) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return res, nil | 		return res, nil | ||||||
| 	} | 	} | ||||||
| @ -1075,7 +1075,7 @@ func (h *Handlers) RetrieveBlockedNumber(ctx context.Context, sym string, input | |||||||
| 		return res, fmt.Errorf("missing session") | 		return res, fmt.Errorf("missing session") | ||||||
| 	} | 	} | ||||||
| 	store := h.userdataStore | 	store := h.userdataStore | ||||||
| 	blockedNumber, _ := store.ReadEntry(ctx, sessionId, utils.DATA_BLOCKED_NUMBER) | 	blockedNumber, _ := store.ReadEntry(ctx, sessionId, common.DATA_BLOCKED_NUMBER) | ||||||
| 
 | 
 | ||||||
| 	res.Content = string(blockedNumber) | 	res.Content = string(blockedNumber) | ||||||
| 
 | 
 | ||||||
|  | |||||||
							
								
								
									
										18
									
								
								internal/models/tokenresponse.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								internal/models/tokenresponse.go
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,18 @@ | |||||||
|  | package models | ||||||
|  | 
 | ||||||
|  | type ApiResponse struct { | ||||||
|  | 	OK          bool   `json:"ok"` | ||||||
|  | 	Description string `json:"description"` | ||||||
|  | 	Result      Result `json:"result"` | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | type Result struct { | ||||||
|  | 	Holdings []Holding `json:"holdings"` | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | type Holding struct { | ||||||
|  | 	ContractAddress string `json:"contractAddress"` | ||||||
|  | 	TokenSymbol     string `json:"tokenSymbol"` | ||||||
|  | 	TokenDecimals   string `json:"tokenDecimals"` | ||||||
|  | 	Balance         string `json:"balance"` | ||||||
|  | } | ||||||
							
								
								
									
										14
									
								
								internal/models/vouchersresponse.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								internal/models/vouchersresponse.go
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,14 @@ | |||||||
|  | package models | ||||||
|  | 
 | ||||||
|  | import dataserviceapi "github.com/grassrootseconomics/ussd-data-service/pkg/api" | ||||||
|  | 
 | ||||||
|  | type VoucherHoldingResponse struct { | ||||||
|  | 	Ok          bool          `json:"ok"` | ||||||
|  | 	Description string        `json:"description"` | ||||||
|  | 	Result      VoucherResult `json:"result"` | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // VoucherResult holds the list of token holdings
 | ||||||
|  | type VoucherResult struct { | ||||||
|  | 	Holdings []dataserviceapi.TokenHoldings `json:"holdings"` | ||||||
|  | } | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user