first commit

This commit is contained in:
kicap1992
2022-08-10 22:03:16 +08:00
commit 9ea6fc9802
7 changed files with 3450 additions and 0 deletions

5
.env Normal file
View File

@ -0,0 +1,5 @@
PORT = 3004
# DB_CONNECTION = mongodb://localhost:27017/gempa_db
DB_CONNECTION = mongodb+srv://user1:user1456@mycluster.1zth1.mongodb.net/gempa_db?retryWrites=true&w=majority
# HOST_URL = http://localhost:3004
HOST_URL = https://tanah-longosor-be.herokuapp.com/

2
.gitignore vendored Normal file
View File

@ -0,0 +1,2 @@
# ignore node
/node_modules

108
index.js Normal file
View File

@ -0,0 +1,108 @@
const express = require('express');
const app = express();
const mongoose = require('mongoose');
require('dotenv/config');
const formData = require('express-form-data');
const cors = require('cors')
const http = require('http');
const server = http.createServer(app);
const { Server } = require("socket.io");
const io = new Server(server);
// const io = require("socket.io")(server, {
// cors: {
// origin: "https://192.168.43.125",
// methods: ["GET", "POST"],
// // allowedHeaders: ["my-custom-header"],
// // credentials: true
// }
// });
let users = {};
app.use(express.json());
app.use(express.urlencoded({ extended: true }));
app.use(formData.parse());
app.options('*', cors())
app.use(cors())
mongoose.connect(process.env.DB_CONNECTION, { useNewUrlParser: true, useUnifiedTopology: true, family: 4, })
let db = mongoose.connection;
db.on('error', console.error.bind(console, 'connection error:'));
db.once('open', function () {
console.log("Connected to db")
})
// import routes
const from_esp32_routes = require('./routes/from_esp32_routes');
// routes
app.use('/api/from_esp32', from_esp32_routes)
app.get('/', (req, res) => {
const id = req.query.id;
console.log(id);
console.log("ada pengambilan data")
res.send('ii dia pyan fdssfsd ');
})
app.get('/ambil_data_1', (req, res) => {
res.send('ini ambil data 1');
})
const port = process.env.PORT || 3001;
io.on('connection', (socket) => {
let userId = socket.id;
if (!users[userId]) users[userId] = [];
users[userId].push(socket.id);
console.log('socket connected', userId);
socket.on('reload_calibation', (_) => {
socket.broadcast.emit('reload_calibation', {
message: 'reload_calibation'
});
})
socket.on('new_device', (_) => {
socket.broadcast.emit('new_device', {
message: _.id
});
})
socket.on('hehe', (_) => {
socket.broadcast.emit('hehe', {
_
});
})
socket.on('notif_to_phone', (_) => {
// console.log(_ , " ini sebelum broadcast")
socket.broadcast.emit('notif_to_phone', {
message: _.message,
id: _.id,
status : _.status,
lat: _.lat,
lng : _.lng
});
})
socket.on('disconnect', (_) => {
console.log('user disconnected');
console.log(_)
});
});
server.listen(port, () => {
console.log(`Server running on port ${port}`);
})

68
models/device_model.js Normal file
View File

@ -0,0 +1,68 @@
const mongoose = require('mongoose');
const deviceSchema = new mongoose.Schema(
{
_id : {
type : String,
required : true,
maxLength : 12,
},
lat:{
type : String
},
lng:{
type : String
},
status : {
type : String,
// required : true,
},
created_at : {
type : Date,
default : Date.now,
},
updated_at : {
type : Date,
default : Date.now,
}
}
)
const newDeviceSchema = new mongoose.Schema(
{
_id : {
type : String,
required : true,
},
lat:{
type : String
},
lng:{
type : String
},
status: {
type : String,
default : 'Pending',
}
}
)
const notificationSchema = new mongoose.Schema(
{
_id : {
type : String,
required : true,
},
status: {
type : String,
required : true,
}
}
)
const deviceModel = mongoose.model('device', deviceSchema, 'device');
const newDeviceModel = mongoose.model('new_device', newDeviceSchema, 'new_device');
const notificationModel = mongoose.model('notification', notificationSchema, 'notification');
module.exports = {deviceModel , newDeviceModel, notificationModel};

2965
package-lock.json generated Normal file

File diff suppressed because it is too large Load Diff

22
package.json Normal file
View File

@ -0,0 +1,22 @@
{
"name": "tanah_longsor_server",
"version": "1.0.0",
"description": "Tanah Longsor Server",
"main": "index.js",
"scripts": {
"dev": "nodemon index.js",
"test": "echo \"Error: no test specified\" && exit 1"
},
"author": "kicap karan",
"license": "ISC",
"dependencies": {
"cors": "^2.8.5",
"dotenv": "^16.0.1",
"express": "^4.18.1",
"express-form-data": "^2.0.18",
"mongoose": "^6.4.6",
"nodemon": "^2.0.19",
"socket.io": "^4.4.1",
"socket.io-client": "^4.4.1"
}
}

280
routes/from_esp32_routes.js Normal file
View File

@ -0,0 +1,280 @@
const express = require('express');
const router = express.Router();
require('dotenv/config');
const { deviceModel, newDeviceModel, notificationModel } = require('../models/device_model');
const io_sock = require("socket.io-client");
const socket = io_sock(`${process.env.HOST_URL}/`);
async function update_device_data(device_id, lat, lng, status) {
// console.log(device_id)
function send_notif(message, id, status, lat, lng) {
// console.log(lat, "ini lat");
// console.log(lng , "ini lng");
socket.emit('notif_to_phone', {
message: message,
id: id,
status: status,
lat: lat,
lng: lng
})
}
const device = await deviceModel.findOne({ _id: device_id });
let statusnya, message;
if (lat != '' && lng != '') {
let cek_lng = parseFloat(device_id.lng) - parseFloat(lng);
let cek_lat = parseFloat(device_id.lat) - parseFloat(lat);
// change cek_lng and cek_lat to positive value
cek_lng = Math.abs(cek_lng);
cek_lat = Math.abs(cek_lat);
// console.log(status, "ini status");
if (status > 100) {
statusnya = "Danger";
message = "Bahaya tanah longsor, berhati-hati lewati jalur yang berdekatan dengan titik lokasi";
}
else if (cek_lng > 0.0007 && cek_lat > 0.0007 && status > 100) {
statusnya = "Danger Area";
message = "Bahaya tanah longsor berdekatan dengan titik lokasi";
}
else if (cek_lng > 0.0007 && cek_lat > 0.0007) {
statusnya = "Danger Area";
message = "Bahaya tanah longsor berdekatan dengan titik lokasi";
}
else if (status > 80) {
statusnya = "Warning";
message = "Amaran tanah longsor, berhati-hati lewati jalur yang berdekatan dengan titik lokasi";
} else {
statusnya = "Normal";
message = "ini normal";
}
} else {
// if (status > 100) {
// statusnya = "Danger";
// message = "Bahaya tanah longsor, berhati-hati lewati jalur yang berdekatan dengan titik lokasi";
// }
// else
if (status > 80) {
statusnya = "Warning";
message = "Amaran tanah longsor, berhati-hati lewati jalur yang berdekatan dengan titik lokasi";
} else {
statusnya = "Normal";
message = "ini normal";
}
}
cek_data_notif = await notificationModel.findOne({ device_id: device_id });
if (!cek_data_notif) {
// insert data notification
if (statusnya != "Normal") {
send_notif(message, device_id.id, statusnya, device_id.lat, device_id.lng);
// console.log(message);
}
const new_notif = new notificationModel({
_id: device_id,
status: statusnya,
})
await new_notif.save();
} else {
if (cek_data_notif.status != statusnya) {
// update data notification
await notificationModel.updateOne({ id: device_id.id }, { status: statusnya });
if (statusnya != "Normal") {
send_notif(message, device_id.id, statusnya, device_id.lat, device_id.lng);
// console.log(message);
} else {
socket.emit('notif_to_phone', {
message: '',
id: device_id.id,
status: statusnya,
lat: device_id.lat,
lng: device_id.lng
})
}
}
}
const current_time = new Date();
device.updated_at = current_time;
device.status = statusnya
await device.save();
// console.log(status, "ini status");
// console.log(device, " ini device");
return device;
}
router.post('/', async (req, res) => {
try {
const { id, latitude, longitude, soilMoistureValue } = req.body;
// console.log(req.body , "ini req.body");
// res.status(200).send({ status: 0, message: "Success" , id: id , derajat: derajat , jarak: jarak , lembab: lembab });
// check if device id exist
const cek_device_db = await deviceModel.findOne({ _id: id });
if (!cek_device_db) {
// insert data to newDeviceModel
const cek_new_device_db = await newDeviceModel.findOne({ _id: id });
if (!cek_new_device_db) {
const device_baru = new newDeviceModel({
_id: id,
lat: latitude,
lng: longitude,
status: "Waiting Calibration",
});
await device_baru.save();
socket.emit("new_device", { id: id });
} else {
if (cek_new_device_db.status != "Waiting Calibration") {
socket.emit("new_device", { id: id });
}
await newDeviceModel.updateOne({ _id: id }, { $set: { lat: latitude, lng: longitude, status: "Waiting Calibration", } });
}
return res.status(200).send({ status: 'new device detected, need calibration', message: "Success" });
} else {
// console.log("di sini dia");
if (cek_device_db.status === 'calibration') {
// console.log("sini calibrate")
const lat = latitude;
const lng = longitude;
if (lat != '' && lng != '') {
// update device data
await deviceModel.findOneAndUpdate({ _id: id }, { $set: { lat: latitude, lng: longitude } });
await update_device_data(cek_device_db, lat, lng, soilMoistureValue);
socket.emit('reload_calibation');
return res.status(200).send({ status: 'calibration right', message: "Success" });
} else {
// if (check_device_db.lat != '' && check_device_db.lng != '') {
return res.status(200).send({ status: 'calibration wrong', message: "Success" });
}
} else {
// console.log("sini normal dia lagi")
// check curren time and last update time if it's more than 12 hours
const current_time = new Date();
const last_update_time = cek_device_db.updated_at;
const diff_time = current_time.getTime() - last_update_time.getTime();
const diff_hours = diff_time / (1000 * 3600);
if (diff_hours > 12) {
// console.log("sini dia lagi 3");
// cross check if the data is same as last update
if (longitude != "" && latitude != "") {
let cek_lng = parseFloat(cek_device_db.lng) - parseFloat(longitude);
let cek_lat = parseFloat(cek_device_db.lat) - parseFloat(latitude);
cek_lng = Math.abs(cek_lng);
cek_lat = Math.abs(cek_lat);
if (cek_lng > 0.0007 && cek_lat > 0.0007) {
// update last update time
// update status
const current_time = new Date();
cek_device_db.lat = '';
cek_device_db.lng = '';
cek_device_db.status = "calibration";
// cek_device_db.created_at = current_time;
// cek_device_db.updated_at = current_time;
await cek_device_db.save();
return res.status(200).send({ status: 'device data changed, need calibration', message: "Success" });
} else {
const datanya = await update_device_data(cek_device_db, latitude, longitude, soilMoistureValue);
return res.status(200).send({ status: 'device data updated', message: "Success", data: datanya });
}
} else {
const datanya = await update_device_data(cek_device_db, latitude, longitude, soilMoistureValue);
return res.status(200).send({ status: 'device data updated', message: "Success", data: datanya });
}
} else {
const datanya = await update_device_data(cek_device_db, latitude, longitude, soilMoistureValue);
return res.status(200).send({ status: 'device data updated', message: "Success", data: datanya });
}
}
}
} catch (error) {
console.log(error);
res.status(500).send({ status: 2, message: error })
}
})
router.post('/calibration', async (req, res) => {
try {
const id = req.body.id;
console.log(id);
if (!id) return res.status(400).send({ status: 2, message: "id is required" });
// check if device id exist
const cek_device_db = await deviceModel.findOne({ _id: id });
if (!cek_device_db) {
// insert new device
const new_device = new deviceModel({
_id: id,
lat: '',
lng: '',
status: "calibration",
})
await new_device.save();
} else {
// update status
const current_time = new Date();
cek_device_db.lat = '';
cek_device_db.lng = '';
cek_device_db.status = "calibration";
cek_device_db.created_at = current_time;
cek_device_db.updated_at = current_time;
await cek_device_db.save();
}
await newDeviceModel.deleteOne({ _id: id });
res.status(200).send({ status: 0, message: "Success" });
} catch (error) {
console.log(error);
res.status(500).send({ status: 2, message: err })
}
})
router.post('/calibrate_map', async (req, res) => {
const id = req.query.id;
const lat = -4.007484879014992; //-4.007484879014992, 119.62836226144522
const lng = 119.62836226144522;
const update_device_db = await deviceModel.findOneAndUpdate({ _id: id }, { $set: { lat: lat, lng: lng } });
const cek_device_db = await deviceModel.findOne({ _id: id });
const datanya = await update_device_data(cek_device_db, '', '', 0);
res.status(200).send({ status: 0, message: "Success", datanya: datanya });
})
router.get('/device_list', async (req, res) => {
const device_list = await deviceModel.find({});
res.status(200).send({ status: true, message: "success", data: device_list });
})
router.get('/device_baru', async (req, res) => {
const device_list = await newDeviceModel.find({});
res.status(200).send({ status: true, message: "success", data: device_list });
})
router.get('/hehe', async (req, res) => {
socket.emit("hehe", { id: "123" });
res.status(200).send("hahah");
})
module.exports = router;