mirror of
https://github.com/onsonr/sonr.git
synced 2025-03-10 21:09:11 +00:00
* fix: correct HTTP error handling in gateway * refactor: migrate database and ORM to internal modules * feat: introduce taskfile build system for improved workflow management * refactor: update taskfiles to use relative paths * feat: add profile status field * refactor: move rendering logic to context package * fix: improve error handling in credentials retrieval * refactor: optimize HTTP request handling in Wasm environment * refactor: refactor config loading in motr command * chore: add process-compose for service management * chore: remove default task and update gum format command * fix: update project dependencies * refactor: improve code readability and maintainability * refactor: consolidate error handling components * refactor: update index handler to use new context package * refactor: consolidate database scripts and move to deploy directory * feat: Update flake.nix with development tools and environment configuration * fix: ignore flake.lock file * refactor: migrate build process to use taskfiles for improved modularity and maintainability * refactor: improve GatewayContext and reorganize handlers * refactor: Remove unused profile creation functions * (chore): templ generation * test: add test file for vaults.go * maintenance: remove defunct Discord server link * docs: update checks workflow documentation * test: remove obsolete vaults test file * refactor: move version bumping logic to release workflow
46 lines
1.1 KiB
Go
46 lines
1.1 KiB
Go
package context
|
|
|
|
import (
|
|
"github.com/onsonr/sonr/crypto/mpc"
|
|
"github.com/onsonr/sonr/pkg/common"
|
|
"lukechampine.com/blake3"
|
|
)
|
|
|
|
func (cc *GatewayContext) Spawn(handle, origin string) (*CreatePasskeyParams, error) {
|
|
challenge := GetAuthChallenge(cc)
|
|
sid := GetSessionID(cc)
|
|
nonce, err := calcNonce(sid)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
encl, err := mpc.GenEnclave(nonce)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
cc.stagedEnclaves[sid] = encl
|
|
common.WriteCookie(cc, common.SonrAddress, encl.Address())
|
|
return &CreatePasskeyParams{
|
|
Address: encl.Address(),
|
|
Handle: handle,
|
|
Name: origin,
|
|
Challenge: challenge,
|
|
CreationBlock: cc.StatusBlock(),
|
|
}, nil
|
|
}
|
|
|
|
// Uses blake3 to hash the sessionID to generate a nonce of length 12 bytes
|
|
func calcNonce(sessionID string) ([]byte, error) {
|
|
hash := blake3.New(32, nil)
|
|
_, err := hash.Write([]byte(sessionID))
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
// Read the hash into a byte slice
|
|
nonce := make([]byte, 12)
|
|
_, err = hash.Write(nonce)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return nonce, nil
|
|
}
|