wip-account-creation #4
92
cmd/main.go
92
cmd/main.go
@ -26,6 +26,7 @@ const (
|
||||
USERFLAG_ACCOUNT_UNLOCKED
|
||||
invalidRecipient
|
||||
invalidRecipientWithInvite
|
||||
USERFLAG_INCORRECTPIN
|
||||
)
|
||||
|
||||
const (
|
||||
@ -131,8 +132,7 @@ func (fsd *fsData) create_account(ctx context.Context, sym string, input []byte)
|
||||
if err != nil {
|
||||
return res, err
|
||||
}
|
||||
|
||||
res.FlagSet = []uint32{USERFLAG_ACCOUNT_CREATED}
|
||||
res.FlagSet = append(res.FlagSet, USERFLAG_ACCOUNT_CREATED)
|
||||
return res, err
|
||||
}
|
||||
|
||||
@ -156,16 +156,33 @@ func (fsd *fsData) checkIdentifier(ctx context.Context, sym string, input []byte
|
||||
return res, nil
|
||||
}
|
||||
Alfred-mk marked this conversation as resolved
Outdated
|
||||
|
||||
|
||||
func (fsd *fsData) unlock(ctx context.Context,sym string,input []byte) (resource.Result,error){
|
||||
func (fsd *fsData) unLock(ctx context.Context, sym string, input []byte) (resource.Result, error) {
|
||||
res := resource.Result{}
|
||||
//res.FlagSet = []uint32{USERFLAG_ACCOUNT_UNLOCKED}
|
||||
pin := string(input)
|
||||
if len(input) > 0 {
|
||||
if pin == "0000" {
|
||||
res.FlagSet = append(res.FlagSet, USERFLAG_INCORRECTPIN)
|
||||
res.FlagReset = append(res.FlagReset, USERFLAG_ACCOUNT_UNLOCKED)
|
||||
return res, nil
|
||||
}
|
||||
if fsd.st.MatchFlag(USERFLAG_ACCOUNT_UNLOCKED, false) {
|
||||
Alfred-mk marked this conversation as resolved
Outdated
lash
commented
perhaps check this input, 2 or 4 digits, numeric perhaps check this input, 2 or 4 digits, numeric
lash
commented
priority **priority**
|
||||
res.FlagSet = append(res.FlagSet, USERFLAG_ACCOUNT_UNLOCKED)
|
||||
} else {
|
||||
res.FlagReset = append(res.FlagReset, USERFLAG_ACCOUNT_UNLOCKED)
|
||||
}
|
||||
return res,nil
|
||||
}
|
||||
return res, nil
|
||||
}
|
||||
|
||||
func (fsd *fsData) ResetIncorrectPin(ctx context.Context, sym string, input []byte) (resource.Result, error) {
|
||||
res := resource.Result{}
|
||||
isIncorrectPinSet := fsd.st.MatchFlag(USERFLAG_INCORRECTPIN, true)
|
||||
if isIncorrectPinSet {
|
||||
res.FlagReset = append(res.FlagReset, USERFLAG_INCORRECTPIN)
|
||||
} else {
|
||||
res.FlagReset = append(res.FlagReset, USERFLAG_INCORRECTPIN)
|
||||
}
|
||||
return res, nil
|
||||
}
|
||||
|
||||
func (fsd *fsData) check_account_status(ctx context.Context, sym string, input []byte) (resource.Result, error) {
|
||||
@ -192,16 +209,14 @@ func (fsd *fsData) check_account_status(ctx context.Context, sym string, input [
|
||||
|
||||
accountData["Status"] = status
|
||||
|
||||
if status == "SUCCESS" {
|
||||
if status == "REVERTED" {
|
||||
res.FlagSet = append(res.FlagSet, USERFLAG_ACCOUNT_SUCCESS)
|
||||
res.FlagReset = append(res.FlagReset,USERFLAG_ACCOUNT_PENDING)
|
||||
res.FlagReset = append(res.FlagReset, USERFLAG_ACCOUNT_PENDING)
|
||||
} else {
|
||||
res.FlagReset = append(res.FlagSet, USERFLAG_ACCOUNT_SUCCESS)
|
||||
res.FlagSet = append(res.FlagReset,USERFLAG_ACCOUNT_PENDING)
|
||||
res.FlagSet = append(res.FlagReset, USERFLAG_ACCOUNT_PENDING)
|
||||
}
|
||||
|
||||
|
||||
|
||||
updatedJsonData, err := json.Marshal(accountData)
|
||||
if err != nil {
|
||||
return res, err
|
||||
@ -261,15 +276,9 @@ func checkAccountStatus(trackingId string) (string, error) {
|
||||
|
||||
func (fsd *fsData) quit(ctx context.Context, sym string, input []byte) (resource.Result, error) {
|
||||
res := resource.Result{
|
||||
Content: "",
|
||||
Content: "Your account is being created",
|
||||
}
|
||||
st := fsd.st
|
||||
if(st.MatchFlag(USERFLAG_ACCOUNT_UNLOCKED,true)){
|
||||
//res.FlagReset = []uint32{USERFLAG_ACCOUNT_UNLOCKED}
|
||||
// res.FlagReset = append(res.FlagReset, USERFLAG_ACCOUNT_UNLOCKED)
|
||||
}else {
|
||||
res.FlagReset = append(res.FlagReset, USERFLAG_ACCOUNT_UNLOCKED)
|
||||
lash
commented
this shouldnt switch on the input string; that requires manual syncing between here and the menu code. how about using INCMP and the language switches on the sym instead? Have a look at the this shouldnt switch on the input string; that requires manual syncing between here and the menu code.
how about using INCMP and the language switches on the sym instead?
Have a look at the `lash/reuse-example` go-vise branch, I've added an example that might illustrate.
lash
commented
priority **priority**
lash
commented
I see this still isn't resolved. I will make an issue of this, and mark it priority. We will handle it after merge. I see this still isn't resolved.
I will make an issue of this, and mark it priority. We will handle it after merge.
|
||||
}
|
||||
return res, nil
|
||||
}
|
||||
|
||||
@ -480,6 +489,44 @@ func (fsd *fsData) get_sender(ctx context.Context, sym string, input []byte) (re
|
||||
return res, nil
|
||||
}
|
||||
|
||||
|
||||
func (fsd *fsData) quitWithBalance(ctx context.Context, sym string, input []byte) (resource.Result, error) {
|
||||
res := resource.Result{
|
||||
}
|
||||
fp := fsd.path + "_data"
|
||||
|
||||
jsonData, err := os.ReadFile(fp)
|
||||
if err != nil {
|
||||
return res, err
|
||||
}
|
||||
|
||||
var accountData map[string]string
|
||||
err = json.Unmarshal(jsonData, &accountData)
|
||||
if err != nil {
|
||||
return res, err
|
||||
}
|
||||
resp, err := http.Get(checkBalanceURL + accountData["PublicKey"])
|
||||
if err != nil {
|
||||
return res, nil
|
||||
}
|
||||
defer resp.Body.Close()
|
||||
|
||||
body, err := io.ReadAll(resp.Body)
|
||||
if err != nil {
|
||||
return res, nil
|
||||
}
|
||||
|
||||
var balanceResp balanceResponse
|
||||
err = json.Unmarshal(body, &balanceResp)
|
||||
if err != nil {
|
||||
return res, nil
|
||||
}
|
||||
balance := balanceResp.Result.Balance
|
||||
res.Content = fmt.Sprintf("Your account balance is: %s", balance)
|
||||
res.FlagReset = append(res.FlagReset, USERFLAG_ACCOUNT_UNLOCKED)
|
||||
return res, nil
|
||||
}
|
||||
|
||||
var (
|
||||
scriptDir = path.Join("services", "registration")
|
||||
)
|
||||
@ -497,12 +544,13 @@ func main() {
|
||||
fmt.Fprintf(os.Stderr, "starting session at symbol '%s' using resource dir: %s\n", root, dir)
|
||||
|
||||
ctx := context.Background()
|
||||
st := state.NewState(7)
|
||||
st := state.NewState(9)
|
||||
st.UseDebug()
|
||||
state.FlagDebugger.Register(USERFLAG_LANGUAGE_SET, "LANGUAGE_CHANGE")
|
||||
state.FlagDebugger.Register(USERFLAG_ACCOUNT_CREATED, "ACCOUNT_CREATED")
|
||||
state.FlagDebugger.Register(USERFLAG_ACCOUNT_SUCCESS, "ACCOUNT_SUCCESS")
|
||||
state.FlagDebugger.Register(USERFLAG_ACCOUNT_PENDING, "ACCOUNT_PENDING")
|
||||
state.FlagDebugger.Register(USERFLAG_INCORRECTPIN, "INCORRECTPIN")
|
||||
|
||||
rfs := resource.NewFsResource(scriptDir)
|
||||
ca := cache.NewCache()
|
||||
@ -519,6 +567,7 @@ func main() {
|
||||
}
|
||||
pr := persist.NewFsPersister(dp)
|
||||
en, err := engine.NewPersistedEngine(ctx, cfg, pr, rfs)
|
||||
|
||||
if err != nil {
|
||||
pr = pr.WithContent(&st, ca)
|
||||
err = pr.Save(cfg.SessionId)
|
||||
@ -541,7 +590,7 @@ func main() {
|
||||
rfs.AddLocalFunc("create_account", fs.create_account)
|
||||
rfs.AddLocalFunc("check_identifier", fs.checkIdentifier)
|
||||
rfs.AddLocalFunc("check_account_status", fs.check_account_status)
|
||||
rfs.AddLocalFunc("unlock_account", fs.unlock)
|
||||
rfs.AddLocalFunc("unlock_account", fs.unLock)
|
||||
rfs.AddLocalFunc("quit", fs.quit)
|
||||
rfs.AddLocalFunc("check_balance", fs.checkBalance)
|
||||
rfs.AddLocalFunc("validate_recipient", fs.validate_recipient)
|
||||
@ -550,8 +599,11 @@ func main() {
|
||||
rfs.AddLocalFunc("validate_amount", fs.validate_amount)
|
||||
rfs.AddLocalFunc("get_recipient", fs.get_recipient)
|
||||
rfs.AddLocalFunc("get_sender", fs.get_sender)
|
||||
rfs.AddLocalFunc("reset_incorrect", fs.ResetIncorrectPin)
|
||||
rfs.AddLocalFunc("quit_with_balance",fs.quitWithBalance)
|
||||
|
||||
cont, err := en.Init(ctx)
|
||||
en.SetDebugger(engine.NewSimpleDebug(nil))
|
||||
if err != nil {
|
||||
fmt.Fprintf(os.Stderr, "engine init exited with error: %v\n", err)
|
||||
os.Exit(1)
|
||||
|
@ -1,3 +1,4 @@
|
||||
LOAD create_account 0
|
||||
LOAD quit 0
|
||||
HALT
|
||||
MOVE quit
|
||||
|
||||
|
@ -4,5 +4,5 @@ MOUT back 0
|
||||
HALT
|
||||
INCMP ^ 0
|
||||
INCMP my_balance 1
|
||||
INCMP my_community_balance 2
|
||||
INCMP community_balance 2
|
||||
|
||||
|
6
services/registration/community_balance.vis
Normal file
6
services/registration/community_balance.vis
Normal file
@ -0,0 +1,6 @@
|
||||
LOAD reset_incorrect 0
|
||||
CATCH incorrect_pin 15 1
|
||||
CATCH pin_entry 12 0
|
||||
LOAD quit_with_balance 0
|
||||
HALT
|
||||
|
@ -1,4 +1,4 @@
|
||||
MOUT back 0
|
||||
HALT
|
||||
INCMP ^ 0
|
||||
INCMP _ 0
|
||||
INCMP display_profile_info *
|
||||
|
1
services/registration/incorrect_pin
Normal file
1
services/registration/incorrect_pin
Normal file
@ -0,0 +1 @@
|
||||
Incorrect pin
|
7
services/registration/incorrect_pin.vis
Normal file
7
services/registration/incorrect_pin.vis
Normal file
@ -0,0 +1,7 @@
|
||||
LOAD reset_incorrect 0
|
||||
RELOAD reset_incorrect
|
||||
MOUT retry 1
|
||||
MOUT quit 9
|
||||
HALT
|
||||
INCMP _ 1
|
||||
INCMP quit 9
|
1
services/registration/incorrect_pin_swa
Normal file
1
services/registration/incorrect_pin_swa
Normal file
@ -0,0 +1 @@
|
||||
PIN ulioeka sio sahihi
|
@ -1,3 +1,6 @@
|
||||
LOAD reset_incorrect 0
|
||||
CATCH incorrect_pin 15 1
|
||||
CATCH pin_entry 12 0
|
||||
LOAD quit_with_balance 0
|
||||
HALT
|
||||
MOVE quit
|
||||
|
||||
|
@ -1,3 +0,0 @@
|
||||
CATCH pin_entry 12 0
|
||||
HALT
|
||||
MOVE quit
|
Loading…
Reference in New Issue
Block a user
This code is repeated many times. Could we please abstract the json fs part of the get and set to a module implementing an interface with
Get
andPut
?