lash/export-to-term #157
| @ -22,17 +22,14 @@ const ( | |||||||
| 	DATA_OFFERINGS | 	DATA_OFFERINGS | ||||||
| 	DATA_RECIPIENT | 	DATA_RECIPIENT | ||||||
| 	DATA_AMOUNT | 	DATA_AMOUNT | ||||||
| 	DATA_TEMPORARY_PIN | 	DATA_TEMPORARY_VALUE | ||||||
| 	DATA_VOUCHER_LIST | 	DATA_VOUCHER_LIST | ||||||
| 	DATA_TEMPORARY_SYM |  | ||||||
| 	DATA_ACTIVE_SYM | 	DATA_ACTIVE_SYM | ||||||
| 	DATA_TEMPORARY_BAL |  | ||||||
| 	DATA_ACTIVE_BAL | 	DATA_ACTIVE_BAL | ||||||
| 	DATA_PUBLIC_KEY_REVERSE | 	DATA_PUBLIC_KEY_REVERSE | ||||||
| 	DATA_TEMPORARY_DECIMAL |  | ||||||
| 	DATA_ACTIVE_DECIMAL | 	DATA_ACTIVE_DECIMAL | ||||||
| 	DATA_TEMPORARY_ADDRESS |  | ||||||
| 	DATA_ACTIVE_ADDRESS | 	DATA_ACTIVE_ADDRESS | ||||||
|  | 
 | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| func typToBytes(typ DataTyp) []byte { | func typToBytes(typ DataTyp) []byte { | ||||||
|  | |||||||
| @ -97,45 +97,30 @@ func MatchVoucher(input, symbols, balances, decimals, addresses string) (symbol, | |||||||
| 
 | 
 | ||||||
| // StoreTemporaryVoucher saves voucher metadata as temporary entries in the DataStore.
 | // StoreTemporaryVoucher saves voucher metadata as temporary entries in the DataStore.
 | ||||||
| func StoreTemporaryVoucher(ctx context.Context, store DataStore, sessionId string, data *dataserviceapi.TokenHoldings) error { | func StoreTemporaryVoucher(ctx context.Context, store DataStore, sessionId string, data *dataserviceapi.TokenHoldings) error { | ||||||
| 	entries := map[DataTyp][]byte{ | 	tempData := fmt.Sprintf("%s,%s,%s,%s", data.TokenSymbol, data.Balance, data.TokenDecimals, data.ContractAddress) | ||||||
| 		DATA_TEMPORARY_SYM:     []byte(data.TokenSymbol), | 
 | ||||||
| 		DATA_TEMPORARY_BAL:     []byte(data.Balance), | 	if err := store.WriteEntry(ctx, sessionId, DATA_TEMPORARY_VALUE, []byte(tempData)); err != nil { | ||||||
| 		DATA_TEMPORARY_DECIMAL: []byte(data.TokenDecimals), | 		return err | ||||||
| 		DATA_TEMPORARY_ADDRESS: []byte(data.ContractAddress), |  | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	for key, value := range entries { |  | ||||||
| 		if err := store.WriteEntry(ctx, sessionId, key, value); err != nil { |  | ||||||
| 			return err |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // GetTemporaryVoucherData retrieves temporary voucher metadata from the DataStore.
 | // GetTemporaryVoucherData retrieves temporary voucher metadata from the DataStore.
 | ||||||
| func GetTemporaryVoucherData(ctx context.Context, store DataStore, sessionId string) (*dataserviceapi.TokenHoldings, error) { | func GetTemporaryVoucherData(ctx context.Context, store DataStore, sessionId string) (*dataserviceapi.TokenHoldings, error) { | ||||||
| 	keys := []DataTyp{ | 	temp_data, err := store.ReadEntry(ctx, sessionId, DATA_TEMPORARY_VALUE) | ||||||
| 		DATA_TEMPORARY_SYM, | 	if err != nil { | ||||||
| 		DATA_TEMPORARY_BAL, | 		return nil, err | ||||||
| 		DATA_TEMPORARY_DECIMAL, |  | ||||||
| 		DATA_TEMPORARY_ADDRESS, |  | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | 	values := strings.SplitN(string(temp_data), ",", 4) | ||||||
|  | 
 | ||||||
| 	data := &dataserviceapi.TokenHoldings{} | 	data := &dataserviceapi.TokenHoldings{} | ||||||
| 	values := make([][]byte, len(keys)) |  | ||||||
| 
 | 
 | ||||||
| 	for i, key := range keys { | 	data.TokenSymbol = values[0] | ||||||
| 		value, err := store.ReadEntry(ctx, sessionId, key) | 	data.Balance = values[1] | ||||||
| 		if err != nil { | 	data.TokenDecimals = values[2] | ||||||
| 			return nil, err | 	data.ContractAddress = values[3] | ||||||
| 		} |  | ||||||
| 		values[i] = value |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	data.TokenSymbol = string(values[0]) |  | ||||||
| 	data.Balance = string(values[1]) |  | ||||||
| 	data.TokenDecimals = string(values[2]) |  | ||||||
| 	data.ContractAddress = string(values[3]) |  | ||||||
| 
 | 
 | ||||||
| 	return data, nil | 	return data, nil | ||||||
| } | } | ||||||
|  | |||||||
| @ -2,6 +2,7 @@ package common | |||||||
| 
 | 
 | ||||||
| import ( | import ( | ||||||
| 	"context" | 	"context" | ||||||
|  | 	"fmt" | ||||||
| 	"testing" | 	"testing" | ||||||
| 
 | 
 | ||||||
| 	"github.com/alecthomas/assert/v2" | 	"github.com/alecthomas/assert/v2" | ||||||
| @ -127,18 +128,11 @@ func TestStoreTemporaryVoucher(t *testing.T) { | |||||||
| 	require.NoError(t, err) | 	require.NoError(t, err) | ||||||
| 
 | 
 | ||||||
| 	// Verify stored data
 | 	// Verify stored data
 | ||||||
| 	expectedEntries := map[common.DataTyp][]byte{ | 	expectedData := fmt.Sprintf("%s,%s,%s,%s", "SRF", "200", "6", "0xd4c288865Ce0985a481Eef3be02443dF5E2e4Ea9") | ||||||
| 		common.DATA_TEMPORARY_SYM:     []byte("SRF"), |  | ||||||
| 		common.DATA_TEMPORARY_BAL:     []byte("200"), |  | ||||||
| 		common.DATA_TEMPORARY_DECIMAL: []byte("6"), |  | ||||||
| 		common.DATA_TEMPORARY_ADDRESS: []byte("0xd4c288865Ce0985a481Eef3be02443dF5E2e4Ea9"), |  | ||||||
| 	} |  | ||||||
| 
 | 
 | ||||||
| 	for key, expectedValue := range expectedEntries { | 	storedValue, err := store.ReadEntry(ctx, sessionId, DATA_TEMPORARY_VALUE) | ||||||
| 		storedValue, err := store.ReadEntry(ctx, sessionId, key) | 	require.NoError(t, err) | ||||||
| 		require.NoError(t, err) | 	require.Equal(t, expectedData, string(storedValue), "Mismatch for key %v", DATA_TEMPORARY_VALUE) | ||||||
| 		require.Equal(t, expectedValue, storedValue, "Mismatch for key %v", key) |  | ||||||
| 	} |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func TestGetTemporaryVoucherData(t *testing.T) { | func TestGetTemporaryVoucherData(t *testing.T) { | ||||||
|  | |||||||
| @ -19,9 +19,9 @@ import ( | |||||||
| 	"git.defalsify.org/vise.git/persist" | 	"git.defalsify.org/vise.git/persist" | ||||||
| 	"git.defalsify.org/vise.git/resource" | 	"git.defalsify.org/vise.git/resource" | ||||||
| 	"git.defalsify.org/vise.git/state" | 	"git.defalsify.org/vise.git/state" | ||||||
| 	"git.grassecon.net/urdt/ussd/internal/utils" |  | ||||||
| 	"git.grassecon.net/urdt/ussd/common" | 	"git.grassecon.net/urdt/ussd/common" | ||||||
| 	"git.grassecon.net/urdt/ussd/remote" | 	"git.grassecon.net/urdt/ussd/internal/handlers/server" | ||||||
|  | 	"git.grassecon.net/urdt/ussd/internal/utils" | ||||||
| 	"gopkg.in/leonelquinteros/gotext.v1" | 	"gopkg.in/leonelquinteros/gotext.v1" | ||||||
| 
 | 
 | ||||||
| 	"git.grassecon.net/urdt/ussd/internal/storage" | 	"git.grassecon.net/urdt/ussd/internal/storage" | ||||||
| @ -33,7 +33,6 @@ var ( | |||||||
| 	translationDir = path.Join(scriptDir, "locale") | 	translationDir = path.Join(scriptDir, "locale") | ||||||
| 	okResponse     *api.OKResponse | 	okResponse     *api.OKResponse | ||||||
| 	errResponse    *api.ErrResponse | 	errResponse    *api.ErrResponse | ||||||
| 	backOption     = []byte("0") |  | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| // FlagManager handles centralized flag management
 | // FlagManager handles centralized flag management
 | ||||||
| @ -222,7 +221,7 @@ func (h *Handlers) VerifyNewPin(ctx context.Context, sym string, input []byte) ( | |||||||
| 	return res, nil | 	return res, nil | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // SaveTemporaryPin saves the valid PIN input to the DATA_TEMPORARY_PIN
 | // SaveTemporaryPin saves the valid PIN input to the DATA_TEMPORARY_VALUE
 | ||||||
| // during the account creation process
 | // during the account creation process
 | ||||||
| // and during the change PIN process
 | // and during the change PIN process
 | ||||||
| func (h *Handlers) SaveTemporaryPin(ctx context.Context, sym string, input []byte) (resource.Result, error) { | func (h *Handlers) SaveTemporaryPin(ctx context.Context, sym string, input []byte) (resource.Result, error) { | ||||||
| @ -247,7 +246,7 @@ func (h *Handlers) SaveTemporaryPin(ctx context.Context, sym string, input []byt | |||||||
| 	res.FlagReset = append(res.FlagReset, flag_incorrect_pin) | 	res.FlagReset = append(res.FlagReset, flag_incorrect_pin) | ||||||
| 
 | 
 | ||||||
| 	store := h.userdataStore | 	store := h.userdataStore | ||||||
| 	err = store.WriteEntry(ctx, sessionId, common.DATA_TEMPORARY_PIN, []byte(accountPIN)) | 	err = store.WriteEntry(ctx, sessionId, utils.DATA_TEMPORARY_VALUE, []byte(accountPIN)) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return res, err | 		return res, err | ||||||
| 	} | 	} | ||||||
| @ -264,7 +263,7 @@ func (h *Handlers) ConfirmPinChange(ctx context.Context, sym string, input []byt | |||||||
| 	flag_pin_mismatch, _ := h.flagManager.GetFlag("flag_pin_mismatch") | 	flag_pin_mismatch, _ := h.flagManager.GetFlag("flag_pin_mismatch") | ||||||
| 
 | 
 | ||||||
| 	store := h.userdataStore | 	store := h.userdataStore | ||||||
| 	temporaryPin, err := store.ReadEntry(ctx, sessionId, common.DATA_TEMPORARY_PIN) | 	temporaryPin, err := store.ReadEntry(ctx, sessionId, utils.DATA_TEMPORARY_VALUE) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return res, err | 		return res, err | ||||||
| 	} | 	} | ||||||
| @ -295,7 +294,7 @@ func (h *Handlers) VerifyCreatePin(ctx context.Context, sym string, input []byte | |||||||
| 		return res, fmt.Errorf("missing session") | 		return res, fmt.Errorf("missing session") | ||||||
| 	} | 	} | ||||||
| 	store := h.userdataStore | 	store := h.userdataStore | ||||||
| 	temporaryPin, err := store.ReadEntry(ctx, sessionId, common.DATA_TEMPORARY_PIN) | 	temporaryPin, err := store.ReadEntry(ctx, sessionId, utils.DATA_TEMPORARY_VALUE) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return res, err | 		return res, err | ||||||
| 	} | 	} | ||||||
| @ -334,13 +333,18 @@ func (h *Handlers) SaveFirstname(ctx context.Context, sym string, input []byte) | |||||||
| 	if !ok { | 	if !ok { | ||||||
| 		return res, fmt.Errorf("missing session") | 		return res, fmt.Errorf("missing session") | ||||||
| 	} | 	} | ||||||
| 	if len(input) > 0 { | 	firstName := string(input) | ||||||
| 		if bytes.Equal(input, backOption) { | 	store := h.userdataStore | ||||||
| 			return res, nil | 	flag_allow_update, _ := h.flagManager.GetFlag("flag_allow_update") | ||||||
|  | 	allowUpdate := h.st.MatchFlag(flag_allow_update, true) | ||||||
|  | 	if allowUpdate { | ||||||
|  | 		temporaryFirstName, _ := store.ReadEntry(ctx, sessionId, utils.DATA_TEMPORARY_VALUE) | ||||||
|  | 		err = store.WriteEntry(ctx, sessionId, utils.DATA_FIRST_NAME, []byte(temporaryFirstName)) | ||||||
|  | 		if err != nil { | ||||||
|  | 			return res, err | ||||||
| 		} | 		} | ||||||
| 		firstName := string(input) | 	} else { | ||||||
| 		store := h.userdataStore | 		err = store.WriteEntry(ctx, sessionId, utils.DATA_TEMPORARY_VALUE, []byte(firstName)) | ||||||
| 		err = store.WriteEntry(ctx, sessionId, common.DATA_FIRST_NAME, []byte(firstName)) |  | ||||||
| 		if err != nil { | 		if err != nil { | ||||||
| 			return res, err | 			return res, err | ||||||
| 		} | 		} | ||||||
| @ -357,20 +361,25 @@ func (h *Handlers) SaveFamilyname(ctx context.Context, sym string, input []byte) | |||||||
| 	if !ok { | 	if !ok { | ||||||
| 		return res, fmt.Errorf("missing session") | 		return res, fmt.Errorf("missing session") | ||||||
| 	} | 	} | ||||||
| 	if len(input) > 0 { | 
 | ||||||
| 		if bytes.Equal(input, backOption) { | 	store := h.userdataStore | ||||||
| 			return res, nil | 	familyName := string(input) | ||||||
| 		} | 
 | ||||||
| 		familyName := string(input) | 	flag_allow_update, _ := h.flagManager.GetFlag("flag_allow_update") | ||||||
| 		store := h.userdataStore | 	allowUpdate := h.st.MatchFlag(flag_allow_update, true) | ||||||
| 		err = store.WriteEntry(ctx, sessionId, common.DATA_FAMILY_NAME, []byte(familyName)) | 
 | ||||||
|  | 	if allowUpdate { | ||||||
|  | 		temporaryFamilyName, _ := store.ReadEntry(ctx, sessionId, utils.DATA_TEMPORARY_VALUE) | ||||||
|  | 		err = store.WriteEntry(ctx, sessionId, utils.DATA_FAMILY_NAME, []byte(temporaryFamilyName)) | ||||||
| 		if err != nil { | 		if err != nil { | ||||||
| 			return res, err | 			return res, err | ||||||
| 		} | 		} | ||||||
| 	} else { | 	} else { | ||||||
| 		return res, fmt.Errorf("a family name cannot be less than one character") | 		err = store.WriteEntry(ctx, sessionId, utils.DATA_TEMPORARY_VALUE, []byte(familyName)) | ||||||
|  | 		if err != nil { | ||||||
|  | 			return res, err | ||||||
|  | 		} | ||||||
| 	} | 	} | ||||||
| 
 |  | ||||||
| 	return res, nil | 	return res, nil | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -382,10 +391,19 @@ func (h *Handlers) SaveYob(ctx context.Context, sym string, input []byte) (resou | |||||||
| 	if !ok { | 	if !ok { | ||||||
| 		return res, fmt.Errorf("missing session") | 		return res, fmt.Errorf("missing session") | ||||||
| 	} | 	} | ||||||
| 	if len(input) == 4 { | 	yob := string(input) | ||||||
| 		yob := string(input) | 	store := h.userdataStore | ||||||
| 		store := h.userdataStore | 	flag_allow_update, _ := h.flagManager.GetFlag("flag_allow_update") | ||||||
| 		err = store.WriteEntry(ctx, sessionId, common.DATA_YOB, []byte(yob)) | 	allowUpdate := h.st.MatchFlag(flag_allow_update, true) | ||||||
|  | 
 | ||||||
|  | 	if allowUpdate { | ||||||
|  | 		temporaryYob, _ := store.ReadEntry(ctx, sessionId, utils.DATA_TEMPORARY_VALUE) | ||||||
|  | 		err = store.WriteEntry(ctx, sessionId, utils.DATA_YOB, []byte(temporaryYob)) | ||||||
|  | 		if err != nil { | ||||||
|  | 			return res, err | ||||||
|  | 		} | ||||||
|  | 	} else { | ||||||
|  | 		err = store.WriteEntry(ctx, sessionId, utils.DATA_TEMPORARY_VALUE, []byte(yob)) | ||||||
| 		if err != nil { | 		if err != nil { | ||||||
| 			return res, err | 			return res, err | ||||||
| 		} | 		} | ||||||
| @ -402,13 +420,20 @@ func (h *Handlers) SaveLocation(ctx context.Context, sym string, input []byte) ( | |||||||
| 	if !ok { | 	if !ok { | ||||||
| 		return res, fmt.Errorf("missing session") | 		return res, fmt.Errorf("missing session") | ||||||
| 	} | 	} | ||||||
| 	if len(input) > 0 { | 	location := string(input) | ||||||
| 		if bytes.Equal(input, backOption) { | 	store := h.userdataStore | ||||||
| 			return res, nil | 
 | ||||||
|  | 	flag_allow_update, _ := h.flagManager.GetFlag("flag_allow_update") | ||||||
|  | 	allowUpdate := h.st.MatchFlag(flag_allow_update, true) | ||||||
|  | 
 | ||||||
|  | 	if allowUpdate { | ||||||
|  | 		temporaryLocation, _ := store.ReadEntry(ctx, sessionId, utils.DATA_TEMPORARY_VALUE) | ||||||
|  | 		err = store.WriteEntry(ctx, sessionId, utils.DATA_LOCATION, []byte(temporaryLocation)) | ||||||
|  | 		if err != nil { | ||||||
|  | 			return res, err | ||||||
| 		} | 		} | ||||||
| 		location := string(input) | 	} else { | ||||||
| 		store := h.userdataStore | 		err = store.WriteEntry(ctx, sessionId, utils.DATA_TEMPORARY_VALUE, []byte(location)) | ||||||
| 		err = store.WriteEntry(ctx, sessionId, common.DATA_LOCATION, []byte(location)) |  | ||||||
| 		if err != nil { | 		if err != nil { | ||||||
| 			return res, err | 			return res, err | ||||||
| 		} | 		} | ||||||
| @ -426,14 +451,22 @@ func (h *Handlers) SaveGender(ctx context.Context, sym string, input []byte) (re | |||||||
| 	if !ok { | 	if !ok { | ||||||
| 		return res, fmt.Errorf("missing session") | 		return res, fmt.Errorf("missing session") | ||||||
| 	} | 	} | ||||||
| 	if bytes.Equal(input, backOption) { |  | ||||||
| 		return res, nil |  | ||||||
| 	} |  | ||||||
| 	gender := strings.Split(symbol, "_")[1] | 	gender := strings.Split(symbol, "_")[1] | ||||||
| 	store := h.userdataStore | 	store := h.userdataStore | ||||||
| 	err = store.WriteEntry(ctx, sessionId, common.DATA_GENDER, []byte(gender)) | 	flag_allow_update, _ := h.flagManager.GetFlag("flag_allow_update") | ||||||
| 	if err != nil { | 	allowUpdate := h.st.MatchFlag(flag_allow_update, true) | ||||||
| 		return res, nil | 
 | ||||||
|  | 	if allowUpdate { | ||||||
|  | 		temporaryGender, _ := store.ReadEntry(ctx, sessionId, utils.DATA_TEMPORARY_VALUE) | ||||||
|  | 		err = store.WriteEntry(ctx, sessionId, utils.DATA_GENDER, []byte(temporaryGender)) | ||||||
|  | 		if err != nil { | ||||||
|  | 			return res, err | ||||||
|  | 		} | ||||||
|  | 	} else { | ||||||
|  | 		err = store.WriteEntry(ctx, sessionId, utils.DATA_TEMPORARY_VALUE, []byte(gender)) | ||||||
|  | 		if err != nil { | ||||||
|  | 			return res, err | ||||||
|  | 		} | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	return res, nil | 	return res, nil | ||||||
| @ -447,12 +480,23 @@ func (h *Handlers) SaveOfferings(ctx context.Context, sym string, input []byte) | |||||||
| 	if !ok { | 	if !ok { | ||||||
| 		return res, fmt.Errorf("missing session") | 		return res, fmt.Errorf("missing session") | ||||||
| 	} | 	} | ||||||
| 	if len(input) > 0 { | 
 | ||||||
| 		offerings := string(input) | 	offerings := string(input) | ||||||
| 		store := h.userdataStore | 	store := h.userdataStore | ||||||
| 		err = store.WriteEntry(ctx, sessionId, common.DATA_OFFERINGS, []byte(offerings)) | 
 | ||||||
|  | 	flag_allow_update, _ := h.flagManager.GetFlag("flag_allow_update") | ||||||
|  | 	allowUpdate := h.st.MatchFlag(flag_allow_update, true) | ||||||
|  | 
 | ||||||
|  | 	if allowUpdate { | ||||||
|  | 		temporaryOfferings, _ := store.ReadEntry(ctx, sessionId, utils.DATA_TEMPORARY_VALUE) | ||||||
|  | 		err = store.WriteEntry(ctx, sessionId, utils.DATA_OFFERINGS, []byte(temporaryOfferings)) | ||||||
| 		if err != nil { | 		if err != nil { | ||||||
| 			return res, nil | 			return res, err | ||||||
|  | 		} | ||||||
|  | 	} else { | ||||||
|  | 		err = store.WriteEntry(ctx, sessionId, utils.DATA_TEMPORARY_VALUE, []byte(offerings)) | ||||||
|  | 		if err != nil { | ||||||
|  | 			return res, err | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -19,6 +19,7 @@ import ( | |||||||
| 	"git.grassecon.net/urdt/ussd/internal/testutil/testservice" | 	"git.grassecon.net/urdt/ussd/internal/testutil/testservice" | ||||||
| 
 | 
 | ||||||
| 	"git.grassecon.net/urdt/ussd/common" | 	"git.grassecon.net/urdt/ussd/common" | ||||||
|  | 	"git.grassecon.net/urdt/ussd/internal/utils" | ||||||
| 	"github.com/alecthomas/assert/v2" | 	"github.com/alecthomas/assert/v2" | ||||||
| //	"github.com/grassrootseconomics/eth-custodial/pkg/api"
 | //	"github.com/grassrootseconomics/eth-custodial/pkg/api"
 | ||||||
| 	testdataloader "github.com/peteole/testdata-loader" | 	testdataloader "github.com/peteole/testdata-loader" | ||||||
| @ -168,8 +169,11 @@ func TestWithPersister_PanicWhenAlreadySet(t *testing.T) { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func TestSaveFirstname(t *testing.T) { | func TestSaveFirstname(t *testing.T) { | ||||||
| 	// Create a new instance of MockMyDataStore
 | 	// Create new mocks
 | ||||||
| 	mockStore := new(mocks.MockUserDataStore) | 	mockStore := new(mocks.MockUserDataStore) | ||||||
|  | 	mockState := state.NewState(16) | ||||||
|  | 
 | ||||||
|  | 	fm, err := NewFlagManager(flagsPath) | ||||||
| 
 | 
 | ||||||
| 	// Define test data
 | 	// Define test data
 | ||||||
| 	sessionId := "session123" | 	sessionId := "session123" | ||||||
| @ -177,11 +181,17 @@ func TestSaveFirstname(t *testing.T) { | |||||||
| 	ctx := context.WithValue(context.Background(), "SessionId", sessionId) | 	ctx := context.WithValue(context.Background(), "SessionId", sessionId) | ||||||
| 
 | 
 | ||||||
| 	// Set up the expected behavior of the mock
 | 	// Set up the expected behavior of the mock
 | ||||||
|  | <<<<<<< HEAD | ||||||
| 	mockStore.On("WriteEntry", ctx, sessionId, common.DATA_FIRST_NAME, []byte(firstName)).Return(nil) | 	mockStore.On("WriteEntry", ctx, sessionId, common.DATA_FIRST_NAME, []byte(firstName)).Return(nil) | ||||||
|  | ======= | ||||||
|  | 	mockStore.On("WriteEntry", ctx, sessionId, utils.DATA_TEMPORARY_VALUE, []byte(firstName)).Return(nil) | ||||||
|  | >>>>>>> master | ||||||
| 
 | 
 | ||||||
| 	// Create the Handlers instance with the mock store
 | 	// Create the Handlers instance with the mock store
 | ||||||
| 	h := &Handlers{ | 	h := &Handlers{ | ||||||
| 		userdataStore: mockStore, | 		userdataStore: mockStore, | ||||||
|  | 		flagManager:   fm.parser, | ||||||
|  | 		st:            mockState, | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	// Call the method
 | 	// Call the method
 | ||||||
| @ -198,6 +208,9 @@ func TestSaveFirstname(t *testing.T) { | |||||||
| func TestSaveFamilyname(t *testing.T) { | func TestSaveFamilyname(t *testing.T) { | ||||||
| 	// Create a new instance of UserDataStore
 | 	// Create a new instance of UserDataStore
 | ||||||
| 	mockStore := new(mocks.MockUserDataStore) | 	mockStore := new(mocks.MockUserDataStore) | ||||||
|  | 	mockState := state.NewState(16) | ||||||
|  | 
 | ||||||
|  | 	fm, err := NewFlagManager(flagsPath) | ||||||
| 
 | 
 | ||||||
| 	// Define test data
 | 	// Define test data
 | ||||||
| 	sessionId := "session123" | 	sessionId := "session123" | ||||||
| @ -205,11 +218,17 @@ func TestSaveFamilyname(t *testing.T) { | |||||||
| 	ctx := context.WithValue(context.Background(), "SessionId", sessionId) | 	ctx := context.WithValue(context.Background(), "SessionId", sessionId) | ||||||
| 
 | 
 | ||||||
| 	// Set up the expected behavior of the mock
 | 	// Set up the expected behavior of the mock
 | ||||||
|  | <<<<<<< HEAD | ||||||
| 	mockStore.On("WriteEntry", ctx, sessionId, common.DATA_FAMILY_NAME, []byte(familyName)).Return(nil) | 	mockStore.On("WriteEntry", ctx, sessionId, common.DATA_FAMILY_NAME, []byte(familyName)).Return(nil) | ||||||
|  | ======= | ||||||
|  | 	mockStore.On("WriteEntry", ctx, sessionId, utils.DATA_TEMPORARY_VALUE, []byte(familyName)).Return(nil) | ||||||
|  | >>>>>>> master | ||||||
| 
 | 
 | ||||||
| 	// Create the Handlers instance with the mock store
 | 	// Create the Handlers instance with the mock store
 | ||||||
| 	h := &Handlers{ | 	h := &Handlers{ | ||||||
| 		userdataStore: mockStore, | 		userdataStore: mockStore, | ||||||
|  | 		st:            mockState, | ||||||
|  | 		flagManager:   fm.parser, | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	// Call the method
 | 	// Call the method
 | ||||||
| @ -265,7 +284,11 @@ func TestSaveTemporaryPin(t *testing.T) { | |||||||
| 		t.Run(tt.name, func(t *testing.T) { | 		t.Run(tt.name, func(t *testing.T) { | ||||||
| 
 | 
 | ||||||
| 			// Set up the expected behavior of the mock
 | 			// Set up the expected behavior of the mock
 | ||||||
|  | <<<<<<< HEAD | ||||||
| 			mockStore.On("WriteEntry", ctx, sessionId, common.DATA_TEMPORARY_PIN, []byte(tt.input)).Return(nil) | 			mockStore.On("WriteEntry", ctx, sessionId, common.DATA_TEMPORARY_PIN, []byte(tt.input)).Return(nil) | ||||||
|  | ======= | ||||||
|  | 			mockStore.On("WriteEntry", ctx, sessionId, utils.DATA_TEMPORARY_VALUE, []byte(tt.input)).Return(nil) | ||||||
|  | >>>>>>> master | ||||||
| 
 | 
 | ||||||
| 			// Call the method
 | 			// Call the method
 | ||||||
| 			res, err := h.SaveTemporaryPin(ctx, "save_pin", tt.input) | 			res, err := h.SaveTemporaryPin(ctx, "save_pin", tt.input) | ||||||
| @ -282,8 +305,11 @@ func TestSaveTemporaryPin(t *testing.T) { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func TestSaveYoB(t *testing.T) { | func TestSaveYoB(t *testing.T) { | ||||||
| 	// Create a new instance of MockMyDataStore
 | 	// Create  new instances
 | ||||||
| 	mockStore := new(mocks.MockUserDataStore) | 	mockStore := new(mocks.MockUserDataStore) | ||||||
|  | 	mockState := state.NewState(16) | ||||||
|  | 
 | ||||||
|  | 	fm, err := NewFlagManager(flagsPath) | ||||||
| 
 | 
 | ||||||
| 	// Define test data
 | 	// Define test data
 | ||||||
| 	sessionId := "session123" | 	sessionId := "session123" | ||||||
| @ -291,11 +317,17 @@ func TestSaveYoB(t *testing.T) { | |||||||
| 	ctx := context.WithValue(context.Background(), "SessionId", sessionId) | 	ctx := context.WithValue(context.Background(), "SessionId", sessionId) | ||||||
| 
 | 
 | ||||||
| 	// Set up the expected behavior of the mock
 | 	// Set up the expected behavior of the mock
 | ||||||
|  | <<<<<<< HEAD | ||||||
| 	mockStore.On("WriteEntry", ctx, sessionId, common.DATA_YOB, []byte(yob)).Return(nil) | 	mockStore.On("WriteEntry", ctx, sessionId, common.DATA_YOB, []byte(yob)).Return(nil) | ||||||
|  | ======= | ||||||
|  | 	mockStore.On("WriteEntry", ctx, sessionId, utils.DATA_TEMPORARY_VALUE, []byte(yob)).Return(nil) | ||||||
|  | >>>>>>> master | ||||||
| 
 | 
 | ||||||
| 	// Create the Handlers instance with the mock store
 | 	// Create the Handlers instance with the mock store
 | ||||||
| 	h := &Handlers{ | 	h := &Handlers{ | ||||||
| 		userdataStore: mockStore, | 		userdataStore: mockStore, | ||||||
|  | 		st:            mockState, | ||||||
|  | 		flagManager:   fm.parser, | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	// Call the method
 | 	// Call the method
 | ||||||
| @ -312,6 +344,9 @@ func TestSaveYoB(t *testing.T) { | |||||||
| func TestSaveLocation(t *testing.T) { | func TestSaveLocation(t *testing.T) { | ||||||
| 	// Create a new instance of MockMyDataStore
 | 	// Create a new instance of MockMyDataStore
 | ||||||
| 	mockStore := new(mocks.MockUserDataStore) | 	mockStore := new(mocks.MockUserDataStore) | ||||||
|  | 	mockState := state.NewState(16) | ||||||
|  | 
 | ||||||
|  | 	fm, err := NewFlagManager(flagsPath) | ||||||
| 
 | 
 | ||||||
| 	// Define test data
 | 	// Define test data
 | ||||||
| 	sessionId := "session123" | 	sessionId := "session123" | ||||||
| @ -319,11 +354,17 @@ func TestSaveLocation(t *testing.T) { | |||||||
| 	ctx := context.WithValue(context.Background(), "SessionId", sessionId) | 	ctx := context.WithValue(context.Background(), "SessionId", sessionId) | ||||||
| 
 | 
 | ||||||
| 	// Set up the expected behavior of the mock
 | 	// Set up the expected behavior of the mock
 | ||||||
|  | <<<<<<< HEAD | ||||||
| 	mockStore.On("WriteEntry", ctx, sessionId, common.DATA_LOCATION, []byte(yob)).Return(nil) | 	mockStore.On("WriteEntry", ctx, sessionId, common.DATA_LOCATION, []byte(yob)).Return(nil) | ||||||
|  | ======= | ||||||
|  | 	mockStore.On("WriteEntry", ctx, sessionId, utils.DATA_TEMPORARY_VALUE, []byte(yob)).Return(nil) | ||||||
|  | >>>>>>> master | ||||||
| 
 | 
 | ||||||
| 	// Create the Handlers instance with the mock store
 | 	// Create the Handlers instance with the mock store
 | ||||||
| 	h := &Handlers{ | 	h := &Handlers{ | ||||||
| 		userdataStore: mockStore, | 		userdataStore: mockStore, | ||||||
|  | 		st:            mockState, | ||||||
|  | 		flagManager:   fm.parser, | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	// Call the method
 | 	// Call the method
 | ||||||
| @ -340,6 +381,9 @@ func TestSaveLocation(t *testing.T) { | |||||||
| func TestSaveOfferings(t *testing.T) { | func TestSaveOfferings(t *testing.T) { | ||||||
| 	// Create a new instance of MockUserDataStore
 | 	// Create a new instance of MockUserDataStore
 | ||||||
| 	mockStore := new(mocks.MockUserDataStore) | 	mockStore := new(mocks.MockUserDataStore) | ||||||
|  | 	mockState := state.NewState(16) | ||||||
|  | 
 | ||||||
|  | 	fm, err := NewFlagManager(flagsPath) | ||||||
| 
 | 
 | ||||||
| 	// Define test data
 | 	// Define test data
 | ||||||
| 	sessionId := "session123" | 	sessionId := "session123" | ||||||
| @ -347,11 +391,17 @@ func TestSaveOfferings(t *testing.T) { | |||||||
| 	ctx := context.WithValue(context.Background(), "SessionId", sessionId) | 	ctx := context.WithValue(context.Background(), "SessionId", sessionId) | ||||||
| 
 | 
 | ||||||
| 	// Set up the expected behavior of the mock
 | 	// Set up the expected behavior of the mock
 | ||||||
|  | <<<<<<< HEAD | ||||||
| 	mockStore.On("WriteEntry", ctx, sessionId, common.DATA_OFFERINGS, []byte(offerings)).Return(nil) | 	mockStore.On("WriteEntry", ctx, sessionId, common.DATA_OFFERINGS, []byte(offerings)).Return(nil) | ||||||
|  | ======= | ||||||
|  | 	mockStore.On("WriteEntry", ctx, sessionId, utils.DATA_TEMPORARY_VALUE, []byte(offerings)).Return(nil) | ||||||
|  | >>>>>>> master | ||||||
| 
 | 
 | ||||||
| 	// Create the Handlers instance with the mock store
 | 	// Create the Handlers instance with the mock store
 | ||||||
| 	h := &Handlers{ | 	h := &Handlers{ | ||||||
| 		userdataStore: mockStore, | 		userdataStore: mockStore, | ||||||
|  | 		st:            mockState, | ||||||
|  | 		flagManager:   fm.parser, | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	// Call the method
 | 	// Call the method
 | ||||||
| @ -366,10 +416,12 @@ func TestSaveOfferings(t *testing.T) { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func TestSaveGender(t *testing.T) { | func TestSaveGender(t *testing.T) { | ||||||
| 	// Create a new instance of MockMyDataStore
 | 	// Create a new mock instances
 | ||||||
| 	mockStore := new(mocks.MockUserDataStore) | 	mockStore := new(mocks.MockUserDataStore) | ||||||
| 	mockState := state.NewState(16) | 	mockState := state.NewState(16) | ||||||
| 
 | 
 | ||||||
|  | 	fm, _ := NewFlagManager(flagsPath) | ||||||
|  | 
 | ||||||
| 	// Define the session ID and context
 | 	// Define the session ID and context
 | ||||||
| 	sessionId := "session123" | 	sessionId := "session123" | ||||||
| 	ctx := context.WithValue(context.Background(), "SessionId", sessionId) | 	ctx := context.WithValue(context.Background(), "SessionId", sessionId) | ||||||
| @ -409,16 +461,24 @@ func TestSaveGender(t *testing.T) { | |||||||
| 		t.Run(tt.name, func(t *testing.T) { | 		t.Run(tt.name, func(t *testing.T) { | ||||||
| 			// Set up expectations for the mock database
 | 			// Set up expectations for the mock database
 | ||||||
| 			if tt.expectCall { | 			if tt.expectCall { | ||||||
|  | <<<<<<< HEAD | ||||||
| 				expectedKey := common.DATA_GENDER | 				expectedKey := common.DATA_GENDER | ||||||
| 				mockStore.On("WriteEntry", ctx, sessionId, expectedKey, []byte(tt.expectedGender)).Return(nil) | 				mockStore.On("WriteEntry", ctx, sessionId, expectedKey, []byte(tt.expectedGender)).Return(nil) | ||||||
| 			} else { | 			} else { | ||||||
| 				mockStore.On("WriteEntry", ctx, sessionId, common.DATA_GENDER, []byte(tt.expectedGender)).Return(nil) | 				mockStore.On("WriteEntry", ctx, sessionId, common.DATA_GENDER, []byte(tt.expectedGender)).Return(nil) | ||||||
|  | ======= | ||||||
|  | 				expectedKey := utils.DATA_TEMPORARY_VALUE | ||||||
|  | 				mockStore.On("WriteEntry", ctx, sessionId, expectedKey, []byte(tt.expectedGender)).Return(nil) | ||||||
|  | 			} else { | ||||||
|  | 				mockStore.On("WriteEntry", ctx, sessionId, utils.DATA_TEMPORARY_VALUE, []byte(tt.expectedGender)).Return(nil) | ||||||
|  | >>>>>>> master | ||||||
| 			} | 			} | ||||||
| 			mockState.ExecPath = append(mockState.ExecPath, tt.executingSymbol) | 			mockState.ExecPath = append(mockState.ExecPath, tt.executingSymbol) | ||||||
| 			// Create the Handlers instance with the mock store
 | 			// Create the Handlers instance with the mock store
 | ||||||
| 			h := &Handlers{ | 			h := &Handlers{ | ||||||
| 				userdataStore: mockStore, | 				userdataStore: mockStore, | ||||||
| 				st:            mockState, | 				st:            mockState, | ||||||
|  | 				flagManager:   fm.parser, | ||||||
| 			} | 			} | ||||||
| 
 | 
 | ||||||
| 			// Call the method
 | 			// Call the method
 | ||||||
| @ -429,9 +489,15 @@ func TestSaveGender(t *testing.T) { | |||||||
| 
 | 
 | ||||||
| 			// Verify expectations
 | 			// Verify expectations
 | ||||||
| 			if tt.expectCall { | 			if tt.expectCall { | ||||||
|  | <<<<<<< HEAD | ||||||
| 				mockStore.AssertCalled(t, "WriteEntry", ctx, sessionId, common.DATA_GENDER, []byte(tt.expectedGender)) | 				mockStore.AssertCalled(t, "WriteEntry", ctx, sessionId, common.DATA_GENDER, []byte(tt.expectedGender)) | ||||||
| 			} else { | 			} else { | ||||||
| 				mockStore.AssertNotCalled(t, "WriteEntry", ctx, sessionId, common.DATA_GENDER, []byte(tt.expectedGender)) | 				mockStore.AssertNotCalled(t, "WriteEntry", ctx, sessionId, common.DATA_GENDER, []byte(tt.expectedGender)) | ||||||
|  | ======= | ||||||
|  | 				mockStore.AssertCalled(t, "WriteEntry", ctx, sessionId, utils.DATA_TEMPORARY_VALUE, []byte(tt.expectedGender)) | ||||||
|  | 			} else { | ||||||
|  | 				mockStore.AssertNotCalled(t, "WriteEntry", ctx, sessionId, utils.DATA_TEMPORARY_VALUE, []byte(tt.expectedGender)) | ||||||
|  | >>>>>>> master | ||||||
| 			} | 			} | ||||||
| 		}) | 		}) | ||||||
| 	} | 	} | ||||||
| @ -1006,7 +1072,11 @@ func TestVerifyCreatePin(t *testing.T) { | |||||||
| 		}, | 		}, | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | <<<<<<< HEAD | ||||||
| 	typ := common.DATA_TEMPORARY_PIN | 	typ := common.DATA_TEMPORARY_PIN | ||||||
|  | ======= | ||||||
|  | 	typ := utils.DATA_TEMPORARY_VALUE | ||||||
|  | >>>>>>> master | ||||||
| 
 | 
 | ||||||
| 	for _, tt := range tests { | 	for _, tt := range tests { | ||||||
| 		t.Run(tt.name, func(t *testing.T) { | 		t.Run(tt.name, func(t *testing.T) { | ||||||
| @ -1746,7 +1816,11 @@ func TestConfirmPin(t *testing.T) { | |||||||
| 			// Set up the expected behavior of the mock
 | 			// Set up the expected behavior of the mock
 | ||||||
| 			mockDataStore.On("WriteEntry", ctx, sessionId, common.DATA_ACCOUNT_PIN, []byte(tt.temporarypin)).Return(nil) | 			mockDataStore.On("WriteEntry", ctx, sessionId, common.DATA_ACCOUNT_PIN, []byte(tt.temporarypin)).Return(nil) | ||||||
| 
 | 
 | ||||||
|  | <<<<<<< HEAD | ||||||
| 			mockDataStore.On("ReadEntry", ctx, sessionId, common.DATA_TEMPORARY_PIN).Return(tt.temporarypin, nil) | 			mockDataStore.On("ReadEntry", ctx, sessionId, common.DATA_TEMPORARY_PIN).Return(tt.temporarypin, nil) | ||||||
|  | ======= | ||||||
|  | 			mockDataStore.On("ReadEntry", ctx, sessionId, utils.DATA_TEMPORARY_VALUE).Return(tt.temporarypin, nil) | ||||||
|  | >>>>>>> master | ||||||
| 
 | 
 | ||||||
| 			//Call the function under test
 | 			//Call the function under test
 | ||||||
| 			res, _ := h.ConfirmPinChange(ctx, "confirm_pin_change", tt.temporarypin) | 			res, _ := h.ConfirmPinChange(ctx, "confirm_pin_change", tt.temporarypin) | ||||||
| @ -1984,16 +2058,9 @@ func TestViewVoucher(t *testing.T) { | |||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	// Set up expectations for mockDataStore
 | 	// Set up expectations for mockDataStore
 | ||||||
| 	expectedData := map[common.DataTyp]string{ | 	expectedData := fmt.Sprintf("%s,%s,%s,%s", "SRF", "100", "6", "0xd4c288865Ce") | ||||||
| 		common.DATA_TEMPORARY_SYM:     "SRF", |  | ||||||
| 		common.DATA_TEMPORARY_BAL:     "100", |  | ||||||
| 		common.DATA_TEMPORARY_DECIMAL: "6", |  | ||||||
| 		common.DATA_TEMPORARY_ADDRESS: "0xd4c288865Ce", |  | ||||||
| 	} |  | ||||||
| 
 | 
 | ||||||
| 	for dataType, dataValue := range expectedData { | 	mockDataStore.On("WriteEntry", ctx, sessionId, utils.DATA_TEMPORARY_VALUE, []byte(expectedData)).Return(nil) | ||||||
| 		mockDataStore.On("WriteEntry", ctx, sessionId, dataType, []byte(dataValue)).Return(nil) |  | ||||||
| 	} |  | ||||||
| 
 | 
 | ||||||
| 	res, err := h.ViewVoucher(ctx, "view_voucher", []byte("1")) | 	res, err := h.ViewVoucher(ctx, "view_voucher", []byte("1")) | ||||||
| 	assert.NoError(t, err) | 	assert.NoError(t, err) | ||||||
| @ -2017,6 +2084,8 @@ func TestSetVoucher(t *testing.T) { | |||||||
| 		ContractAddress: "0xd4c288865Ce0985a481Eef3be02443dF5E2e4Ea9", | 		ContractAddress: "0xd4c288865Ce0985a481Eef3be02443dF5E2e4Ea9", | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | 	expectedData := fmt.Sprintf("%s,%s,%s,%s", "SRF", "200", "6", "0xd4c288865Ce0985a481Eef3be02443dF5E2e4Ea9") | ||||||
|  | 
 | ||||||
| 	// Define the expected active entries
 | 	// Define the expected active entries
 | ||||||
| 	activeEntries := map[common.DataTyp][]byte{ | 	activeEntries := map[common.DataTyp][]byte{ | ||||||
| 		common.DATA_ACTIVE_SYM:     []byte(tempData.TokenSymbol), | 		common.DATA_ACTIVE_SYM:     []byte(tempData.TokenSymbol), | ||||||
| @ -2025,30 +2094,14 @@ func TestSetVoucher(t *testing.T) { | |||||||
| 		common.DATA_ACTIVE_ADDRESS: []byte(tempData.ContractAddress), | 		common.DATA_ACTIVE_ADDRESS: []byte(tempData.ContractAddress), | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	// Define the temporary entries to be cleared
 |  | ||||||
| 	tempEntries := map[common.DataTyp][]byte{ |  | ||||||
| 		common.DATA_TEMPORARY_SYM:     []byte(""), |  | ||||||
| 		common.DATA_TEMPORARY_BAL:     []byte(""), |  | ||||||
| 		common.DATA_TEMPORARY_DECIMAL: []byte(""), |  | ||||||
| 		common.DATA_TEMPORARY_ADDRESS: []byte(""), |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	// Mocking ReadEntry calls for temporary data retrieval
 | 	// Mocking ReadEntry calls for temporary data retrieval
 | ||||||
| 	mockDataStore.On("ReadEntry", ctx, sessionId, common.DATA_TEMPORARY_SYM).Return([]byte(tempData.TokenSymbol), nil) | 	mockDataStore.On("ReadEntry", ctx, sessionId, utils.DATA_TEMPORARY_VALUE).Return([]byte(expectedData), nil) | ||||||
| 	mockDataStore.On("ReadEntry", ctx, sessionId, common.DATA_TEMPORARY_BAL).Return([]byte(tempData.Balance), nil) |  | ||||||
| 	mockDataStore.On("ReadEntry", ctx, sessionId, common.DATA_TEMPORARY_DECIMAL).Return([]byte(tempData.TokenDecimals), nil) |  | ||||||
| 	mockDataStore.On("ReadEntry", ctx, sessionId, common.DATA_TEMPORARY_ADDRESS).Return([]byte(tempData.ContractAddress), nil) |  | ||||||
| 
 | 
 | ||||||
| 	// Mocking WriteEntry calls for setting active data
 | 	// Mocking WriteEntry calls for setting active data
 | ||||||
| 	for key, value := range activeEntries { | 	for key, value := range activeEntries { | ||||||
| 		mockDataStore.On("WriteEntry", ctx, sessionId, key, value).Return(nil) | 		mockDataStore.On("WriteEntry", ctx, sessionId, key, value).Return(nil) | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	// Mocking WriteEntry calls for clearing temporary data
 |  | ||||||
| 	for key, value := range tempEntries { |  | ||||||
| 		mockDataStore.On("WriteEntry", ctx, sessionId, key, value).Return(nil) |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	h := &Handlers{ | 	h := &Handlers{ | ||||||
| 		userdataStore: mockDataStore, | 		userdataStore: mockDataStore, | ||||||
| 	} | 	} | ||||||
|  | |||||||
| @ -1,5 +1,5 @@ | |||||||
| CATCH incorrect_pin flag_incorrect_pin 1 | CATCH incorrect_pin flag_incorrect_pin 1 | ||||||
| CATCH profile_update_success flag_allow_update 1 | CATCH update_familyname flag_allow_update 1 | ||||||
| MOUT back 0 | MOUT back 0 | ||||||
| HALT | HALT | ||||||
| LOAD save_familyname 0 | LOAD save_familyname 0 | ||||||
|  | |||||||
| @ -1,5 +1,5 @@ | |||||||
| CATCH incorrect_pin flag_incorrect_pin 1 | CATCH incorrect_pin flag_incorrect_pin 1 | ||||||
| CATCH profile_update_success flag_allow_update 1 | CATCH update_location flag_allow_update 1 | ||||||
| MOUT back 0 | MOUT back 0 | ||||||
| HALT | HALT | ||||||
| LOAD save_location 0 | LOAD save_location 0 | ||||||
|  | |||||||
| @ -1,5 +1,5 @@ | |||||||
| CATCH incorrect_pin flag_incorrect_pin 1 | CATCH incorrect_pin flag_incorrect_pin 1 | ||||||
| CATCH profile_update_success flag_allow_update 1 | CATCH update_firstname flag_allow_update 1 | ||||||
| MOUT back 0 | MOUT back 0 | ||||||
| HALT | HALT | ||||||
| LOAD save_firstname 0 | LOAD save_firstname 0 | ||||||
|  | |||||||
| @ -1,5 +1,5 @@ | |||||||
| CATCH incorrect_pin flag_incorrect_pin 1 | CATCH incorrect_pin flag_incorrect_pin 1 | ||||||
| CATCH profile_update_success flag_allow_update 1 | CATCH update_offerings flag_allow_update 1 | ||||||
| LOAD save_offerings 0 | LOAD save_offerings 0 | ||||||
| MOUT back 0 | MOUT back 0 | ||||||
| HALT | HALT | ||||||
|  | |||||||
| @ -1,10 +1,10 @@ | |||||||
| CATCH incorrect_pin flag_incorrect_pin 1 | CATCH incorrect_pin flag_incorrect_pin 1 | ||||||
| CATCH profile_update_success flag_allow_update 1 | CATCH update_yob flag_allow_update 1 | ||||||
| LOAD save_yob 0 |  | ||||||
| MOUT back 0 | MOUT back 0 | ||||||
| HALT | HALT | ||||||
| LOAD verify_yob 0 | LOAD verify_yob 0 | ||||||
| CATCH incorrect_date_format flag_incorrect_date_format 1 | CATCH incorrect_date_format flag_incorrect_date_format 1 | ||||||
|  | LOAD save_yob 0 | ||||||
| RELOAD save_yob | RELOAD save_yob | ||||||
| INCMP _ 0 | INCMP _ 0 | ||||||
| INCMP pin_entry * | INCMP pin_entry * | ||||||
|  | |||||||
| @ -1,4 +1,4 @@ | |||||||
| LOAD save_gender 0 | LOAD save_gender 0 | ||||||
| CATCH incorrect_pin flag_incorrect_pin 1 | CATCH incorrect_pin flag_incorrect_pin 1 | ||||||
| CATCH profile_update_success flag_allow_update 1 | CATCH update_gender flag_allow_update 1 | ||||||
| MOVE pin_entry | MOVE pin_entry | ||||||
|  | |||||||
| @ -1,4 +1,4 @@ | |||||||
| LOAD save_gender 0 | LOAD save_gender 0 | ||||||
| CATCH incorrect_pin flag_incorrect_pin 1 | CATCH incorrect_pin flag_incorrect_pin 1 | ||||||
| CATCH profile_update_success flag_allow_update 1 | CATCH update_gender flag_allow_update 1 | ||||||
| MOVE pin_entry | MOVE pin_entry | ||||||
|  | |||||||
| @ -1,4 +1,4 @@ | |||||||
| LOAD save_gender 0 | LOAD save_gender 0 | ||||||
| CATCH incorrect_pin flag_incorrect_pin 1 | CATCH incorrect_pin flag_incorrect_pin 1 | ||||||
| CATCH profile_update_success flag_allow_update 1 | CATCH update_gender flag_allow_update 1 | ||||||
| MOVE pin_entry | MOVE pin_entry | ||||||
|  | |||||||
							
								
								
									
										2
									
								
								services/registration/update_age
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								services/registration/update_age
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,2 @@ | |||||||
|  | RELOAD save_yob | ||||||
|  | CATCH profile_update_success flag_allow_update 1 | ||||||
							
								
								
									
										2
									
								
								services/registration/update_familyname.vis
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								services/registration/update_familyname.vis
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,2 @@ | |||||||
|  | RELOAD save_familyname | ||||||
|  | CATCH profile_update_success flag_allow_update 1 | ||||||
							
								
								
									
										2
									
								
								services/registration/update_firstname.vis
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								services/registration/update_firstname.vis
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,2 @@ | |||||||
|  | RELOAD save_firstname | ||||||
|  | CATCH profile_update_success flag_allow_update 1 | ||||||
							
								
								
									
										2
									
								
								services/registration/update_gender.vis
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								services/registration/update_gender.vis
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,2 @@ | |||||||
|  | RELOAD save_gender | ||||||
|  | CATCH profile_update_success flag_allow_update 1 | ||||||
							
								
								
									
										2
									
								
								services/registration/update_location.vis
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								services/registration/update_location.vis
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,2 @@ | |||||||
|  | RELOAD save_location | ||||||
|  | CATCH profile_update_success flag_allow_update 1 | ||||||
							
								
								
									
										2
									
								
								services/registration/update_offerings.vis
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								services/registration/update_offerings.vis
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,2 @@ | |||||||
|  | RELOAD save_offerings | ||||||
|  | CATCH profile_update_success flag_allow_update 1 | ||||||
							
								
								
									
										2
									
								
								services/registration/update_yob.vis
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								services/registration/update_yob.vis
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,2 @@ | |||||||
|  | RELOAD save_yob | ||||||
|  | CATCH profile_update_success flag_allow_update 1 | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user