Technologies used : Google Cloud AMD instance , MongoDB with google cloud , Node.js , Express.js , React.js , React-router-dom , JWT , Bcrypt , React-Leaflet
Made a user schema for this. Made extra restriction on the basis of
- If name ,email , password or phone is missing
- If password is not the same as confirm Password field
Data is stored in the user schema. Address is taken from the user to provide the latitude and longitude for our further api calls. The more accurate the address is the more accurate the location is.
Check the password with respect to the email provided. Made extra restriction on the basis of
- If name ,email is missing
In both signup and login , useNavigate() from react-router-dom is taken
Guest Login : If the user is not signed in the profile feature would not be available to him. Also if you are guest it will show signup to access when you access resource in home. You can check the optimal crops in your region.
As a logged in user you can check the optimal crops and also assess which crops should you grow and the methods for it. When a user registers for the first time , the polygon boundary is set in the polygon model.
If a user is first in that polygon boundary the user becomes the parent user with the polygon boundaries and the polygon is uniquely identified with the help of an id which is implemented with email and useId hook in react. However if a user is present inside a polygon already created he gets assigned that same id which groups the farmers under one polygon. The key idea is the soil temperature is almost constant across a small polygon which will make our data more reliable and foster relevant advices through the medium of farmers phone.
A person will be able to navigate to different pages using react-router-dom. A person will be able to navigate to his own profile using this. Logout , login feature implemented. Local storage added so as to store the data when a user reloads.
The weather data will be available to both guests and the logged in users.
The farmer will be able to see all the farmers in the polygon. And on the popup of the map the person navigates to the profile. This is implemented with the help of react-leaflet and also using useNavigate from react-router-dom.
In order to incentivize the farmers to input what crops they are growing , the crop button are only visible after filling the form in the profile. After filling the form in the profile the user will be able to see what crops the farmers in their polygon are growing and suitably grow their crops and assess market needs.
This is implemented using the cropsSchema in order to obtain the form data. In the profile , friends feature is implemented which will be explained in the profile paragraph. If a user is friend then they will be able to see their phone number. In order to reduce the loading time , hashing is done using the email key as it is unique.
The farmer will be able to see the stores nearby which is done using an api call. The parameters which were used in the api call is latitude and longitude. The map is shown using react-leaflet and openStreet Map. This will help the farmers to assess how far the stores are. Also the farmers will be able to see which agricultural supplies to buy from.
Name , email ,phone of the current user is visible. If a user is friend then the user will be able to see their phone number. The friends feature is implemented using the friendsSchema in mongoDB. A form is done to incentivize the farmers as mentioned above. The friends feature include:
- People around you (Querying the database to find the users on basis of polygon id)
- Notifications (If a person sends you a friend request)
- Friends (This includes the friends made) The basic feature of implementing friends is to secure the farmers data and to show phone number of each other if they are friend.
If a user navigates to other profile either from friends or from map in local crops. A user will be able to see the phone only if the user is a friend. To speed up we have used hashing of the friends email.