By default when using the -https flag with the Cloud C2 binary, a Let's Encrypt certificate will be used. In the case that you wish to provide a self-signed certificate, please note the following additional deployment details:
1) When generating the certificate, the Common Name must be the IP address or FQDN of the server. See this example:
Our self-signed certificate was generated like this: (192.168.0.119 is the IP address of the machine running the Hak5 Cloud C2 server)
openssl req -newkey rsa:2048 -x509 -sha256 -days 3650 -nodes -out cert.crt -keyout cert.key Country Name (2 letter code) [AU]:GB
State or Province Name (full name) [Some-State]:Manchester
Locality Name (eg, city) :Manchester
Organization Name (eg, company) [Internet Widgits Pty Ltd]:Hak5
Organizational Unit Name (eg, section) :Developers
Common Name (e.g. server FQDN or YOUR name) :192.168.0.119
Email Address :firstname.lastname@example.org
2) When provisioning the device, in addition to copying the device.config file to /etc/, the generated cert.crt must be appended to the cert.pem file in /etc/ssl/.
1) SCP the resulting cert.crt to your devices, in "/etc/ssl/certs"
2) SSH into your device
3) Execute "cd /etc/ssl"
4) Execute "cat certs/cert.crt >> cert.pem"
5) Reboot the device The device should now successfully check-in to the Hak5 Cloud C2
3) the command line arguments should be passed in the order -hostname, -https, -keyFile and -certFile
./c2_pro-linux-64 -hostname 192.168.0.119 -https -keyFile /var/hak5c2/cert.key -certFile /var/hak5c2/cert.crt