268 lines
11 KiB
Python
268 lines
11 KiB
Python
from flask import session, jsonify
|
|
# from app.models.loan import Loan
|
|
from app.utils.logger import logger
|
|
from app.api.services.base_service import BaseService
|
|
from app.api.schemas.eligibility_check import EligibilityCheckSchema
|
|
from marshmallow import ValidationError
|
|
from app.api.enums import TransactionType
|
|
# from app.api.integrations import SimbrellaIntegration
|
|
from app.extensions import db
|
|
from app.models import Members, MembersActions, MembersProfile
|
|
# from app.api.services.offer_analysis import OfferAnalysis
|
|
from app.api.helpers.response_helper import ResponseHelper
|
|
from werkzeug.security import generate_password_hash, check_password_hash
|
|
from app.api.schemas.user import UserSchema
|
|
from app.api.schemas.start_profile import StartProfileSchema
|
|
|
|
import datetime
|
|
import jwt
|
|
import random
|
|
from app.config import Config
|
|
|
|
|
|
class AccountService(BaseService):
|
|
|
|
@staticmethod
|
|
def process_bar_request(data):
|
|
bar_data = {
|
|
"last_update": datetime.datetime.utcnow(),
|
|
"top_bar": [
|
|
{"id": "1", "description": "Contacts", "last_update": "10-10-2010 11:00 AM",
|
|
"value": random.randint(0, 10), "data_span": 'Last 2 months',"link":"#", "extra_style" : ''},
|
|
{"id": "2", "description": "Site Traffic", "last_update": "10-10-2010 11:30 AM",
|
|
"value": random.randint(0, 10), "data_span": 'Past 12 hours',"link":"#", "extra_style" : ''},
|
|
{"id": "3", "description": "Appointments", "last_update": "10-12-2010 11:30 AM",
|
|
"value": random.randint(0, 10), "data_span": 'Last 14 days',"link":"#", "extra_style" : ''},
|
|
{"id": "4", "description": "Upgrade Account", "last_update": "10-12-2010 11:30 AM",
|
|
"value": "Free Trial", "data_span": 'End: 10/10/2025',"link":"/subscription", "extra_style" : " billing "}
|
|
]
|
|
}
|
|
return ResponseHelper.success(data=bar_data)
|
|
|
|
|
|
def process_action_request(data):
|
|
|
|
try:
|
|
with db.session.begin():
|
|
|
|
validated_data = AccountService.validate_data(data, UserSchema())
|
|
user_token = validated_data.get('token')
|
|
uid = str(validated_data.get('uid'))
|
|
member_data = Members.get_member_by_uid(uid)
|
|
|
|
member_actions = MembersActions.get_recent_member_actions(member_data.id)
|
|
member_actions_data = []
|
|
|
|
for t in member_actions:
|
|
member_actions_data.append({
|
|
'id': t.id,
|
|
'uid': t.uid,
|
|
'member_id': t.member_id,
|
|
'member_uid': t.member_uid,
|
|
'action_label': t.action_label,
|
|
'action_name': t.action_name,
|
|
'status_description': t.status_description,
|
|
'status': t.status,
|
|
'added': t.added,
|
|
'updated': t.updated
|
|
})
|
|
|
|
|
|
action_data = {
|
|
"recent_actions": member_actions_data,
|
|
"last_update": datetime.datetime.utcnow(),
|
|
"initial": random.randint(0, 10),
|
|
"processing": random.randint(0, 10),
|
|
"verifying": random.randint(0, 10),
|
|
"completed": random.randint(0, 10)
|
|
}
|
|
|
|
logger.info(f"Member Actions Error: {action_data}")
|
|
|
|
return ResponseHelper.success(data=action_data)
|
|
|
|
except ValidationError as err:
|
|
|
|
logger.error(f"Validation Error: {getattr(err, 'messages', str(err))}")
|
|
db.session.rollback()
|
|
return ResponseHelper.unprocessable_entity(result_description="Validation exception")
|
|
|
|
except ValueError as err:
|
|
logger.error(f"{getattr(err, 'messages', str(err))}")
|
|
db.session.rollback()
|
|
return ResponseHelper.error(result_description=str(err))
|
|
|
|
except Exception as e:
|
|
logger.error(f"An error occurred: {str(e)}", exc_info=True)
|
|
db.session.rollback()
|
|
return ResponseHelper.internal_server_error()
|
|
|
|
|
|
|
|
@staticmethod
|
|
def process_request(data):
|
|
try:
|
|
with db.session.begin():
|
|
|
|
validated_data = AccountService.validate_data(data, UserSchema())
|
|
user_token = validated_data.get('token')
|
|
uid = str(validated_data.get('uid'))
|
|
|
|
member = Members.get_member_by_uid(uid)
|
|
|
|
# Simulate processing
|
|
response_data = {
|
|
"member_id": member.id,
|
|
"uid": str(uid),
|
|
"username": member.username,
|
|
"account_name": member.account_name,
|
|
"profile_completed": member.profile_completed,
|
|
"firstname":member.firstname,
|
|
"lastname": member.lastname,
|
|
"email": member.email,
|
|
"room": member.uid,
|
|
"token": user_token
|
|
}
|
|
|
|
return ResponseHelper.success(data=response_data)
|
|
|
|
except ValidationError as err:
|
|
|
|
logger.error(f"Validation Error: {getattr(err, 'messages', str(err))}")
|
|
db.session.rollback()
|
|
return ResponseHelper.unprocessable_entity(result_description="Validation exception")
|
|
|
|
except ValueError as err:
|
|
logger.error(f"{getattr(err, 'messages', str(err))}")
|
|
db.session.rollback()
|
|
return ResponseHelper.error(result_description=str(err))
|
|
|
|
except Exception as e:
|
|
logger.error(f"An error occurred: {str(e)}", exc_info=True)
|
|
db.session.rollback()
|
|
return ResponseHelper.internal_server_error()
|
|
|
|
|
|
@staticmethod
|
|
def process_startprofile(data):
|
|
try:
|
|
with db.session.begin():
|
|
|
|
validated_data = AccountService.validate_data(data, StartProfileSchema())
|
|
user_token = validated_data.get('token')
|
|
uid = str(validated_data.get('uid'))
|
|
practice = str(validated_data.get('practice'))
|
|
specialization = str(validated_data.get('specialization'))
|
|
introduction = str(validated_data.get('introduction'))
|
|
profile_uid = ''
|
|
profile_completed = None
|
|
member = Members.get_member_by_uid(uid)
|
|
if member:
|
|
# Simulate processing
|
|
member_data = {
|
|
"member_id": member.id,
|
|
"uid": str(uid),
|
|
"username": member.username,
|
|
"account_name": member.account_name,
|
|
"firstname":member.firstname,
|
|
"lastname": member.lastname,
|
|
"email": member.email,
|
|
"room": member.uid,
|
|
"token": user_token
|
|
}
|
|
current_profile = MembersProfile.get_member_profile_by_member_id(member.id)
|
|
if current_profile is not None:
|
|
profile_uid=current_profile.uid
|
|
profile_completed = member.profile_completed
|
|
else:
|
|
profle_result = MembersProfile.create_member_profile(member.id, practice, specialization, introduction)
|
|
if profle_result:
|
|
profile_uid = profle_result.uid
|
|
if profile_uid is not None and profile_uid != '':
|
|
profile_completed = Members.set_member_profile_completed(member_data['uid'])
|
|
|
|
result_data = {
|
|
"profile_completed": profile_completed,
|
|
"profile_uid": profile_uid,
|
|
"last_update": datetime.datetime.utcnow()
|
|
}
|
|
|
|
return ResponseHelper.success(data=result_data)
|
|
|
|
except ValidationError as err:
|
|
|
|
logger.error(f"Validation Error: {getattr(err, 'messages', str(err))}")
|
|
db.session.rollback()
|
|
return ResponseHelper.unprocessable_entity(result_description="Validation exception")
|
|
|
|
except ValueError as err:
|
|
logger.error(f"{getattr(err, 'messages', str(err))}")
|
|
db.session.rollback()
|
|
return ResponseHelper.error(result_description=str(err))
|
|
|
|
except Exception as e:
|
|
logger.error(f"An error occurred: {str(e)}", exc_info=True)
|
|
db.session.rollback()
|
|
return ResponseHelper.internal_server_error()
|
|
|
|
|
|
@staticmethod
|
|
def process_calendar(data):
|
|
try:
|
|
with db.session.begin():
|
|
|
|
validated_data = AccountService.validate_data(data, UserSchema())
|
|
user_token = validated_data.get('token')
|
|
uid = str(validated_data.get('uid'))
|
|
|
|
dList = []
|
|
sample_range = random.randint(20, 60)
|
|
for x in range(sample_range):
|
|
timeMin = random.randint(1440, 2880)
|
|
calDate = datetime.datetime.utcnow() + datetime.timedelta(minutes=timeMin * random.randint(0, 20))
|
|
new_l = {"uid": "425611f2-c692-4404-b93d-76ca7a5ce7" + str(x),
|
|
"title": "Calendar Random Item on " + str(x), "start": calDate,
|
|
"category": random.randint(1, 4)}
|
|
dList.append(new_l)
|
|
|
|
calendar_data = {
|
|
"last_update": datetime.datetime.utcnow(),
|
|
"category": [
|
|
{
|
|
"cid": "1",
|
|
"description": "Health Check"
|
|
},
|
|
{
|
|
"cid": "2",
|
|
"description": "Product Updates"
|
|
},
|
|
{
|
|
"cid": "3",
|
|
"description": "Provisioning"
|
|
},
|
|
{
|
|
"cid": "4",
|
|
"description": "Contacts"
|
|
}
|
|
],
|
|
"list": dList
|
|
}
|
|
|
|
return ResponseHelper.success(data=calendar_data)
|
|
|
|
except ValidationError as err:
|
|
|
|
logger.error(f"Validation Error: {getattr(err, 'messages', str(err))}")
|
|
db.session.rollback()
|
|
return ResponseHelper.unprocessable_entity(result_description="Validation exception")
|
|
|
|
except ValueError as err:
|
|
logger.error(f"{getattr(err, 'messages', str(err))}")
|
|
db.session.rollback()
|
|
return ResponseHelper.error(result_description=str(err))
|
|
|
|
except Exception as e:
|
|
logger.error(f"An error occurred: {str(e)}", exc_info=True)
|
|
db.session.rollback()
|
|
return ResponseHelper.internal_server_error()
|