Complete BZZZ functionality port to CHORUS
🎭 CHORUS now contains full BZZZ functionality adapted for containers Core systems ported: - P2P networking (libp2p with DHT and PubSub) - Task coordination (COOEE protocol) - HMMM collaborative reasoning - SHHH encryption and security - SLURP admin election system - UCXL content addressing - UCXI server integration - Hypercore logging system - Health monitoring and graceful shutdown - License validation with KACHING Container adaptations: - Environment variable configuration (no YAML files) - Container-optimized logging to stdout/stderr - Auto-generated agent IDs for container deployments - Docker-first architecture All proven BZZZ P2P protocols, AI integration, and collaboration features are now available in containerized form. Next: Build and test container deployment. 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
58
pkg/agentid/crypto.go
Normal file
58
pkg/agentid/crypto.go
Normal file
@@ -0,0 +1,58 @@
|
||||
package agentid
|
||||
|
||||
import (
|
||||
"bytes"
|
||||
"io"
|
||||
"strings"
|
||||
|
||||
"filippo.io/age"
|
||||
"filippo.io/age/armor"
|
||||
)
|
||||
|
||||
func EncryptPayload(payload []byte, publicKey string) ([]byte, error) {
|
||||
recipient, err := age.ParseX25519Recipient(publicKey)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
var buf bytes.Buffer
|
||||
// Optional: wrap with armor for ASCII output (can omit if binary preferred)
|
||||
w := armor.NewWriter(&buf)
|
||||
encryptor := age.NewEncryptor(w, recipient)
|
||||
_, err = encryptor.Write(payload)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
if err := encryptor.Close(); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
if err := w.Close(); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
return buf.Bytes(), nil
|
||||
}
|
||||
|
||||
|
||||
func DecryptPayload(ciphertext []byte, privateKey string) ([]byte, error) {
|
||||
identity, err := age.ParseX25519Identity(privateKey)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
// Support armored input:
|
||||
r := bytes.NewReader(ciphertext)
|
||||
decoder := armor.NewReader(r)
|
||||
|
||||
decryptor, err := age.Decrypt(decoder, identity)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
defer decryptor.Close()
|
||||
|
||||
plaintext, err := io.ReadAll(decryptor)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
return plaintext, nil
|
||||
}
|
||||
Reference in New Issue
Block a user