Replaced legacy `*.orly` module imports with `next.orly.dev/pkg` paths across the codebase for consistency. Removed legacy `go.mod` files from sub-packages, consolidating dependency management. Added Dockerfiles and configurations for benchmarking environments.
41 lines
786 B
Go
41 lines
786 B
Go
//go:build cgo
|
|
|
|
package p256k
|
|
|
|
import (
|
|
"lol.mleku.dev/chk"
|
|
"next.orly.dev/pkg/encoders/hex"
|
|
"next.orly.dev/pkg/interfaces/signer"
|
|
)
|
|
|
|
func NewSecFromHex[V []byte | string](skh V) (sign signer.I, err error) {
|
|
sk := make([]byte, len(skh)/2)
|
|
if _, err = hex.DecBytes(sk, []byte(skh)); chk.E(err) {
|
|
return
|
|
}
|
|
sign = &Signer{}
|
|
if err = sign.InitSec(sk); chk.E(err) {
|
|
return
|
|
}
|
|
return
|
|
}
|
|
|
|
func NewPubFromHex[V []byte | string](pkh V) (sign signer.I, err error) {
|
|
pk := make([]byte, len(pkh)/2)
|
|
if _, err = hex.DecBytes(pk, []byte(pkh)); chk.E(err) {
|
|
return
|
|
}
|
|
sign = &Signer{}
|
|
if err = sign.InitPub(pk); chk.E(err) {
|
|
return
|
|
}
|
|
return
|
|
}
|
|
|
|
func HexToBin(hexStr string) (b []byte, err error) {
|
|
if b, err = hex.DecAppend(b, []byte(hexStr)); chk.E(err) {
|
|
return
|
|
}
|
|
return
|
|
}
|