Arbi_Yusuf_Ramanda

iot_data_generator.py

Oct 1st, 2025
84
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
Python 5.88 KB | Source Code | 0 0
  1. import pymongo
  2. import random
  3. import time
  4. from datetime import datetime
  5. import json
  6.  
  7. # Connection ke MongoDB
  8. client = pymongo.MongoClient("mongodb://iot_user:iot_password@localhost:27017/iot_db")
  9. db = client.iot_db
  10.  
  11. def generate_temperature_data(device_id):
  12.     """Generate data sensor suhu dan kelembaban"""
  13.     return {
  14.         'device_id': device_id,
  15.         'timestamp': datetime.utcnow(),
  16.         'sensor_type': 'temperature_humidity',
  17.         'data': {
  18.             'temperature': round(random.uniform(20.0, 35.0), 2),
  19.             'humidity': round(random.uniform(40.0, 80.0), 2),
  20.             'heat_index': round(random.uniform(25.0, 40.0), 2)
  21.         },
  22.         'location': 'Living Room',
  23.         'battery_level': random.randint(60, 100),
  24.         'signal_strength': random.randint(-80, -30)
  25.     }
  26.  
  27. def generate_motion_data(device_id):
  28.     """Generate data sensor gerak"""
  29.     return {
  30.         'device_id': device_id,
  31.         'timestamp': datetime.utcnow(),
  32.         'sensor_type': 'motion',
  33.         'data': {
  34.             'motion_detected': random.choice([True, False]),
  35.             'motion_intensity': random.randint(1, 10) if random.choice([True, False]) else 0
  36.         },
  37.         'location': 'Bedroom',
  38.         'battery_level': random.randint(70, 100),
  39.         'signal_strength': random.randint(-75, -35)
  40.     }
  41.  
  42. def generate_light_data(device_id):
  43.     """Generate data sensor cahaya"""
  44.     return {
  45.         'device_id': device_id,
  46.         'timestamp': datetime.utcnow(),
  47.         'sensor_type': 'light',
  48.         'data': {
  49.             'light_intensity': random.randint(0, 1000),
  50.             'uv_index': round(random.uniform(0, 11), 1)
  51.         },
  52.         'location': 'Garden',
  53.         'battery_level': random.randint(50, 100),
  54.         'signal_strength': random.randint(-70, -40)
  55.     }
  56.  
  57. def generate_soil_moisture_data(device_id):
  58.     """Generate data sensor soil moisture"""
  59.     return {
  60.         'device_id': device_id,
  61.         'timestamp': datetime.utcnow(),
  62.         'sensor_type': 'soil_moisture',
  63.         'data': {
  64.             'soil_moisture': random.randint(0, 100),
  65.             'soil_temperature': round(random.uniform(15.0, 30.0), 2),
  66.             'ph_level': round(random.uniform(5.5, 8.0), 2)
  67.         },
  68.         'location': 'Greenhouse',
  69.         'battery_level': random.randint(50, 100),
  70.         'signal_strength': random.randint(-80, -40)
  71.     }
  72.  
  73. def generate_air_quality_data(device_id):
  74.     """Generate data sensor kualitas udara"""
  75.     return {
  76.         'device_id': device_id,
  77.         'timestamp': datetime.utcnow(),
  78.         'sensor_type': 'air_quality',
  79.         'data': {
  80.             'pm2_5': random.randint(0, 500),
  81.             'pm10': random.randint(0, 500),
  82.             'co2_level': random.randint(400, 5000)
  83.         },
  84.         'location': 'Office',
  85.         'battery_level': random.randint(50, 100),
  86.         'signal_strength': random.randint(-75, -35)
  87.     }
  88.  
  89. def generate_alert(device_id, alert_type, message):
  90.     """Generate alert jika ada kondisi tertentu"""
  91.     return {
  92.         'device_id': device_id,
  93.         'timestamp': datetime.utcnow(),
  94.         'alert_type': alert_type,
  95.         'severity': random.choice(['low', 'medium', 'high']),
  96.         'message': message,
  97.         'acknowledged': False,
  98.         'created_at': datetime.utcnow()
  99.     }
  100.  
  101. def main():
  102.     print("Starting IoT Data Generator...")
  103.    
  104.     try:
  105.         while True:
  106.             # Generate data untuk setiap device
  107.             temp_data = generate_temperature_data('ESP32_001')
  108.             motion_data = generate_motion_data('ESP32_002')
  109.             light_data = generate_light_data('ESP32_003')
  110.             soil_data = generate_soil_moisture_data('ESP32_004')
  111.             air_data = generate_air_quality_data('ESP32_005')
  112.            
  113.             # Insert data ke MongoDB
  114.             db.sensor_data.insert_one(temp_data)
  115.             db.sensor_data.insert_one(motion_data)
  116.             db.sensor_data.insert_one(light_data)
  117.             db.sensor_data.insert_one(soil_data)
  118.             db.sensor_data.insert_one(air_data)
  119.            
  120.             # Generate alerts berdasarkan kondisi tertentu
  121.             if temp_data['data']['temperature'] > 30:
  122.                 alert = generate_alert('ESP32_001', 'high_temperature',
  123.                                      f"High temperature detected: {temp_data['data']['temperature']}°C")
  124.                 db.alerts.insert_one(alert)
  125.                
  126.             if motion_data['data']['motion_detected'] and motion_data['data']['motion_intensity'] > 7:
  127.                 alert = generate_alert('ESP32_002', 'motion_detected',
  128.                                      f"High motion intensity detected: {motion_data['data']['motion_intensity']}")
  129.                 db.alerts.insert_one(alert)
  130.                
  131.             if light_data['data']['light_intensity'] < 100:
  132.                 alert = generate_alert('ESP32_003', 'low_light',
  133.                                      f"Low light detected: {light_data['data']['light_intensity']} lux")
  134.                 db.alerts.insert_one(alert)
  135.  
  136.             if soil_data['data']['soil_moisture'] < 20:
  137.                 alert = generate_alert('ESP32_004', 'low_soil_moisture',
  138.                                      f"Soil moisture too low: {soil_data['data']['soil_moisture']}%")
  139.                 db.alerts.insert_one(alert)
  140.  
  141.             if air_data['data']['co2_level'] > 2000:
  142.                 alert = generate_alert('ESP32_005', 'high_co2',
  143.                                      f"High CO2 level detected: {air_data['data']['co2_level']} ppm")
  144.                 db.alerts.insert_one(alert)
  145.            
  146.             print(f"Data inserted at {datetime.now().strftime('%Y-%m-%d %H:%M:%S')}")
  147.             time.sleep(10)  # Generate data setiap 10 detik
  148.            
  149.     except KeyboardInterrupt:
  150.         print("\nData generator stopped.")
  151.     finally:
  152.         client.close()
  153.  
  154. if __name__ == "__main__":
  155.     main()
  156.  
Advertisement
Add Comment
Please, Sign In to add comment