74 lines
2 KiB
PHP
74 lines
2 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers\Api;
|
|
|
|
use App\Http\Controllers\Controller;
|
|
use App\Http\Requests\UpdateRecipientKeyRequest;
|
|
use App\Http\Resources\RecipientResource;
|
|
|
|
class RecipientKeyController extends Controller
|
|
{
|
|
protected $gnupg;
|
|
|
|
public function __construct()
|
|
{
|
|
$this->gnupg = new \gnupg();
|
|
}
|
|
|
|
public function update(UpdateRecipientKeyRequest $request, $id)
|
|
{
|
|
$recipient = user()->recipients()->findOrFail($id);
|
|
|
|
$info = $this->gnupg->import($request->key_data);
|
|
|
|
if (!$info || !$info['fingerprint']) {
|
|
return response('Key could not be imported', 404);
|
|
}
|
|
|
|
$recipient->update([
|
|
'should_encrypt' => true,
|
|
'fingerprint' => $info['fingerprint']
|
|
]);
|
|
|
|
return new RecipientResource($recipient->fresh());
|
|
}
|
|
|
|
public function destroy($id)
|
|
{
|
|
$recipient = user()->recipients()->findOrFail($id);
|
|
|
|
$key = $this->gnupg->keyinfo($recipient->fingerprint);
|
|
|
|
if (! isset($key[0]['uids'][0]['email'])) {
|
|
return response('Key could not be deleted', 404);
|
|
}
|
|
|
|
$recipientEmails = user()->verifiedRecipients()
|
|
->get()
|
|
->map(function ($item) {
|
|
return $item->email;
|
|
})
|
|
->toArray();
|
|
|
|
// Check that the user can delete the key.
|
|
if (in_array(strtolower($key[0]['uids'][0]['email']), $recipientEmails)) {
|
|
if (!$this->gnupg->deletekey($recipient->fingerprint)) {
|
|
return response('Key could not be deleted', 404);
|
|
}
|
|
}
|
|
|
|
// Remove the key from all user recipients using that same fingerprint.
|
|
user()
|
|
->recipients()
|
|
->get()
|
|
->where('fingerprint', $recipient->fingerprint)
|
|
->each(function ($recipient) {
|
|
$recipient->update([
|
|
'should_encrypt' => false,
|
|
'fingerprint' => null
|
|
]);
|
|
});
|
|
|
|
return response('', 204);
|
|
}
|
|
}
|