NucuCar is a .Net Core IoT application for environment monitoring and home automation powered by Raspberry Pi.
Find a file
2020-11-23 21:24:01 +02:00
.circleci Add circle ci config file 2019-12-24 00:41:59 +02:00
Docs Update readme & add fritzing diagram 2019-12-05 18:55:05 +02:00
NucuCar.Domain NUC-4: Fix unhandled InvalidJson exception in Firestore publisher. 2020-10-25 15:24:34 +02:00
NucuCar.Sensors Update Bme680 and HeartbeatSensor.cs ids. 2020-11-23 21:24:01 +02:00
NucuCar.Telemetry Update Readme & directory structure. 2020-11-23 20:41:55 +02:00
NucuCar.TestClient Update Readme & directory structure. 2020-11-23 20:41:55 +02:00
NucuCar.UnitTests Update Readme & directory structure. 2020-11-23 20:41:55 +02:00
NucuHub.Android NUC-11: Finishing implementing Environment Sensor activity. 2020-11-22 21:47:32 +02:00
.editorconfig Turn NucuCar.TestClient into a command line client 2019-11-17 16:33:24 +02:00
.gitignore Update .gitignore 2020-10-31 16:58:02 +02:00
docker-compose.yml Add newline to docker-compose.yml 2020-08-09 12:51:19 +03:00
LICENSE Create LICENSE 2020-02-02 16:22:21 +02:00
NucuCar.sln Update Readme & directory structure. 2020-11-23 20:41:55 +02:00
NucuCar.sln.DotSettings Add Grpc word to dictionary 2020-08-01 16:37:22 +03:00
Readme.md Update Readme & directory structure. 2020-11-23 20:41:55 +02:00

Introduction (WIP)

An attempt to create a remote weather station hub on the Raspberry Pi.

The repository consists on several modules written in C# and an Android application written in Java.

Communication between the Raspberry and the Android application is done via gRPC.

The project is still undergoing development and it's not production ready.

CircleCI

Architecture

TBD

Installing and Developing

Requirements

To build this project you will need to install .Net Core 3.1 and Android Studio.

To run this project on the Raspberry Pi you will need dotnet core 3.1. installed.

Building

The following script provides instructions on how to build the whole project and deploy the NucuCar.Sensors module on the Raspberry Pi.

Manual

// Build project
dotnet build --runtime linux-arm -p:PublishSingleFile=true --configuration Release

// Navigate to desired project directory, for example NucuCar.Sensors.
cd NucuCar.Sensors

// Create .tar
tar -zcvf nh.tar.gz .\bin\Release\netcoreapp3.1\linux-arm\*

// Copy onto pi (replace with your ip, user)
sftp pi@192.168.0.100
sftp> put nh.tar.gz
sftp> exit

// SSH into pi
ssh pi@192.168.0.100

// Extract the archive and cd into it
tar -zxvf nh.tar.gz
cd bin/Release/netcoreapp3.1/linux-arm/

// Grant execution permissions
chmod +x NucuCar.Sensors

// Run the program
./NucuCar.Sensors

Docker-Compose

To run the project you can take advantage of docker-compsose and run it with the following commands:

git clone https://github.com/dnutiu/NucuCar.git
cd NucuCar
docker-compose up

(This is not recommended as the performance will take a significant hit.)

Directory Structure Overview

NucuHub.Android

Holds the Android application.

We are currently targeting Android API 29+.

NucuCar.Domain

Holds common classes and interfaces that are required by the projects, provides all the types that are generated via protocol buffers and some utility classes.

NucuCar.Telemetry

Holds concrete implementation for telemetry publishers and workers. The Telemetry project can be used by other projects such as NucuCar.Sensors to send telemetry into the cloud.

This project is not deployed.

NucuCar.Sensors

Manages all the sensors. For more info see the readme file located in the project directory.

This module is runnable and is deployed on the Raspberry Pi.

NucuCar.TestClient

Command line utility to play around with the car functionality. You can use it to remotely read data from the sensors via gRPC methods and to publish and read telemetry data.

Docs

Holds project resources and documentation.