Compare commits

...

2 commits

Author SHA1 Message Date
0c7f0f4ca4 added update to user 2024-01-09 11:22:53 +02:00
2c00caa023 adding a single user GET 2024-01-09 11:17:01 +02:00
4 changed files with 58 additions and 12 deletions

View file

@ -12,7 +12,6 @@ update, delete, and be reminded of events with additional advanced features.
- location
- The User will be abale to create/update a new event
- The User will be able to login/out
- The User can `Attend`/`UnAttend` to an event
- The Anonymous User will be able to create a new user
- Event:
@ -25,9 +24,7 @@ update, delete, and be reminded of events with additional advanced features.
# Backend-reminder
- The Users will be able to be reminded of upcoming events.
- The backend will Send reminders 30 minutes before the event's scheduled time.
- The backend will Send reminders 30 minutes before the event's scheduled time based on there location and the event location.
@ -49,10 +46,9 @@ update, delete, and be reminded of events with additional advanced features.
- DueDate (string, required)
- User_id (string, required, foreign key)
- User Event Association (Many to Many)
- User_id (string, required, foreign key)
- Event_id (Integer, required, foreign key)
- Notifiyed Made (bool, default: false)
- User Event Association (Many to Many) - this table will hold the notifyed users to the event
- User_id (string, required, foreign key, primary key)
- Event_id (Integer, required, foreign key, primary key)
# API EndPoints
@ -62,9 +58,19 @@ update, delete, and be reminded of events with additional advanced features.
- PUT /events/{id} - update an event (Auth + authorized)
- DELETE /events/{id} - (Soft)delete an event (Auth + authorized)
- GET /user - returns all users
- GET /user/{id} - returns a single user
- POST /user - create a new user
- PUT /user/{id} - update an user (Auth + authorized)
- DELETE /user/{id} - (Soft)delete an user (Auth + authorized)
# Application init flow
- init schaduler
- run the flask app
# how to run?
- pip install -r requirements.txt
- flask db upgrade

3
app.py
View file

@ -27,7 +27,8 @@ class App:
self.scheduler.init_app(self.app)
self.scheduler.start()
# Schedule the job
self.scheduler.add_job(id='notifyUpcommingEvents', func=self.notifyUpcommingEvents, trigger='interval', seconds=1)
self.scheduler.add_job(id='notifyUpcommingEvents', func=self.notifyUpcommingEvents, trigger='interval', minutes=30)
print("Scheduler started")
def set_config(self):

View file

@ -1,7 +1,7 @@
from flask import Blueprint, jsonify, request
from flask import Blueprint, jsonify, request, g
from services.UserService import UserService
from flask_jwt_extended import JWTManager, jwt_required, create_access_token
from middlewares.userMiddlewares import validate_user_post_request, validate_user_login_request
from middlewares.userMiddlewares import validate_user_post_request, validate_user_login_request, authenticate_user
userRoutes = Blueprint('userRoutes', __name__)
@ -11,6 +11,30 @@ def allUsers():
users = UserService.get_all_users()
return jsonify(users), 200
@userRoutes.route('/<string:user_id>', methods=['GET'])
def getUser(user_id):
user = UserService.get_user_by_id(user_id)
if user:
return jsonify(user), 200
else:
return jsonify({'error': 'User not found'}), 404
@userRoutes.route('/<string:user_id>', methods=['PUT'])
@validate_user_post_request
@authenticate_user
def updateUser(user_id):
try:
if user_id != g.user_id:
return jsonify({'error': 'Unauthorized'}), 401
data = request.json
updated_user = UserService.update_user(user_id, data)
if updated_user:
return jsonify(updated_user), 200
else:
return jsonify({'error': 'User not found'}), 404
except Exception as e:
return jsonify({'error': str(e)}), 500
@userRoutes.route('/', methods=['POST'])
@userRoutes.route('', methods=['POST'])
@validate_user_post_request

View file

@ -28,7 +28,10 @@ class UserService:
@staticmethod
def get_user_by_id(user_id):
return User.query.get(user_id)
user = User.query.filter_by(id=user_id).first()
if user:
return user.to_dict()
return
@staticmethod
def verify_user(data):
@ -44,3 +47,15 @@ class UserService:
return [user.to_dict() for user in users]
@staticmethod
def update_user(user_id, data):
# update user
user = User.query.filter_by(id=user_id).first()
if user:
user.name = data['username']
user.email = data['email']
user.location = data['location']
db.session.commit()
return user.to_dict()
return None