示例#1
0
def subscribe():
    try:
        subscribedUser = request.get_json()
    except Exception as e:
        return jsonify(ExceptionTransformers().transformExceptionSubcribedUser(
            Constants.INVALID_INPUT, str(e), Constants.STATUS_FAILED))
    else:
        from controllers.controllers import SubscriptionController
        return jsonify(SubscriptionController().subscribe(subscribedUser))
def login():
    try:
        loginUser = request.get_json()
    except BadRequest as badRequest:
        return jsonify(ExceptionTransformers().transformExceptionSubcribedUser(
            Constants.INVALID_INPUT, str(e), Constants.STATUS_FAILED))
    else:
        from controllers.controllers import AuthenticationController
        return jsonify(AuthenticationController().login(loginUser))
示例#3
0
def careers():
    try:
        careerDetails = request.get_json()
    except Exception as e:
        return jsonify(ExceptionTransformers().transformExceptionCareer(
            Constants.INVALID_INPUT, Constants.INVALID_JSON,
            Constants.STATUS_FAILED))
    else:
        from controllers.controllers import CareerController
        return jsonify(CareerController().insertUserInCareers(careerDetails))
示例#4
0
def customerFeedback():
    try:
        feedback = request.get_json()
    except BadRequest as e:
        return jsonify(ExceptionTransformers().transformException(
            Constants.INVALID_INPUT, Constants.INVALID_JSON,
            Constants.STATUS_FAILED))
    else:
        from controllers.controllers import FeedbackController
        feedbackResponse = FeedbackController().customerFeedBack(feedback)
        sendMail(feedbackResponse)
        return jsonify(feedbackResponse)
示例#5
0
 def subscribe(self, subscribedUser):
     from utility.utilities import validateEmail, generateUniqueId
     isEmailValidated = validateEmail(subscribedUser.get('email'))
     if (isEmailValidated):
         from models.models import SubscribedUser
         subscriptionData = SubscribedUser(str(generateUniqueId()),
                                           subscribedUser.get('email'),
                                           True)
         return DBOperations().susbscribe(subscriptionData)
     else:
         return ExceptionTransformers().transformExceptionSubcribedUser(
             Constants.INVALID_INPUT, Constants.INVALID_EMAIL,
             Constants.STATUS_FAILED)
示例#6
0
 def insertContactUsDetails(self, contactUsDetails):
     from utility.utilities import validateEmail, validatePhoneNumber, generateUniqueId
     isEmailValidated = validateEmail(contactUsDetails.get('email'))
     # isPhoneValidated = validatePhoneNumber(contactUsDetails.get('phone'))
     if isEmailValidated:
         from models.models import ContactUs
         contactUsModel = ContactUs(str(generateUniqueId()),
                                    contactUsDetails.get('name'),
                                    contactUsDetails.get('email'),
                                    contactUsDetails.get('phone'))
         return self.dbConnection.insertContactUsDetails(contactUsModel)
     else:
         return ExceptionTransformers().transformExceptionContactUs(
             Constants.INVALID_INPUT, Constants.INVALID_EMAIL,
             Constants.STATUS_FAILED)
示例#7
0
def bookCook():
    try:
        cookBookingDetails = request.get_json()
    except Exception as e:
        return jsonify(ExceptionTransformers().transformException(
            Constants.INVALID_INPUT, Constants.INVALID_JSON,
            Constants.STATUS_FAILED))
    else:
        from controllers.controllers import BookingController
        response = BookingController().bookACook(cookBookingDetails)
        from utility.mailer import Mailer
        from controllers.controllers import AdminController
        adminUsers = AdminController().getAdminUsers()
        adminUsersEmailList = []
        if adminUsers:
            for admin in adminUsers:
                adminUsersEmailList.append(admin.email)
            Mailer().sendAsyncMail(subject='New Booking details',
                                   senders='*****@*****.**',
                                   receivers=adminUsersEmailList,
                                   body='newbook.html',
                                   details=response)
        return jsonify(response)
示例#8
0
 def __init__(self):
     self.session = db.session()
     from transformer.transformers import Transformers, ExceptionTransformers
     self.transformer = Transformers()
     self.exceptionTransformer = ExceptionTransformers()
示例#9
0
class DBOperations:
    def __init__(self):
        self.session = db.session()
        from transformer.transformers import Transformers, ExceptionTransformers
        self.transformer = Transformers()
        self.exceptionTransformer = ExceptionTransformers()

    def susbscribe(self, subscriptionData):
        try:
            self.session.add(subscriptionData)
            self.session.commit()
        except Exception as e:
            return self.exceptionTransformer.transformExceptionSubcribedUser(
                Constants.DATABASE_ERROR, e.message, Constants.STATUS_FAILED)
        else:
            return self.transformer.transformSubscribedUser(
                SubscribedUser.query.filter_by(id=subscriptionData.id).first(),
                Constants.STATUS_SUCCESS, Constants.SUCCESS_CODE)

    def getUsers(self, model):
        try:
            if model == SubscribedUser:
                return model.query.filter_by(email=model.email).filter_by(
                    isSubscribed=True).all()
        except Exception as e:
            return e.message

    def unsubscribeUser(self, email):
        try:
            response = SubscribedUser.query.filter_by(email=email).first()
            response.isSubscribed = False
            self.session.commit()

        except Exception as e:
            return self.exceptionTransformer.transformExceptionSubcribedUser(
                Constants.DATABASE_ERROR, e.message, Constants.STATUS_FAILED)

        else:
            return self.transformer.transformSubscribedUser(
                SubscribedUser.query.filter_by(id=response.id).first(),
                Constants.STATUS_SUCCESS, Constants.SUCCESS_CODE)

    #Inserting users in careers table
    def insertUserInCareers(self, careers):
        try:
            print careers
            self.session.add(careers)
            self.session.commit()
        except Exception as e:
            return self.exceptionTransformer.transformExceptionCareer(
                Constants.DATABASE_ERROR, e.message, Constants.STATUS_FAILED)

        else:
            return self.transformer.transformCareer(
                Careers.query.filter_by(id=careers.id).first(),
                Constants.STATUS_SUCCESS, Constants.SUCCESS_CODE)

    #Inserting Contact Us Details
    def insertContactUsDetails(self, contactUs):
        try:
            self.session.add(contactUs)
            self.session.commit()
        except Exception as e:
            return self.exceptionTransformer.transformExceptionContactUs(
                Constants.DATABASE_ERROR, e.message, Constants.STATUS_FAILED)
        else:
            return self.transformer.transformContactUS(
                ContactUs.query.filter_by(id=contactUs.id).first(),
                Constants.STATUS_SUCCESS, Constants.SUCCESS_CODE)

    #Inserting basic cook details
    def addCookBasicDetais(self, cookDetails):
        try:
            self.session.add(cookDetails)
            self.session.commit()
        except Exception as e:
            return e.message
        else:
            return self.transformer.transformCookBasicDetails(
                CookBasicDetails.query.filter_by(id=cookDetails.id).first(),
                Constants.STATUS_SUCCESS, Constants.SUCCESS_CODE)

    #Get length of Table
    def getLengthOfTable(self, model):
        try:
            response = model.query.all()
        except Exception as e:
            return -1
        else:
            return len(response)
示例#10
0
class DBOperations:
    def __init__(self):
        self.session = db.session()
        from transformer.transformers import Transformers, ExceptionTransformers
        self.transformer = Transformers()
        self.exceptionTransformer = ExceptionTransformers()

    def susbscribe(self, subscriptionData):
        try:
            self.session.add(subscriptionData)
            self.session.commit()
        except IntegrityError as integrityError:
            return self.exceptionTransformer.transformException(
                Constants.INTEGRITY_ERROR_CODE, Constants.SUBSCRIBED_USER,
                Constants.STATUS_FAILED)
        except Exception as e:
            return self.exceptionTransformer.transformExceptionSubcribedUser(
                Constants.DATABASE_ERROR, e.message, Constants.STATUS_FAILED)
        else:
            return self.transformer.transformSubscribedUser(
                SubscribedUser.query.filter_by(id=subscriptionData.id).first(),
                Constants.STATUS_SUCCESS, Constants.SUCCESS_CODE)

    def getUsers(self, model):
        try:
            if model == SubscribedUser:
                return model.query.filter_by(email=model.email).filter_by(
                    isSubscribed=True).all()
        except Exception as e:
            return e.message

    def unsubscribeUser(self, email):
        try:
            response = SubscribedUser.query.filter_by(email=email).first()
            response.isSubscribed = False
            self.session.commit()

        except Exception as e:
            return self.exceptionTransformer.transformExceptionSubcribedUser(
                Constants.DATABASE_ERROR, e.message, Constants.STATUS_FAILED)

        else:
            return self.transformer.transformSubscribedUser(
                SubscribedUser.query.filter_by(id=response.id).first(),
                Constants.STATUS_SUCCESS, Constants.SUCCESS_CODE)

    #Inserting users in careers table
    def insertUserInCareers(self, careers):
        try:
            print careers
            self.session.add(careers)
            self.session.commit()
        except IntegrityError as integrityError:
            return self.exceptionTransformer.transformException(
                Constants.INTEGRITY_ERROR_CODE,
                Constants.EMAIL_OR_PHONENUMBER_EXISTS, Constants.STATUS_FAILED)
        except Exception as e:
            return self.exceptionTransformer.transformExceptionCareer(
                Constants.DATABASE_ERROR, e.message, Constants.STATUS_FAILED)

        else:
            return self.transformer.transformCareer(
                Careers.query.filter_by(id=careers.id).first(),
                Constants.STATUS_SUCCESS, Constants.SUCCESS_CODE)

    #Inserting Contact Us Details
    def insertContactUsDetails(self, contactUs):
        try:
            self.session.add(contactUs)
            self.session.commit()
        except IntegrityError as integrityError:
            return self.exceptionTransformer.transformException(
                Constants.INTEGRITY_ERROR_CODE,
                Constants.EMAIL_OR_PHONENUMBER_EXISTS, Constants.STATUS_FAILED)
        except Exception as e:
            return self.exceptionTransformer.transformExceptionContactUs(
                Constants.DATABASE_ERROR, e.message, Constants.STATUS_FAILED)
        else:
            return self.transformer.transformContactUS(
                ContactUs.query.filter_by(id=contactUs.id).first(),
                Constants.STATUS_SUCCESS, Constants.SUCCESS_CODE)

    #Inserting basic cook details
    def addCookBasicDetais(self, cookDetails):
        try:
            self.session.add(cookDetails)
            self.session.commit()
        except Exception as e:
            return e.message
        else:
            return self.transformer.transformCookBasicDetails(
                CookBasicDetails.query.filter_by(id=cookDetails.id).first(),
                Constants.STATUS_SUCCESS, Constants.SUCCESS_CODE)

    #Get length of Table
    def getLengthOfTable(self, model):
        try:
            response = model.query.all()
        except Exception as e:
            return -1
        else:
            return len(response)

    #Apply operations on Table
    def applyOperations(self, optAndCol, model):
        opt = optAndCol.get('operation')
        col = optAndCol.get('col')
        if opt == '=':
            try:
                response = model.query.filter(
                    col == optAndCol.get('value')).all()
            except Exception as e:
                return e.message
            else:
                print response
                return response

        elif opt == 'ilike':
            try:
                response = model.query.filter(col.ilike(
                    optAndCol.get('value'))).all()
            except Exception as e:
                return self.exceptionTransformer.transformException(
                    Constants.DATABASE_ERROR, e.message,
                    Constants.STATUS_FAILED)
            else:
                return response

    #Get cook details
    def getCookDetails(self, optAndCol):
        if optAndCol:
            response = self.applyOperations(optAndCol, CookBasicDetails)
            return self.transformer.transformCookBasicDetailsList(
                response, Constants.STATUS_SUCCESS, Constants.SUCCESS_CODE)
        else:
            response = CookBasicDetails.query.all()
            return self.transformer.transformCookBasicDetailsList(
                response, Constants.STATUS_SUCCESS, Constants.SUCCESS_CODE)

    #Temporary cook booking
    def bookACook(self, cookBookingDetails):
        try:
            self.session.add(cookBookingDetails)
            self.session.commit()
        except IntegrityError as integrityError:
            return self.exceptionTransformer.transformException(
                Constants.INTEGRITY_ERROR_CODE,
                Constants.EMAIL_OR_PHONENUMBER_EXISTS, Constants.STATUS_FAILED)
        except Exception as e:
            return self.exceptionTransformer.transformException(
                Constants.DATABASE_ERROR, e.message, Constants.STATUS_FAILED)

        else:
            return self.transformer.transformerBookACook(
                cookBookingDetails.query.filter_by(
                    id=cookBookingDetails.id).first(),
                Constants.STATUS_SUCCESS, Constants.SUCCESS_CODE)

    #Temporary customer feedback
    def customerFeedback(self, feedback):
        global customerId
        try:
            response = CustomerDetailsTemp.query.filter_by(
                customerPhone=feedback.get('customerPhone')).first()
            from utility.utilities import generateUniqueId
            if response is None:
                customerDetails = CustomerDetailsTemp(
                    str(generateUniqueId()), feedback.get('customerName'),
                    feedback.get('customerEmail'),
                    feedback.get('customerPhone'), feedback.get('cookName'))
                customerId = str(generateUniqueId())
                comment = Feedback(customerId, customerDetails.id,
                                   feedback.get('feedback'))
                self.session.add(customerDetails)
                self.session.add(comment)
            else:
                customerId = response.id
                comment = Feedback(str(generateUniqueId()), customerId,
                                   feedback.get('feedback'))
                self.session.add(comment)
            self.session.commit()
            cust = CustomerDetailsTemp.query.filter_by(
                customerPhone=feedback.get('customerPhone')).first()
            return self.transformer.transformReviewInsert(
                cust, Constants.STATUS_SUCCESS, Constants.SUCCESS_CODE)

        except Exception as e:
            return self.exceptionTransformer.transformException(
                Constants.DATABASE_ERROR, e.message, Constants.STATUS_FAILED)

    #Retreive feedback
    def getFeedbacks(self):
        try:
            response = CustomerDetailsTemp.query.all()
        except Exception as e:
            return self.exceptionTransformer.transformException(
                Constants.DATABASE_ERROR, e.message, Constants.STATUS_FAILED)
        else:
            return response

    #Register User
    def registerUser(self, userDetails):
        try:
            self.session.add(userDetails)
            self.session.commit()
        except IntegrityError as integrityError:
            return self.exceptionTransformer.transformException(
                Constants.INTEGRITY_ERROR_CODE, integrityError.message,
                Constants.INTEGRITY_ERROR)
        except Exception as e:
            return self.exceptionTransformer.transformException(
                Constants.DATABASE_ERROR, e.message, Constants.STATUS_FAILED)

        else:
            return self.transformer.transformerRegisterUser(
                userDetails.query.filter_by(id=userDetails.id).first(),
                Constants.STATUS_SUCCESS, Constants.SUCCESS_CODE)

    #verify email
    def verifyEmail(self, model, id):
        try:
            response = model.query.filter_by(id=id).first()
            response.isEmailVerified = True
            self.session.commit()
        except Exception as e:
            return self.exceptionTransformer.transformException(
                Constants.DATABASE_ERROR, e.message, Constants.STATUS_FAILED)
        else:
            return response.isEmailVerified

    #approve feedback
    def approveFeedback(self, feedbackId):
        try:
            response = Feedback.query.filter_by(id=feedbackId).first()
            response.isApproved = True
            self.session.commit()
        except Exception as e:
            return self.exceptionTransformer.transformException(
                Constants.DATABASE_ERROR, e.message, Constants.STATUS_FAILED)
        else:
            return 'The feedback has been approved'

    #modify feedback
    def modifyFeedback(self, feedback, feedbackId):
        try:
            response = Feedback.query.filter_by(id=feedbackId).first()
            response.isApproved = True
            response.feedback = feedback
            self.session.commit()
        except Exception as e:
            return self.exceptionTransformer.transformException(
                Constants.DATABASE_ERROR, e.message, Constants.STATUS_FAILED)
        else:
            return 'The feedback was modified'

    #login
    def login(self, model, email, password):
        try:
            response = model.query.filter_by(email=email).first()
            if response:
                if response.password == password:
                    return self.transformer.transformUser(
                        response, Constants.STATUS_SUCCESS,
                        Constants.SUCCESS_CODE)
                else:
                    return self.exceptionTransformer.transformException(
                        Constants.INVALID_PASSWORD_CODE,
                        Constants.INVALID_PASSWORD, Constants.STATUS_FAILED)

            else:
                return self.exceptionTransformer.transformException(
                    Constants.NO_USER_FOUND, Constants.USER_NOT_REGISTER,
                    Constants.STATUS_FAILED)
        except Exception as e:
            return self.exceptionTransformer.transformException(
                Constants.DATABASE_ERROR, e.message, Constants.STATUS_FAILED)

    #get admin users
    def getAdminUsers(self):
        try:
            response = AdminUser.query.all()
        except Exception as e:
            return None
        else:
            return response