strukt/key

Cryptography

Installs: 92

Dependents: 0

Suggesters: 0

Security: 0

Stars: 0

Watchers: 1

Forks: 0

Open Issues: 0

pkg:composer/strukt/key

v1.1.0-alpha 2025-04-21 14:43 UTC

This package is auto-updated.

Last update: 2025-10-22 01:11:08 UTC


README

Installation

Composer

Create composer.json script with contents below then run composer update

{
    "require":{

        "strukt/key":"v1.1.0-alpha"
    },
    "minimum-stability":"dev"
}

Hashing

Bcrypt

$hash = bcry("p@55w0rd")->encode();
$success = bcry("p@55w0rd")->verify($hash);

Sha256 (Doubled)

$hash = sha256dbl('p@55w0rd');

Public & Private Keys

Auto generate keys

// $k = Strukt\Ssl\All::makeKeys();
$ks = ssl()->getKeys();
$ks->getPrivateKey()->getPem();//get Private Key
$ks->getPublicKey()->getPem();//get Public Key
$c = $ks->useCipher();
$enc = $c->encrypt("p@55w0rd");
$dec = $c->decrypt($enc);

Use existing key

You can generate your key via ssh-keygen if you wantta.

$file = "file:///home/churchill/.ssh/id_rsa"
// $k = Strukt\Ssl\All::keyPath($file)
$k = ssl($file);

Encrypt message with Public Key

$message = "Hi! My name is (what?)
My name is (who?)
My name is
Slim Shady
Hi! My name is (huh?)
My name is (what?)
My name is
Slim Shady";

$file = "file:///home/churchill/.ssh/id_rsa.pub"

// $p = new Strukt\Ssl\KeyPair();//No Private Key
// $p->setPublicKey($file);
// $p = keypair()->setPublicKey($file); //No Private Key
// $p = pubkey(local("strukt.pub")); //No Private Key
$p = pubkey($file);

// $enc = Strukt\Ssl\All::useKeys($p)->toSend($message);
$enc = ssl($p)->toSend($message);

Encrypt with password

// $p = new Strukt\Ssl\KeyPair($path, "p@55w0rd");
// $p->getPublicKey(); // Trigger public key extraction from private key
$p = keypair($path, "p@55w0rd");
$p->getPublicKey(); // Trigger public key extraction from private key

// $k = Strukt\Ssl\All::useKeys($p)
$k = ssl($p);

Certificate Signing Request (CSR)

Sign & verify certificate

$kpath = "file:///home/churchill/.ssh/id_rsa"
$cpath = "file:///home/churchill/.ssh/cacert.pem"

// $oCsr = Strukt\Ssl\All::keyPath($kpath)->withCert($cpath);
$oCsr = ssl($kpath)->withCert($cpath);
$cert = $oCsr->sign();
$success = $oCsr->verify($cert);

Note

For local keys in your project or project root. Example:

├── strukt     # Private Key
└── strukt.pub # Public Key

You can use helper local to localize your path to url:

$k = ssl(local("strukt"));
// $p = keypair()->setPublicKey(local("strukt.pub"));