Skip to content

Sirowa warehouse sensor temperature and humidity data visualization logserver πŸ πŸ•ΉοΈπŸŒ‘οΈπŸ’§πŸ“ˆπŸš¨

Notifications You must be signed in to change notification settings

oskar-anderson/Tempsens

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

Tempsens

Sirowa warehouse sensor temperature and humidity data visualization logserver.

Preview image

Installation

Local

  1. Download/git clone the project
  2. Create .env file from .env_template file and adjust parameters
  3. Run composer install in root folder to generate dependencies and autoloading. If the command throws error 'Root composer.json requires PHP extension ext-soap ...' uncomment extension=soap attribute in the php.ini global PHP config file.
  4. Open terminal and cd site
  5. (if you have data files) Copy backupCSV folder to site/db and generate db with sample data php -r "require './db/Initializer.php'; App\db\Initializer::Initialize();". If the command throws a "Fatal error: Uncaught PDOException: could not find driver in ..." error, uncomment extension=pdo_mysql in php.ini.
  6. Start php server by running command php -S localhost:8080
  7. Open in browser http://127.0.0.1:8080

Possible errors:

  • No database access - Go into your php.ini file and uncomment extension=pdo_mysql

Docker

  1. Follow 1. and 2. step from local install
  2. Run docker-compose --env-file ../.env up -d in docker directory
  3. Install dependencies docker-compose exec tempsens-app composer install
  4. Open in browser http://127.0.0.1:8000

Dependencies

Server side

Client side

  • Reset CSS - Cross browser style inconsistency remover
  • Bootstrap Icons - Different icons (class tags bi bi-)
  • jQuery - Needed for jQuery UI
  • jQuery UI - Cross browser identical calendar/datepicker, kinda stupid for such a simple thing
  • bootstrap - HTML, CSS and JavaScript framework, Used components: collapsable, modal
  • Google Chart (charts/loader.js) - Drawing charts
  • Day.js (with plugins: customParseFormat) - date parsing, needed for chart data manipulation

Documentation

General documentation:

IT documentation - Temperature and Humidity Monitoring in the Baltic Warehouse [link]

API

Documentation for physical sensor API and Tempsens logserver API:
API Documentation

Database Schema

+------------------------------------+      +---------------------------------------------+                                                                                                              
|               Sensors              |      |               SensorReading                 |                                                                                                              
+--------------+---------------+-----+      +--------------+----------------+-------------+                                                                                                              
| id           | string!       | PK  |      | id           | string!        | PK          |                                                                                                              
| name         | string!       |     |1....*| sensor_id    | string!        | FK(sensors) |                                                                                                              
| serial       | string!       |     |      | temp         | decimal(18,1)! |             |                                                                                                              
| model        | string!       |     |      | rel_hum      | decimal(18,1)! |             |                                                                           
| ip           | string!       |     |      | date_recorded| string!        |             |                                                                           
| location     | string!       |     |      | date_added   | string?        |             |                                                                        
| is_portable  | bool!         |     |      +--------------+----------------+-------------+                                                                                                        
| min_temp     | decimal(18,1)!|     |                                                                                                              
| max_temp     | decimal(18,1)!|     |                                                                                                                                         
| min_rel_hum  | decimal(18,1)!|     |                                                                                                                                                           
| max_rel_hum  | decimal(18,1)!|     |                                                                                                              
| reading_inter| int!          |     |                                                                                                               
+--------------+---------------+-----+                                                                        

Date format is YYYYMMDDHHmm. This makes ordering SensorReadings by date easy (eg 13:42, 13.03.2021 becomes 202103131342)
DateAdded is null for not isPortable sensors.

Testing

Sample data for Database

Script site/db/Initializer.php generates new database tables and imports data from local CSV files. Modify the script to fit your needs then run php Initializer.php to execute the script.

Sample CSV data files are available on request [link]. Create directory site/db/backupCSV and place the data there.

Test web upload:

Sample CSV data files are available on request [link] to test portable sensor's sensor readings import functionality.

Test API

Api request endpoint and body is described in API.

Versioning

Versioning follows major.minor.patch three digit numbering:

  • major - Breaking database changes
  • minor - API changes or 5+ patch changes worth documenting
  • patch - Small tweaks

0.1.0

15.01.2020 by Indrek Hiie - Soap Data Collector

0.2.0

27.02.2020 by Timm Soodla - initial GUI version

0.3.0

30.12.2020 by Indrek Hiie - moved to PDO MySQL driver, sensors now in DB, more modular code and some bugfixes applied

0.3.4 (was used in production)

Preview image

0.3.5 (didn't reach production)

24.01.2021 - watchdog added

1.0.0

Preview image

Notes:

  • Remade database (removed: alarms, emails, emails_to_sensor, parms, portable and queue. Redesigned sensor and sensorReading)
  • Removed unnecessary values sent by sensors from being saved to sensorReading
  • Removed scripts/alarms.php - Email sending didn't work
  • Removed confusing alerts(global vs sensor) and Max/min(total vs sensor)
  • Removed ambiguous sensor state .png balls in v0.3.5
  • Removed unused Composer dependencies(php-jwt, Guzzle, oauth2-client, random_compaq, Phpmailer, http-message, getallHeaders, oauth-keycloak, Symfony)
  • Replaced Db generated int Ids with server-side 22 char base64 random generated ones
  • Added Db default data initialization script and migrations
  • Now all sensors are shown together and can be graphed together
  • Added relative humidity to overview and graph
  • Fixed bugs with selecting end date changing start date value
  • Added CRUD functionality to sensor
  • Added cache file for fast last sensor readings
  • Added options for chart drawing
  • Added option to export graph as screenshot
  • Added option to upload CSV data to portable sensors
  • Restructured code
  • Separated views and controllers, following MVC design
  • Added partial views
  • Created favicon
  • Used new PHP 8.0 and below features (function parameter and return types, named arguments, constructor property promotion)

Made with ❀️ by Karl Oskar Anderson

1.1.0

Notes:

  • Update UI - Sensor info (Alerts, Actions, Details) are organized into clickable nav element buttons
  • Change database table collation to binary. All field comparisons are now case-sensitive.
  • Remove dependency from existing database:
    • Update environment variable reading
    • Change database initializer to work with CSV files
  • Refactor code, increase readability
  • Fix a bug causing alert packing to result in a null pointer exception

Made with ❀️ by Karl Oskar Anderson

1.1.1

Preview image

Notes:

  • Used REST API for cleaner controllers
  • Minor UI tweaks to sensor alert view
  • Reduced memory usage
  • Removed cache file
  • Refactored project structure

1.1.2

Preview image

Notes:

  • Changed database table ID to UUIDv4 and time fields to ISO8601
  • Switched all times to UTC timezone to remove false alert due to daylight savings
  • Added support for missing readings alerts

About

Sirowa warehouse sensor temperature and humidity data visualization logserver πŸ πŸ•ΉοΈπŸŒ‘οΈπŸ’§πŸ“ˆπŸš¨

Topics

Resources

Stars

Watchers

Forks

Contributors 3

  •  
  •  
  •