mirror of
https://github.com/logos-messaging/logos-chat.git
synced 2026-02-28 04:43:07 +00:00
45 lines
1.0 KiB
Nim
45 lines
1.0 KiB
Nim
|
|
import crypto/ecdh
|
|
import results
|
|
import strformat
|
|
import utils
|
|
|
|
export PublicKey, PrivateKey, loadPrivateKeyFromBytes, loadPublicKeyFromBytes
|
|
|
|
|
|
type
|
|
Identity* = object
|
|
name*: string
|
|
privateKey*: PrivateKey # TODO: protect key exposure
|
|
|
|
|
|
#################################################
|
|
# Constructors
|
|
#################################################
|
|
|
|
proc createIdentity*(name: string): Identity =
|
|
let privKey = createRandomKey().get()
|
|
result = Identity(name: name, privateKey: privKey)
|
|
|
|
|
|
#################################################
|
|
# Parameter Access
|
|
#################################################
|
|
|
|
proc getPubkey*(self: Identity): PublicKey =
|
|
result = self.privateKey.getPublicKey()
|
|
|
|
proc getAddr*(self: Identity): string =
|
|
result = get_addr(self.getPubKey())
|
|
|
|
proc getName*(self: Identity): string =
|
|
result = self.name
|
|
|
|
proc toHex(key: PublicKey): string =
|
|
bytesToHex(key.bytes())
|
|
|
|
proc `$`*(key: PublicKey): string =
|
|
let byteStr = toHex(key)
|
|
fmt"{byteStr[0..3]}..{byteStr[^4 .. ^1]}"
|
|
|