first commit
This commit is contained in:
		
							
								
								
									
										210
									
								
								app/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										210
									
								
								app/__init__.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,210 @@ | ||||
| # coding=utf-8 | ||||
| from flask import Flask, jsonify | ||||
| from flask_bcrypt import Bcrypt | ||||
| from flask_cors import CORS | ||||
| from flask_marshmallow import Marshmallow | ||||
|  | ||||
| from flask_sqlalchemy import SQLAlchemy | ||||
| from flask_session import Session | ||||
| from flask_login import LoginManager | ||||
| from sqlalchemy.orm import sessionmaker | ||||
| from werkzeug.routing import BaseConverter | ||||
| from flask_mail import Mail | ||||
|  | ||||
| try: | ||||
|     from local_settings import ApplicationConfig | ||||
| except Exception as e: | ||||
|     from settings import ApplicationConfig | ||||
|  | ||||
|  | ||||
| app = Flask(__name__, | ||||
|             static_url_path='', | ||||
|             static_folder='static', | ||||
|             template_folder='templates') | ||||
|  | ||||
|  | ||||
| app.config.from_object(ApplicationConfig) | ||||
|  | ||||
| session = sessionmaker() | ||||
|  | ||||
| check_enviroment = ApplicationConfig.CURRENT_SETTINGS | ||||
| print(f"starting server with {check_enviroment} settings") | ||||
|  | ||||
|  | ||||
| class RegexConverter(BaseConverter): | ||||
|     def __init__(self, url_map, *items): | ||||
|         super(RegexConverter, self).__init__(url_map) | ||||
|         self.regex = items[0] | ||||
|  | ||||
|  | ||||
| app.url_map.converters['regex'] = RegexConverter | ||||
| app.jinja_env.autoescape = True | ||||
|  | ||||
|  | ||||
| # configuration | ||||
| UPLOADED_FILES_DEST_ITEM = ApplicationConfig.UPLOADED_FILES_DEST_ITEM | ||||
| UPLOADED_FILES_ALLOW = ApplicationConfig.UPLOADED_FILES_ALLOW | ||||
| CURRENT_SETTINGS = ApplicationConfig.CURRENT_SETTINGS | ||||
|  | ||||
| app.config['UPLOADED_FILES_DEST_ITEM'] = ApplicationConfig.UPLOADED_FILES_DEST_ITEM | ||||
| app.config['UPLOADED_FILES_ALLOW'] = ApplicationConfig.UPLOADED_FILES_ALLOW | ||||
| app.config['MAX_CONTENT_LENGTH'] = ApplicationConfig.MAX_CONTENT_LENGTH | ||||
| app.config['SESSION_COOKIE_NAME'] = ApplicationConfig.SESSION_COOKIE_NAME | ||||
| app.config['SESSION_COOKIE_SECURE'] = ApplicationConfig.SESSION_COOKIE_SECURE | ||||
| app.config['SESSION_COOKIE_HTTPONLY'] = ApplicationConfig.SESSION_COOKIE_HTTPONLY | ||||
| app.config['SESSION_COOKIE_SAMESITE'] = ApplicationConfig.SESSION_COOKIE_SAMESITE | ||||
| app.config['SESSION_PERMANENT'] = ApplicationConfig.SESSION_PERMANENT | ||||
| app.config['SESSION_USE_SIGNER'] = ApplicationConfig.SESSION_USE_SIGNER | ||||
| app.config['ORIGIN_URL'] = ApplicationConfig.ORIGIN_URL | ||||
| app.config['CURRENT_SETTINGS'] = ApplicationConfig.CURRENT_SETTINGS | ||||
| app.config['SECRET_KEY'] = ApplicationConfig.SECRET_KEY | ||||
|  | ||||
| session.configure(bind=ApplicationConfig.SQLALCHEMY_DATABASE_URI) | ||||
| db = SQLAlchemy(app) | ||||
| bcrypt = Bcrypt(app) | ||||
| server_session = Session(app) | ||||
| ma = Marshmallow(app) | ||||
| mail = Mail(app) | ||||
|  | ||||
|  | ||||
| login_manager = LoginManager(app) | ||||
| login_manager.session_protection = 'strong' | ||||
| login_manager.anonymous_user = "Guest" | ||||
|  | ||||
|  | ||||
| @login_manager.request_loader | ||||
| def load_user_from_request(request): | ||||
|     from app.classes.auth import Auth_User | ||||
|     # first, try to log in using the api_key url arg | ||||
|     api_key = request.args.get('api_key') | ||||
|     if api_key: | ||||
|         user = db.session\ | ||||
|             .query(Auth_User)\ | ||||
|             .filter_by(api_key=api_key)\ | ||||
|             .first() | ||||
|         if user: | ||||
|             return user | ||||
|     # next, try to log in using Basic Auth | ||||
|     api_key_auth = request.headers.get('Authorization') | ||||
|     if api_key_auth: | ||||
|         api_key = api_key_auth.replace('bearer ', '', 1) | ||||
|         if api_key.startswith('"') and api_key.endswith('"'): | ||||
|             api_key = api_key[1:-1] | ||||
|         user = db.session\ | ||||
|             .query(Auth_User)\ | ||||
|             .filter_by(api_key=api_key)\ | ||||
|             .first() | ||||
|         if user: | ||||
|             return user | ||||
|     return None | ||||
|  | ||||
|  | ||||
| api_main = { | ||||
|     "origins": [ApplicationConfig.ORIGIN_URL], | ||||
|     "methods": ["GET", "POST", "PUT", "DELETE", "PATCH", "OPTIONS", "HEAD"], | ||||
|     "allow_headers": ['Authorization', 'application/json', 'authorization', 'Content-Type', | ||||
|                       'Access-Control-Allow-Headers', 'Origin,Accept', | ||||
|                       'X-Requested-With', 'Content-Type', 'Access-Control-Request-Method',  | ||||
|                       'Access-Control-Request-Headers'] | ||||
| } | ||||
| cors = CORS(app,  supports_credentials=True, resources={r'/*': api_main}) | ||||
|  | ||||
|  | ||||
| # bind a function after each request, even if an exception is encountered. | ||||
| @app.teardown_request | ||||
| def teardown_request(error): | ||||
|     db.session.remove() | ||||
|  | ||||
|  | ||||
| @app.teardown_appcontext | ||||
| def teardown_appcontext(error): | ||||
|     db.session.remove() | ||||
|  | ||||
|  | ||||
| @app.errorhandler(500) | ||||
| def internal_error500(): | ||||
|     return jsonify({"error": "Internal Error 500"}), 500 | ||||
|  | ||||
|  | ||||
| @app.errorhandler(502) | ||||
| def internal_error502(): | ||||
|     return jsonify({"error": "Internal Error 502"}), 502 | ||||
|  | ||||
|  | ||||
| @app.errorhandler(404) | ||||
| def internal_error404(): | ||||
|     return jsonify({"error": "Internal Error 400"}), 400 | ||||
|  | ||||
|  | ||||
| @app.errorhandler(401) | ||||
| def internal_error404(): | ||||
|     return jsonify({"error": "Internal Error 401"}), 401 | ||||
|  | ||||
|  | ||||
| @app.errorhandler(400) | ||||
| def internal_error400(): | ||||
|     return jsonify({"error": "Internal Error 400"}), 400 | ||||
|  | ||||
|  | ||||
| @app.errorhandler(413) | ||||
| def to_large_file(): | ||||
|     return jsonify({"error": "File is too large.  Use a smaller image/file."}), 413 | ||||
|  | ||||
|  | ||||
| @app.errorhandler(403) | ||||
| def internal_error403(): | ||||
|     return jsonify({"error": "Internal Error 403"}), 403 | ||||
|  | ||||
|  | ||||
| @app.errorhandler(405) | ||||
| def internal_error(): | ||||
|     return jsonify({"error": "Internal Error 405"}), 405 | ||||
|  | ||||
|  | ||||
| # link locations | ||||
| from .admin import admin as admin_blueprint | ||||
| app.register_blueprint(admin_blueprint, url_prefix='/admin') | ||||
|  | ||||
| from .main import main as main_blueprint | ||||
| app.register_blueprint(main_blueprint, url_prefix='/main') | ||||
|  | ||||
| from .customer import customer as customer_blueprint | ||||
| app.register_blueprint(customer_blueprint, url_prefix='/customer') | ||||
|  | ||||
| from .service import service as service_blueprint | ||||
| app.register_blueprint(service_blueprint, url_prefix='/service') | ||||
|  | ||||
| from .delivery import delivery as delivery_blueprint | ||||
| app.register_blueprint(delivery_blueprint, url_prefix='/delivery') | ||||
|  | ||||
| from .delivery_data import delivery_data as delivery_data_blueprint | ||||
| app.register_blueprint(delivery_data_blueprint, url_prefix='/deliverydata') | ||||
|  | ||||
| from .search import search as search_blueprint | ||||
| app.register_blueprint(search_blueprint, url_prefix='/search') | ||||
|  | ||||
| from .reports import reports as reports_blueprint | ||||
| app.register_blueprint(reports_blueprint, url_prefix='/report') | ||||
|  | ||||
| from .query import query as query_blueprint | ||||
| app.register_blueprint(query_blueprint, url_prefix='/query') | ||||
|  | ||||
| from .payment import payment as payment_blueprint | ||||
| app.register_blueprint(payment_blueprint, url_prefix='/payment') | ||||
|  | ||||
| from .auth import auth as auth_blueprint | ||||
| app.register_blueprint(auth_blueprint, url_prefix='/auth') | ||||
|  | ||||
| from .employees import employees as employees_blueprint | ||||
| app.register_blueprint(employees_blueprint, url_prefix='/employee') | ||||
|  | ||||
| from .info import info as info_blueprint | ||||
| app.register_blueprint(info_blueprint, url_prefix='/info') | ||||
|  | ||||
| from .stats import stats as stats_blueprint | ||||
| app.register_blueprint(stats_blueprint, url_prefix='/stats') | ||||
|  | ||||
| with app.app_context(): | ||||
|     db.configure_mappers() | ||||
|     db.create_all() | ||||
|     db.session.commit() | ||||
							
								
								
									
										6
									
								
								app/admin/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								app/admin/__init__.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | ||||
| # coding=utf-8 | ||||
| from flask import Blueprint | ||||
|  | ||||
| admin = Blueprint('admin', __name__) | ||||
|  | ||||
| from . import views | ||||
							
								
								
									
										92
									
								
								app/admin/views.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										92
									
								
								app/admin/views.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,92 @@ | ||||
| from flask import request, jsonify | ||||
| from flask_login import current_user, logout_user, login_user, login_required | ||||
| from app.admin import admin | ||||
| from app import db | ||||
| from datetime import datetime | ||||
| from app.classes.pricing import (Pricing_Service_General, | ||||
|                                  Pricing_Oil_Oil, | ||||
|                                  Pricing_Service_General_schema, | ||||
|                                  Pricing_Oil_Oil_schema) | ||||
|  | ||||
|  | ||||
| @admin.route("/oil/create", methods=["POST"]) | ||||
| def create_oil_price(): | ||||
|     """ | ||||
|     Changes the price for oil deliveries | ||||
|     """ | ||||
|     now = datetime.utcnow() | ||||
|     price_from_supplier = request.json["price_from_supplier"] | ||||
|     price_for_customer = request.json["price_for_customer"] | ||||
|     price_for_employee = request.json["price_for_employee"] | ||||
|  | ||||
|     new_admin_oil_price = Pricing_Oil_Oil( | ||||
|         price_from_supplier=price_from_supplier, | ||||
|         price_for_customer=price_for_customer, | ||||
|         price_for_employee=price_for_employee, | ||||
|         date=now, | ||||
|     ) | ||||
|  | ||||
|     db.session.add(new_admin_oil_price) | ||||
|     db.session.commit() | ||||
|  | ||||
|     return jsonify({ | ||||
|         "ok": True, | ||||
|         'price': new_admin_oil_price.id, | ||||
|     }), 200 | ||||
|  | ||||
|  | ||||
| @admin.route("/service/create", methods=["POST"]) | ||||
| def create_service_price(): | ||||
|     """ | ||||
|     Changes general labor rates prices | ||||
|     """ | ||||
|     now = datetime.utcnow() | ||||
|     price_service_hour = request.json["price_service_hour"] | ||||
|     price_emergency_service_hourly_rate = request.json["price_emergency_service_hour"] | ||||
|     price_emergency_call = request.json["price_emergency_call"] | ||||
|     price_out_of_oil = request.json["price_out_of_oil"] | ||||
|     price_prime = request.json["price_prime"] | ||||
|  | ||||
|     price_service = Pricing_Service_General( | ||||
|         price_service_hour=price_service_hour, | ||||
|         price_out_of_oil=price_out_of_oil, | ||||
|         price_emergency_service_hour=price_emergency_service_hourly_rate, | ||||
|         price_prime=price_prime, | ||||
|         price_emergency_call=price_emergency_call, | ||||
|         date=now, | ||||
|     ) | ||||
|  | ||||
|     db.session.add(price_service) | ||||
|     db.session.commit() | ||||
|  | ||||
|     return jsonify({ | ||||
|         "ok": True, | ||||
|         'price': price_service.id, | ||||
|     }), 200 | ||||
|  | ||||
|  | ||||
| @admin.route("/service/get", methods=["GET"]) | ||||
| def get_service_price(): | ||||
|     """ | ||||
|     gets service prices | ||||
|     """ | ||||
|     get_service_prices = (db.session | ||||
|                           .query(Pricing_Service_General) | ||||
|                           .order_by(Pricing_Service_General.date.desc()) | ||||
|                           .first()) | ||||
|  | ||||
|     price_schema = Pricing_Service_General_schema(many=False) | ||||
|     return jsonify(price_schema.dump(get_service_prices)) | ||||
|  | ||||
|  | ||||
| @admin.route("/oil/get", methods=["GET"]) | ||||
| def get_oil_price(): | ||||
|     """ | ||||
|     gets oil prices | ||||
|     """ | ||||
|     get_oil_prices = (db.session | ||||
|                       .query(Pricing_Oil_Oil) | ||||
|                       .order_by(Pricing_Oil_Oil.date.desc()) | ||||
|                       .first()) | ||||
|     price_schema = Pricing_Oil_Oil_schema(many=False) | ||||
|     return jsonify(price_schema.dump(get_oil_prices)) | ||||
							
								
								
									
										6
									
								
								app/auth/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								app/auth/__init__.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | ||||
| # coding=utf-8 | ||||
| from flask import Blueprint | ||||
|  | ||||
| auth = Blueprint('auth', __name__) | ||||
|  | ||||
| from . import views | ||||
							
								
								
									
										215
									
								
								app/auth/views.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										215
									
								
								app/auth/views.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,215 @@ | ||||
| from flask import request, jsonify | ||||
| from flask_login import current_user, logout_user, login_user, login_required | ||||
| from app.auth import auth | ||||
| from app import db, bcrypt | ||||
| from datetime import datetime | ||||
| from uuid import uuid4 | ||||
| from app.classes.auth import Auth_User | ||||
|  | ||||
|  | ||||
| @auth.route("/whoami", methods=["GET"]) | ||||
| def check_session(): | ||||
|     """ | ||||
|     Checks auth token to ensure user is authenticated | ||||
|     """ | ||||
|    | ||||
|     api_key = request.headers.get('Authorization') | ||||
|     if not api_key: | ||||
|         return jsonify({"error": "True"}), 200 | ||||
|     else: | ||||
|         api_key = api_key.replace('bearer ', '', 1) | ||||
|         api_key = api_key.replace('"', '') | ||||
|         user_exists = (db.session | ||||
|                           .query(Auth_User) | ||||
|                           .filter(Auth_User.api_key == api_key) | ||||
|                           .first()) | ||||
|         if not user_exists: | ||||
|             return jsonify({"error": True}), 200 | ||||
|         else: | ||||
|             user = db.session\ | ||||
|                 .query(Auth_User)\ | ||||
|                 .filter(Auth_User.api_key == api_key)\ | ||||
|                 .first() | ||||
|             return jsonify({ | ||||
|                 "ok": True, | ||||
|                 'user': { | ||||
|                     'user_name': user.username, | ||||
|                     'user_id': user.id, | ||||
|                     'user_email': user.email, | ||||
|                     'user_admin': user.admin_role, | ||||
|                     'token': user.api_key, | ||||
|                     'confirmed': user.confirmed | ||||
|                          }, | ||||
|                 'token': user.api_key | ||||
|             }), 200 | ||||
|  | ||||
|  | ||||
| @auth.route("/amiconfirmed", methods=["GET"]) | ||||
| @login_required | ||||
| def check_confirmed(): | ||||
|     """ | ||||
|     Checks to see if user confirmed with email or key | ||||
|     """ | ||||
|     user = db.session\ | ||||
|         .query(Auth_User)\ | ||||
|         .filter(Auth_User.id == current_user.id)\ | ||||
|         .first() | ||||
|     if user.confirmed == 0: | ||||
|         confirmed = False | ||||
|     else: | ||||
|         confirmed = True | ||||
|  | ||||
|     return jsonify({"status": confirmed}), 200 | ||||
|  | ||||
|  | ||||
| @auth.route("/logout", methods=["POST"]) | ||||
| def logout(): | ||||
|     """ | ||||
|     Logs a user out of session on backend | ||||
|     """ | ||||
|     try: | ||||
|         logout_user() | ||||
|         return jsonify({'status': 'logged out'}), 200 | ||||
|     except Exception as e: | ||||
|         return jsonify({"error", 'error'}), 400 | ||||
|  | ||||
|  | ||||
| @auth.route("/login", methods=["POST"]) | ||||
| def login(): | ||||
|     """ | ||||
|     Main post function to  a user | ||||
|     """ | ||||
|     | ||||
|     username = request.json["username"] | ||||
|     password = request.json["password"] | ||||
|  | ||||
|     user = db.session\ | ||||
|                 .query(Auth_User)\ | ||||
|                 .filter_by(username=username)\ | ||||
|                 .first() is not None | ||||
|     if not user: | ||||
|         return jsonify({"error": True}), 200 | ||||
|     user = db.session\ | ||||
|         .query(Auth_User)\ | ||||
|         .filter_by(username=username)\ | ||||
|         .first() | ||||
|     if not bcrypt.check_password_hash(user.password_hash, password): | ||||
|  | ||||
|         current_fails = int(user.fails) | ||||
|         new_fails = current_fails + 1 | ||||
|         user.fails = new_fails | ||||
|         db.session.add(user) | ||||
|         db.session.commit() | ||||
|  | ||||
|         return jsonify({"error": True}), 200 | ||||
|     user.locked = 0 | ||||
|     user.fails = 0 | ||||
|     db.session.add(user) | ||||
|     db.session.commit() | ||||
|  | ||||
|  | ||||
|     return jsonify({ | ||||
|         "ok": True, | ||||
|         'user': {'user_id': user.uuid, | ||||
|                     'user_id': user.id, | ||||
|                     'user_email': user.email, | ||||
|                     'admin_role': user.admin_role, | ||||
|                     'token': user.api_key | ||||
|                     }, | ||||
|         'token': user.api_key | ||||
|     }), 200 | ||||
|  | ||||
| @auth.route("/register", methods=["POST"]) | ||||
| def register_user(): | ||||
|     """ | ||||
|     Main post function to register a user | ||||
|     """ | ||||
|     now = datetime.utcnow() | ||||
|  | ||||
|     username = request.json["username"] | ||||
|     email = request.json["email"] | ||||
|     password = request.json["password"] | ||||
|      | ||||
|     part_one_code = uuid4().hex | ||||
|     part_two_code = uuid4().hex | ||||
|     part_three_code = uuid4().hex | ||||
|     key = part_one_code + part_two_code + part_three_code | ||||
|  | ||||
|     # check if email exists | ||||
|     user_exists_email = db.session\ | ||||
|         .query(Auth_User)\ | ||||
|         .filter_by(email=email)\ | ||||
|         .first() is not None | ||||
|     if user_exists_email: | ||||
|         return jsonify({"error": "Email already exists"}), 200 | ||||
|      | ||||
|     # check if username exists | ||||
|     user_exists_username = db.session\ | ||||
|         .query(Auth_User)\ | ||||
|         .filter_by(username=username)\ | ||||
|         .first() is not None | ||||
|     if user_exists_username: | ||||
|         return jsonify({"error": "User already exists"}), 200 | ||||
|      | ||||
|     # hash password for database | ||||
|     hashed_password = bcrypt.generate_password_hash(password).decode('utf-8') | ||||
|  | ||||
|     new_user = Auth_User( | ||||
|         username=username, | ||||
|         email=email, | ||||
|         password_hash=hashed_password, | ||||
|         member_since=now, | ||||
|         api_key=key, | ||||
|         last_seen=now, | ||||
|         admin=0, | ||||
|         admin_role=0, | ||||
|         confirmed=0, | ||||
|     ) | ||||
|  | ||||
|     db.session.add(new_user) | ||||
|  | ||||
|     # commit to database | ||||
|     db.session.commit() | ||||
|      | ||||
|     # log user in as active not sure if needed with frontend | ||||
|     #login_user(new_user) | ||||
|     # current_user.is_authenticated() | ||||
|     # current_user.is_active() | ||||
|  | ||||
|     return jsonify({ | ||||
|         "ok": True, | ||||
|         'user': { | ||||
|                  'user_email': new_user.email, | ||||
|                  'admin_role': new_user.admin_role, | ||||
|                  'token': new_user.api_key, | ||||
|                  'confirmed': new_user.confirmed, | ||||
|                  }, | ||||
|         'token':  new_user.api_key | ||||
|     }), 200 | ||||
|  | ||||
|  | ||||
| @auth.route('/change-password', methods=['POST']) | ||||
| @login_required | ||||
| def change_password(): | ||||
|  | ||||
|     new_password = request.json["new_password"] | ||||
|     new_password_confirm = request.json["password_confirm"] | ||||
|  | ||||
|     user = db.session\ | ||||
|         .query(Auth_User) \ | ||||
|         .filter(Auth_User.id == current_user.id) \ | ||||
|         .first() | ||||
|  | ||||
|     if str(new_password) != str(new_password_confirm): | ||||
|         return jsonify({"error": "Error: Incorrect Passwords"}), 200 | ||||
|  | ||||
|     hashed_password = bcrypt.generate_password_hash( | ||||
|         new_password).decode('utf8') | ||||
|      | ||||
|     user.password_hash = hashed_password | ||||
|     user.passwordpinallowed = 0 | ||||
|      | ||||
|     db.session.add(user) | ||||
|     db.session.commit() | ||||
|     return jsonify({"ok": "success"}), 200 | ||||
|  | ||||
							
								
								
									
										0
									
								
								app/classes/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								app/classes/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
								
								
									
										26
									
								
								app/classes/admin.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								app/classes/admin.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,26 @@ | ||||
| from app import db, ma | ||||
| from datetime import datetime | ||||
|  | ||||
|  | ||||
| class Admin_Company(db.Model): | ||||
|     __tablename__ = 'admin_company' | ||||
|     __bind_key__ = 'eamco' | ||||
|     __table_args__ = {"schema": "public"} | ||||
|  | ||||
|     id = db.Column(db.Integer, | ||||
|                    primary_key=True, | ||||
|                    autoincrement=True, | ||||
|                    unique=False) | ||||
|     creation_date = db.Column(db.TIMESTAMP(), default=datetime.utcnow()) | ||||
|     account_prefix = db.Column(db.VARCHAR(5)) | ||||
|     company_name = db.Column(db.VARCHAR(250)) | ||||
|     company_address = db.Column(db.VARCHAR(250)) | ||||
|     company_town = db.Column(db.VARCHAR(100)) | ||||
|     company_zip = db.Column(db.VARCHAR(25)) | ||||
|     company_state = db.Column(db.INTEGER()) | ||||
|     company_phone_number = db.Column(db.VARCHAR(50)) | ||||
|  | ||||
| class Admin_Company_schema(ma.SQLAlchemyAutoSchema): | ||||
|     class Meta: | ||||
|         model = Admin_Company | ||||
|  | ||||
							
								
								
									
										79
									
								
								app/classes/auth.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										79
									
								
								app/classes/auth.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,79 @@ | ||||
| from flask_login import UserMixin, AnonymousUserMixin | ||||
| from app import db, ma, login_manager | ||||
| from datetime import datetime | ||||
| from uuid import uuid4 | ||||
|  | ||||
|  | ||||
| def get_uuid(): | ||||
|     return uuid4().hex | ||||
|  | ||||
|  | ||||
| class Auth_User(UserMixin, db.Model): | ||||
|     __tablename__ = 'auth_users' | ||||
|     __bind_key__ = 'eamco' | ||||
|     __table_args__ = {"schema": "public"} | ||||
|  | ||||
|     id = db.Column(db.Integer, | ||||
|                    autoincrement=True, | ||||
|                    primary_key=True, | ||||
|                    unique=True) | ||||
|     uuid = db.Column(db.String(32), default=get_uuid) | ||||
|     api_key = db.Column(db.TEXT) | ||||
|     username = db.Column(db.VARCHAR(40)) | ||||
|     password_hash = db.Column(db.TEXT) | ||||
|     member_since = db.Column(db.TIMESTAMP(), default=datetime.utcnow()) | ||||
|     email = db.Column(db.VARCHAR(350)) | ||||
|     last_seen = db.Column(db.TIMESTAMP(), default=datetime.utcnow()) | ||||
|     admin = db.Column(db.INTEGER) | ||||
|     admin_role = db.Column(db.INTEGER) | ||||
|     confirmed = db.Column(db.INTEGER) | ||||
|  | ||||
|     def __init__(self, | ||||
|                  username, | ||||
|                  api_key, | ||||
|                  password_hash, | ||||
|                  member_since, | ||||
|                  email, | ||||
|                  last_seen, | ||||
|                  admin, | ||||
|                  admin_role, | ||||
|                  confirmed, | ||||
|                  ): | ||||
|         self.username = username | ||||
|         self.api_key = api_key | ||||
|         self.password_hash = password_hash | ||||
|         self.member_since = member_since | ||||
|         self.email = email | ||||
|         self.last_seen = last_seen | ||||
|         self.admin = admin | ||||
|         self.admin_role = admin_role | ||||
|         self.confirmed = confirmed | ||||
|  | ||||
|     def is_authenticated(self): | ||||
|         return True | ||||
|  | ||||
|     def is_active(self): | ||||
|         return True | ||||
|  | ||||
|     def is_anonymous(self): | ||||
|         return False | ||||
|  | ||||
|     def get_id(self): | ||||
|         return self.id | ||||
|  | ||||
|  | ||||
| class Auth_User_Schema(ma.SQLAlchemyAutoSchema): | ||||
|     class Meta: | ||||
|         model = Auth_User | ||||
|  | ||||
|  | ||||
| user_schema = Auth_User_Schema() | ||||
| users_schema = Auth_User_Schema(many=True) | ||||
|  | ||||
|  | ||||
| class AnonymousUser(AnonymousUserMixin): | ||||
|     def __init__(self): | ||||
|         self.username = 'Guest' | ||||
|  | ||||
|  | ||||
| login_manager.anonymous_user = AnonymousUser | ||||
							
								
								
									
										49
									
								
								app/classes/auto.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										49
									
								
								app/classes/auto.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,49 @@ | ||||
|  | ||||
| from app import db, ma | ||||
| from datetime import datetime | ||||
|  | ||||
|  | ||||
| class Auto_Temp(db.Model): | ||||
|     __tablename__ = 'auto_temp' | ||||
|     __bind_key__ = 'eamco' | ||||
|     __table_args__ = {"schema": "public"} | ||||
|      | ||||
|     id = db.Column(db.Integer, | ||||
|                    primary_key=True, | ||||
|                    autoincrement=True, | ||||
|                    unique=False) | ||||
|     todays_date = db.Column(db.TIMESTAMP(), default=datetime.utcnow()) | ||||
|     temp = db.Column(db.DECIMAL(50, 2)) | ||||
|     temp_max = db.Column(db.DECIMAL(50, 2)) | ||||
|     temp_min = db.Column(db.DECIMAL(50, 2)) | ||||
|     temp_avg = db.Column(db.DECIMAL(50, 2)) | ||||
|     degree_day = db.Column(db.INTEGER()) | ||||
|  | ||||
| class Auto_Temp_schema(ma.SQLAlchemyAutoSchema): | ||||
|     class Meta: | ||||
|         model = Auto_Temp | ||||
|  | ||||
|  | ||||
|  | ||||
| class Auto_Delivery(db.Model): | ||||
|     __tablename__ = 'auto_delivery' | ||||
|     __bind_key__ = 'eamco' | ||||
|     __table_args__ = {"schema": "public"} | ||||
|      | ||||
|     id = db.Column(db.Integer, | ||||
|                    primary_key=True, | ||||
|                    autoincrement=True, | ||||
|                    unique=False) | ||||
|     customer_id =  db.Column(db.INTEGER()) | ||||
|     customer_full_name = db.Column(db.DECIMAL(50, 2)) | ||||
|     last_fill = db.Column(db.TIMESTAMP()) | ||||
|     last_updated = db.Column(db.TIMESTAMP()) | ||||
|     estimated_gallons_left = db.Column(db.INTEGER()) | ||||
|     estimated_gallons_left_prev_day = db.Column(db.INTEGER()) | ||||
|     tank_height = db.Column(db.VARCHAR(25)) | ||||
|     tank_size = db.Column(db.VARCHAR(25)) | ||||
|     k_factor = db.Column(db.DECIMAL(50, 2)) | ||||
|  | ||||
| class Auto_Delivery_schema(ma.SQLAlchemyAutoSchema): | ||||
|     class Meta: | ||||
|         model = Auto_Delivery | ||||
							
								
								
									
										29
									
								
								app/classes/cards.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								app/classes/cards.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,29 @@ | ||||
|  | ||||
| from app import db, ma | ||||
| from datetime import datetime | ||||
|  | ||||
|  | ||||
| class Card_Card(db.Model): | ||||
|     __tablename__ = 'card_card' | ||||
|     __bind_key__ = 'eamco' | ||||
|     __table_args__ = {"schema": "public"} | ||||
|      | ||||
|     id = db.Column(db.Integer, | ||||
|                    primary_key=True, | ||||
|                    autoincrement=True, | ||||
|                    unique=False) | ||||
|     date_added = db.Column(db.TIMESTAMP(), default=datetime.utcnow()) | ||||
|     user_id = db.Column(db.INTEGER()) | ||||
|     card_number = db.Column(db.VARCHAR(50)) | ||||
|     last_four_digits = db.Column(db.INTEGER()) | ||||
|     name_on_card = db.Column(db.VARCHAR(500)) | ||||
|     expiration_month = db.Column(db.INTEGER()) | ||||
|     expiration_year = db.Column(db.INTEGER()) | ||||
|     type_of_card = db.Column(db.VARCHAR(500)) | ||||
|     security_number = db.Column(db.INTEGER()) | ||||
|     accepted_or_declined = db.Column(db.INTEGER()) | ||||
|     main_card = db.Column(db.BOOLEAN()) | ||||
|      | ||||
| class Card_Card_schema(ma.SQLAlchemyAutoSchema): | ||||
|     class Meta: | ||||
|         model = Card_Card | ||||
							
								
								
									
										25
									
								
								app/classes/company.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								app/classes/company.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,25 @@ | ||||
| from app import db, ma | ||||
|  | ||||
|  | ||||
|  | ||||
| class Company_Company(db.Model): | ||||
|     __tablename__ = 'company_company' | ||||
|     __bind_key__ = 'eamco' | ||||
|     __table_args__ = {"schema": "public"} | ||||
|      | ||||
|     id = db.Column(db.Integer, | ||||
|                    primary_key=True, | ||||
|                    autoincrement=True, | ||||
|                    unique=False) | ||||
|      | ||||
|     company_dba_name = db.Column(db.VARCHAR(250)) | ||||
|     company_llc_name = db.Column(db.VARCHAR(250)) | ||||
|     company_town = db.Column(db.VARCHAR(140)) | ||||
|     company_state = db.Column(db.VARCHAR(140)) | ||||
|     company_zip = db.Column(db.INTEGER) | ||||
|  | ||||
|  | ||||
| class Company_Company_schema(ma.SQLAlchemyAutoSchema): | ||||
|     class Meta: | ||||
|         model = Company_Company | ||||
|  | ||||
							
								
								
									
										82
									
								
								app/classes/customer.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										82
									
								
								app/classes/customer.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,82 @@ | ||||
|  | ||||
| from app import db, ma, login_manager | ||||
| from datetime import datetime | ||||
|  | ||||
|  | ||||
| class Customer_Customer(db.Model): | ||||
|     __tablename__ = 'customer_customer' | ||||
|     __bind_key__ = 'eamco' | ||||
|     __table_args__ = {"schema": "public"} | ||||
|      | ||||
|     id = db.Column(db.Integer, | ||||
|                    primary_key=True, | ||||
|                    autoincrement=True, | ||||
|                    unique=False) | ||||
|     account_number = db.Column(db.VARCHAR(25)) | ||||
|     customer_last_name = db.Column(db.VARCHAR(250)) | ||||
|     customer_first_name = db.Column(db.VARCHAR(250)) | ||||
|     customer_town = db.Column(db.VARCHAR(140)) | ||||
|     customer_state = db.Column(db.INTEGER) | ||||
|     customer_zip = db.Column(db.VARCHAR(25)) | ||||
|     customer_first_call = db.Column(db.TIMESTAMP(), default=datetime.utcnow()) | ||||
|     customer_email = db.Column(db.VARCHAR(500)) | ||||
|     customer_automatic = db.Column(db.INTEGER) | ||||
|     customer_phone_number = db.Column(db.VARCHAR(25)) | ||||
|     customer_home_type = db.Column(db.INTEGER) | ||||
|     customer_apt = db.Column(db.VARCHAR(140)) | ||||
|     customer_address = db.Column(db.VARCHAR(1000)) | ||||
|  | ||||
|  | ||||
| class Customer_Customer_schema(ma.SQLAlchemyAutoSchema): | ||||
|     class Meta: | ||||
|         model = Customer_Customer | ||||
|  | ||||
|  | ||||
| class Customer_Property(db.Model): | ||||
|     __tablename__ = 'customer_property' | ||||
|     __bind_key__ = 'eamco' | ||||
|     __table_args__ = {"schema": "public"} | ||||
|      | ||||
|     id = db.Column(db.Integer, | ||||
|                    primary_key=True, | ||||
|                    autoincrement=True, | ||||
|                    unique=False) | ||||
|      | ||||
|     customer_id = db.Column(db.INTEGER) | ||||
|      | ||||
|     # residential = 0 | ||||
|     # condo = 1 | ||||
|     # apartment = 2 | ||||
|     # commercial = 3 | ||||
|     # business = 4 | ||||
|     # vehicle = 4 | ||||
|     customer_property_type = db.Column(db.INTEGER) | ||||
|  | ||||
|      | ||||
| class Customer_Property_schema(ma.SQLAlchemyAutoSchema): | ||||
|     class Meta: | ||||
|         model = Customer_Property | ||||
|  | ||||
|  | ||||
| class Customer_Payment_Credit(db.Model): | ||||
|     __tablename__ = 'customer_payment' | ||||
|     __bind_key__ = 'eamco' | ||||
|     __table_args__ = {"schema": "public"} | ||||
|      | ||||
|     id = db.Column(db.Integer, | ||||
|                    primary_key=True, | ||||
|                    autoincrement=True, | ||||
|                    unique=False) | ||||
|      | ||||
|     customer_id = db.Column(db.INTEGER) | ||||
|    | ||||
|     credit_card_type = db.Column(db.INTEGER) | ||||
|     credit_card_name = db.Column(db.VARCHAR(240)) | ||||
|     credit_card_number = db.Column(db.VARCHAR(140)) | ||||
|     credit_card_security = db.Column(db.VARCHAR(140)) | ||||
|     customer_card_expiration = db.Column(db.TIMESTAMP(), default=datetime.utcnow()) | ||||
|  | ||||
|  | ||||
| class Customer_Payment_Credit_schema(ma.SQLAlchemyAutoSchema): | ||||
|     class Meta: | ||||
|         model = Customer_Payment_Credit | ||||
							
								
								
									
										117
									
								
								app/classes/delivery.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										117
									
								
								app/classes/delivery.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,117 @@ | ||||
| from app import db, ma | ||||
| from datetime import datetime | ||||
|  | ||||
|  | ||||
| class Delivery_Delivery(db.Model): | ||||
|     __tablename__ = 'delivery_delivery' | ||||
|     __bind_key__ = 'eamco' | ||||
|     __table_args__ = {"schema": "public"} | ||||
|      | ||||
|     id = db.Column(db.Integer, | ||||
|                    primary_key=True, | ||||
|                    autoincrement=True, | ||||
|                    unique=False) | ||||
|      | ||||
|     customer_id = db.Column(db.INTEGER) | ||||
|     customer_name = db.Column(db.VARCHAR(1000)) | ||||
|     customer_address = db.Column(db.VARCHAR(1000)) | ||||
|     customer_town = db.Column(db.VARCHAR(140)) | ||||
|     customer_state = db.Column(db.VARCHAR(140)) | ||||
|     customer_zip = db.Column(db.INTEGER) | ||||
|     # how many gallons ordered | ||||
|     gallons_ordered = db.Column(db.INTEGER) | ||||
|     # if customer asked for a fill | ||||
|     customer_asked_for_fill = db.Column(db.INTEGER) | ||||
|     # integer value if delivered, waiting, cancelled etc | ||||
|     gallons_delivered =db.Column(db.DECIMAL(50, 2)) | ||||
|     # if customer has a full tank | ||||
|     customer_filled = db.Column(db.INTEGER) | ||||
|     # integer value if delivered, waiting, cancelled etc | ||||
|     # waiting = 0 | ||||
|     # delivered = 1 | ||||
|     # out for delivery = 2 | ||||
|     # cancelled = 3 | ||||
|     # partial delivery = 4 | ||||
|     # issue = 5 | ||||
|  | ||||
|     # finalized = 10 | ||||
|     delivery_status = db.Column(db.INTEGER) | ||||
|     # when the call to order took place | ||||
|     when_ordered = db.Column(db.TIMESTAMP(), default=datetime.utcnow()) | ||||
|     # when the delivery date happened | ||||
|     when_delivered = db.Column(db.TIMESTAMP(), default=None) | ||||
|     # when the delivery is expected ie what day | ||||
|     expected_delivery_date = db.Column(db.DATE(), default=None) | ||||
|     # automatic delivery | ||||
|     automatic = db.Column(db.INTEGER) | ||||
|     # OIL info and id from table | ||||
|     oil_id = db.Column(db.INTEGER) | ||||
|     supplier_price = db.Column(db.DECIMAL(50, 2)) | ||||
|     customer_price = db.Column(db.DECIMAL(50, 2)) | ||||
|     # weather | ||||
|     customer_temperature = db.Column(db.DECIMAL(50, 2)) | ||||
|     # services | ||||
|     dispatcher_notes = db.Column(db.TEXT()) | ||||
|     prime = db.Column(db.INTEGER) | ||||
|     same_day = db.Column(db.INTEGER) | ||||
|     # cash = 0 | ||||
|     # credit = 1 | ||||
|     payment_type = db.Column(db.INTEGER) | ||||
|     payment_card_id = db.Column(db.INTEGER) | ||||
|  | ||||
|     driver_employee_id = db.Column(db.VARCHAR(140)) | ||||
|     driver_first_name = db.Column(db.VARCHAR(140)) | ||||
|     driver_last_name = db.Column(db.VARCHAR(140)) | ||||
|  | ||||
|     pre_charge_amount = db.Column(db.DECIMAL(50, 2)) | ||||
|     total_price = db.Column(db.DECIMAL(50, 2)) | ||||
|     final_price = db.Column(db.DECIMAL(50, 2)) | ||||
|  | ||||
| class Delivery_Delivery_schema(ma.SQLAlchemyAutoSchema): | ||||
|     class Meta: | ||||
|         model = Delivery_Delivery | ||||
|  | ||||
|  | ||||
| class Delivery_Payment(db.Model): | ||||
|     __tablename__ = 'delivery_payment' | ||||
|     __bind_key__ = 'eamco' | ||||
|     __table_args__ = {"schema": "public"} | ||||
|  | ||||
|     id = db.Column(db.Integer, | ||||
|                    primary_key=True, | ||||
|                    autoincrement=True, | ||||
|                    unique=False) | ||||
|  | ||||
|     delivery_id = db.Column(db.INTEGER) | ||||
|     time_added = db.Column(db.TIMESTAMP(), default=datetime.utcnow()) | ||||
|     total_amount_oil = db.Column(db.DECIMAL(50, 2)) | ||||
|     total_amount_emergency = db.Column(db.DECIMAL(50, 2)) | ||||
|     total_amount_prime = db.Column(db.DECIMAL(50, 2)) | ||||
|     total_amount_fee = db.Column(db.DECIMAL(50, 2)) | ||||
|     total_amount = db.Column(db.DECIMAL(50, 2)) | ||||
|  | ||||
| class Delivery_Payment_schema(ma.SQLAlchemyAutoSchema): | ||||
|     class Meta: | ||||
|         model = Delivery_Payment | ||||
|  | ||||
|  | ||||
| class Delivery_Notes_Driver(db.Model): | ||||
|     __tablename__ = 'delivery_notes' | ||||
|     __bind_key__ = 'eamco' | ||||
|     __table_args__ = {"schema": "public"} | ||||
|      | ||||
|     id = db.Column(db.Integer, | ||||
|                    primary_key=True, | ||||
|                    autoincrement=True, | ||||
|                    unique=False) | ||||
|      | ||||
|     delivery_id = db.Column(db.INTEGER) | ||||
|     driver_comments = db.Column(db.TEXT) | ||||
|     time_added = db.Column(db.TIMESTAMP(), default=datetime.utcnow()) | ||||
|     driver_id = db.Column(db.INTEGER) | ||||
|     driver_name = db.Column(db.VARCHAR(140)) | ||||
|      | ||||
|      | ||||
| class Delivery_Notes_Driver_schema(ma.SQLAlchemyAutoSchema): | ||||
|     class Meta: | ||||
|         model = Delivery_Notes_Driver | ||||
							
								
								
									
										73
									
								
								app/classes/employee.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										73
									
								
								app/classes/employee.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,73 @@ | ||||
| from app import db, ma | ||||
| from datetime import datetime | ||||
|  | ||||
|  | ||||
| class Employee_Employee(db.Model): | ||||
|     __tablename__ = 'employee_employee' | ||||
|     __bind_key__ = 'eamco' | ||||
|     __table_args__ = {"schema": "public"} | ||||
|      | ||||
|     id = db.Column(db.Integer, | ||||
|                    primary_key=True, | ||||
|                    autoincrement=True, | ||||
|                    unique=False) | ||||
|  | ||||
|     user_id = db.Column(db.INTEGER) | ||||
|     employee_first_name = db.Column(db.VARCHAR(250)) | ||||
|     employee_last_name = db.Column(db.VARCHAR(250)) | ||||
|     employee_apt = db.Column(db.VARCHAR(250)) | ||||
|     employee_address = db.Column(db.VARCHAR(1000)) | ||||
|     employee_town = db.Column(db.VARCHAR(140)) | ||||
|     employee_state = db.Column(db.VARCHAR(140)) | ||||
|     employee_zip = db.Column(db.VARCHAR(25)) | ||||
|     employee_birthday = db.Column(db.DATE(), default=datetime.utcnow()) | ||||
|     employee_type = db.Column(db.INTEGER) | ||||
|     employee_phone_number = db.Column(db.VARCHAR(25)) | ||||
|     employee_start_date = db.Column(db.DATE(), default=datetime.utcnow()) | ||||
|     employee_end_date = db.Column(db.DATE(), default=None) | ||||
|  | ||||
|  | ||||
| class Employee_Employee_schema(ma.SQLAlchemyAutoSchema): | ||||
|     class Meta: | ||||
|         model = Employee_Employee | ||||
|  | ||||
|  | ||||
| class Employee_Credentials(db.Model): | ||||
|     __tablename__ = 'employee_credentials' | ||||
|     __bind_key__ = 'eamco' | ||||
|     __table_args__ = {"schema": "public"} | ||||
|      | ||||
|     id = db.Column(db.Integer, | ||||
|                    primary_key=True, | ||||
|                    autoincrement=True, | ||||
|                    unique=False) | ||||
|     employee_id = db.Column(db.INTEGER) | ||||
|     employee_name = db.Column(db.VARCHAR(140)) | ||||
|     employee_cdl_expire = db.Column(db.TIMESTAMP(), default=datetime.utcnow()) | ||||
|     employee_hvac_expire = db.Column(db.TIMESTAMP(), default=datetime.utcnow()) | ||||
|  | ||||
|  | ||||
| class Employee_Credentials_schema(ma.SQLAlchemyAutoSchema): | ||||
|     class Meta: | ||||
|         model = Employee_Credentials | ||||
|  | ||||
|  | ||||
| class Employee_Vacation(db.Model): | ||||
|     __tablename__ = 'employee_vacation' | ||||
|     __bind_key__ = 'eamco' | ||||
|     __table_args__ = {"schema": "public"} | ||||
|      | ||||
|     id = db.Column(db.Integer, | ||||
|                    primary_key=True, | ||||
|                    autoincrement=True, | ||||
|                    unique=False) | ||||
|     employee_id = db.Column(db.INTEGER) | ||||
|     employee_name = db.Column(db.VARCHAR(140)) | ||||
|     employee_total_days_off = db.Column(db.INTEGER) | ||||
|     employee_days_off_multiplier = db.Column(db.DECIMAL(50, 2)) | ||||
|     employee_days_off_per_year = db.Column(db.INTEGER) | ||||
|  | ||||
|  | ||||
| class Employee_Vacation_schema(ma.SQLAlchemyAutoSchema): | ||||
|     class Meta: | ||||
|         model = Employee_Vacation | ||||
							
								
								
									
										49
									
								
								app/classes/pricing.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										49
									
								
								app/classes/pricing.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,49 @@ | ||||
| from app import db, ma, login_manager | ||||
| from datetime import datetime | ||||
|  | ||||
|  | ||||
| class Pricing_Service_General(db.Model): | ||||
|     __tablename__ = 'pricing_service_general' | ||||
|     __bind_key__ = 'eamco' | ||||
|     __table_args__ = {"schema": "public"} | ||||
|  | ||||
|     id = db.Column(db.Integer, | ||||
|                    primary_key=True, | ||||
|                    autoincrement=True, | ||||
|                    unique=False) | ||||
|  | ||||
|     price_service_hour = db.Column(db.DECIMAL(50, 2)) | ||||
|     price_emergency_service_hour = db.Column(db.DECIMAL(50, 2)) | ||||
|     price_emergency_call = db.Column(db.DECIMAL(50, 2)) | ||||
|     price_out_of_oil = db.Column(db.DECIMAL(50, 2)) | ||||
|     price_prime = db.Column(db.DECIMAL(50, 2)) | ||||
|     price_same_day = db.Column(db.DECIMAL(50, 2)) | ||||
|     price_cleaning = db.Column(db.DECIMAL(50, 2)) | ||||
|     date = db.Column(db.TIMESTAMP(), default=datetime.utcnow()) | ||||
|  | ||||
|  | ||||
| class Pricing_Service_General_schema(ma.SQLAlchemyAutoSchema): | ||||
|     class Meta: | ||||
|         model = Pricing_Service_General | ||||
|  | ||||
|  | ||||
| class Pricing_Oil_Oil(db.Model): | ||||
|     __tablename__ = 'pricing_oil_oil' | ||||
|     __bind_key__ = 'eamco' | ||||
|     __table_args__ = {"schema": "public"} | ||||
|  | ||||
|     id = db.Column(db.Integer, | ||||
|                    primary_key=True, | ||||
|                    autoincrement=True, | ||||
|                    unique=False) | ||||
|  | ||||
|     price_from_supplier = db.Column(db.DECIMAL(50, 2)) | ||||
|     price_for_customer = db.Column(db.DECIMAL(50, 2)) | ||||
|     price_for_employee = db.Column(db.DECIMAL(50, 2)) | ||||
|     date = db.Column(db.TIMESTAMP(), default=datetime.utcnow()) | ||||
|  | ||||
|  | ||||
| class Pricing_Oil_Oil_schema(ma.SQLAlchemyAutoSchema): | ||||
|      class Meta: | ||||
|         model = Pricing_Oil_Oil | ||||
|  | ||||
							
								
								
									
										88
									
								
								app/classes/query.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										88
									
								
								app/classes/query.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,88 @@ | ||||
|  | ||||
| from app import db, ma | ||||
|  | ||||
|  | ||||
| class Query_EmployeeTypeList(db.Model): | ||||
|     __tablename__ = 'query_employee_type_list' | ||||
|     __bind_key__ = 'eamco' | ||||
|     __table_args__ = {"schema": "public"} | ||||
|     id = db.Column(db.Integer, primary_key=True, autoincrement=True) | ||||
|     value = db.Column(db.INTEGER) | ||||
|     text = db.Column(db.VARCHAR(140)) | ||||
|  | ||||
|  | ||||
| class Query_EmployeeTypeList_Schema(ma.SQLAlchemyAutoSchema): | ||||
|     class Meta: | ||||
|         model = Query_EmployeeTypeList | ||||
|     id = ma.auto_field() | ||||
|     text = ma.auto_field() | ||||
|     value = ma.auto_field() | ||||
|  | ||||
| class Query_StateList(db.Model): | ||||
|     __tablename__ = 'query_state_list' | ||||
|     __bind_key__ = 'eamco' | ||||
|     __table_args__ = {"schema": "public"} | ||||
|     id = db.Column(db.Integer, primary_key=True, autoincrement=True) | ||||
|     value = db.Column(db.INTEGER) | ||||
|     text = db.Column(db.VARCHAR(140)) | ||||
|  | ||||
|  | ||||
| class Query_StateList_Schema(ma.SQLAlchemyAutoSchema): | ||||
|     class Meta: | ||||
|         model = Query_StateList | ||||
|     id = ma.auto_field() | ||||
|     text = ma.auto_field() | ||||
|     value = ma.auto_field() | ||||
|  | ||||
|  | ||||
| class Query_CustomerTypeList(db.Model): | ||||
|     __tablename__ = 'query_customer_type_list' | ||||
|     __bind_key__ = 'eamco' | ||||
|     __table_args__ = {"schema": "public"} | ||||
|     id = db.Column(db.Integer, primary_key=True, autoincrement=True) | ||||
|     value = db.Column(db.INTEGER) | ||||
|     text = db.Column(db.VARCHAR(140)) | ||||
|  | ||||
|  | ||||
| class Query_CustomerTypeList_Schema(ma.SQLAlchemyAutoSchema): | ||||
|     class Meta: | ||||
|         model = Query_CustomerTypeList | ||||
|     id = ma.auto_field() | ||||
|     text = ma.auto_field() | ||||
|     value = ma.auto_field() | ||||
|  | ||||
|  | ||||
|  | ||||
| class Query_ServiceTypeList(db.Model): | ||||
|     __tablename__ = 'query_service_type_list' | ||||
|     __bind_key__ = 'eamco' | ||||
|     __table_args__ = {"schema": "public"} | ||||
|     id = db.Column(db.Integer, primary_key=True, autoincrement=True) | ||||
|     value = db.Column(db.INTEGER) | ||||
|     text = db.Column(db.VARCHAR(140)) | ||||
|  | ||||
|  | ||||
| class Query_ServiceTypeList_Schema(ma.SQLAlchemyAutoSchema): | ||||
|     class Meta: | ||||
|         model = Query_ServiceTypeList | ||||
|     id = ma.auto_field() | ||||
|     text = ma.auto_field() | ||||
|     value = ma.auto_field() | ||||
|  | ||||
|  | ||||
|  | ||||
| class Query_DeliveryStatusList(db.Model): | ||||
|     __tablename__ = 'query_delivery_type_list' | ||||
|     __bind_key__ = 'eamco' | ||||
|     __table_args__ = {"schema": "public"} | ||||
|     id = db.Column(db.Integer, primary_key=True, autoincrement=True) | ||||
|     value = db.Column(db.INTEGER) | ||||
|     text = db.Column(db.VARCHAR(140)) | ||||
|  | ||||
|  | ||||
| class Query_DeliveryStatusList_Schema(ma.SQLAlchemyAutoSchema): | ||||
|     class Meta: | ||||
|         model = Query_DeliveryStatusList | ||||
|     id = ma.auto_field() | ||||
|     text = ma.auto_field() | ||||
|     value = ma.auto_field() | ||||
							
								
								
									
										126
									
								
								app/classes/service.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										126
									
								
								app/classes/service.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,126 @@ | ||||
|  | ||||
| from app import db, ma | ||||
| from datetime import datetime | ||||
|  | ||||
|  | ||||
| class Service_Call(db.Model): | ||||
|     __tablename__ = 'service_call' | ||||
|     __bind_key__ = 'eamco' | ||||
|     __table_args__ = {"schema": "public"} | ||||
|      | ||||
|     id = db.Column(db.Integer, | ||||
|                    primary_key=True, | ||||
|                    autoincrement=True, | ||||
|                    unique=False) | ||||
|      | ||||
|     customer_id = db.Column(db.INTEGER) | ||||
|     customer_last_name = db.Column(db.VARCHAR(250)) | ||||
|     customer_first_name = db.Column(db.VARCHAR(250)) | ||||
|     customer_town = db.Column(db.VARCHAR(140)) | ||||
|     customer_state = db.Column(db.INTEGER) | ||||
|     customer_zip = db.Column(db.VARCHAR(25)) | ||||
|     customer_apt = db.Column(db.VARCHAR(140)) | ||||
|     customer_address = db.Column(db.VARCHAR(1000)) | ||||
|  | ||||
|     #0 = closed | ||||
|     #1 = open | ||||
|     status = db.Column(db.INTEGER) | ||||
|  | ||||
|     # 0 = unknown | ||||
|     # 1 = cleaning / tuneup | ||||
|     # 2 = problem | ||||
|     # 3 = install | ||||
|     # 3 = callback | ||||
|     service_type = db.Column(db.INTEGER) | ||||
|     # when the call to service took place | ||||
|     when_called = db.Column(db.DATE(), default=datetime.utcnow()) | ||||
|     # what day the call will take place | ||||
|     scheduled_date = db.Column(db.DATE(), default=datetime.utcnow()) | ||||
|     # what day the call will take place | ||||
|     scheduled_time = db.Column(db.INTEGER) | ||||
|     # when the service took place | ||||
|     when_serviced = db.Column(db.DATE(), default=datetime.utcnow()) | ||||
|     # is the call finished or not | ||||
|     # 0  = open | ||||
|     #1 = finished | ||||
|     completed = db.Column(db.INTEGER) | ||||
|     tech_id = db.Column(db.INTEGER) | ||||
|     tech_first_name = db.Column(db.VARCHAR(300)) | ||||
|     tech_last_name = db.Column(db.VARCHAR(300)) | ||||
|  | ||||
|     payment_type = db.Column(db.INTEGER) | ||||
|     payment_card_id = db.Column(db.INTEGER) | ||||
|  | ||||
|  | ||||
| class Service_Call_schema(ma.SQLAlchemyAutoSchema): | ||||
|     class Meta: | ||||
|         model = Service_Call | ||||
|  | ||||
|  | ||||
| class Service_Call_Money(db.Model): | ||||
|     __tablename__ = 'service_money' | ||||
|     __bind_key__ = 'eamco' | ||||
|     __table_args__ = {"schema": "public"} | ||||
|      | ||||
|     id = db.Column(db.Integer, | ||||
|                    primary_key=True, | ||||
|                    autoincrement=True, | ||||
|                    unique=False) | ||||
|      | ||||
|     service_call_id = db.Column(db.INTEGER) | ||||
|     hours = db.Column(db.DECIMAL(50, 2)) | ||||
|     cost_per_hour = db.Column(db.DECIMAL(50, 2)) | ||||
|     parts_cost = db.Column(db.DECIMAL(50, 2)) | ||||
|  | ||||
|  | ||||
| class Service_Call_Money_schema(ma.SQLAlchemyAutoSchema): | ||||
|     class Meta: | ||||
|         model = Service_Call_Money | ||||
|  | ||||
|  | ||||
| class Service_Call_Notes_Dispatcher(db.Model): | ||||
|     __tablename__ = 'service_notes_dispatcher' | ||||
|     __bind_key__ = 'eamco' | ||||
|     __table_args__ = {"schema": "public"} | ||||
|      | ||||
|     id = db.Column(db.Integer, | ||||
|                    primary_key=True, | ||||
|                    autoincrement=True, | ||||
|                    unique=False) | ||||
|      | ||||
|     service_call_id = db.Column(db.INTEGER) | ||||
|     dispatcher_notes = db.Column(db.TEXT) | ||||
|     dispatcher_subject = db.Column(db.VARCHAR(1024)) | ||||
|     time_added = db.Column(db.TIMESTAMP(), default=datetime.utcnow()) | ||||
|     dispatcher_id = db.Column(db.INTEGER) | ||||
|     dispatcher_name = db.Column(db.VARCHAR(140)) | ||||
|      | ||||
|      | ||||
| class Service_Call_Notes_Dispatcher_schema(ma.SQLAlchemyAutoSchema): | ||||
|     class Meta: | ||||
|         model = Service_Call_Notes_Dispatcher | ||||
|  | ||||
|  | ||||
| class Service_Call_Notes_Technician(db.Model): | ||||
|     __tablename__ = 'service_notes_technician' | ||||
|     __bind_key__ = 'eamco' | ||||
|     __table_args__ = {"schema": "public"} | ||||
|      | ||||
|     id = db.Column(db.Integer, | ||||
|                    primary_key=True, | ||||
|                    autoincrement=True, | ||||
|                    unique=False) | ||||
|      | ||||
|     service_call_id = db.Column(db.INTEGER) | ||||
|     technician_comments = db.Column(db.TEXT) | ||||
|     time_added = db.Column(db.TIMESTAMP(), default=datetime.utcnow()) | ||||
|     technician_id = db.Column(db.INTEGER) | ||||
|     technician_name = db.Column(db.VARCHAR(140)) | ||||
|  | ||||
|  | ||||
| class Service_Call_Notes_Technician_schema(ma.SQLAlchemyAutoSchema): | ||||
|     class Meta: | ||||
|         model = Service_Call_Notes_Technician | ||||
|  | ||||
|  | ||||
|  | ||||
							
								
								
									
										29
									
								
								app/classes/stats_customer.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								app/classes/stats_customer.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,29 @@ | ||||
|  | ||||
| from app import db, ma, login_manager | ||||
| from datetime import datetime | ||||
|  | ||||
|  | ||||
| class Stats_Customer(db.Model): | ||||
|     __tablename__ = 'stats_customer' | ||||
|     __bind_key__ = 'eamco' | ||||
|     __table_args__ = {"schema": "public"} | ||||
|      | ||||
|     id = db.Column(db.Integer, | ||||
|                    primary_key=True, | ||||
|                    autoincrement=True, | ||||
|                    unique=False) | ||||
|      | ||||
|     total_calls = db.Column(db.INTEGER) | ||||
|     service_calls_total = db.Column(db.INTEGER) | ||||
|     service_calls_total_spent = db.Column(db.DECIMAL(50, 2)) | ||||
|     service_calls_total_profit = db.Column(db.DECIMAL(50, 2)) | ||||
|      | ||||
|      | ||||
|     oil_deliveries = db.Column(db.INTEGER) | ||||
|     oil_total_gallons = db.Column(db.INTEGER) | ||||
|     oil_total_spent = db.Column(db.DECIMAL(50, 2)) | ||||
|     oil_total_profit = db.Column(db.DECIMAL(50, 2)) | ||||
|      | ||||
| class Stats_Customer_schema(ma.SQLAlchemyAutoSchema): | ||||
|     class Meta: | ||||
|         model = Stats_Customer | ||||
							
								
								
									
										46
									
								
								app/classes/stats_employee.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										46
									
								
								app/classes/stats_employee.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,46 @@ | ||||
|  | ||||
| from app import db, ma, login_manager | ||||
| from datetime import datetime | ||||
|  | ||||
|  | ||||
| class Stats_Employee_Oil(db.Model): | ||||
|     __tablename__ = 'stats_employee_oil' | ||||
|     __bind_key__ = 'eamco' | ||||
|     __table_args__ = {"schema": "public"} | ||||
|      | ||||
|     id = db.Column(db.Integer, | ||||
|                    primary_key=True, | ||||
|                    autoincrement=True, | ||||
|                    unique=False) | ||||
|      | ||||
|     total_deliveries = db.Column(db.INTEGER) | ||||
|     total_gallons_delivered = db.Column(db.INTEGER) | ||||
|     total_primes = db.Column(db.INTEGER) | ||||
|     total_gallons_fuel = db.Column(db.INTEGER) | ||||
|     oil_total_profit_delivered = db.Column(db.DECIMAL(50, 2)) | ||||
|      | ||||
| class Stats_Employee_Oil_schema(ma.SQLAlchemyAutoSchema): | ||||
|     class Meta: | ||||
|         model = Stats_Employee_Oil | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| class Stats_Employee_Service(db.Model): | ||||
|     __tablename__ = 'stats_employee_service' | ||||
|     __bind_key__ = 'eamco' | ||||
|     __table_args__ = {"schema": "public"} | ||||
|      | ||||
|     id = db.Column(db.Integer, | ||||
|                    primary_key=True, | ||||
|                    autoincrement=True, | ||||
|                    unique=False) | ||||
|      | ||||
|     total_service_calls = db.Column(db.INTEGER) | ||||
|     total_service_calls_hours = db.Column(db.INTEGER) | ||||
|     total_gallons_fuel = db.Column(db.INTEGER) | ||||
|     total_amount_billed= db.Column(db.DECIMAL(50, 2)) | ||||
|     total_profit_made = db.Column(db.DECIMAL(50, 2)) | ||||
| class Stats_Employee_Service_schema(ma.SQLAlchemyAutoSchema): | ||||
|     class Meta: | ||||
|         model = Stats_Employee_Service | ||||
							
								
								
									
										27
									
								
								app/classes/stripe.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								app/classes/stripe.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,27 @@ | ||||
| from app import db, ma | ||||
| from datetime import datetime | ||||
|  | ||||
|  | ||||
|  | ||||
| class Delivery_Payment(db.Model): | ||||
|     __tablename__ = 'delivery_payment' | ||||
|     __bind_key__ = 'eamco' | ||||
|     __table_args__ = {"schema": "public"} | ||||
|  | ||||
|     id = db.Column(db.Integer, | ||||
|                    primary_key=True, | ||||
|                    autoincrement=True, | ||||
|                    unique=False) | ||||
|  | ||||
|     delivery_id = db.Column(db.INTEGER) | ||||
|     time_added = db.Column(db.TIMESTAMP(), default=datetime.utcnow()) | ||||
|     total_amount_oil = db.Column(db.DECIMAL(50, 2)) | ||||
|     total_amount_emergency = db.Column(db.DECIMAL(50, 2)) | ||||
|     total_amount_prime = db.Column(db.DECIMAL(50, 2)) | ||||
|     total_amount_fee = db.Column(db.DECIMAL(50, 2)) | ||||
|     total_amount = db.Column(db.DECIMAL(50, 2)) | ||||
|  | ||||
| class Delivery_Payment_schema(ma.SQLAlchemyAutoSchema): | ||||
|     class Meta: | ||||
|         model = Delivery_Payment | ||||
|  | ||||
							
								
								
									
										0
									
								
								app/common/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								app/common/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
								
								
									
										16
									
								
								app/common/decorators.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								app/common/decorators.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | ||||
| from flask_login import current_user | ||||
| from flask import abort | ||||
|  | ||||
| from functools import wraps | ||||
|  | ||||
| def login_required(f): | ||||
|     @wraps(f) | ||||
|  | ||||
|     def decorated_function(*args, **kwargs): | ||||
|         if current_user.is_authenticated: | ||||
|             pass | ||||
|         else: | ||||
|             abort(401) | ||||
|         return f(*args, **kwargs) | ||||
|  | ||||
|     return decorated_function | ||||
							
								
								
									
										8
									
								
								app/customer/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								app/customer/__init__.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | ||||
| # coding=utf-8 | ||||
| from flask import Blueprint | ||||
|  | ||||
|  | ||||
| customer = Blueprint('customer', __name__) | ||||
|  | ||||
|  | ||||
| from . import views | ||||
							
								
								
									
										198
									
								
								app/customer/views.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										198
									
								
								app/customer/views.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,198 @@ | ||||
| from flask import request, jsonify | ||||
| from flask_login import login_required | ||||
| from app.customer import customer | ||||
| from app import db | ||||
| from datetime import datetime | ||||
| from app.classes.cards import Card_Card | ||||
| from app.classes.customer import \ | ||||
|     Customer_Customer, \ | ||||
|     Customer_Customer_schema | ||||
| from app.classes.admin import Admin_Company | ||||
| import string | ||||
| import random | ||||
|  | ||||
| @customer.route("/all", methods=["GET"]) | ||||
| @login_required | ||||
| def all_customers_around(): | ||||
|     customer_list = db.session \ | ||||
|         .query(Customer_Customer) \ | ||||
|         .all() | ||||
|     customer_schema = Customer_Customer_schema(many=True) | ||||
|     return jsonify(customer_schema.dump(customer_list)) | ||||
|  | ||||
|  | ||||
| @customer.route("/all/<int:page>", methods=["GET"]) | ||||
| @login_required | ||||
| def all_customers(page): | ||||
|     """ | ||||
|     pagination all customers | ||||
|     """ | ||||
|  | ||||
|     per_page_amount = 50 | ||||
|     if page is None: | ||||
|         offset_limit = 0 | ||||
|     elif page == 1: | ||||
|         offset_limit = 0 | ||||
|     else: | ||||
|         offset_limit = (per_page_amount * page) - per_page_amount | ||||
|  | ||||
|     customer_list = db.session \ | ||||
|         .query(Customer_Customer) \ | ||||
|         .limit(per_page_amount).offset(offset_limit) | ||||
|  | ||||
|     customer_schema = Customer_Customer_schema(many=True) | ||||
|     return jsonify(customer_schema.dump(customer_list)) | ||||
|  | ||||
|  | ||||
| @customer.route("/<int:customer_id>", methods=["GET"]) | ||||
| def get_a_customer(customer_id): | ||||
|     """ | ||||
|     Checks auth token to ensure user is authenticated | ||||
|     """ | ||||
|     get_customer = (db.session | ||||
|         .query(Customer_Customer) | ||||
|         .filter(Customer_Customer.id == customer_id) | ||||
|         .first()) | ||||
|     print(get_customer) | ||||
|     customer_schema = Customer_Customer_schema(many=False) | ||||
|     return jsonify(customer_schema.dump(get_customer)) | ||||
|  | ||||
| def id_generator(size=6, chars=string.ascii_uppercase + string.digits): | ||||
|     return ''.join(random.choice(chars) for _ in range(size)) | ||||
|  | ||||
| @customer.route("/create", methods=["POST"]) | ||||
| @login_required | ||||
| def create_customer(): | ||||
|     """ | ||||
|     """ | ||||
|     now = datetime.utcnow() | ||||
|     get_company = db.session.query(Admin_Company).filter(Admin_Company.id == 1).first() | ||||
|  | ||||
|     starter_digits = str(get_company.account_prefix) + '-' + id_generator() | ||||
|  | ||||
|     made_account_number = starter_digits | ||||
|  | ||||
|     response_customer_last_name = request.json["customer_last_name"] | ||||
|     response_customer_first_name = request.json["customer_first_name"] | ||||
|     response_customer_town = request.json["customer_town"] | ||||
|     response_customer_state = request.json["customer_state"] | ||||
|     response_customer_zip = request.json["customer_zip"] | ||||
|     response_customer_email = request.json["customer_email"] | ||||
|     response_customer_automatic = request.json["customer_automatic"] | ||||
|     response_customer_home_type = request.json["customer_home_type"] | ||||
|     customer_phone_number = request.json["customer_phone_number"] | ||||
|     customer_address = request.json["customer_address"] | ||||
|     customer_apt = request.json["customer_apt"] | ||||
|     if response_customer_automatic is True: | ||||
|         auto_customer = 1 | ||||
|     else: | ||||
|         auto_customer = 0 | ||||
|  | ||||
|     int_customer_home_type = int(response_customer_home_type) | ||||
|     response_customer_zip = int(response_customer_zip) | ||||
|     response_customer_state = int(response_customer_state) | ||||
|  | ||||
|     new_customer = Customer_Customer( | ||||
|         account_number=made_account_number, | ||||
|         customer_last_name=response_customer_last_name, | ||||
|         customer_first_name=response_customer_first_name, | ||||
|         customer_town=response_customer_town, | ||||
|         customer_state=response_customer_state, | ||||
|         customer_zip=response_customer_zip, | ||||
|         customer_first_call=now, | ||||
|         customer_email=response_customer_email, | ||||
|         customer_automatic=auto_customer, | ||||
|         customer_home_type=int_customer_home_type, | ||||
|         customer_phone_number=customer_phone_number, | ||||
|         customer_address=customer_address, | ||||
|         customer_apt=customer_apt | ||||
|  | ||||
|     ) | ||||
|  | ||||
|     db.session.add(new_customer) | ||||
|     db.session.commit() | ||||
|  | ||||
|     return jsonify({ | ||||
|         "ok": True, | ||||
|         'user': { | ||||
|             'user_id': new_customer.id, | ||||
|             'user_name': new_customer.customer_last_name, | ||||
|             'user_email': new_customer.customer_email, | ||||
|         }, | ||||
|     }), 200 | ||||
|  | ||||
|  | ||||
| @customer.route("/edit/<int:customer_id>", methods=["PUT"]) | ||||
| @login_required | ||||
| def edit_customer(customer_id): | ||||
|     """ | ||||
|     """ | ||||
|     get_customer = (db.session | ||||
|                     .query(Customer_Customer) | ||||
|                     .filter(Customer_Customer.id == customer_id) | ||||
|                     .first()) | ||||
|     response_customer_last_name = request.json["customer_last_name"] | ||||
|     response_customer_first_name = request.json["customer_first_name"] | ||||
|     response_customer_town = request.json["customer_town"] | ||||
|     response_customer_state = request.json["customer_state"] | ||||
|     response_customer_zip = request.json["customer_zip"] | ||||
|     response_customer_phone_number = request.json["customer_phone_number"] | ||||
|     response_customer_email = request.json["customer_email"] | ||||
|     response_customer_automatic = request.json["customer_automatic"] | ||||
|     response_customer_home_type = request.json["customer_home_type"] | ||||
|     response_customer_address = request.json["customer_address"] | ||||
|  | ||||
|     get_customer.customer_address = response_customer_address | ||||
|     get_customer.customer_home_type = response_customer_home_type | ||||
|     get_customer.customer_automatic = response_customer_automatic | ||||
|     get_customer.customer_phone_number = response_customer_phone_number | ||||
|     get_customer.customer_last_name = response_customer_last_name | ||||
|     get_customer.customer_first_name = response_customer_first_name | ||||
|     get_customer.customer_town = response_customer_town | ||||
|     get_customer.customer_state = response_customer_state | ||||
|     get_customer.customer_zip = response_customer_zip | ||||
|     get_customer.customer_email = response_customer_email | ||||
|  | ||||
|     db.session.add(get_customer) | ||||
|     db.session.commit() | ||||
|  | ||||
|     return jsonify({ | ||||
|         "ok": True, | ||||
|         'user': { | ||||
|             'user_name': get_customer.customer_last_name, | ||||
|  | ||||
|             'user_email': get_customer.customer_email, | ||||
|         }, | ||||
|     }), 200 | ||||
|  | ||||
|  | ||||
| @customer.route("/delete/<int:customer_id>", methods=["DELETE"]) | ||||
| @login_required | ||||
| def delete_customer(customer_id): | ||||
|     """ | ||||
|     """ | ||||
|     get_customer = (db.session | ||||
|                     .query(Customer_Customer) | ||||
|                     .filter(Customer_Customer.id == customer_id) | ||||
|                     .first()) | ||||
|  | ||||
|     get_cards = (db.session | ||||
|                  .query(Card_Card) | ||||
|                  .filter(Card_Card.user_id == get_customer.id) | ||||
|                  .first()) | ||||
|  | ||||
|     if get_cards is not None: | ||||
|         db.session.delete(get_cards) | ||||
|  | ||||
|     db.session.delete(get_customer) | ||||
|     db.session.commit() | ||||
|     print("deleted") | ||||
|     return jsonify({ | ||||
|         "ok": True, | ||||
|         'user': { | ||||
|             'user_name': get_customer.customer_last_name, | ||||
|             'user_email': get_customer.customer_email, | ||||
|         }, | ||||
|     }), 200 | ||||
|  | ||||
|  | ||||
							
								
								
									
										8
									
								
								app/delivery/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								app/delivery/__init__.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | ||||
| # coding=utf-8 | ||||
| from flask import Blueprint | ||||
|  | ||||
|  | ||||
| delivery = Blueprint('delivery', __name__) | ||||
|  | ||||
|  | ||||
| from . import views | ||||
							
								
								
									
										686
									
								
								app/delivery/views.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										686
									
								
								app/delivery/views.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,686 @@ | ||||
| from flask import request, jsonify | ||||
| from flask_login import current_user | ||||
| from datetime import date | ||||
| from app.delivery import delivery | ||||
| from app import db | ||||
| from datetime import datetime | ||||
| from app.classes.customer import Customer_Customer | ||||
| from app.classes.delivery import (Delivery_Delivery, | ||||
|                                   Delivery_Delivery_schema, | ||||
|                                   Delivery_Notes_Driver, | ||||
|                                   Delivery_Payment, | ||||
|                                   Delivery_Payment_schema, | ||||
|                                   ) | ||||
| from app.classes.cards import Card_Card | ||||
| from app.classes.pricing import Pricing_Oil_Oil | ||||
| from app.classes.auth import Auth_User | ||||
| from app.classes.pricing import Pricing_Service_General | ||||
|  | ||||
| @delivery.route("/<int:delivery_id>", methods=["GET"]) | ||||
| def get_a_delivery(delivery_id): | ||||
|     """ | ||||
|     """ | ||||
|  | ||||
|     get_delivery = db.session\ | ||||
|                 .query(Delivery_Delivery)\ | ||||
|                 .filter(Delivery_Delivery.id == delivery_id)\ | ||||
|                 .first() | ||||
|  | ||||
|     return jsonify({ | ||||
|             "ok": True, | ||||
|             'delivery': { | ||||
|                 'id': get_delivery.id, | ||||
|                 'customer_id': get_delivery.customer_id, | ||||
|                 'delivery_expected_delivery_date': str(get_delivery.expected_delivery_date), | ||||
|                 'delivery_asked_for_fill': get_delivery.customer_asked_for_fill, | ||||
|                 'delivery_gallons_ordered': get_delivery.gallons_ordered, | ||||
|                 'delivery_dispatcher_notes': get_delivery.dispatcher_notes, | ||||
|                 'delivery_prime': get_delivery.prime, | ||||
|                 'delivery_same_day': get_delivery.same_day, | ||||
|                 'when_ordered': get_delivery.when_ordered, | ||||
|                 'customer_price': get_delivery.customer_price, | ||||
|                 'delivery_status': get_delivery.delivery_status, | ||||
|                 'payment_type': get_delivery.payment_type, | ||||
|                 'payment_card_id': get_delivery.payment_card_id, | ||||
|  | ||||
|             }, | ||||
|     }), 200 | ||||
|  | ||||
| @delivery.route("/order/<int:delivery_id>", methods=["GET"]) | ||||
| def get_a_specific_delivery(delivery_id): | ||||
|  | ||||
|     get_delivery = db.session\ | ||||
|                 .query(Delivery_Delivery)\ | ||||
|                 .filter(Delivery_Delivery.id == delivery_id)\ | ||||
|                 .first() | ||||
|     delivery_schema = Delivery_Delivery_schema(many=False) | ||||
|     return jsonify(delivery_schema.dump(get_delivery)) | ||||
|  | ||||
|  | ||||
| @delivery.route("/order/money/<int:delivery_id>", methods=["GET"]) | ||||
| def get_a_specific_delivery_money(delivery_id): | ||||
|  | ||||
|     get_delivery_money = db.session\ | ||||
|                 .query(Delivery_Payment)\ | ||||
|                 .filter(Delivery_Payment.id == delivery_id)\ | ||||
|                 .first() | ||||
|     delivery_schema = Delivery_Payment_schema(many=False) | ||||
|     return jsonify(delivery_schema.dump(get_delivery_money)) | ||||
|  | ||||
|  | ||||
| @delivery.route("/cash/<int:delivery_id>/<int:type_of_payment>", methods=["PUT"]) | ||||
| def update_a_delivery_payment(delivery_id, type_of_payment): | ||||
|     """ | ||||
|     This update  a delivery for example if user updates to a fill | ||||
|     """ | ||||
|  | ||||
|     get_delivery = (db.session | ||||
|         .query(Delivery_Delivery) | ||||
|         .filter(Delivery_Delivery.id == delivery_id) | ||||
|         .first()) | ||||
|  | ||||
|     get_delivery.payment_type = type_of_payment | ||||
|  | ||||
|     db.session.add(get_delivery) | ||||
|     db.session.commit() | ||||
|  | ||||
|     return jsonify({"ok": True}), 200 | ||||
|  | ||||
|  | ||||
| @delivery.route("/all", methods=["GET"]) | ||||
| def get_deliveries_not_delivered_all(): | ||||
|     """ | ||||
|     This will get deliveries not done | ||||
|     """ | ||||
|  | ||||
|     deliveries = db.session \ | ||||
|         .query(Delivery_Delivery) \ | ||||
|         .filter(Delivery_Delivery.delivery_status != 1) \ | ||||
|         .filter(Delivery_Delivery.delivery_status != 3) \ | ||||
|         .all() | ||||
|  | ||||
|     customer_schema = Delivery_Delivery_schema(many=True) | ||||
|     return jsonify(customer_schema.dump(deliveries)) | ||||
|  | ||||
|  | ||||
| @delivery.route("/customer/<int:customer_id>/<int:page>", methods=["GET"]) | ||||
| def get_deliveries_from_customer(customer_id, page): | ||||
|     """ | ||||
|     This will get deliveries not done | ||||
|     """ | ||||
|     per_page_amount = 50 | ||||
|     if page is None: | ||||
|         offset_limit = 0 | ||||
|     elif page == 1: | ||||
|         offset_limit = 0 | ||||
|     else: | ||||
|         offset_limit = (per_page_amount * page) - per_page_amount | ||||
|  | ||||
|     deliveries = db.session \ | ||||
|         .query(Delivery_Delivery) \ | ||||
|         .filter(Delivery_Delivery.customer_id == customer_id) \ | ||||
|         .limit(per_page_amount).offset(offset_limit) | ||||
|  | ||||
|     customer_schema = Delivery_Delivery_schema(many=True) | ||||
|     return jsonify(customer_schema.dump(deliveries)) | ||||
|  | ||||
| @delivery.route("/all/<int:page>", methods=["GET"]) | ||||
| def get_deliveries_not_delivered(page): | ||||
|      | ||||
|     """ | ||||
|     This will get deliveries not done | ||||
|     """ | ||||
|     per_page_amount = 50 | ||||
|     if page is None: | ||||
|         offset_limit = 0 | ||||
|     elif page == 1: | ||||
|         offset_limit = 0 | ||||
|     else: | ||||
|         offset_limit = (per_page_amount * page) - per_page_amount | ||||
|  | ||||
|     deliveries = db.session\ | ||||
|                         .query(Delivery_Delivery)\ | ||||
|                         .filter(Delivery_Delivery.delivery_status == 0)\ | ||||
|                         .order_by(Delivery_Delivery.when_ordered.desc())\ | ||||
|                         .limit(per_page_amount).offset(offset_limit) | ||||
|  | ||||
|     customer_schema = Delivery_Delivery_schema(many=True) | ||||
|     return jsonify(customer_schema.dump(deliveries)) | ||||
|  | ||||
| @delivery.route("/waiting/<int:page>", methods=["GET"]) | ||||
| def get_deliveries_waiting(page): | ||||
|     """ | ||||
|     This will get deliveries not done | ||||
|     """ | ||||
|     per_page_amount = 50 | ||||
|     if page is None: | ||||
|         offset_limit = 0 | ||||
|     elif page == 1: | ||||
|         offset_limit = 0 | ||||
|     else: | ||||
|         offset_limit = (per_page_amount * page) - per_page_amount | ||||
|  | ||||
|     deliveries = db.session \ | ||||
|         .query(Delivery_Delivery) \ | ||||
|         .filter(Delivery_Delivery.delivery_status == 0) \ | ||||
|         .order_by(Delivery_Delivery.when_ordered.desc()) \ | ||||
|         .limit(per_page_amount).offset(offset_limit) | ||||
|  | ||||
|     customer_schema = Delivery_Delivery_schema(many=True) | ||||
|     return jsonify(customer_schema.dump(deliveries)) | ||||
|  | ||||
| @delivery.route("/delivered/<int:page>", methods=["GET"]) | ||||
| def get_deliveries_delivered(page): | ||||
|     """ | ||||
|     This will get deliveries not done | ||||
|     """ | ||||
|     per_page_amount = 50 | ||||
|     if page is None: | ||||
|         offset_limit = 0 | ||||
|     elif page == 1: | ||||
|         offset_limit = 0 | ||||
|     else: | ||||
|         offset_limit = (per_page_amount * page) - per_page_amount | ||||
|  | ||||
|     deliveries = db.session \ | ||||
|         .query(Delivery_Delivery) \ | ||||
|         .filter(Delivery_Delivery.delivery_status == 1) \ | ||||
|         .order_by(Delivery_Delivery.when_ordered.desc()) \ | ||||
|         .limit(per_page_amount).offset(offset_limit) | ||||
|  | ||||
|     customer_schema = Delivery_Delivery_schema(many=True) | ||||
|     return jsonify(customer_schema.dump(deliveries)) | ||||
|  | ||||
| @delivery.route("/outfordelivery/<int:page>", methods=["GET"]) | ||||
| def get_deliveries_outfordelivery(page): | ||||
|     """ | ||||
|     This will get deliveries not done | ||||
|     """ | ||||
|     per_page_amount = 50 | ||||
|     if page is None: | ||||
|         offset_limit = 0 | ||||
|     elif page == 1: | ||||
|         offset_limit = 0 | ||||
|     else: | ||||
|         offset_limit = (per_page_amount * page) - per_page_amount | ||||
|  | ||||
|     deliveries = db.session \ | ||||
|         .query(Delivery_Delivery) \ | ||||
|         .filter(Delivery_Delivery.delivery_status == 2) \ | ||||
|         .order_by(Delivery_Delivery.when_ordered.desc()) \ | ||||
|         .limit(per_page_amount).offset(offset_limit) | ||||
|  | ||||
|     customer_schema = Delivery_Delivery_schema(many=True) | ||||
|     return jsonify(customer_schema.dump(deliveries)) | ||||
|  | ||||
| @delivery.route("/finalized/<int:page>", methods=["GET"]) | ||||
| def get_deliveries_finalized(page): | ||||
|     """ | ||||
|     This will get deliveries not done | ||||
|     """ | ||||
|     per_page_amount = 50 | ||||
|     if page is None: | ||||
|         offset_limit = 0 | ||||
|     elif page == 1: | ||||
|         offset_limit = 0 | ||||
|     else: | ||||
|         offset_limit = (per_page_amount * page) - per_page_amount | ||||
|  | ||||
|     deliveries = db.session \ | ||||
|         .query(Delivery_Delivery) \ | ||||
|         .filter(Delivery_Delivery.delivery_status == 10) \ | ||||
|         .order_by(Delivery_Delivery.when_ordered.desc()) \ | ||||
|         .limit(per_page_amount).offset(offset_limit) | ||||
|  | ||||
|     customer_schema = Delivery_Delivery_schema(many=True) | ||||
|     return jsonify(customer_schema.dump(deliveries)) | ||||
|  | ||||
|  | ||||
|  | ||||
| @delivery.route("/cancelled/<int:page>", methods=["GET"]) | ||||
| def get_deliveries_cancelled(page): | ||||
|     """ | ||||
|     This will get deliveries not done | ||||
|     """ | ||||
|     per_page_amount = 50 | ||||
|     if page is None: | ||||
|         offset_limit = 0 | ||||
|     elif page == 1: | ||||
|         offset_limit = 0 | ||||
|     else: | ||||
|         offset_limit = (per_page_amount * page) - per_page_amount | ||||
|  | ||||
|     deliveries = db.session \ | ||||
|         .query(Delivery_Delivery) \ | ||||
|         .filter(Delivery_Delivery.delivery_status == 3) \ | ||||
|         .order_by(Delivery_Delivery.when_ordered.desc()) \ | ||||
|         .limit(per_page_amount).offset(offset_limit) | ||||
|  | ||||
|     customer_schema = Delivery_Delivery_schema(many=True) | ||||
|     return jsonify(customer_schema.dump(deliveries)) | ||||
|  | ||||
|  | ||||
| @delivery.route("/partialdelivery/<int:page>", methods=["GET"]) | ||||
| def get_deliveries_partial(page): | ||||
|     """ | ||||
|     This will get deliveries not done | ||||
|     """ | ||||
|     per_page_amount = 50 | ||||
|     if page is None: | ||||
|         offset_limit = 0 | ||||
|     elif page == 1: | ||||
|         offset_limit = 0 | ||||
|     else: | ||||
|         offset_limit = (per_page_amount * page) - per_page_amount | ||||
|  | ||||
|     deliveries = db.session \ | ||||
|         .query(Delivery_Delivery) \ | ||||
|         .filter(Delivery_Delivery.delivery_status == 4) \ | ||||
|         .order_by(Delivery_Delivery.when_ordered.desc()) \ | ||||
|         .limit(per_page_amount).offset(offset_limit) | ||||
|  | ||||
|     customer_schema = Delivery_Delivery_schema(many=True) | ||||
|     return jsonify(customer_schema.dump(deliveries)) | ||||
|  | ||||
| @delivery.route("/issue/<int:page>", methods=["GET"]) | ||||
| def get_deliveries_issue(page): | ||||
|     """ | ||||
|     This will get deliveries not done | ||||
|     """ | ||||
|     per_page_amount = 50 | ||||
|     if page is None: | ||||
|         offset_limit = 0 | ||||
|     elif page == 1: | ||||
|         offset_limit = 0 | ||||
|     else: | ||||
|         offset_limit = (per_page_amount * page) - per_page_amount | ||||
|  | ||||
|     deliveries = db.session \ | ||||
|         .query(Delivery_Delivery) \ | ||||
|         .filter(Delivery_Delivery.delivery_status == 5) \ | ||||
|         .order_by(Delivery_Delivery.when_ordered.desc()) \ | ||||
|         .limit(per_page_amount).offset(offset_limit) | ||||
|  | ||||
|     customer_schema = Delivery_Delivery_schema(many=True) | ||||
|     return jsonify(customer_schema.dump(deliveries)) | ||||
|  | ||||
|  | ||||
| @delivery.route("/time/today", methods=["GET"]) | ||||
| def get_deliveries_today(): | ||||
|     """ | ||||
|     This will get today's deliveries | ||||
|     """ | ||||
|  | ||||
|     deliveries = db.session \ | ||||
|         .query(Delivery_Delivery) \ | ||||
|         .filter(Delivery_Delivery.expected_delivery_date == date.today()) \ | ||||
|         .all() | ||||
|  | ||||
|     customer_schema = Delivery_Delivery_schema(many=True) | ||||
|     return jsonify(customer_schema.dump(deliveries)) | ||||
|  | ||||
| @delivery.route("/amount/<int:delivery_id>", methods=["GET"]) | ||||
| def get_deliveries_amount_total(delivery_id): | ||||
|     """ | ||||
|     This will get  deliveries totals | ||||
|     """ | ||||
|  | ||||
|     delivery_amount = db.session \ | ||||
|         .query(Delivery_Payment) \ | ||||
|         .filter(Delivery_Payment.delivery_id == delivery_id) \ | ||||
|         .all() | ||||
|  | ||||
|     delivery_schema = Delivery_Delivery_schema(many=False) | ||||
|     return jsonify(delivery_schema.dump(delivery_amount)) | ||||
|  | ||||
|  | ||||
| @delivery.route("/edit/<int:delivery_id>", methods=["POST"]) | ||||
| def edit_a_delivery(delivery_id): | ||||
|     """ | ||||
|     This will create a delivery using a customer id | ||||
|     """ | ||||
|     get_delivery = db.session \ | ||||
|         .query(Delivery_Delivery) \ | ||||
|         .filter(Delivery_Delivery.id == delivery_id) \ | ||||
|         .first() | ||||
|  | ||||
|     get_today_price = db.session \ | ||||
|         .query(Pricing_Oil_Oil) \ | ||||
|         .order_by(Pricing_Oil_Oil.id.desc()) \ | ||||
|         .first() | ||||
|  | ||||
|     get_customer = db.session \ | ||||
|         .query(Customer_Customer) \ | ||||
|         .filter(Customer_Customer.id == get_delivery.customer_id) \ | ||||
|         .first() | ||||
|  | ||||
|     if not get_delivery: | ||||
|         return jsonify({"ok": False}), 200 | ||||
|     else: | ||||
|  | ||||
|         gallons_ordered = request.json["gallons_ordered"] | ||||
|         delivery_status = request.json["delivery_status"] | ||||
|         when_to_deliver = request.json["expected_delivery_date"] | ||||
|         dispatcher_notes_taken = request.json["dispatcher_notes_taken"] | ||||
|  | ||||
|         customer_wants_fill = request.json["customer_asked_for_fill"] | ||||
|  | ||||
|         card_payment = request.json["credit"] | ||||
|         cash_payment = request.json["cash"] | ||||
|  | ||||
|  | ||||
|         if request.json["credit_card_id"]: | ||||
|             card_payment_id = request.json["credit_card_id"] | ||||
|         else: | ||||
|             card_payment_id = None | ||||
|  | ||||
|  | ||||
|         if card_payment_id is not None: | ||||
|             get_card = (db.session | ||||
|                         .query(Card_Card) | ||||
|                         .filter(Card_Card.id == card_payment_id) | ||||
|                         .filter(Card_Card.user_id == get_customer.id) | ||||
|                         .first()) | ||||
|             card_id_from_customer = get_card.id | ||||
|         else: | ||||
|             card_id_from_customer = None | ||||
|  | ||||
|         if cash_payment is True and card_payment is False: | ||||
|             delivery_payment_method = 0 | ||||
|         elif card_payment is True and cash_payment is False: | ||||
|             delivery_payment_method = 1 | ||||
|  | ||||
|         elif card_payment is True and cash_payment is True: | ||||
|             delivery_payment_method = 2 | ||||
|         else: | ||||
|             delivery_payment_method = 3 | ||||
|  | ||||
|         if customer_wants_fill is True: | ||||
|             customer_wants_fill = 1 | ||||
|         else: | ||||
|             customer_wants_fill = 0 | ||||
|  | ||||
|         same_day_info = request.json["same_day"] | ||||
|         if same_day_info is True: | ||||
|             same_day_info = 1 | ||||
|         else: | ||||
|             same_day_info = 0 | ||||
|  | ||||
|         prime_info = request.json["prime"] | ||||
|         if prime_info is True: | ||||
|             prime_info = 1 | ||||
|         else: | ||||
|             prime_info = 0 | ||||
|  | ||||
|         get_delivery.delivery_status = delivery_status | ||||
|         get_delivery.gallons_ordered = gallons_ordered | ||||
|         get_delivery.customer_asked_for_fill = customer_wants_fill | ||||
|         get_delivery.expected_delivery_date = when_to_deliver | ||||
|         get_delivery.dispatcher_notes = dispatcher_notes_taken | ||||
|         get_delivery.prime = prime_info | ||||
|         get_delivery.same_day = same_day_info | ||||
|         get_delivery.gallons_ordered = gallons_ordered | ||||
|         get_delivery.payment_type = delivery_payment_method | ||||
|         get_delivery.payment_card_id = card_id_from_customer | ||||
|  | ||||
|         db.session.add(get_delivery) | ||||
|         db.session.commit() | ||||
|  | ||||
|         return jsonify({ | ||||
|             "ok": True, | ||||
|             'customer': { | ||||
|                 'user_id': get_customer.id, | ||||
|             }, | ||||
|         }), 200 | ||||
|  | ||||
|  | ||||
| @delivery.route("/create/<int:user_id>", methods=["POST"]) | ||||
| def create_a_delivery(user_id): | ||||
|     """ | ||||
|     This will create a delivery using a customer id | ||||
|     """ | ||||
|     get_customer = db.session\ | ||||
|         .query(Customer_Customer)\ | ||||
|         .filter(Customer_Customer.id == user_id)\ | ||||
|         .first() | ||||
|          | ||||
|     get_today_price = db.session\ | ||||
|         .query(Pricing_Oil_Oil)\ | ||||
|         .order_by(Pricing_Oil_Oil.id.desc())\ | ||||
|         .first()  | ||||
|  | ||||
|     get_service_prices = (db.session | ||||
|                           .query(Pricing_Service_General) | ||||
|                           .order_by(Pricing_Service_General.id.desc()) | ||||
|                           .first()) | ||||
|     if not get_customer: | ||||
|         return jsonify({"ok": False}), 200 | ||||
|     else: | ||||
|         gallons_ordered = request.json["gallons_ordered"] | ||||
|         customer_wants_fill = request.json["customer_asked_for_fill"] | ||||
|         when_to_deliver = request.json["expected_delivery_date"] | ||||
|         dispatcher_notes_taken = request.json["dispatcher_notes_taken"] | ||||
|         prime_info = request.json["prime"] | ||||
|         same_day_info = request.json["same_day"] | ||||
|  | ||||
|         card_payment = request.json["credit"] | ||||
|         cash_payment = request.json["cash"] | ||||
|         try: | ||||
|             if request.json["credit_card_id"]: | ||||
|                 card_payment_id = request.json["credit_card_id"] | ||||
|             else: | ||||
|                 card_payment_id = None | ||||
|         except: | ||||
|             card_payment_id = None | ||||
|  | ||||
|         if card_payment_id is not None: | ||||
|             get_card = (db.session | ||||
|                         .query(Card_Card) | ||||
|                         .filter(Card_Card.id == card_payment_id) | ||||
|                         .filter(Card_Card.user_id == get_customer.id) | ||||
|                         .first()) | ||||
|             card_id_from_customer = get_card.id | ||||
|         else: | ||||
|             card_id_from_customer = None | ||||
|  | ||||
|         if cash_payment is True and card_payment is False: | ||||
|             delivery_payment_method = 0 | ||||
|         elif card_payment is True and cash_payment is False: | ||||
|             delivery_payment_method = 1 | ||||
|  | ||||
|         elif card_payment is True and cash_payment is True: | ||||
|             delivery_payment_method = 2 | ||||
|         else: | ||||
|             delivery_payment_method = 3 | ||||
|  | ||||
|         if customer_wants_fill is True: | ||||
|             customer_fill_up = 1 | ||||
|             gallons_ordered = 250 | ||||
|         else: | ||||
|             customer_fill_up = 0 | ||||
|  | ||||
|         if prime_info is True: | ||||
|             prime_asked = 1 | ||||
|         else: | ||||
|             prime_asked = 0 | ||||
|  | ||||
|         if same_day_info is True: | ||||
|             same_day_asked = 1 | ||||
|         else: | ||||
|             same_day_asked = 0 | ||||
|  | ||||
|         date_object = datetime.strptime(when_to_deliver, '%Y-%m-%d').date() | ||||
|  | ||||
|         customer_filled_name = get_customer.customer_last_name + ' ' + get_customer.customer_first_name | ||||
|         now = datetime.utcnow() | ||||
|  | ||||
|  | ||||
|         # Pricing | ||||
|         if customer_fill_up == 1: | ||||
|             precharge_amount = (250 * get_today_price.price_for_customer) | ||||
|         else: | ||||
|             precharge_amount = int(gallons_ordered) * get_today_price.price_for_customer | ||||
|  | ||||
|         if same_day_asked == 1 and prime_asked == 0: | ||||
|             total_precharge_amount = precharge_amount + get_service_prices.price_same_day | ||||
|  | ||||
|         elif prime_asked == 1 and same_day_asked == 0: | ||||
|             total_precharge_amount = precharge_amount + get_service_prices.price_prime | ||||
|  | ||||
|         else: | ||||
|             total_precharge_amount = precharge_amount + get_service_prices.price_prime + get_service_prices.price_same_day | ||||
|  | ||||
|  | ||||
|         new_delivery = Delivery_Delivery( | ||||
|             customer_id=get_customer.id, | ||||
|             customer_address=get_customer.customer_address, | ||||
|             customer_name=customer_filled_name, | ||||
|             customer_town=get_customer.customer_town, | ||||
|             customer_state=get_customer.customer_state, | ||||
|             customer_zip=get_customer.customer_zip, | ||||
|             gallons_ordered=gallons_ordered, | ||||
|             customer_asked_for_fill=customer_fill_up, | ||||
|             gallons_delivered=0, | ||||
|             customer_filled=0, | ||||
|             delivery_status=0, | ||||
|             when_ordered=now, | ||||
|             when_delivered=None, | ||||
|             expected_delivery_date=date_object, | ||||
|             automatic=get_customer.customer_automatic, | ||||
|             oil_id=get_today_price.id, | ||||
|             supplier_price=get_today_price.price_from_supplier, | ||||
|             customer_price=get_today_price.price_for_customer, | ||||
|             customer_temperature=None, | ||||
|             dispatcher_notes=dispatcher_notes_taken, | ||||
|             prime=prime_asked, | ||||
|             same_day=same_day_asked, | ||||
|             payment_type=delivery_payment_method, | ||||
|             payment_card_id=card_id_from_customer, | ||||
|             pre_charge_amount=total_precharge_amount, | ||||
|             total_price=precharge_amount, | ||||
|             final_price=0, | ||||
|  | ||||
|         ) | ||||
|          | ||||
|         db.session.add(new_delivery) | ||||
|         db.session.commit() | ||||
|  | ||||
|         return jsonify({ | ||||
|             "ok": True, | ||||
|             'delivery_id': new_delivery.id, | ||||
|         }), 200 | ||||
|  | ||||
|  | ||||
|  | ||||
| @delivery.route("/cancel/<int:delivery_id>", methods=["POST"]) | ||||
| def cancel_a_delivery(delivery_id): | ||||
|     """ | ||||
|     This will cancel a delivery | ||||
|     """ | ||||
|     get_delivery = db.session\ | ||||
|         .query(Delivery_Delivery)\ | ||||
|         .filter(Delivery_Delivery.id == delivery_id)\ | ||||
|         .first() | ||||
|         | ||||
|     get_delivery.delivery_status = 3 | ||||
|     db.session.add(get_delivery) | ||||
|     db.session.commit() | ||||
|      | ||||
|     return jsonify({"ok": True}), 200 | ||||
|  | ||||
|  | ||||
| @delivery.route("/delivered/<int:delivery_id>", methods=["POST"]) | ||||
| def mark_as_delivered(delivery_id): | ||||
|     """ | ||||
|     This will mark the delivery as delivered | ||||
|     """ | ||||
|     # how many gallons delivered | ||||
|     gallons_put_into_tank = request.json["gallons_put_into_tank"] | ||||
|     # was the tank full or not | ||||
|     was_it_filled = request.json["filled"] | ||||
|      | ||||
|     get_delivery = db.session\ | ||||
|         .query(Delivery_Delivery)\ | ||||
|         .filter(Delivery_Delivery.id == delivery_id)\ | ||||
|         .first() | ||||
|         | ||||
|     get_delivery.delivery_status = 1 | ||||
|     get_delivery.gallons_delivered = gallons_put_into_tank | ||||
|     get_delivery.customer_filled = was_it_filled | ||||
|  | ||||
|     db.session.add(get_delivery) | ||||
|     db.session.commit() | ||||
|      | ||||
|     return jsonify({"ok": True}), 200 | ||||
|  | ||||
|  | ||||
| @delivery.route("/partial/<int:delivery_id>", methods=["POST"]) | ||||
| def partial_delivery(delivery_id): | ||||
|     """ | ||||
|     This will mark the delivery as delivered | ||||
|     """ | ||||
|     # how many gallons delivered | ||||
|     gallons_put_into_tank = request.json["gallons_put_into_tank"] | ||||
|      | ||||
|     get_delivery = db.session\ | ||||
|         .query(Delivery_Delivery)\ | ||||
|         .filter(Delivery_Delivery.id == delivery_id)\ | ||||
|         .first() | ||||
|         | ||||
|     get_delivery.delivery_status = 4 | ||||
|     get_delivery.gallons_delivered = gallons_put_into_tank | ||||
|     get_delivery.customer_filled = 0 | ||||
|  | ||||
|     db.session.add(get_delivery) | ||||
|     db.session.commit() | ||||
|      | ||||
|     return jsonify({"ok": True}), 200 | ||||
|  | ||||
|  | ||||
| @delivery.route("/note/technician/<int:delivery_id>", methods=["PUT"]) | ||||
| def delivery_note_driver(delivery_id): | ||||
|      | ||||
|     """ | ||||
|     Update a service call diagnosis | ||||
|     """    | ||||
|     # | ||||
|     driver_notes = request.json["driver_notes"] | ||||
|     now = datetime.utcnow() | ||||
|      | ||||
|     user = db.session\ | ||||
|         .query(Auth_User)\ | ||||
|         .filter(Auth_User.id == current_user.id)\ | ||||
|         .first() | ||||
|          | ||||
|     get_delivery = db.session\ | ||||
|         .query(Delivery_Delivery)\ | ||||
|         .filter(Delivery_Delivery.id == delivery_id)\ | ||||
|         .first() | ||||
|          | ||||
|     create_new_note = Delivery_Notes_Driver( | ||||
|         delivery_id=get_delivery.id, | ||||
|         driver_comments=driver_notes, | ||||
|         time_added=now, | ||||
|         driver_id=user.id, | ||||
|         driver_name=user.user, | ||||
|     ) | ||||
|      | ||||
|     db.session.add(create_new_note) | ||||
|     db.session.commit() | ||||
|      | ||||
|     return jsonify({"ok": True}), 200 | ||||
|  | ||||
|  | ||||
| @delivery.route("/delete/<int:delivery_id>", methods=["DELETE"]) | ||||
| def service_delete_call(delivery_id): | ||||
|     """ | ||||
|     delete a delivery call | ||||
|     """ | ||||
|     get_call_to_delete = (db.session | ||||
|                           .query(Delivery_Delivery) | ||||
|                           .filter(Delivery_Delivery.id == delivery_id) | ||||
|                           .first()) | ||||
|     db.session.delete(get_call_to_delete) | ||||
|     db.session.commit() | ||||
|  | ||||
|     return jsonify({"ok": True}), 200 | ||||
							
								
								
									
										7
									
								
								app/delivery_data/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								app/delivery_data/__init__.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| # coding=utf-8 | ||||
|  | ||||
| from flask import Blueprint | ||||
|  | ||||
| delivery_data = Blueprint('delivery_data', __name__) | ||||
|  | ||||
| from . import views | ||||
							
								
								
									
										123
									
								
								app/delivery_data/views.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										123
									
								
								app/delivery_data/views.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,123 @@ | ||||
| from flask import request, jsonify | ||||
| from flask_login import current_user | ||||
| from datetime import date | ||||
| from app.delivery_data import delivery_data | ||||
| from app import db | ||||
| from datetime import datetime | ||||
| from app.classes.customer import Customer_Customer | ||||
| from app.classes.delivery import (Delivery_Delivery, | ||||
|                                   Delivery_Delivery_schema, | ||||
|                                   Delivery_Notes_Driver, | ||||
|                                   Delivery_Payment, | ||||
|                                   Delivery_Payment_schema, | ||||
|                                   ) | ||||
| from app.classes.cards import Card_Card | ||||
| from app.classes.pricing import Pricing_Oil_Oil | ||||
| from app.classes.auth import Auth_User | ||||
| from app.classes.pricing import Pricing_Service_General | ||||
|  | ||||
|  | ||||
|  | ||||
| @delivery_data.route("/pending", methods=["GET"]) | ||||
| def pending_delivery(): | ||||
|     """ | ||||
|     Get deliveries that have been delivered | ||||
|     """ | ||||
|  | ||||
|     delivery_ticket = (db.session | ||||
|                      .query(Delivery_Delivery) | ||||
|                      .filter(Delivery_Delivery.delivery_status!=0) | ||||
|                      .all()) | ||||
|  | ||||
|  | ||||
|     delivery_schema = Delivery_Delivery_schema(many=True) | ||||
|     return jsonify(delivery_schema.dump(delivery_ticket)) | ||||
|  | ||||
|  | ||||
|  | ||||
| @delivery_data.route("/finalize/<int:delivery_id>", methods=["PUT"]) | ||||
| def finalize_delivery(delivery_id): | ||||
|     """ | ||||
|     Get deliveries that have been delivered | ||||
|     """ | ||||
|  | ||||
|     """ | ||||
|     Finalizes a delivery from office | ||||
|     """ | ||||
|     get_delivery = db.session \ | ||||
|         .query(Delivery_Delivery) \ | ||||
|         .filter(Delivery_Delivery.id == delivery_id) \ | ||||
|         .first() | ||||
|  | ||||
|     get_today_price = db.session \ | ||||
|         .query(Pricing_Oil_Oil) \ | ||||
|         .order_by(Pricing_Oil_Oil.id.desc()) \ | ||||
|         .first() | ||||
|  | ||||
|     get_customer = db.session \ | ||||
|         .query(Customer_Customer) \ | ||||
|         .filter(Customer_Customer.id == get_delivery.customer_id) \ | ||||
|         .first() | ||||
|  | ||||
|  | ||||
|     gallons_delivered = request.json["gallons_delivered"] | ||||
|     card_payment = request.json["credit"] | ||||
|     cash_payment = request.json["cash"] | ||||
|  | ||||
|     if request.json["credit_card_id"]: | ||||
|         card_payment_id = request.json["credit_card_id"] | ||||
|     else: | ||||
|         card_payment_id = None | ||||
|  | ||||
|  | ||||
|     if card_payment_id is not None: | ||||
|         get_card = (db.session | ||||
|                     .query(Card_Card) | ||||
|                     .filter(Card_Card.id == card_payment_id) | ||||
|                     .filter(Card_Card.user_id == get_customer.id) | ||||
|                     .first()) | ||||
|         card_id_from_customer = get_card.id | ||||
|     else: | ||||
|         card_id_from_customer = None | ||||
|  | ||||
|     if cash_payment is True and card_payment is False: | ||||
|         delivery_payment_method = 0 | ||||
|     elif card_payment is True and cash_payment is False: | ||||
|         delivery_payment_method = 1 | ||||
|  | ||||
|     elif card_payment is True and cash_payment is True: | ||||
|         delivery_payment_method = 2 | ||||
|     else: | ||||
|         delivery_payment_method = 3 | ||||
|  | ||||
|  | ||||
|  | ||||
|     same_day_info = request.json["same_day"] | ||||
|     if same_day_info is True: | ||||
|         same_day_info = 1 | ||||
|     else: | ||||
|         same_day_info = 0 | ||||
|  | ||||
|     prime_info = request.json["prime"] | ||||
|     if prime_info is True: | ||||
|         prime_info = 1 | ||||
|     else: | ||||
|         prime_info = 0 | ||||
|  | ||||
|     get_delivery.gallons_delivered = gallons_delivered | ||||
|     get_delivery.prime = prime_info | ||||
|     get_delivery.same_day = same_day_info | ||||
|     get_delivery.payment_type = delivery_payment_method | ||||
|     get_delivery.payment_card_id = card_id_from_customer | ||||
|  | ||||
|     get_delivery.delivery_status = 10 | ||||
|     db.session.add(get_delivery) | ||||
|     db.session.commit() | ||||
|  | ||||
|     return jsonify({ | ||||
|         "ok": True, | ||||
|         'delivery': { | ||||
|             'id': get_delivery.id, | ||||
|         }, | ||||
|     }), 200 | ||||
|  | ||||
							
								
								
									
										8
									
								
								app/employees/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								app/employees/__init__.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | ||||
| # coding=utf-8 | ||||
| from flask import Blueprint | ||||
|  | ||||
|  | ||||
| employees = Blueprint('employees', __name__) | ||||
|  | ||||
|  | ||||
| from . import views | ||||
							
								
								
									
										176
									
								
								app/employees/views.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										176
									
								
								app/employees/views.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,176 @@ | ||||
| from flask import request, jsonify | ||||
| from flask_login import current_user | ||||
| from sqlalchemy import or_ | ||||
| from datetime import date, timedelta | ||||
| from flask_login import login_required | ||||
| from app.employees import employees | ||||
| from app import db | ||||
| from datetime import datetime | ||||
| from app.classes.employee import Employee_Employee, Employee_Employee_schema | ||||
|  | ||||
|  | ||||
| @employees.route("/<int:userid>", methods=["GET"]) | ||||
| @login_required | ||||
| def get_specific_employee(userid): | ||||
|     employee = db.session \ | ||||
|         .query(Employee_Employee) \ | ||||
|         .filter(Employee_Employee.id == userid) \ | ||||
|         .first() | ||||
|     employee_schema = Employee_Employee_schema(many=False) | ||||
|     return jsonify(employee_schema.dump(employee)) | ||||
|  | ||||
|  | ||||
| @employees.route("/userid/<int:userid>", methods=["GET"]) | ||||
| @login_required | ||||
| def get_specific_employee_user_id(userid): | ||||
|     employee = db.session \ | ||||
|         .query(Employee_Employee) \ | ||||
|         .filter(Employee_Employee.user_id == userid) \ | ||||
|         .first() | ||||
|     # print(employee.id) | ||||
|     employee_schema = Employee_Employee_schema(many=False) | ||||
|     return jsonify(employee_schema.dump(employee)) | ||||
|  | ||||
|  | ||||
| @employees.route("/all/<int:page>", methods=["GET"]) | ||||
| @login_required | ||||
| def all_employees_paginated(page): | ||||
|     """ | ||||
|     pagination all employees | ||||
|     """ | ||||
|     per_page_amount = 50 | ||||
|     if page is None: | ||||
|         offset_limit = 0 | ||||
|     elif page == 1: | ||||
|         offset_limit = 0 | ||||
|     else: | ||||
|         offset_limit = (per_page_amount * page) - per_page_amount | ||||
|  | ||||
|     employee_list = (db.session | ||||
|                      .query(Employee_Employee) \ | ||||
|                      .limit(per_page_amount).offset(offset_limit)) | ||||
|  | ||||
|     employee_schema = Employee_Employee_schema(many=True) | ||||
|     return jsonify(employee_schema.dump(employee_list)) | ||||
|  | ||||
|  | ||||
| @employees.route("/all", methods=["GET"]) | ||||
| @login_required | ||||
| def all_employees(): | ||||
|     employee_list = db.session \ | ||||
|         .query(Employee_Employee) \ | ||||
|         .all() | ||||
|     customer_schema = Employee_Employee_schema(many=True) | ||||
|     return jsonify(customer_schema.dump(employee_list)) | ||||
|  | ||||
|  | ||||
| @employees.route("/drivers", methods=["GET"]) | ||||
| @login_required | ||||
| def all_employees_drivers(): | ||||
|     employee_list = db.session \ | ||||
|         .query(Employee_Employee) \ | ||||
|         .filter(Employee_Employee.employee_type == 4) \ | ||||
|         .all() | ||||
|     customer_schema = Employee_Employee_schema(mwany=True) | ||||
|     return jsonify(customer_schema.dump(employee_list)) | ||||
|  | ||||
|  | ||||
| @employees.route("/techs", methods=["GET"]) | ||||
| @login_required | ||||
| def all_employees_techs(): | ||||
|     employee_list = db.session \ | ||||
|         .query(Employee_Employee) \ | ||||
|         .filter(or_(Employee_Employee.employee_type == 0, | ||||
|                     Employee_Employee.employee_type == 1, | ||||
|                     Employee_Employee.employee_type == 5, | ||||
|                     Employee_Employee.employee_type == 8, | ||||
|                     )) \ | ||||
|         .all() | ||||
|     customer_schema = Employee_Employee_schema(many=True) | ||||
|     return jsonify(customer_schema.dump(employee_list)) | ||||
|  | ||||
|  | ||||
| @employees.route("/create", methods=["POST"]) | ||||
| @login_required | ||||
| def employee_create(): | ||||
|     """ | ||||
|     This will create an employee | ||||
|     """ | ||||
|     e_last_name = request.json["employee_last_name"] | ||||
|     e_first_name = request.json["employee_first_name"] | ||||
|     e_town = request.json["employee_town"] | ||||
|     e_state = request.json["employee_state"] | ||||
|     e_address = request.json["employee_address"] | ||||
|     e_zip = request.json["employee_zip"] | ||||
|     e_birthday = request.json["employee_birthday"] | ||||
|     e_type = request.json["employee_type"] | ||||
|     e_start_date = request.json["employee_start_date"] | ||||
|     e_end_date = request.json["employee_end_date"] | ||||
|     e_phone_number = request.json["employee_phone_number"] | ||||
|  | ||||
|     emp_state = int(e_state) | ||||
|     emp_type = int(e_type) | ||||
|     emp_zip = int(e_zip) | ||||
|  | ||||
|     if e_end_date == '': | ||||
|         e_end_date = None | ||||
|  | ||||
|     new_employee = Employee_Employee( | ||||
|  | ||||
|         employee_last_name=e_last_name, | ||||
|         employee_first_name=e_first_name, | ||||
|         employee_town=e_town, | ||||
|         employee_state=emp_state, | ||||
|         employee_zip=emp_zip, | ||||
|         employee_address=e_address, | ||||
|         employee_birthday=e_birthday, | ||||
|         employee_type=emp_type, | ||||
|         employee_start_date=e_start_date, | ||||
|         employee_end_date=e_end_date, | ||||
|         employee_phone_number=e_phone_number, | ||||
|     ) | ||||
|  | ||||
|     db.session.add(new_employee) | ||||
|     db.session.commit() | ||||
|  | ||||
|     return jsonify({"ok": True, | ||||
|                     'user_id': new_employee.id, | ||||
|                     }), 200 | ||||
|  | ||||
|  | ||||
| @employees.route("/edit/<int:employee_id>", methods=["POST"]) | ||||
| def employee_edit(employee_id): | ||||
|     """ | ||||
|     This will update an employee | ||||
|     """ | ||||
|     e_last_name = request.json["employee_last_name"] | ||||
|     e_first_name = request.json["employee_first_name"] | ||||
|     e_town = request.json["employee_town"] | ||||
|     e_state = request.json["employee_state"] | ||||
|     e_zip = request.json["employee_zip"] | ||||
|     e_birthday = request.json["employee_birthday"] | ||||
|     e_type = request.json["employee_type"] | ||||
|     e_start_date = request.json["employee_start_date"] | ||||
|     e_end_date = request.json["employee_end_date"] | ||||
|     print(request.json["employee_end_date"]) | ||||
|  | ||||
|     get_employee = db.session \ | ||||
|         .query(Employee_Employee) \ | ||||
|         .filter(Employee_Employee.id == employee_id) \ | ||||
|         .first() | ||||
|  | ||||
|     get_employee.employee_first_name = e_first_name | ||||
|     get_employee.employee_last_name = e_last_name | ||||
|     get_employee.employee_town = e_town | ||||
|     get_employee.employee_state = e_state | ||||
|     get_employee.employee_zip = e_zip | ||||
|     get_employee.employee_birthday = e_birthday | ||||
|     get_employee.employee_type = e_type | ||||
|     get_employee.employee_start_date = e_start_date | ||||
|     if e_end_date != 'None': | ||||
|         get_employee.employee_end_date = e_end_date | ||||
|  | ||||
|     db.session.add(get_employee) | ||||
|     db.session.commit() | ||||
|  | ||||
|     return jsonify({"ok": True}), 200 | ||||
							
								
								
									
										8
									
								
								app/info/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								app/info/__init__.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | ||||
| # coding=utf-8 | ||||
| from flask import Blueprint | ||||
|  | ||||
|  | ||||
| info = Blueprint('info', __name__) | ||||
|  | ||||
|  | ||||
| from . import views | ||||
							
								
								
									
										46
									
								
								app/info/views.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										46
									
								
								app/info/views.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,46 @@ | ||||
| from flask import jsonify | ||||
| from app.info import info | ||||
| from app import db | ||||
| from app.classes.pricing import Pricing_Oil_Oil, Pricing_Service_General | ||||
| from app.classes.admin import Admin_Company | ||||
|  | ||||
|  | ||||
| @info.route("/price/oil", methods=["GET"]) | ||||
| def get_oil_price(): | ||||
|     get_price_query = (db.session | ||||
|                      .query(Pricing_Oil_Oil) | ||||
|                      .order_by(Pricing_Oil_Oil.date.desc()) | ||||
|                      .first()) | ||||
|     return jsonify({"ok": True, | ||||
|                     'price': get_price_query.price_for_customer, | ||||
|                     }), 200 | ||||
|  | ||||
|  | ||||
| @info.route("/price/service", methods=["GET"]) | ||||
| def get_service_price(): | ||||
|     get_price_query = (db.session | ||||
|                          .query(Pricing_Service_General) | ||||
|                          .order_by(Pricing_Service_General.date.desc()) | ||||
|                          .first()) | ||||
|  | ||||
|     return jsonify({"ok": True, | ||||
|                     'same_day': get_price_query.price_same_day, | ||||
|                     'price_hourly': get_price_query.price_service_hour, | ||||
|                     'emergency_fee': get_price_query.price_emergency_call, | ||||
|                     'emergency_rate': get_price_query.price_emergency_service_hour, | ||||
|                     'prime': get_price_query.price_prime, | ||||
|                     'cleaning': get_price_query.price_cleaning, | ||||
|                     'out_of_oil': get_price_query.price_out_of_oil, | ||||
|                     }), 200 | ||||
|  | ||||
|  | ||||
| @info.route("/company", methods=["GET"]) | ||||
| def get_company(): | ||||
|     get_data_company = (db.session | ||||
|                         .query(Admin_Company) | ||||
|                         .first()) | ||||
|  | ||||
|     return jsonify({"ok": True, | ||||
|                     'name': get_data_company.company_name, | ||||
|                     'telephone': get_data_company.company_phone_number, | ||||
|                     }), 200 | ||||
							
								
								
									
										7
									
								
								app/main/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								app/main/__init__.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| # coding=utf-8 | ||||
|  | ||||
| from flask import Blueprint | ||||
|  | ||||
| main = Blueprint('main', __name__) | ||||
|  | ||||
| from . import views | ||||
							
								
								
									
										19
									
								
								app/main/views.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								app/main/views.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,19 @@ | ||||
| from flask import jsonify, Response | ||||
| from app import app | ||||
|  | ||||
|  | ||||
| @app.route('/robots.txt') | ||||
| @app.route('/sitemap.xml') | ||||
| def static_from_root(): | ||||
|     def disallow(string): return 'Disallow: {0}'.format(string) | ||||
|     return Response("User-agent: *\n{0}\n".format("\n".join([ | ||||
|         disallow('/bin/*'), | ||||
|         disallow('/admin'), | ||||
|     ]))) | ||||
|  | ||||
|  | ||||
| @app.route('/index', methods=['GET']) | ||||
| @app.route('/', methods=['GET']) | ||||
| def index(): | ||||
|     return jsonify({"success": "Api is online"}), 200 | ||||
|  | ||||
							
								
								
									
										7
									
								
								app/payment/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								app/payment/__init__.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| # coding=utf-8 | ||||
|  | ||||
| from flask import Blueprint | ||||
|  | ||||
| payment = Blueprint('payment', __name__) | ||||
|  | ||||
| from . import views | ||||
							
								
								
									
										206
									
								
								app/payment/views.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										206
									
								
								app/payment/views.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,206 @@ | ||||
| from flask import jsonify, request | ||||
| from app.payment import payment | ||||
| from app import db | ||||
| from app.classes.customer import Customer_Customer | ||||
| from app.classes.cards import Card_Card, Card_Card_schema | ||||
| from flask_login import current_user | ||||
|  | ||||
|  | ||||
| def set_card_main(user_id): | ||||
|     """ | ||||
|     updates a card of a user | ||||
|     """ | ||||
|     get_card_count = db.session \ | ||||
|         .query(Card_Card) \ | ||||
|         .filter(Card_Card.user_id == user_id) \ | ||||
|         .count() | ||||
|     print(get_card_count) | ||||
|     if get_card_count > 0: | ||||
|         print("true") | ||||
|  | ||||
|         get_old_card = db.session \ | ||||
|             .query(Card_Card) \ | ||||
|             .filter(Card_Card.main_card == True) \ | ||||
|             .filter(Card_Card.user_id == user_id) \ | ||||
|             .first() | ||||
|         print(get_old_card.id) | ||||
|  | ||||
|         get_old_card.main_card = False | ||||
|  | ||||
|         db.session.add(get_old_card) | ||||
|  | ||||
|         db.session.commit() | ||||
|  | ||||
|  | ||||
| @payment.route("/cards/<int:user_id>", methods=["GET"]) | ||||
| def get_user_cards(user_id): | ||||
|     """ | ||||
|     gets all cards of a user | ||||
|     """ | ||||
|     get_u_cards = db.session \ | ||||
|         .query(Card_Card) \ | ||||
|         .filter(Card_Card.user_id == user_id) \ | ||||
|         .all() | ||||
|  | ||||
|     card_schema = Card_Card_schema(many=True) | ||||
|     return jsonify(card_schema.dump(get_u_cards)) | ||||
|  | ||||
|  | ||||
| @payment.route("/cards/onfile/<int:user_id>", methods=["GET"]) | ||||
| def get_user_cards_count(user_id): | ||||
|     """ | ||||
|     gets all cards of a user | ||||
|     """ | ||||
|  | ||||
|     get_u_cards = db.session \ | ||||
|         .query(Card_Card) \ | ||||
|         .filter(Card_Card.user_id == user_id) \ | ||||
|         .count() | ||||
|  | ||||
|     return jsonify({ | ||||
|         "ok": True, | ||||
|         'cards': get_u_cards, | ||||
|     }), 200 | ||||
|  | ||||
|  | ||||
| @payment.route("/card/<int:card_id>", methods=["GET"]) | ||||
| def get_user_specific_card(card_id): | ||||
|     """ | ||||
|     gets a specific card of a user | ||||
|     """ | ||||
|  | ||||
|     get_user_card = db.session \ | ||||
|         .query(Card_Card) \ | ||||
|         .filter(Card_Card.id == card_id) \ | ||||
|         .first() | ||||
|  | ||||
|     card_schema = Card_Card_schema(many=False) | ||||
|     return jsonify(card_schema.dump(get_user_card)) | ||||
|  | ||||
|  | ||||
| @payment.route("/card/create/<int:user_id>", methods=["POST"]) | ||||
| def create_user_card(user_id): | ||||
|     """ | ||||
|     adds a card of a user | ||||
|     """ | ||||
|  | ||||
|     get_customer = db.session \ | ||||
|         .query(Customer_Customer) \ | ||||
|         .filter(Customer_Customer.id == user_id) \ | ||||
|         .first() | ||||
|  | ||||
|     name_on_card = request.json["card_name"] | ||||
|     expiration_month = request.json["expiration_month"] | ||||
|     expiration_year = request.json["expiration_year"] | ||||
|     type_of_card = request.json["type_of_card"] | ||||
|     security_number = request.json["security_number"] | ||||
|     main_card = request.json["main_card"] | ||||
|  | ||||
|     card_number = request.json["card_number"] | ||||
|     last_four = card_number[-4] | ||||
|  | ||||
|     create_new_card = Card_Card( | ||||
|         user_id=get_customer.id, | ||||
|         card_number=card_number, | ||||
|         last_four_digits=last_four, | ||||
|         name_on_card=name_on_card, | ||||
|         expiration_month=expiration_month, | ||||
|         expiration_year=expiration_year, | ||||
|         type_of_card=type_of_card, | ||||
|         security_number=security_number, | ||||
|         accepted_or_declined=None, | ||||
|         main_card=main_card, | ||||
|     ) | ||||
|     print(main_card) | ||||
|     if main_card is True: | ||||
|         set_card_main(user_id=get_customer.id) | ||||
|     db.session.add(create_new_card) | ||||
|     db.session.commit() | ||||
|  | ||||
|     return jsonify({"ok": True}), 200 | ||||
|  | ||||
|  | ||||
| @payment.route("/card/main/<int:card_id>/<int:user_id>", methods=["PUT"]) | ||||
| def set_main_card(user_id, card_id): | ||||
|     """ | ||||
|     updates a card of a user | ||||
|     """ | ||||
|  | ||||
|     get_new_main_card = db.session \ | ||||
|         .query(Card_Card) \ | ||||
|         .filter(Card_Card.user_id == user_id) \ | ||||
|         .filter(Card_Card.id == card_id) \ | ||||
|         .first() | ||||
|  | ||||
|     get_other_card = db.session \ | ||||
|         .query(Card_Card) \ | ||||
|         .filter(Card_Card.main_card == True) \ | ||||
|         .filter(Card_Card.user_id == user_id) \ | ||||
|         .first() | ||||
|     if get_other_card is not None: | ||||
|         get_other_card.main_card = False | ||||
|         db.session.add(get_other_card) | ||||
|     get_new_main_card.main_card = True | ||||
|  | ||||
|     db.session.add(get_new_main_card) | ||||
|     db.session.commit() | ||||
|  | ||||
|     return jsonify({"ok": True}), 200 | ||||
|  | ||||
|  | ||||
| @payment.route("/card/edit/<int:card_id>", methods=["PUT"]) | ||||
| def update_user_card(card_id): | ||||
|     """ | ||||
|     edits a card | ||||
|     """ | ||||
|  | ||||
|     get_card = db.session \ | ||||
|         .query(Card_Card) \ | ||||
|         .filter(Card_Card.id == card_id) \ | ||||
|         .first() | ||||
|  | ||||
|     get_customer = db.session \ | ||||
|         .query(Customer_Customer) \ | ||||
|         .filter(Customer_Customer.id == get_card.user_id) \ | ||||
|         .first() | ||||
|     name_on_card = request.json["card_name"] | ||||
|     expiration_month = request.json["expiration_month"] | ||||
|     expiration_year = request.json["expiration_year"] | ||||
|     type_of_card = request.json["type_of_card"] | ||||
|     security_number = request.json["security_number"] | ||||
|     card_number = request.json["card_number"] | ||||
|     main_card = request.json["main_card"] | ||||
|  | ||||
|     get_card.user_id = get_customer.id | ||||
|     get_card.card_number = card_number | ||||
|     get_card.name_on_card = name_on_card | ||||
|     get_card.expiration_month = expiration_month | ||||
|     get_card.expiration_year = expiration_year | ||||
|     get_card.type_of_card = type_of_card | ||||
|     get_card.security_number = security_number | ||||
|     get_card.main_card = main_card | ||||
|  | ||||
|     if main_card is True: | ||||
|         set_card_main(user_id=get_customer.id, card_id=get_card.id) | ||||
|  | ||||
|     db.session.add(get_card) | ||||
|     db.session.commit() | ||||
|  | ||||
|     return jsonify({"ok": True}), 200 | ||||
|  | ||||
|  | ||||
| @payment.route("/card/remove/<int:card_id>", methods=["DELETE"]) | ||||
| def remove_user_card(card_id): | ||||
|     """ | ||||
|     removes a card  | ||||
|     """ | ||||
|  | ||||
|     get_card = db.session \ | ||||
|         .query(Card_Card) \ | ||||
|         .filter(Card_Card.id == card_id) \ | ||||
|         .first() | ||||
|  | ||||
|     db.session.delete(get_card) | ||||
|     db.session.commit() | ||||
|  | ||||
|     return jsonify({"ok": True}), 200 | ||||
							
								
								
									
										7
									
								
								app/query/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								app/query/__init__.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| # coding=utf-8 | ||||
|  | ||||
| from flask import Blueprint | ||||
|  | ||||
| query = Blueprint('query', __name__) | ||||
|  | ||||
| from . import views | ||||
							
								
								
									
										82
									
								
								app/query/views.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										82
									
								
								app/query/views.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,82 @@ | ||||
| from flask import request, jsonify | ||||
| from flask_login import current_user | ||||
| from datetime import date, timedelta | ||||
| from app.query import query | ||||
| from app import db | ||||
| from datetime import datetime | ||||
| from app.classes.query import Query_StateList, \ | ||||
|     Query_DeliveryStatusList, \ | ||||
|     Query_DeliveryStatusList_Schema, \ | ||||
|     Query_StateList_Schema, \ | ||||
|     Query_CustomerTypeList, \ | ||||
|     Query_CustomerTypeList_Schema,\ | ||||
|     Query_EmployeeTypeList, \ | ||||
|     Query_EmployeeTypeList_Schema,\ | ||||
|     Query_ServiceTypeList,\ | ||||
|     Query_ServiceTypeList_Schema | ||||
|  | ||||
|  | ||||
| @query.route("/states", methods=["GET"]) | ||||
| def get_state_list(): | ||||
|     """ | ||||
|     This will get states | ||||
|     """ | ||||
|  | ||||
|     query_data = db.session \ | ||||
|         .query(Query_StateList) \ | ||||
|         .all() | ||||
|  | ||||
|     customer_schema = Query_StateList_Schema(many=True) | ||||
|     return jsonify(customer_schema.dump(query_data)) | ||||
|  | ||||
|  | ||||
| @query.route("/customertype", methods=["GET"]) | ||||
| def get_customer_type_list(): | ||||
|     """ | ||||
|     This will get types of customers | ||||
|     """ | ||||
|  | ||||
|     query_data = db.session \ | ||||
|         .query(Query_CustomerTypeList) \ | ||||
|         .all() | ||||
|     customer_schema = Query_CustomerTypeList_Schema(many=True) | ||||
|     return jsonify(customer_schema.dump(query_data)) | ||||
|  | ||||
|  | ||||
| @query.route("/servicetype", methods=["GET"]) | ||||
| def get_service_type_list(): | ||||
|     """ | ||||
|     This will get types of service | ||||
|     """ | ||||
|  | ||||
|     query_data = db.session \ | ||||
|         .query(Query_ServiceTypeList) \ | ||||
|         .all() | ||||
|     customer_schema = Query_ServiceTypeList_Schema(many=True) | ||||
|     return jsonify(customer_schema.dump(query_data)) | ||||
|  | ||||
|  | ||||
| @query.route("/employeetype", methods=["GET"]) | ||||
| def get_employee_type_list(): | ||||
|     """ | ||||
|     This will get types of service | ||||
|     """ | ||||
|  | ||||
|     query_data = db.session \ | ||||
|         .query(Query_EmployeeTypeList) \ | ||||
|         .all() | ||||
|     customer_schema = Query_EmployeeTypeList_Schema(many=True) | ||||
|     return jsonify(customer_schema.dump(query_data)) | ||||
|  | ||||
|  | ||||
| @query.route("/deliverystatus", methods=["GET"]) | ||||
| def get_delivery_status_list(): | ||||
|     """ | ||||
|     This will get delivery status | ||||
|     """ | ||||
|  | ||||
|     query_data = db.session \ | ||||
|         .query(Query_DeliveryStatusList) \ | ||||
|         .all() | ||||
|     delivery_schema = Query_DeliveryStatusList_Schema(many=True) | ||||
|     return jsonify(delivery_schema.dump(query_data)) | ||||
							
								
								
									
										7
									
								
								app/reports/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								app/reports/__init__.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| # coding=utf-8 | ||||
|  | ||||
| from flask import Blueprint | ||||
|  | ||||
| reports = Blueprint('reports', __name__) | ||||
|  | ||||
| from . import views | ||||
							
								
								
									
										24
									
								
								app/reports/views.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										24
									
								
								app/reports/views.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,24 @@ | ||||
| from flask import request, jsonify | ||||
| from flask_login import current_user | ||||
| from sqlalchemy.sql import func | ||||
| from datetime import date, timedelta | ||||
| from app.reports import reports | ||||
| from app import db | ||||
| from datetime import datetime | ||||
|  | ||||
| from app.classes.auth import Auth_User | ||||
| from app.classes.customer import Customer_Customer | ||||
| from app.classes.service import Service_Call, Service_Call_schema | ||||
| from app.classes.employee import Employee_Employee | ||||
| from app.classes.service import Service_Call_Notes_Dispatcher, Service_Call_Notes_Technician | ||||
| from app.classes.delivery import Delivery_Delivery | ||||
|  | ||||
|  | ||||
| @reports.route("/oil/total", methods=["GET"]) | ||||
| def oil_total_gallons(): | ||||
|     total_oil = db.session\ | ||||
|     .query(func.sum(Delivery_Delivery.gallons_delivered))\ | ||||
|     .group_by(Delivery_Delivery.id)\ | ||||
|     .all() | ||||
|      | ||||
|     return jsonify({"ok": True }), 200 | ||||
							
								
								
									
										7
									
								
								app/search/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								app/search/__init__.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| # coding=utf-8 | ||||
|  | ||||
| from flask import Blueprint | ||||
|  | ||||
| search = Blueprint('search', __name__) | ||||
|  | ||||
| from . import views | ||||
							
								
								
									
										79
									
								
								app/search/views.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										79
									
								
								app/search/views.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,79 @@ | ||||
| from flask import request, jsonify | ||||
| from flask_login import current_user | ||||
| from sqlalchemy.sql import func | ||||
| from datetime import date, timedelta | ||||
| from app.search import search | ||||
| from app import db | ||||
| from datetime import datetime | ||||
|  | ||||
| from app.classes.auth import Auth_User | ||||
| from app.classes.customer import Customer_Customer, Customer_Customer_schema | ||||
| from app.classes.service import Service_Call, Service_Call_schema | ||||
| from app.classes.employee import Employee_Employee | ||||
| from app.classes.service import Service_Call_Notes_Dispatcher, Service_Call_Notes_Technician | ||||
| from app.classes.delivery import Delivery_Delivery, Delivery_Delivery_schema | ||||
|  | ||||
|  | ||||
| @search.route("/customer", methods=["GET"]) | ||||
| def search_customers(): | ||||
|     """ | ||||
|  | ||||
|     """ | ||||
|  | ||||
|     keyword = request.args.get('q') | ||||
|     search = "%{}%".format(keyword) | ||||
|     search_type = (search[1]) | ||||
|     search = search.replace("!", "") | ||||
|     search = search.replace("#", "") | ||||
|     search = search.replace("@", "") | ||||
|     # search by last name | ||||
|     if search_type == '@': | ||||
|         search = search[1:] | ||||
|         customer_list = (db.session | ||||
|                          .query(Customer_Customer) | ||||
|                          .filter(Customer_Customer.customer_first_name.ilike(search)) | ||||
|                          .all()) | ||||
|  | ||||
|     elif search_type == '!': | ||||
|  | ||||
|         search = search[::1] | ||||
|         customer_list = (db.session | ||||
|                          .query(Customer_Customer) | ||||
|                          .filter(Customer_Customer.customer_address.ilike(search)) | ||||
|                          .all()) | ||||
|     # Phone Number | ||||
|     elif search_type == '#': | ||||
|         search = search[::1] | ||||
|         customer_list = (db.session | ||||
|                          .query(Customer_Customer) | ||||
|                          .filter(Customer_Customer.customer_phone_number.ilike(search)) | ||||
|                          .all()) | ||||
|  | ||||
|     else: | ||||
|         customer_list = (db.session | ||||
|                          .query(Customer_Customer) | ||||
|                          .filter(Customer_Customer.customer_last_name.ilike(search)) | ||||
|                          .all()) | ||||
|  | ||||
|  | ||||
|     customer_schema = Customer_Customer_schema(many=True) | ||||
|     return jsonify(customer_schema.dump(customer_list)) | ||||
|  | ||||
|  | ||||
| @search.route("/delivery", methods=["GET"]) | ||||
| def search_delivery(): | ||||
|     """ | ||||
|     pagination all customers | ||||
|     """ | ||||
|     keyword = request.args.get('q') | ||||
|     search = "%{}%".format(keyword) | ||||
|     search_type = (search[1]) | ||||
|  | ||||
|     delivery_ticket = (db.session | ||||
|                      .query(Delivery_Delivery) | ||||
|                      .filter(Delivery_Delivery.id.ilike(search)) | ||||
|                      .all()) | ||||
|  | ||||
|  | ||||
|     delivery_schema = Delivery_Delivery_schema(many=True) | ||||
|     return jsonify(delivery_schema.dump(delivery_ticket)) | ||||
							
								
								
									
										7
									
								
								app/service/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								app/service/__init__.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| # coding=utf-8 | ||||
|  | ||||
| from flask import Blueprint | ||||
|  | ||||
| service = Blueprint('service', __name__) | ||||
|  | ||||
| from . import views | ||||
							
								
								
									
										397
									
								
								app/service/views.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										397
									
								
								app/service/views.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,397 @@ | ||||
| from flask import request, jsonify | ||||
| from flask_login import current_user, login_required | ||||
| from app.service import service | ||||
| from app import db | ||||
| from datetime import datetime | ||||
|  | ||||
| from app.classes.auth import Auth_User | ||||
| from app.classes.customer import Customer_Customer | ||||
| from app.classes.service import (Service_Call, | ||||
|                                  Service_Call_schema, | ||||
|                                  Service_Call_Notes_Dispatcher, | ||||
|                                  Service_Call_Notes_Technician, | ||||
|                                  Service_Call_Notes_Dispatcher_schema, | ||||
|                                  ) | ||||
| from app.classes.cards import Card_Card | ||||
| from app.classes.employee import Employee_Employee | ||||
|  | ||||
|  | ||||
| @service.route("/<string:service_id>", methods=["GET"]) | ||||
| @login_required | ||||
| def get_specific_service_call(service_id): | ||||
|  | ||||
|     service_call = db.session \ | ||||
|         .query(Service_Call) \ | ||||
|         .filter(Service_Call.id == service_id) \ | ||||
|         .first() | ||||
|  | ||||
|     service_schema = Service_Call_schema(many=False) | ||||
|     return jsonify(service_schema.dump(service_call)) | ||||
|  | ||||
|  | ||||
| @service.route("/paymenttype/<int:service_id>/<int:type_of_payment>", methods=["PUT"]) | ||||
| def update_a_service_payment(service_id, type_of_payment): | ||||
|     """ | ||||
|     This update  a delivery for example if user updates to a fill | ||||
|     """ | ||||
|  | ||||
|     service_call = (db.session | ||||
|         .query(Service_Call) | ||||
|         .filter(Service_Call.id == service_id) | ||||
|         .first()) | ||||
|  | ||||
|     service_call.payment_type = type_of_payment | ||||
|  | ||||
|     db.session.add(service_call) | ||||
|     db.session.commit() | ||||
|  | ||||
|     return jsonify({"ok": True}), 200 | ||||
|  | ||||
|  | ||||
| @service.route("/call/notes/<string:service_id>", methods=["GET"]) | ||||
| @login_required | ||||
| def get_service_notes_call(service_id): | ||||
|     service_call = db.session \ | ||||
|         .query(Service_Call_Notes_Dispatcher) \ | ||||
|         .filter(Service_Call_Notes_Dispatcher.service_call_id == service_id) \ | ||||
|         .first() | ||||
|  | ||||
|     service_schema = Service_Call_Notes_Dispatcher_schema(many=False) | ||||
|     return jsonify(service_schema.dump(service_call)) | ||||
|  | ||||
|  | ||||
| @service.route("/all", methods=["GET"]) | ||||
| def service_view_all(): | ||||
|     """ | ||||
|     Get all service calls | ||||
|     """ | ||||
|  | ||||
|     service_calls = db.session \ | ||||
|         .query(Service_Call) \ | ||||
|         .filter(Service_Call.completed == 0) \ | ||||
|         .order_by(Service_Call.when_called.desc()) \ | ||||
|         .all() | ||||
|  | ||||
|     customer_schema = Service_Call_schema(many=True) | ||||
|     return jsonify(customer_schema.dump(service_calls)) | ||||
|  | ||||
|  | ||||
| @service.route("/all/<int:page>", methods=["GET"]) | ||||
| def service_view(page): | ||||
|     """ | ||||
|     Get all service calls | ||||
|     """ | ||||
|     per_page_amount = 50 | ||||
|     if page is None: | ||||
|         offset_limit = 0 | ||||
|     elif page == 1: | ||||
|         offset_limit = 0 | ||||
|     else: | ||||
|         offset_limit = (per_page_amount * page) - per_page_amount | ||||
|  | ||||
|     service_calls = db.session \ | ||||
|         .query(Service_Call) \ | ||||
|         .filter(Service_Call.completed == 0) \ | ||||
|         .order_by(Service_Call.when_called.desc()) \ | ||||
|         .limit(per_page_amount).offset(offset_limit) | ||||
|  | ||||
|     customer_schema = Service_Call_schema(many=True) | ||||
|     return jsonify(customer_schema.dump(service_calls)) | ||||
|  | ||||
|  | ||||
| @service.route("/customer/<int:customer_id>/<int:page>", methods=["GET"]) | ||||
| def service_customer_view(customer_id, page): | ||||
|     """ | ||||
|     Get all service calls | ||||
|     """ | ||||
|     per_page_amount = 50 | ||||
|     if page is None: | ||||
|         offset_limit = 0 | ||||
|     elif page == 1: | ||||
|         offset_limit = 0 | ||||
|     else: | ||||
|         offset_limit = (per_page_amount * page) - per_page_amount | ||||
|  | ||||
|     service_calls = db.session \ | ||||
|         .query(Service_Call) \ | ||||
|         .filter(Service_Call.customer_id == customer_id) \ | ||||
|         .order_by(Service_Call.id.desc()) \ | ||||
|         .limit(per_page_amount).offset(offset_limit) | ||||
|  | ||||
|     customer_schema = Service_Call_schema(many=True) | ||||
|     return jsonify(customer_schema.dump(service_calls)) | ||||
|  | ||||
|  | ||||
| @service.route("/create/<int:user_id>", methods=["POST"]) | ||||
| def service_create_call(user_id): | ||||
|     """ | ||||
|     create a service call | ||||
|     """ | ||||
|  | ||||
|     now = datetime.utcnow() | ||||
|     get_customer = db.session \ | ||||
|         .query(Customer_Customer) \ | ||||
|         .filter(Customer_Customer.id == user_id) \ | ||||
|         .first() | ||||
|     print(request.json) | ||||
|     get_service_type = request.json["type_of_service"] | ||||
|     service_note = request.json["dispatcher_notes_taken"] | ||||
|     service_subject = request.json["dispatcher_subject_taken"] | ||||
|     scheduled_date_date = request.json["date_scheduled"] | ||||
|     dispatcher_id = request.json["dispatcher_id"] | ||||
|  | ||||
|     card_payment = request.json["credit"] | ||||
|     cash_payment = request.json["cash"] | ||||
|     try: | ||||
|         if request.json["credit_card_id"]: | ||||
|             card_payment_id = request.json["credit_card_id"] | ||||
|         else: | ||||
|             card_payment_id = None | ||||
|     except: | ||||
|         card_payment_id = None | ||||
|  | ||||
|     if cash_payment is True and card_payment is False: | ||||
|         delivery_payment_method = 0 | ||||
|     elif card_payment is True and cash_payment is False: | ||||
|         delivery_payment_method = 1 | ||||
|  | ||||
|     elif card_payment is True and cash_payment is True: | ||||
|         delivery_payment_method = 2 | ||||
|     else: | ||||
|         delivery_payment_method = 3 | ||||
|  | ||||
|     if card_payment_id is not None: | ||||
|         get_card = (db.session | ||||
|                     .query(Card_Card) | ||||
|                     .filter(Card_Card.id == card_payment_id) | ||||
|                     .filter(Card_Card.user_id == get_customer.id) | ||||
|                     .first()) | ||||
|         card_id_from_customer = get_card.id | ||||
|     else: | ||||
|         card_id_from_customer = None | ||||
|  | ||||
|     date_object = datetime.strptime(scheduled_date_date, '%Y-%m-%d').date() | ||||
|  | ||||
|     get_tech = (db.session | ||||
|                 .query(Employee_Employee) | ||||
|                 .first()) | ||||
|  | ||||
|     create_a_call = Service_Call( | ||||
|         customer_id=get_customer.id, | ||||
|         customer_last_name=get_customer.customer_last_name, | ||||
|         customer_first_name=get_customer.customer_first_name, | ||||
|         customer_town=get_customer.customer_town, | ||||
|         customer_state=get_customer.customer_state, | ||||
|         customer_zip=get_customer.customer_zip, | ||||
|         customer_apt=get_customer.customer_apt, | ||||
|         customer_address=get_customer.customer_address, | ||||
|         status=0, | ||||
|         service_type=get_service_type, | ||||
|         when_called=now, | ||||
|         scheduled_date=date_object, | ||||
|         when_serviced=None, | ||||
|         tech_id=get_tech.id, | ||||
|         tech_first_name=get_tech.employee_first_name, | ||||
|         tech_last_name=get_tech.employee_last_name, | ||||
|         completed=0, | ||||
|         payment_type=delivery_payment_method, | ||||
|         payment_card_id=card_id_from_customer, | ||||
|     ) | ||||
|  | ||||
|     db.session.add(create_a_call) | ||||
|     db.session.flush() | ||||
|  | ||||
|     create_new_note = Service_Call_Notes_Dispatcher( | ||||
|         service_call_id=create_a_call.id, | ||||
|         dispatcher_subject=service_subject, | ||||
|         dispatcher_notes=service_note, | ||||
|         time_added=now, | ||||
|         dispatcher_id=dispatcher_id, | ||||
|         dispatcher_name=None, | ||||
|     ) | ||||
|  | ||||
|     db.session.add(create_new_note) | ||||
|     db.session.commit() | ||||
|  | ||||
|     db.session.commit() | ||||
|  | ||||
|     return jsonify({"ok": True, | ||||
|                     'user_id': get_customer.id, | ||||
|                     'service_id': create_a_call.id, | ||||
|                     }), 200 | ||||
|  | ||||
| @service.route("/delete/<int:service_id>", methods=["DELETE"]) | ||||
| def service_delete_call(service_id): | ||||
|     """ | ||||
|     delete a service call | ||||
|     """ | ||||
|     get_call_to_delete = (db.session | ||||
|                           .query(Service_Call) | ||||
|                           .filter(Service_Call.id == service_id) | ||||
|                           .first()) | ||||
|     db.session.delete(get_call_to_delete) | ||||
|     db.session.commit() | ||||
|  | ||||
|     return jsonify({"ok": True}), 200 | ||||
|  | ||||
|  | ||||
|  | ||||
| @service.route("/edit/<int:service_id>", methods=["PUT"]) | ||||
| def service_edit_call(service_id): | ||||
|     """ | ||||
|     Update a service call | ||||
|     """ | ||||
|  | ||||
|     get_service_type = request.json["type_of_service"] | ||||
|     scheduled_date_date = request.json["date_scheduled"] | ||||
|     dispatcher_subject_taken = request.json["dispatcher_subject_taken"] | ||||
|     dispatcher_notes_taken = request.json["dispatcher_notes_taken"] | ||||
|     tech_id = request.json["tech_id"] | ||||
|  | ||||
|     card_payment = request.json["credit"] | ||||
|     cash_payment = request.json["cash"] | ||||
|  | ||||
|     if request.json["credit_card_id"]: | ||||
|         card_payment_id = request.json["credit_card_id"] | ||||
|     else: | ||||
|         card_payment_id = None | ||||
|  | ||||
|     get_tech = db.session \ | ||||
|         .query(Employee_Employee) \ | ||||
|         .filter(Employee_Employee.id == tech_id) \ | ||||
|         .first() | ||||
|  | ||||
|     get_service_call_call = db.session \ | ||||
|         .query(Service_Call) \ | ||||
|         .filter(Service_Call.id == service_id) \ | ||||
|         .first() | ||||
|  | ||||
|     if card_payment_id is not None: | ||||
|         get_customer = db.session \ | ||||
|             .query(Customer_Customer) \ | ||||
|             .filter(Customer_Customer.id == get_service_call_call.customer_id) \ | ||||
|             .first() | ||||
|  | ||||
|         get_card = (db.session | ||||
|                     .query(Card_Card) | ||||
|                     .filter(Card_Card.id == card_payment_id) | ||||
|                     .filter(Card_Card.user_id == get_customer.id) | ||||
|                     .first()) | ||||
|         card_id_from_customer = get_card.id | ||||
|     else: | ||||
|         card_id_from_customer = None | ||||
|  | ||||
|     if cash_payment is True and card_payment is False: | ||||
|         delivery_payment_method = 0 | ||||
|     elif card_payment is True and cash_payment is False: | ||||
|         delivery_payment_method = 1 | ||||
|  | ||||
|     elif card_payment is True and cash_payment is True: | ||||
|         delivery_payment_method = 2 | ||||
|     else: | ||||
|         delivery_payment_method = 3 | ||||
|  | ||||
|     get_service_call_notes = (db.session | ||||
|                               .query(Service_Call_Notes_Dispatcher) | ||||
|                               .filter(Service_Call_Notes_Dispatcher.service_call_id == get_service_call_call.id) | ||||
|                               .first()) | ||||
|  | ||||
|     get_service_call_notes.dispatcher_subject = dispatcher_subject_taken | ||||
|     get_service_call_notes.dispatcher_notes = dispatcher_notes_taken | ||||
|  | ||||
|     get_service_call_call.service_type = get_service_type | ||||
|     get_service_call_call.scheduled_date = scheduled_date_date | ||||
|     get_service_call_call.tech_id = get_tech.id | ||||
|     get_service_call_call.payment_type = delivery_payment_method | ||||
|     get_service_call_call.payment_card_id = card_id_from_customer | ||||
|  | ||||
|     db.session.add(get_service_call_call) | ||||
|     db.session.commit() | ||||
|  | ||||
|     return jsonify({"ok": True}), 200 | ||||
|  | ||||
|  | ||||
| @service.route("/update/type/<int:service_id>", methods=["PUT"]) | ||||
| def service_update_service_type(service_id): | ||||
|     """ | ||||
|     Update a service call diagnosis | ||||
|     """ | ||||
|     get_service_type = request.json["service_type"] | ||||
|  | ||||
|     get_service_call = db.session \ | ||||
|         .query(Service_Call) \ | ||||
|         .filter(Service_Call.service_id == service_id) \ | ||||
|         .first() | ||||
|  | ||||
|     get_service_call.service_type = get_service_type | ||||
|  | ||||
|     db.session.add(get_service_call) | ||||
|     db.session.commit() | ||||
|  | ||||
|     return jsonify({"ok": True}), 200 | ||||
|  | ||||
|  | ||||
| @service.route("/note/dispatcher/<int:service_id>", methods=["PUT"]) | ||||
| def service_create_note_dispatcher(service_id): | ||||
|     """ | ||||
|     Initial dispatcher note about the call | ||||
|     """ | ||||
|  | ||||
|     service_note = request.json["dispatcher_text"] | ||||
|     now = datetime.utcnow() | ||||
|  | ||||
|     user = db.session \ | ||||
|         .query(Auth_User) \ | ||||
|         .filter(Auth_User.id == current_user.id) \ | ||||
|         .first() | ||||
|  | ||||
|     get_service_call_order = db.session \ | ||||
|         .query(Service_Call) \ | ||||
|         .filter(Service_Call.service_id == service_id) \ | ||||
|         .first() | ||||
|  | ||||
|     create_new_note = Service_Call_Notes_Dispatcher( | ||||
|         service_call_id=get_service_call_order.id, | ||||
|         dispatcher_notes=service_note, | ||||
|         time_added=now, | ||||
|         dispatcher_id=user.id, | ||||
|         dispatcher_name=user.username, | ||||
|     ) | ||||
|  | ||||
|     db.session.add(create_new_note) | ||||
|     db.session.commit() | ||||
|  | ||||
|     return jsonify({"ok": True}), 200 | ||||
|  | ||||
|  | ||||
| @service.route("/note/technician/<int:service_id>", methods=["PUT"]) | ||||
| def service_create_note_technician(service_id): | ||||
|     """ | ||||
|     Technician can create notes on the call | ||||
|     """ | ||||
|  | ||||
|     service_technician_notes = request.json["technician_comments"] | ||||
|     now = datetime.utcnow() | ||||
|  | ||||
|     user = db.session \ | ||||
|         .query(Auth_User) \ | ||||
|         .filter(Auth_User.id == current_user.id) \ | ||||
|         .first() | ||||
|  | ||||
|     get_service_call = db.session \ | ||||
|         .query(Service_Call) \ | ||||
|         .filter(Service_Call.service_id == service_id) \ | ||||
|         .first() | ||||
|  | ||||
|     create_new_note = Service_Call_Notes_Technician( | ||||
|         service_call_id=get_service_call.id, | ||||
|         technician_comments=service_technician_notes, | ||||
|         time_added=now, | ||||
|         technician_id=user.id, | ||||
|         technician_name=user.username, | ||||
|     ) | ||||
|  | ||||
|     db.session.add(create_new_note) | ||||
|     db.session.commit() | ||||
|  | ||||
|     return jsonify({"ok": True}), 200 | ||||
							
								
								
									
										7
									
								
								app/stats/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								app/stats/__init__.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| # coding=utf-8 | ||||
|  | ||||
| from flask import Blueprint | ||||
|  | ||||
| stats = Blueprint('stats', __name__) | ||||
|  | ||||
| from . import views | ||||
							
								
								
									
										31
									
								
								app/stats/views.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								app/stats/views.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,31 @@ | ||||
| from flask import jsonify | ||||
| from sqlalchemy import func | ||||
| from datetime import date | ||||
| from app.stats import stats | ||||
| from app import db | ||||
| from app.classes.delivery import Delivery_Delivery | ||||
| from app.classes.service import Service_Call | ||||
|  | ||||
|  | ||||
| @stats.route("/delivery/count/today", methods=["GET"]) | ||||
| def get_delivery_today(): | ||||
|     today_deliveries = (db.session | ||||
|                         .query(Delivery_Delivery) | ||||
|                         .order_by(func.date(Delivery_Delivery.expected_delivery_date) == date.today()) | ||||
|                         .count()) | ||||
|  | ||||
|     return jsonify({"ok": True, | ||||
|                     'data': today_deliveries, | ||||
|                     }), 200 | ||||
|  | ||||
|  | ||||
| @stats.route("/service/count/today", methods=["GET"]) | ||||
| def get_service_today(): | ||||
|     today_calls = (db.session | ||||
|                         .query(Service_Call) | ||||
|                         .order_by(func.date(Service_Call.scheduled_date) == date.today()) | ||||
|                         .count()) | ||||
|  | ||||
|     return jsonify({"ok": True, | ||||
|                     'data': today_calls, | ||||
|                     }), 200 | ||||
		Reference in New Issue
	
	Block a user