Compare commits
2 Commits
master
...
self-pin-r
| Author | SHA1 | Date | |
|---|---|---|---|
| fe5772fb3b | |||
| 82d0e588c9 |
1
.gitignore
vendored
1
.gitignore
vendored
@ -8,4 +8,3 @@ id_*
|
|||||||
*.gdbm
|
*.gdbm
|
||||||
*.log
|
*.log
|
||||||
user-data
|
user-data
|
||||||
**/*/vise-asm
|
|
||||||
|
|||||||
@ -21,6 +21,7 @@ func (h *MenuHandlers) Authorize(ctx context.Context, sym string, input []byte)
|
|||||||
flag_incorrect_pin, _ := h.flagManager.GetFlag("flag_incorrect_pin")
|
flag_incorrect_pin, _ := h.flagManager.GetFlag("flag_incorrect_pin")
|
||||||
flag_account_authorized, _ := h.flagManager.GetFlag("flag_account_authorized")
|
flag_account_authorized, _ := h.flagManager.GetFlag("flag_account_authorized")
|
||||||
flag_allow_update, _ := h.flagManager.GetFlag("flag_allow_update")
|
flag_allow_update, _ := h.flagManager.GetFlag("flag_allow_update")
|
||||||
|
flag_account_pin_reset, _ := h.flagManager.GetFlag("flag_account_pin_reset")
|
||||||
|
|
||||||
pinInput := string(input)
|
pinInput := string(input)
|
||||||
|
|
||||||
@ -33,7 +34,9 @@ func (h *MenuHandlers) Authorize(ctx context.Context, sym string, input []byte)
|
|||||||
AccountPin, err := store.ReadEntry(ctx, sessionId, storedb.DATA_ACCOUNT_PIN)
|
AccountPin, err := store.ReadEntry(ctx, sessionId, storedb.DATA_ACCOUNT_PIN)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
logg.ErrorCtxf(ctx, "failed to read AccountPin entry with", "key", storedb.DATA_ACCOUNT_PIN, "error", err)
|
logg.ErrorCtxf(ctx, "failed to read AccountPin entry with", "key", storedb.DATA_ACCOUNT_PIN, "error", err)
|
||||||
return res, err
|
logg.InfoCtxf(ctx, "Setting the flag_account_pin_reset flag for the user to set their own PIN")
|
||||||
|
res.FlagSet = append(res.FlagSet, flag_account_pin_reset)
|
||||||
|
return res, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// verify that the user provided the correct PIN
|
// verify that the user provided the correct PIN
|
||||||
|
|||||||
@ -258,7 +258,6 @@ func (h *MenuHandlers) TransactionReset(ctx context.Context, sym string, input [
|
|||||||
|
|
||||||
flag_invalid_recipient, _ := h.flagManager.GetFlag("flag_invalid_recipient")
|
flag_invalid_recipient, _ := h.flagManager.GetFlag("flag_invalid_recipient")
|
||||||
flag_invalid_recipient_with_invite, _ := h.flagManager.GetFlag("flag_invalid_recipient_with_invite")
|
flag_invalid_recipient_with_invite, _ := h.flagManager.GetFlag("flag_invalid_recipient_with_invite")
|
||||||
|
|
||||||
store := h.userdataStore
|
store := h.userdataStore
|
||||||
err = store.WriteEntry(ctx, sessionId, storedb.DATA_AMOUNT, []byte(""))
|
err = store.WriteEntry(ctx, sessionId, storedb.DATA_AMOUNT, []byte(""))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -337,13 +336,28 @@ func (h *MenuHandlers) MaxAmount(ctx context.Context, sym string, input []byte)
|
|||||||
// Format the active balance amount to 2 decimal places
|
// Format the active balance amount to 2 decimal places
|
||||||
formattedBalance, _ := store.TruncateDecimalString(string(activeBal), 2)
|
formattedBalance, _ := store.TruncateDecimalString(string(activeBal), 2)
|
||||||
|
|
||||||
// If normal transaction return balance
|
// If normal transaction, or if the sym is send_max_amount, return balance
|
||||||
if string(transactionType) == "normal" {
|
if string(transactionType) == "normal" || sym == "send_max_amount" {
|
||||||
res.FlagReset = append(res.FlagReset, flag_swap_transaction)
|
res.FlagReset = append(res.FlagReset, flag_swap_transaction)
|
||||||
|
|
||||||
res.Content = l.Get("Maximum amount: %s %s\nEnter amount:", formattedBalance, string(activeSym))
|
res.Content = l.Get("Maximum amount: %s %s\nEnter amount:", formattedBalance, string(activeSym))
|
||||||
|
|
||||||
return res, nil
|
return res, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
res.FlagSet = append(res.FlagSet, flag_swap_transaction)
|
||||||
|
|
||||||
|
// Get the recipient's phone number to read other data items
|
||||||
|
recipientPhoneNumber, err := userStore.ReadEntry(ctx, sessionId, storedb.DATA_RECIPIENT_PHONE_NUMBER)
|
||||||
|
if err != nil {
|
||||||
|
// invalid state
|
||||||
|
return res, err
|
||||||
|
}
|
||||||
|
recipientActiveSym, recipientActiveAddress, recipientActiveDecimal, err := h.getRecipientData(ctx, string(recipientPhoneNumber))
|
||||||
|
if err != nil {
|
||||||
|
return res, err
|
||||||
|
}
|
||||||
|
|
||||||
// Resolve active pool address
|
// Resolve active pool address
|
||||||
activePoolAddress, err := h.resolveActivePoolAddress(ctx, sessionId)
|
activePoolAddress, err := h.resolveActivePoolAddress(ctx, sessionId)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -358,31 +372,16 @@ func (h *MenuHandlers) MaxAmount(ctx context.Context, sym string, input []byte)
|
|||||||
logg.ErrorCtxf(ctx, "failed on CheckTokenInPool", "error", err)
|
logg.ErrorCtxf(ctx, "failed on CheckTokenInPool", "error", err)
|
||||||
return res, nil
|
return res, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
res.FlagReset = append(res.FlagReset, flag_swap_transaction)
|
res.FlagReset = append(res.FlagReset, flag_swap_transaction)
|
||||||
res.Content = l.Get("Maximum amount: %s %s\nEnter amount:", formattedBalance, string(activeSym))
|
res.Content = l.Get("Maximum amount: %s %s\nEnter amount:", formattedBalance, string(activeSym))
|
||||||
return res, nil
|
return res, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// Get the recipient's phone number to read other data items
|
|
||||||
recipientPhoneNumber, err := userStore.ReadEntry(ctx, sessionId, storedb.DATA_RECIPIENT_PHONE_NUMBER)
|
|
||||||
if err != nil {
|
|
||||||
// invalid state
|
|
||||||
return res, err
|
|
||||||
}
|
|
||||||
recipientActiveSym, recipientActiveAddress, recipientActiveDecimal, err := h.getRecipientData(ctx, string(recipientPhoneNumber))
|
|
||||||
if err != nil {
|
|
||||||
return res, err
|
|
||||||
}
|
|
||||||
|
|
||||||
// retrieve the max credit send amounts
|
// retrieve the max credit send amounts
|
||||||
maxSAT, maxRAT, err := h.calculateSendCreditLimits(ctx, activePoolAddress, activeAddress, recipientActiveAddress, publicKey, activeDecimal, recipientActiveDecimal)
|
maxSAT, maxRAT, err := h.calculateSendCreditLimits(ctx, activePoolAddress, activeAddress, recipientActiveAddress, publicKey, activeDecimal, recipientActiveDecimal)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
// if an error (such as Swap rates not found for the speficied pool and tokens), fall back to a normal transaction
|
res.FlagSet = append(res.FlagSet, flag_api_call_error)
|
||||||
logg.ErrorCtxf(ctx, "failed on calculateSendCreditLimits", "error", err)
|
logg.ErrorCtxf(ctx, "failed on calculateSendCreditLimits", "error", err)
|
||||||
res.FlagReset = append(res.FlagReset, flag_swap_transaction)
|
|
||||||
res.Content = l.Get("Maximum amount: %s %s\nEnter amount:", formattedBalance, string(activeSym))
|
|
||||||
|
|
||||||
return res, nil
|
return res, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -414,9 +413,6 @@ func (h *MenuHandlers) MaxAmount(ctx context.Context, sym string, input []byte)
|
|||||||
return res, err
|
return res, err
|
||||||
}
|
}
|
||||||
|
|
||||||
// only set the flag once all checks pass
|
|
||||||
res.FlagSet = append(res.FlagSet, flag_swap_transaction)
|
|
||||||
|
|
||||||
res.Content = l.Get(
|
res.Content = l.Get(
|
||||||
"Credit Available: %s %s\n(You can swap up to %s %s -> %s %s).\nEnter %s amount:",
|
"Credit Available: %s %s\n(You can swap up to %s %s -> %s %s).\nEnter %s amount:",
|
||||||
maxRAT,
|
maxRAT,
|
||||||
|
|||||||
@ -7,6 +7,7 @@ MOUT back 0
|
|||||||
MOUT quit 9
|
MOUT quit 9
|
||||||
HALT
|
HALT
|
||||||
RELOAD authorize_account
|
RELOAD authorize_account
|
||||||
|
CATCH self_reset_pin flag_account_pin_reset 1
|
||||||
CATCH incorrect_pin flag_incorrect_pin 1
|
CATCH incorrect_pin flag_incorrect_pin 1
|
||||||
INCMP _ 0
|
INCMP _ 0
|
||||||
INCMP quit 9
|
INCMP quit 9
|
||||||
|
|||||||
@ -1,5 +1,4 @@
|
|||||||
LOAD reset_transaction_amount 10
|
LOAD reset_transaction_amount 10
|
||||||
RELOAD reset_transaction_amount
|
|
||||||
LOAD credit_max_amount 160
|
LOAD credit_max_amount 160
|
||||||
RELOAD credit_max_amount
|
RELOAD credit_max_amount
|
||||||
CATCH api_failure flag_api_call_error 1
|
CATCH api_failure flag_api_call_error 1
|
||||||
@ -11,6 +10,7 @@ RELOAD clear_trans_type_flag
|
|||||||
CATCH transaction_swap flag_swap_transaction 1
|
CATCH transaction_swap flag_swap_transaction 1
|
||||||
LOAD validate_amount 64
|
LOAD validate_amount 64
|
||||||
RELOAD validate_amount
|
RELOAD validate_amount
|
||||||
|
CATCH api_failure flag_api_call_error 1
|
||||||
CATCH invalid_amount flag_invalid_amount 1
|
CATCH invalid_amount flag_invalid_amount 1
|
||||||
INCMP _ 0
|
INCMP _ 0
|
||||||
LOAD get_recipient 0
|
LOAD get_recipient 0
|
||||||
|
|||||||
1
services/registration/credit_send_menu
Normal file
1
services/registration/credit_send_menu
Normal file
@ -0,0 +1 @@
|
|||||||
|
Credit-Send
|
||||||
1
services/registration/credit_send_menu_swa
Normal file
1
services/registration/credit_send_menu_swa
Normal file
@ -0,0 +1 @@
|
|||||||
|
Tuma-Mkopo
|
||||||
@ -7,6 +7,7 @@ MOUT quit 9
|
|||||||
HALT
|
HALT
|
||||||
LOAD authorize_account 6
|
LOAD authorize_account 6
|
||||||
RELOAD authorize_account
|
RELOAD authorize_account
|
||||||
|
CATCH self_reset_pin flag_account_pin_reset 1
|
||||||
CATCH incorrect_pin flag_incorrect_pin 1
|
CATCH incorrect_pin flag_incorrect_pin 1
|
||||||
INCMP _ 0
|
INCMP _ 0
|
||||||
INCMP quit 9
|
INCMP quit 9
|
||||||
|
|||||||
@ -7,20 +7,22 @@ LOAD check_balance 128
|
|||||||
RELOAD check_balance
|
RELOAD check_balance
|
||||||
MAP check_balance
|
MAP check_balance
|
||||||
MOUT send 1
|
MOUT send 1
|
||||||
MOUT swap 2
|
MOUT credit_send 2
|
||||||
MOUT vouchers 3
|
MOUT swap 3
|
||||||
MOUT select_pool 4
|
MOUT vouchers 4
|
||||||
MOUT mpesa 5
|
MOUT select_pool 5
|
||||||
MOUT account 6
|
MOUT mpesa 6
|
||||||
MOUT help 7
|
MOUT account 7
|
||||||
|
MOUT help 8
|
||||||
MOUT quit 9
|
MOUT quit 9
|
||||||
HALT
|
HALT
|
||||||
INCMP credit_send 1
|
INCMP send 1
|
||||||
INCMP swap_to_list 2
|
INCMP credit_send 2
|
||||||
INCMP my_vouchers 3
|
INCMP swap_to_list 3
|
||||||
INCMP select_pool 4
|
INCMP my_vouchers 4
|
||||||
INCMP mpesa 5
|
INCMP select_pool 5
|
||||||
INCMP my_account 6
|
INCMP mpesa 6
|
||||||
INCMP help 7
|
INCMP my_account 7
|
||||||
|
INCMP help 8
|
||||||
INCMP quit 9
|
INCMP quit 9
|
||||||
INCMP . *
|
INCMP . *
|
||||||
|
|||||||
1
services/registration/send
Normal file
1
services/registration/send
Normal file
@ -0,0 +1 @@
|
|||||||
|
Enter recipient's phone number/address/alias:
|
||||||
12
services/registration/send.vis
Normal file
12
services/registration/send.vis
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
LOAD transaction_reset 0
|
||||||
|
RELOAD transaction_reset
|
||||||
|
CATCH no_voucher flag_no_active_voucher 1
|
||||||
|
MOUT back 0
|
||||||
|
HALT
|
||||||
|
LOAD validate_recipient 50
|
||||||
|
RELOAD validate_recipient
|
||||||
|
CATCH api_failure flag_api_call_error 1
|
||||||
|
CATCH invalid_recipient flag_invalid_recipient 1
|
||||||
|
CATCH invite_recipient flag_invalid_recipient_with_invite 1
|
||||||
|
INCMP _ 0
|
||||||
|
INCMP amount *
|
||||||
@ -6,6 +6,7 @@ MOUT quit 9
|
|||||||
HALT
|
HALT
|
||||||
LOAD authorize_account 6
|
LOAD authorize_account 6
|
||||||
RELOAD authorize_account
|
RELOAD authorize_account
|
||||||
|
CATCH self_reset_pin flag_account_pin_reset 1
|
||||||
CATCH incorrect_pin flag_incorrect_pin 1
|
CATCH incorrect_pin flag_incorrect_pin 1
|
||||||
INCMP _ 0
|
INCMP _ 0
|
||||||
INCMP quit 9
|
INCMP quit 9
|
||||||
|
|||||||
1
services/registration/send_swa
Normal file
1
services/registration/send_swa
Normal file
@ -0,0 +1 @@
|
|||||||
|
Weka nambari ya simu/Anwani/Lakabu:
|
||||||
@ -6,6 +6,7 @@ MOUT quit 9
|
|||||||
LOAD authorize_account 6
|
LOAD authorize_account 6
|
||||||
HALT
|
HALT
|
||||||
RELOAD authorize_account
|
RELOAD authorize_account
|
||||||
|
CATCH self_reset_pin flag_account_pin_reset 1
|
||||||
CATCH incorrect_pin flag_incorrect_pin 1
|
CATCH incorrect_pin flag_incorrect_pin 1
|
||||||
INCMP _ 0
|
INCMP _ 0
|
||||||
INCMP quit 9
|
INCMP quit 9
|
||||||
|
|||||||
@ -9,6 +9,7 @@ MOUT quit 9
|
|||||||
LOAD authorize_account 6
|
LOAD authorize_account 6
|
||||||
HALT
|
HALT
|
||||||
RELOAD authorize_account
|
RELOAD authorize_account
|
||||||
|
CATCH self_reset_pin flag_account_pin_reset 1
|
||||||
CATCH incorrect_pin flag_incorrect_pin 1
|
CATCH incorrect_pin flag_incorrect_pin 1
|
||||||
INCMP _ 0
|
INCMP _ 0
|
||||||
INCMP quit 9
|
INCMP quit 9
|
||||||
|
|||||||
@ -7,6 +7,7 @@ MOUT quit 9
|
|||||||
LOAD authorize_account 6
|
LOAD authorize_account 6
|
||||||
HALT
|
HALT
|
||||||
RELOAD authorize_account
|
RELOAD authorize_account
|
||||||
|
CATCH self_reset_pin flag_account_pin_reset 1
|
||||||
CATCH incorrect_pin flag_incorrect_pin 1
|
CATCH incorrect_pin flag_incorrect_pin 1
|
||||||
INCMP _ 0
|
INCMP _ 0
|
||||||
INCMP quit 9
|
INCMP quit 9
|
||||||
|
|||||||
@ -4,6 +4,7 @@ MOUT quit 9
|
|||||||
LOAD authorize_account 6
|
LOAD authorize_account 6
|
||||||
HALT
|
HALT
|
||||||
RELOAD authorize_account
|
RELOAD authorize_account
|
||||||
|
CATCH self_reset_pin flag_account_pin_reset 1
|
||||||
CATCH incorrect_pin flag_incorrect_pin 1
|
CATCH incorrect_pin flag_incorrect_pin 1
|
||||||
INCMP _ 0
|
INCMP _ 0
|
||||||
INCMP quit 9
|
INCMP quit 9
|
||||||
|
|||||||
@ -4,6 +4,7 @@ MOUT quit 9
|
|||||||
LOAD authorize_account 6
|
LOAD authorize_account 6
|
||||||
HALT
|
HALT
|
||||||
RELOAD authorize_account
|
RELOAD authorize_account
|
||||||
|
CATCH self_reset_pin flag_account_pin_reset 1
|
||||||
CATCH incorrect_pin flag_incorrect_pin 1
|
CATCH incorrect_pin flag_incorrect_pin 1
|
||||||
INCMP _ 0
|
INCMP _ 0
|
||||||
INCMP quit 9
|
INCMP quit 9
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user