Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sonufrienko/smart-parking
Smart Parking application by Sirin Software
https://github.com/sonufrienko/smart-parking
amplify appsync aws graphql iot parking react smart-city typescript
Last synced: 3 months ago
JSON representation
Smart Parking application by Sirin Software
- Host: GitHub
- URL: https://github.com/sonufrienko/smart-parking
- Owner: sonufrienko
- License: mit
- Created: 2019-07-24T07:39:27.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2023-01-04T05:14:08.000Z (about 2 years ago)
- Last Synced: 2024-11-01T00:40:56.314Z (3 months ago)
- Topics: amplify, appsync, aws, graphql, iot, parking, react, smart-city, typescript
- Language: TypeScript
- Homepage: https://sirinsoftware.com
- Size: 5.14 MB
- Stars: 18
- Watchers: 2
- Forks: 8
- Open Issues: 39
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Smart Parking
Cloud and Web dashboard for real-time visualization of parking slots.[Dashboard Demo](https://d1h3e1ucojuxt4.cloudfront.net/)
![](public/images/scr1.png)
![](public/images/scr4.png)
![](public/images/scr3.png)
## Serverless Architecture
![](public/images/aws-cloud-architecture.png)
Cloud
- AWS Amplify
- AWS AppSync (using multiple authorization types)
- AWS Cognito
- DynamoDB
- Lambda
- S3CI/CD
- GitHub Actions (CI)
- AWS Amplify Console (CD)Web app
- React
- TypeScript
- GraphQL
- AmplifyMobile app
- React Native## Features
- Authorization (Amplify React component, AWS Cognito)
- Show parking slots (GraphQL, AWS AppSync)
- Update slot status in real-time (GraphQL subscriptions, AWS AppSync)## Getting Started
```sh
# Install Amplify CLI globally
npm install -g @aws-amplify/cli
amplify configure# Install project and dependencies
git clone https://github.com/sonufrienko/smart-parking
cd smart-parking
npm i# Create a AWS CloudFormation stack
amplify init# Update the cloud resources (deployment)
amplify push# Build and publish both the backend and the front end
# Upload React app to the S3 hosting bucket
amplify publish
```Generate aws-exports.js
```sh
amplify init
# ? Do you want to use an existing environment? **Yes**
# ? Choose the environment you would like to use: **dev**
```Branches
- `master` - Production branch (protected). Used by Amplify Console for Continuous Deployment.
- `dev` - Development branch.Mocking and Testing
```sh
export AWS_REGION=us-west-2# Execute local Lambda function
amplify mock function listSlots# Start GraphQL server
amplify mock api
```## Request from LoRa Gateway
Request to change parking slot status:
- `APPSYNC-API-URL` - AppSync URL, example: https://xxx.appsync-api.us-west-2.amazonaws.com/graphql
- `APPSYNC-API-KEY` - Authorization by API Key
- `PARKING-ID` - Parking ID (string)
- `DEVICE-ID` - Device ID (number)
- `SLOT-STATUS` - Free - 0, Used - 1 (number)```
curl \
-XPOST https:///graphql \
-H "Content-Type:application/graphql" \
-H "x-api-key:" \
-d '{ "query": "mutation { updateSlot(input: { parkingID: \"\" device: slotStatus: }) { parkingID slotNumber slotStatus device }}" }'
```## Scripts
- `npm start` Runs the app in the development mode.
- `npm test` Launches the test runner in the interactive watch mode
- `npm run build` Builds the app for production to the `build` folder.
- `npm run eject` This command will remove the single build dependency from your project.