1: 2: 3: 4: 5: 6: 7: 8: 9: 10: 11: 12: 13: 14: 15: 16: 17: 18: 19: 20: 21: 22: 23: 24: 25: 26: 27: 28: 29: 30: 31: 32: 33: 34: 35: 36: 37: 38: 39: 40: 41: 42: 43: 44: 45: 46: 47: 48: 49: 50: 51: 52: 53: 54: 55: 56: 57: 58: 59: 60: 61: 62: 63: 64: 65: 66: 67: 68: 69: 70: 71: 72: 73: 74: 75: 76: 77: 78: 79: 80: 81: 82: 83: 84: 85: 86: 87: 88: 89: 90: 91: 92: 93: 94: 95: 96: 97: 98: 99: 100: 101: 102: 103: 104: 105: 106: 107: 108: 109: 110: 111: 112: 113: 114: 115: 116: 117: 118: 119: 120: 121: 122: 123: 124: 125:
<?php
declare(strict_types=1);
namespace App\CloudModule\Model;
use Nette;
use Nette\Utils\ArrayHash;
class AwsManager {
use Nette\SmartObject;
private $path = '/etc/iqrf-daemon/certs/';
private $interfaceName = 'MqttMessagingAws';
public function createMqttInterface(ArrayHash $values) {
$paths = $this->createPaths();
$this->uploadCertsAndKey($values, $paths);
$interface = [
'Name' => $this->interfaceName,
'Enabled' => true,
'BrokerAddr' => 'ssl://' . $values['endpoint'] . ':8883',
'ClientId' => 'IqrfDpaMessaging1',
'Persistence' => 1,
'Qos' => 0,
'TopicRequest' => 'Iqrf/DpaRequest',
'TopicResponse' => 'Iqrf/DpaResponse',
'User' => '',
'Password' => '',
'EnabledSSL' => true,
'KeepAliveInterval' => 20,
'ConnectTimeout' => 5,
'MinReconnect' => 1,
'MaxReconnect' => 64,
'TrustStore' => $paths['caCert'],
'KeyStore' => $paths['cert'],
'PrivateKey' => $paths['key'],
'PrivateKeyPassword' => '',
'EnabledCipherSuites' => '',
'EnableServerCertAuth' => false
];
return ArrayHash::from($interface);
}
public function createBaseService() {
$baseService = [
'Name' => 'BaseServiceForMQTTAws',
'Messaging' => $this->interfaceName,
'Serializers' => ['JsonSerializer'],
'Properties' => ['AsyncDpaMessage' => true],
];
return ArrayHash::from($baseService);
}
public function createPaths() {
$timestamp = (new \DateTime())->format(\DateTime::ISO8601);
$path = $this->path . $timestamp;
$paths['caCert'] = $path . 'aws-ca.crt';
$paths['cert'] = $path . '-aws.crt';
$paths['key'] = $path . '-aws.key';
return $paths;
}
public function uploadCertsAndKey(ArrayHash $values, array $paths) {
$caCert = $values['caCert'];
$cert = $values['cert'];
$key = $values['key'];
if ($caCert->isOk()) {
$caCert->move($paths['caCert']);
}
if ($cert->isOk()) {
$cert->move($paths['cert']);
}
if ($key->isOk()) {
$key->move($paths['key']);
}
}
}