blah stupid ca

This commit is contained in:
newtbot 2023-12-26 02:30:35 +08:00
parent f0e2083e19
commit a5be62cc46
4 changed files with 97 additions and 3 deletions

1
.gitignore vendored
View File

@ -1,5 +1,6 @@
node_modules
.env
cert

View File

@ -7,8 +7,19 @@ connection_messages true #log client connect and disconnect
password_file /etc/mosquitto/passwd #speicyf path to password file
max_connections 5 #demo purpose
listener 8883 #port for tls
certfile /etc/letsencrypt/live/mqtt.teeseng.uk/cert.pem
cafile /etc/letsencrypt/live/mqtt.teeseng.uk/chain.pem
keyfile /etc/letsencrypt/live/mqtt.teeseng.uk/privkey.pem
certfile /home/mpuser/letsencrypt-copy/live/mqtt.teeseng.uk-0001/cert.pem
cafile /home/mpuser/letsencrypt-copy/live/mqtt.teeseng.uk-0001/fullchain.pem
keyfile /home/mpuser/letsencrypt-copy/live/mqtt.teeseng.uk-0001/privkey.pem
#mosquitt.conf
pid_file /run/mosquitto/mosquitto.pid
persistence true
persistence_location /var/lib/mosquitto/
log_type all
log_facility 5
log_dest file /var/log/mosquitto/mosquitto.log

View File

@ -0,0 +1,45 @@
const mqtt = require('mqtt');
const fs = require('fs');
const path = require('path')
require('dotenv').config({ path: path.resolve(__dirname, '../../.env') })
// Configuration
const brokerUrl = 'mqtt://mqtt.teeseng.uk';
const options = {
port: 8883, // MQTT broker port with TLS
username: process.env.MQTT_USER,
password: process.env.MQTT_PASS,
protocol: 'mqtts', // Use MQTT over TLS
key: fs.readFileSync(path.resolve(__dirname, '../../cert/privkey.pem')), // Private key for the client
cert: fs.readFileSync(path.resolve(__dirname, '../../cert/cert.pem')), // Client certificate
};
// Create MQTT client
const client = mqtt.connect(brokerUrl, options);
module.exports = client;
// Event handlers
client.on('connect', () => {
console.log('Connected to MQTT broker');
client.subscribe('your-topic'); // Subscribe to a topic
// Publish a message
client.publish('your-topic', 'Hello MQTT with TLS!', { qos: 1 }, (err) => {
if (err) {
console.error('Error publishing message:', err);
} else {
console.log('Message published');
}
client.end(); // Close the connection after publishing
});
});
client.on('message', (topic, message) => {
console.log(`Received message on topic ${topic}: ${message}`);
client.end(); // Close the connection after receiving a message
});
client.on('error', (err) => {
console.error('Error:', err);
client.end(); // Close the connection in case of an error
});

View File

@ -0,0 +1,37 @@
const mqtt = require('mqtt');
const fs = require('fs');
const path = require('path')
require('dotenv').config({ path: path.resolve(__dirname, '../../.env') })
// Configuration
const brokerUrl = 'mqtt://mqtt.teeseng.uk';
const options = {
port: 8883, // MQTT broker port with TLS
username: process.env.MQTT_USER,
password: process.env.MQTT_PASS,
protocol: 'mqtts', // Use MQTT over TLS
key: fs.readFileSync(path.resolve(__dirname, '../../cert/privkey.pem')), // Private key for the client
cert: fs.readFileSync(path.resolve(__dirname, '../../cert/cert.pem')), // Client certificate
};
// Create MQTT client
const client = mqtt.connect(brokerUrl, options);
module.exports = client;
// Event handlers
client.on('connect', () => {
console.log('Connected to MQTT broker');
client.subscribe('your-topic'); // Subscribe to a topic
});
client.on('message', (topic, message) => {
console.log(`Received message on topic ${topic}: ${message}`);
// Additional processing for received message
});
client.on('error', (err) => {
console.error('Error:', err);
client.end(); // Close the connection in case of an error
});