2024-10-23 22:01:10 +02:00
|
|
|
package lookup
|
|
|
|
|
|
|
|
import (
|
2024-11-02 16:38:23 +01:00
|
|
|
"context"
|
|
|
|
|
2024-11-03 01:34:28 +01:00
|
|
|
"git.defalsify.org/vise.git/db"
|
|
|
|
"git.defalsify.org/vise.git/logging"
|
2024-11-02 16:38:23 +01:00
|
|
|
"git.grassecon.net/urdt/ussd/common"
|
2024-10-23 22:01:10 +02:00
|
|
|
)
|
|
|
|
|
2024-11-03 01:34:28 +01:00
|
|
|
var (
|
|
|
|
logg = logging.NewVanilla().WithDomain("term-lookup")
|
|
|
|
)
|
|
|
|
|
2024-11-02 16:38:23 +01:00
|
|
|
type Identity struct {
|
|
|
|
NormalAddress string
|
|
|
|
ChecksumAddress string
|
|
|
|
SessionId string
|
|
|
|
}
|
|
|
|
|
2024-11-02 17:08:05 +01:00
|
|
|
func IdentityFromAddress(ctx context.Context, store *common.UserDataStore, address string) (Identity, error) {
|
2024-11-02 16:38:23 +01:00
|
|
|
var err error
|
|
|
|
var ident Identity
|
|
|
|
|
|
|
|
ident.ChecksumAddress = address
|
|
|
|
ident.NormalAddress, err = common.NormalizeHex(ident.ChecksumAddress)
|
|
|
|
if err != nil {
|
|
|
|
return ident, err
|
|
|
|
}
|
|
|
|
ident.SessionId, err = getSessionIdByAddress(ctx, store, ident.NormalAddress)
|
|
|
|
if err != nil {
|
|
|
|
return ident, err
|
|
|
|
}
|
|
|
|
return ident, nil
|
|
|
|
}
|
|
|
|
|
2024-11-02 17:08:05 +01:00
|
|
|
func getSessionIdByAddress(ctx context.Context, store *common.UserDataStore, address string) (string, error) {
|
2024-11-03 01:34:28 +01:00
|
|
|
logg.Debugf("fooar")
|
|
|
|
// TODO: replace with userdatastore when double sessionid issue fixed
|
|
|
|
//r, err := store.ReadEntry(ctx, address, common.DATA_PUBLIC_KEY_REVERSE)
|
|
|
|
store.Db.SetPrefix(db.DATATYPE_USERDATA)
|
|
|
|
store.Db.SetSession(address)
|
|
|
|
r, err := store.Db.Get(ctx, common.PackKey(common.DATA_PUBLIC_KEY_REVERSE, []byte{}))
|
2024-11-02 16:38:23 +01:00
|
|
|
if err != nil {
|
|
|
|
return "", err
|
|
|
|
}
|
|
|
|
return string(r), nil
|
2024-10-23 22:01:10 +02:00
|
|
|
}
|