2024-08-15 10:12:58 +02:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2024-09-03 14:04:09 +02:00
|
|
|
"encoding/csv"
|
2024-08-15 10:12:58 +02:00
|
|
|
"flag"
|
|
|
|
"fmt"
|
2024-09-03 14:04:09 +02:00
|
|
|
"io"
|
2024-09-04 11:19:34 +02:00
|
|
|
"log"
|
2024-08-15 10:12:58 +02:00
|
|
|
"os"
|
|
|
|
"path"
|
2024-09-03 14:04:09 +02:00
|
|
|
"strconv"
|
2024-08-15 10:12:58 +02:00
|
|
|
|
2024-08-15 12:49:36 +02:00
|
|
|
"git.defalsify.org/vise.git/cache"
|
|
|
|
"git.defalsify.org/vise.git/engine"
|
|
|
|
"git.defalsify.org/vise.git/persist"
|
2024-08-15 10:12:58 +02:00
|
|
|
"git.defalsify.org/vise.git/resource"
|
|
|
|
"git.defalsify.org/vise.git/state"
|
2024-08-26 14:53:07 +02:00
|
|
|
"git.grassecon.net/urdt/ussd/internal/handlers/ussd"
|
2024-08-15 10:12:58 +02:00
|
|
|
)
|
|
|
|
|
2024-08-15 12:49:36 +02:00
|
|
|
var (
|
|
|
|
scriptDir = path.Join("services", "registration")
|
|
|
|
)
|
|
|
|
|
2024-08-15 10:12:58 +02:00
|
|
|
func main() {
|
|
|
|
var dir string
|
|
|
|
var root string
|
|
|
|
var size uint
|
|
|
|
var sessionId string
|
|
|
|
flag.StringVar(&dir, "d", ".", "resource dir to read from")
|
|
|
|
flag.UintVar(&size, "s", 0, "max size of output")
|
2024-08-16 16:57:36 +02:00
|
|
|
flag.StringVar(&root, "root", "root", "entry point symbol")
|
2024-08-15 10:12:58 +02:00
|
|
|
flag.StringVar(&sessionId, "session-id", "default", "session id")
|
|
|
|
flag.Parse()
|
|
|
|
fmt.Fprintf(os.Stderr, "starting session at symbol '%s' using resource dir: %s\n", root, dir)
|
|
|
|
|
|
|
|
ctx := context.Background()
|
2024-08-28 09:12:08 +02:00
|
|
|
st := state.NewState(16)
|
2024-08-19 09:15:26 +02:00
|
|
|
st.UseDebug()
|
2024-09-02 20:06:42 +02:00
|
|
|
|
|
|
|
pfp := path.Join(scriptDir, "pp.csv")
|
2024-09-03 14:04:09 +02:00
|
|
|
file, err := os.Open(pfp)
|
2024-09-02 20:06:42 +02:00
|
|
|
if err != nil {
|
2024-09-03 14:04:09 +02:00
|
|
|
fmt.Fprintf(os.Stderr, "Failed to open CSV file: %v\n", err)
|
2024-09-02 20:06:42 +02:00
|
|
|
os.Exit(1)
|
|
|
|
}
|
2024-09-03 14:04:09 +02:00
|
|
|
defer file.Close()
|
|
|
|
reader := csv.NewReader(file)
|
2024-09-02 20:06:42 +02:00
|
|
|
|
2024-09-03 14:04:09 +02:00
|
|
|
// Iterate through the CSV records and register the flags
|
|
|
|
for {
|
|
|
|
record, err := reader.Read()
|
|
|
|
if err != nil {
|
|
|
|
if err == io.EOF {
|
|
|
|
break
|
|
|
|
}
|
|
|
|
fmt.Fprintf(os.Stderr, "Error reading CSV file: %v\n", err)
|
|
|
|
os.Exit(1)
|
|
|
|
}
|
2024-09-02 20:06:42 +02:00
|
|
|
|
2024-09-03 14:04:09 +02:00
|
|
|
// Ensure the record starts with "flag" and has at least 3 columns
|
|
|
|
if len(record) < 3 || record[0] != "flag" {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
|
|
|
flagName := record[1]
|
|
|
|
flagValue, err := strconv.Atoi(record[2])
|
2024-09-02 20:06:42 +02:00
|
|
|
if err != nil {
|
2024-09-03 14:04:09 +02:00
|
|
|
fmt.Fprintf(os.Stderr, "Failed to convert flag value %s to integer: %v\n", record[2], err)
|
2024-09-02 20:06:42 +02:00
|
|
|
continue
|
|
|
|
}
|
2024-09-03 14:04:09 +02:00
|
|
|
|
|
|
|
// Register the flag
|
2024-09-04 11:19:34 +02:00
|
|
|
log.Printf("Registering flagName:%s; flagValue:%v", flagName, flagValue)
|
2024-09-03 14:04:09 +02:00
|
|
|
state.FlagDebugger.Register(uint32(flagValue), flagName)
|
2024-09-02 20:06:42 +02:00
|
|
|
}
|
2024-08-19 09:59:20 +02:00
|
|
|
|
2024-08-15 12:49:36 +02:00
|
|
|
rfs := resource.NewFsResource(scriptDir)
|
|
|
|
ca := cache.NewCache()
|
|
|
|
cfg := engine.Config{
|
2024-08-16 16:57:36 +02:00
|
|
|
Root: "root",
|
2024-08-15 12:49:36 +02:00
|
|
|
SessionId: sessionId,
|
|
|
|
}
|
2024-08-15 10:12:58 +02:00
|
|
|
|
2024-08-15 12:49:36 +02:00
|
|
|
dp := path.Join(scriptDir, ".state")
|
2024-09-02 20:06:42 +02:00
|
|
|
err = os.MkdirAll(dp, 0700)
|
2024-08-15 10:12:58 +02:00
|
|
|
if err != nil {
|
2024-08-15 12:49:36 +02:00
|
|
|
fmt.Fprintf(os.Stderr, "state dir create exited with error: %v\n", err)
|
2024-08-15 10:12:58 +02:00
|
|
|
os.Exit(1)
|
|
|
|
}
|
2024-08-15 12:49:36 +02:00
|
|
|
pr := persist.NewFsPersister(dp)
|
|
|
|
en, err := engine.NewPersistedEngine(ctx, cfg, pr, rfs)
|
2024-08-21 20:37:29 +02:00
|
|
|
|
2024-08-15 12:49:36 +02:00
|
|
|
if err != nil {
|
|
|
|
pr = pr.WithContent(&st, ca)
|
|
|
|
err = pr.Save(cfg.SessionId)
|
2024-08-17 16:57:39 +02:00
|
|
|
if err != nil {
|
|
|
|
fmt.Fprintf(os.Stderr, "Failed to save state with error: %v\n", err)
|
|
|
|
}
|
2024-08-15 12:49:36 +02:00
|
|
|
en, err = engine.NewPersistedEngine(ctx, cfg, pr, rfs)
|
|
|
|
if err != nil {
|
|
|
|
fmt.Fprintf(os.Stderr, "engine create exited with error: %v\n", err)
|
|
|
|
os.Exit(1)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fp := path.Join(dp, sessionId)
|
2024-08-26 14:53:07 +02:00
|
|
|
|
2024-09-04 11:19:34 +02:00
|
|
|
ussdHandlers, err := ussd.NewHandlers(fp, &st, sessionId)
|
2024-08-31 09:21:20 +02:00
|
|
|
|
2024-09-02 15:05:13 +02:00
|
|
|
if err != nil {
|
2024-08-31 09:21:20 +02:00
|
|
|
fmt.Fprintf(os.Stderr, "handler setup failed with error: %v\n", err)
|
|
|
|
}
|
2024-08-26 14:53:07 +02:00
|
|
|
|
|
|
|
rfs.AddLocalFunc("select_language", ussdHandlers.SetLanguage)
|
|
|
|
rfs.AddLocalFunc("create_account", ussdHandlers.CreateAccount)
|
|
|
|
rfs.AddLocalFunc("save_pin", ussdHandlers.SavePin)
|
|
|
|
rfs.AddLocalFunc("verify_pin", ussdHandlers.VerifyPin)
|
|
|
|
rfs.AddLocalFunc("check_identifier", ussdHandlers.CheckIdentifier)
|
|
|
|
rfs.AddLocalFunc("check_account_status", ussdHandlers.CheckAccountStatus)
|
2024-08-30 10:15:08 +02:00
|
|
|
rfs.AddLocalFunc("authorize_account", ussdHandlers.Authorize)
|
2024-08-26 14:53:07 +02:00
|
|
|
rfs.AddLocalFunc("quit", ussdHandlers.Quit)
|
|
|
|
rfs.AddLocalFunc("check_balance", ussdHandlers.CheckBalance)
|
|
|
|
rfs.AddLocalFunc("validate_recipient", ussdHandlers.ValidateRecipient)
|
|
|
|
rfs.AddLocalFunc("transaction_reset", ussdHandlers.TransactionReset)
|
|
|
|
rfs.AddLocalFunc("max_amount", ussdHandlers.MaxAmount)
|
|
|
|
rfs.AddLocalFunc("validate_amount", ussdHandlers.ValidateAmount)
|
|
|
|
rfs.AddLocalFunc("reset_transaction_amount", ussdHandlers.ResetTransactionAmount)
|
|
|
|
rfs.AddLocalFunc("get_recipient", ussdHandlers.GetRecipient)
|
|
|
|
rfs.AddLocalFunc("get_sender", ussdHandlers.GetSender)
|
2024-08-28 13:11:20 +02:00
|
|
|
rfs.AddLocalFunc("get_amount", ussdHandlers.GetAmount)
|
2024-08-26 14:53:07 +02:00
|
|
|
rfs.AddLocalFunc("reset_incorrect", ussdHandlers.ResetIncorrectPin)
|
|
|
|
rfs.AddLocalFunc("save_firstname", ussdHandlers.SaveFirstname)
|
|
|
|
rfs.AddLocalFunc("save_familyname", ussdHandlers.SaveFamilyname)
|
|
|
|
rfs.AddLocalFunc("save_gender", ussdHandlers.SaveGender)
|
|
|
|
rfs.AddLocalFunc("save_location", ussdHandlers.SaveLocation)
|
|
|
|
rfs.AddLocalFunc("save_yob", ussdHandlers.SaveYob)
|
|
|
|
rfs.AddLocalFunc("save_offerings", ussdHandlers.SaveOfferings)
|
|
|
|
rfs.AddLocalFunc("quit_with_balance", ussdHandlers.QuitWithBalance)
|
2024-08-30 10:15:08 +02:00
|
|
|
rfs.AddLocalFunc("reset_account_authorized", ussdHandlers.ResetAccountAuthorized)
|
|
|
|
rfs.AddLocalFunc("reset_allow_update", ussdHandlers.ResetAllowUpdate)
|
2024-08-26 14:53:07 +02:00
|
|
|
rfs.AddLocalFunc("get_profile_info", ussdHandlers.GetProfileInfo)
|
|
|
|
rfs.AddLocalFunc("verify_yob", ussdHandlers.VerifyYob)
|
|
|
|
rfs.AddLocalFunc("reset_incorrect_date_format", ussdHandlers.ResetIncorrectYob)
|
2024-08-28 09:12:08 +02:00
|
|
|
rfs.AddLocalFunc("set_reset_single_edit", ussdHandlers.SetResetSingleEdit)
|
2024-08-28 13:11:20 +02:00
|
|
|
rfs.AddLocalFunc("initiate_transaction", ussdHandlers.InitiateTransaction)
|
2024-08-16 12:38:58 +02:00
|
|
|
|
2024-08-15 10:12:58 +02:00
|
|
|
cont, err := en.Init(ctx)
|
2024-08-21 20:37:29 +02:00
|
|
|
en.SetDebugger(engine.NewSimpleDebug(nil))
|
2024-08-15 10:12:58 +02:00
|
|
|
if err != nil {
|
|
|
|
fmt.Fprintf(os.Stderr, "engine init exited with error: %v\n", err)
|
|
|
|
os.Exit(1)
|
|
|
|
}
|
|
|
|
if !cont {
|
|
|
|
_, err = en.WriteResult(ctx, os.Stdout)
|
|
|
|
if err != nil {
|
|
|
|
fmt.Fprintf(os.Stderr, "dead init write error: %v\n", err)
|
|
|
|
os.Exit(1)
|
|
|
|
}
|
2024-08-15 12:49:36 +02:00
|
|
|
err = en.Finish()
|
|
|
|
if err != nil {
|
|
|
|
fmt.Fprintf(os.Stderr, "engine finish error: %v\n", err)
|
|
|
|
os.Exit(1)
|
|
|
|
}
|
2024-08-15 10:12:58 +02:00
|
|
|
os.Stdout.Write([]byte{0x0a})
|
|
|
|
os.Exit(0)
|
|
|
|
}
|
|
|
|
err = engine.Loop(ctx, en, os.Stdin, os.Stdout)
|
|
|
|
if err != nil {
|
|
|
|
fmt.Fprintf(os.Stderr, "loop exited with error: %v\n", err)
|
|
|
|
os.Exit(1)
|
|
|
|
}
|
|
|
|
}
|