Exemplo n.º 1
0
def test_load_online_icon_qrcode():
    qrcode = QRcode()
    old_qr = qrcode('Test Data')
    new_qr = qrcode('Test Data',
                    icon_img='http://localhost:5000/tests/icon.jpg')
    assert "data:image/png;base64," in new_qr
    assert len(new_qr) > len(old_qr)
Exemplo n.º 2
0
def closing_pdf(request, key=""):
    report = Report.objects.get(key=key)
    closing = Closing.objects.get(report_id=report.report_id)
    enumeration = Enumeration.objects.get(report_id=report.report_id)
    car = report.car
    contract = report.contract
    customer = contract.customer
    qrcode = get_qrc_code(qr_company=report.pdf_qr_code_company)
    context = {
        'enumeration':
        enumeration,
        'closing':
        closing,
        'report':
        report,
        'qrcode':
        check_qr_code(qrcode),
        'contract':
        contract,
        'car':
        car,
        'customer':
        customer,
        'qrcode_some':
        QRcode.qrcode(
            "http://e-otsenka.uz/pdf/{id}".format(id=report.report_id))
    }

    pdf = generate_pdf(default_template="closing.html",
                       css_name="finish_report.css",
                       context=context)
    reponse = FileResponse(ContentFile(pdf), content_type='application/pdf')
    return reponse
Exemplo n.º 3
0
def test_error_correction_qrcode():
    qrcode = QRcode()
    generated_b64 = qrcode('You can read me even if I\'m 30% hurt.',
                           error_correction='H')
    expected_b64 = ''

    assert generated_b64 == expected_b64
Exemplo n.º 4
0
def create_app(test_config=None):
    app = Flask(__name__, instance_relative_config=True)
    qrcode = QRcode(app)

    app.config.from_mapping(SECRET_KEY='dev',
                            DATABASE=os.path.join(app.instance_path,
                                                  'flaskr.sqlite'))

    if test_config is None:
        # Load the instance config, if it exists, when not testing
        app.config.from_pyfile('config.py', silent=True)
    else:
        app.config.from_mapping(test_config)

    # ensure the instance folder exists
    try:
        os.makedirs(app.instance_path)
    except OSError:
        pass

    # a simple page that says hello

    @app.route('/hello')
    def hello():
        return 'Hello, World'

    from . import db
    db.init_app(app)

    from . import auth
    app.register_blueprint(auth.bp)

    from . import blog
    app.register_blueprint(blog.bp)

    from . import qr
    app.register_blueprint(qr.bp)

    from . import journal
    app.register_blueprint(journal.bp)
    """
    Unlike the auth blueprint, the blog blueprint does not have a url_prefix. 
    So the index view will be at /, the create view at /create, and so on. 
    The blog is the main feature of Flaskr, so it makes sense that the blog 
    index will be the main index.

    However, the endpoint for the index view defined below will be blog.index. 
    Some of the authentication views referred to a plain index endpoint. 
    app.add_url_rule() associates the endpoint name 'index' with the / url so 
    that url_for('index') or url_for('blog.index') will both work,
    generating the same / URL either way.

    In another application you might give the blog blueprint a url_prefix and 
    define a separate index view in the application factory, similar to the 
    hello view. Then the index and blog.index endpoints and URLs would be different.    
    """

    app.add_url_rule('/', endpoint='index')

    return app
Exemplo n.º 5
0
def init_app(app, specter=None):
    '''  see blogpost 19nd Feb 2020 '''
    app.logger.info("Initializing QRcode")
    QRcode(app)  # enable qr codes generation
    # Login via Flask-Login
    app.logger.info("Initializing LoginManager")
    login_manager = LoginManager()
    login_manager.init_app(app)  # Enable Login
    login_manager.login_view = "login"  # Enable redirects if unauthorized

    @login_manager.user_loader
    def load_user(user_id):
        return AuthenticatedUser()

    # let's make it a bit more convenient
    def login():
        login_user(load_user(""))

    app.login = login
    if specter == None:
        # the default. If not None, then it got injected for testing
        app.logger.info("Initializing Specter")
        specter = Specter(DATA_FOLDER)
    # Attach specter instance so child views (e.g. hwi) can access it
    app.specter = specter
    if specter.config.get('auth') == "none":
        app.logger.info("Login disabled")
        app.config["LOGIN_DISABLED"] = True
    else:
        app.logger.info("Login enabled")
    app.logger.info("Initializing Controller ...")
    app.register_blueprint(hwi_views, url_prefix='/hwi')
    with app.app_context():
        from . import controller
    return app
Exemplo n.º 6
0
    def __init__(self):
        super().__init__(__name__)
        cache.init_app(self)
        QRcode(self)
        self.debug = False
        self.config['SECRET_KEY'] = FLASK_SECRET_KEY

        @self.route('/')
        @cache.memoize(timeout=600)
        def index():
            return redirect(url_for('home.index'))

        @self.errorhandler(404)
        @cache.memoize(timeout=600)
        def page_not_found(e):
            return redirect(url_for('home.index'))

        self.admin = Admin(app=self, url='/')
        self.admin.add_view(HomeView(name='Home', endpoint='home'))
        self.admin.add_view(TipView(name='Send a Tip', endpoint='tip'))
        self.admin.add_view(
            PendingChannelsModelView(PendingChannels,
                                     endpoint='pending-channels',
                                     name='Pending Channels',
                                     category='LND'))
        self.admin.add_view(
            OpenChannelsModelView(Channels,
                                  endpoint='channels',
                                  name='Open Channels',
                                  category='LND'))
Exemplo n.º 7
0
def converted_qrcode():

    data = request.form['qrcode']
    qrcode = QRcode()
    img = qrcode(data, border=10)

    return render_template("qrcode.html", img=img, data=data)
Exemplo n.º 8
0
def generate_finish_pdf(report):
    id = report.report_id
    car = report.car
    try:
        enumeration = Enumeration.objects.get(report_id=id)
    except Enumeration.DoesNotExist:
        enumeration = None
    contract = report.contract
    customer = contract.customer
    qrcode = get_qrc_code(qr_company=report.pdf_qr_code_company)
    context = {
        'car':
        car,
        'customer':
        customer,
        'enumeration':
        enumeration,
        'report':
        report,
        'qrcode':
        check_qr_code(qrcode),
        'contract':
        contract,
        'qrcode_some':
        QRcode.qrcode("{url}/pdf/{link}".format(
            url=s.URL_FILES, link=createQRcodeForReport(report))),
        # 'qrcode_some': QRcode.qrcode('https://people.ischool.berkeley.edu/~buckland/20THCENT.pdf')
    }
    file_path = get_name(TemplateMixing.objects.last())
    return generate_pdf(default_template="finishing_report.html",
                        main_template_path=file_path,
                        css_name="finish_report.css",
                        context=context)
Exemplo n.º 9
0
def test_load_online_icon_qrcode():
    qrcode = QRcode()
    old_qr = qrcode('Test Data')
    new_qr = qrcode('Test Data',
                    icon_img='https://www.agner.io/icon.jpg')
    assert "data:image/png;base64," in new_qr
    assert len(new_qr) > len(old_qr)
Exemplo n.º 10
0
def test_load_local_icon_qrcode():
    qrcode = QRcode()
    old_qr = qrcode('Test Data')
    new_qr = qrcode('Test Data',
                    icon_img=os.path.join(testdir, 'icon.jpg'))
    assert "data:image/png;base64," in new_qr
    assert len(new_qr) > len(old_qr)
Exemplo n.º 11
0
def test_error_correction_qrcode():
    qrcode = QRcode()
    generated_b64 = qrcode('You can read me even if I\'m 30% hurt.',
                           error_correction='H')
    expected_b64 = ''

    assert generated_b64 == expected_b64
Exemplo n.º 12
0
def create_app():
    if getattr(sys, 'frozen', False):

        # Best understood with the snippet below this section:
        # https://pyinstaller.readthedocs.io/en/v3.3.1/runtime-information.html#using-sys-executable-and-sys-argv-0
        template_folder = os.path.join(sys._MEIPASS, 'templates')
        static_folder = os.path.join(sys._MEIPASS, 'static')
        logging.info("pyinstaller based instance running in {}".format(
            sys._MEIPASS))
        app = Flask(__name__,
                    template_folder=template_folder,
                    static_folder=static_folder)
    else:
        app = Flask(__name__,
                    template_folder="templates",
                    static_folder="static")
    QRcode(app)  # enable qr codes generation
    specter = Specter(DATA_FOLDER)
    specter.check()
    # Attach specter instance so child views (e.g. hwi) can access it
    app.specter = specter
    app.register_blueprint(hwi_views, url_prefix='/hwi')
    with app.app_context():
        import controller
    return app
Exemplo n.º 13
0
def create_app():
    global application
    if not application:
        application = ipsec_me()

        application.app.url_map.converters['vpn_server'] = VPNServerConverter
        application.app.url_map.converters[
            'device_class'] = DeviceClassConverter
        application.app.url_map.converters['device'] = DeviceConverter
        application.app.url_map.converters[
            'device_secure'] = DeviceSecureConverter

        application.facet("configuration")
        application.facet("logs")
        application.facet("database")
        application.facet("marshalling")
        application.facet("blueprints")
        application.facet("accounts")
        application.facet("signals")
        application.facet("forms")
        application.facet("error_handlers")
        application.facet("request_handlers")
        application.facet("administration")
        # application.facet("rest", api_map=api_map)
        # application.facet("webassets")
        # application.facet("email")
        application.facet("debugger")
        # application.facet("task_queue")

        Bootstrap(application.app)
        Babel(application.app)
        QRcode(application.app)

    # print application.app.url_map
    return application.app
Exemplo n.º 14
0
def create_app():
    app = Flask(__name__)

    qrcode = QRcode(app)
    app.config['SECRET_KEY'] = os.urandom(24)
    app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///users.sqlite'
    app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False

    db.init_app(app)

    from . import initdb
    initdb.init_app(app)

    login_manager.login_view = 'auth.login'
    login_manager.init_app(app)

    # blueprint for auth routes in our app
    from .auth import auth as auth_blueprint
    app.register_blueprint(auth_blueprint)

    # blueprint for non-auth parts of app
    from .main import main as main_blueprint
    app.register_blueprint(main_blueprint)

    return app
Exemplo n.º 15
0
Arquivo: main.py Projeto: KsAmJ/FQM
def create_app(config={}):
    ''' Create the flask app and setup extensions and blueprints.

    Returns
    -------
        app: Flask app
            app with settings and blueprints loadeds.
    '''
    app = Flask(__name__,
                static_folder=absolute_path('static'),
                template_folder=absolute_path('templates'))
    app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False
    app.config[
        'SQLALCHEMY_DATABASE_URI'] = f'sqlite:///{absolute_path(DATABASE_FILE)}?check_same_thread=False'
    app.config['DB_NAME'] = DATABASE_FILE
    # Autoreload if templates change
    app.config['TEMPLATES_AUTO_RELOAD'] = True
    # flask_upload settings
    # app.config['MAX_CONTENT_LENGTH'] = 500 * 1024 * 1024 # Remove Upload limit. FIX ISSUE
    app.config['UPLOADED_FILES_DEST'] = absolute_path('static/multimedia')
    app.config['UPLOADED_FILES_ALLOW'] = reduce(lambda sum, group: sum + group,
                                                SUPPORTED_MEDIA_FILES)
    app.config['SECRET_KEY'] = os.urandom(24)
    app.config.update(config)

    # Initiating extensions before registering blueprints
    Moment(app)
    QRcode(app)
    configure_uploads(app, files)
    login_manager.init_app(app)
    db.init_app(app)
    migrate.init_app(app, db=db)
    datepicker(
        app, local=['static/css/jquery-ui.min.css', 'static/jquery-ui.min.js'])
    colorpicker(app,
                local=['static/css/spectrum.css', 'static/spectrum.min.js'])
    fontpicker(app,
               local=[
                   'static/jquery-ui.min.js', 'static/css/jquery-ui.min.css',
                   'static/webfont.min.js', 'static/webfont.select.min.js',
                   'static/css/webfont.select.css'
               ])
    minify(app,
           js=True,
           cssless=True,
           caching_limit=3,
           fail_safe=True,
           bypass=['.min.*'])
    gTTs.init_app(app)
    gtranslator.init_app(app)

    # Register blueprints
    app.register_blueprint(administrate)
    app.register_blueprint(core)
    app.register_blueprint(cust_app)
    app.register_blueprint(manage_app)
    app.jinja_env.add_extension('jinja2.ext.loopcontrols')

    return app
Exemplo n.º 16
0
def test_color_qrcode():
    qrcode = QRcode()
    generated_b64 = qrcode('You can see green front color and #CCC back color.',
                           error_correction='H', back_color='ccc',
                           fill_color='green')
    expected_b64 = ''

    assert generated_b64 == expected_b64
Exemplo n.º 17
0
def test_local_icon_image_qrcode():
    qrcode = QRcode()
    generated_b64 = qrcode('Load icon image from static folder.',
                           error_correction='H',
                           icon_img=os.path.join(testdir, 'icon.jpg'))
    expected_b64 = ''

    assert generated_b64 == expected_b64
Exemplo n.º 18
0
 def insert_images(self, sign, number_pages, location_sign):
     if sign is not None:
         sign = QRcode.qrcode(sign, mode='raw')
         for i in range(0, number_pages):
             page = self._pdf_file[i]
             size_page = page.rect
             image_rectangle = location_sign(size_page)
             page.insertImage(image_rectangle, stream=sign)
Exemplo n.º 19
0
def test_remote_icon_image_qrcode():
    qrcode = QRcode()
    generated_b64 = qrcode('You can see a icon in QR code.',
                           error_correction='H',
                           icon_img='https://www.agner.io/icon.jpg')
    expected_b64 = ''

    assert generated_b64 == expected_b64
Exemplo n.º 20
0
def test_remote_icon_image_qrcode():
    qrcode = QRcode()
    generated_b64 = qrcode('You can see a icon in QR code.',
                           error_correction='H',
                           icon_img='https://www.agner.io/icon.jpg')
    expected_b64 = ''

    assert generated_b64 == expected_b64
Exemplo n.º 21
0
def test_color_qrcode():
    qrcode = QRcode()
    generated_b64 = qrcode('You can see green front color and #CCC back color.',
                           error_correction='H', back_color='ccc',
                           fill_color='green')
    expected_b64 = ''

    assert generated_b64 == expected_b64
Exemplo n.º 22
0
def create_app():
    app = Flask(__name__)
    app.secret_key = config.settings["secret_key"]

    update_config()
    define_routes(app)
    define_filters(app)
    QRcode(app)
    return app
Exemplo n.º 23
0
def create_app():

    app = Flask(__name__)

    QRcode(app)

    @app.route('/')
    def home():
        return render_template('index.html',
            verse = randomVerse()
        )
    
    return app
Exemplo n.º 24
0
def create_app():
    app = Flask(__name__,
                static_folder=r_path('static'),
                template_folder=r_path('templates'))
    if getattr(sys, 'frozen', False):
        basedir = os.path.dirname(sys.executable)
    else:
        basedir = os.path.abspath(os.path.dirname(__file__))
    # bootstrap = Bootstrap(app)
    pagedown = PageDown(app)
    app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False
    app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///' + r_path(
        'data.sqlite')
    # Autoreload if templates change
    app.config['TEMPLATES_AUTO_RELOAD'] = True
    # flask_upload settings
    # app.config['MAX_CONTENT_LENGTH'] = 500 * 1024 * 1024 # Remove Upload limit. FIX ISSUE
    app.config['UPLOADED_FILES_DEST'] = r_path('static/multimedia')
    app.config['UPLOADED_FILES_ALLOW'] = mdal
    app.config['SECRET_KEY'] = os.urandom(24)
    # Intiating extensions before registering blueprints
    moment = Moment(app)
    qrc = QRcode(app)
    configure_uploads(app, files)
    login_manager.init_app(app)
    db.init_app(app)
    datepicker(
        app, local=['static/css/jquery-ui.min.css', 'static/jquery-ui.min.js'])
    colorpicker(app, local=['static/css/spectrum.css', 'static/spectrum.js'])
    fontpicker(app,
               local=[
                   'static/jquery-ui.min.js', 'static/css/jquery-ui.min.css',
                   'static/webfont.js', 'static/webfont.select.js',
                   'static/css/webfont.select.css'
               ])
    lessc(app)
    minify(app,
           js=True,
           cache=True,
           fail_safe=True,
           bypass=['/touch/<int:a>', '/serial/<int:t_id>', '/display'])
    gtts(app=app, route=True)
    gtranslator.init_app(app)
    # Register blueprints
    app.register_blueprint(administrate)
    app.register_blueprint(core)
    app.register_blueprint(cust_app)
    app.register_blueprint(errorsh_app)
    app.register_blueprint(manage_app)
    app.jinja_env.add_extension('jinja2.ext.loopcontrols')
    return app
Exemplo n.º 25
0
def create_app():
    """Construct the core application."""
    app = Flask(__name__, instance_relative_config=False)
    bootstrap = Bootstrap(app)
    app.config.from_object('config.Config')
    app.config['RECAPTCHA_PUBLIC_KEY'] = 'iubhiukfgjbkhfvgkdfm'
    app.config['RECAPTCHA_PARAMETERS'] = {'size': '100%'}
    qrcode = QRcode(app)


    with app.app_context():
        # Import parts of our application
        from . import routes
        return app
Exemplo n.º 26
0
def create_app():
    """Construct the core application."""
    app = Flask(__name__, instance_relative_config=False)
    bootstrap = Bootstrap(app)
    qrcode = QRcode(app)
    app.config.from_object('config.Config')
    app.config['SECRET_KEY'] = os.environ['APP_SECRET_KEY']
    app.config['RECAPTCHA_USE_SSL'] = False
    app.config['RECAPTCHA_PUBLIC_KEY'] = os.environ['APP_RECAPTCHA_PUBLIC_KEY']
    app.config['RECAPTCHA_PRIVATE_KEY'] = os.environ[
        'APP_RECAPTCHA_PRIVATE_KEY']
    app.config['RECAPTCHA_OPTIONS'] = {'theme': 'white'}

    with app.app_context():
        # Import parts of our application
        from . import routes
        return app
Exemplo n.º 27
0
def create_app(config_name):
    app = Flask(__name__)
    QRcode(app)
    app.config.from_object(config[config_name])
    config[config_name].init_app(app)

    bootstrap.init_app(app)

    if not app.debug and not app.testing and not app.config['SSL_DISABLE']:
        from flask.ext.sslify import SSLify
        sslify = SSLify(app)

    from .main import main as main_blueprint
    app.register_blueprint(main_blueprint)


    return app
Exemplo n.º 28
0
def create_app(config_name=None):
	app = Flask(__name__, instance_relative_config=True)
	app.config.from_object(ProductionConfig)
	app.config.from_pyfile('config.py')
	app.config.update(
	CELERY_BROKER_URL='amqp://guest@localhost//',
	CELERY_RESULT_BACKEND='amqp://guest@localhost//'
)

	from app.oauth2 import (
		query_client, save_token, 
		require_oauth, authorization
		)

	from extensions import db, login_manager

	with app.app_context():
		db.init_app(app)
		authorization.init_app(app, query_client, save_token)
		login_manager.init_app(app)
   
	Bootstrap(app)
	QRcode(app)
	login_manager.login_message = "You must be logged in to access this page."
	login_manager.login_view = "auth.login"
	migrate = Migrate(app, db, compare_type=True)


	#DEFINING BLUEPRINTS
	from .home import home as home_blueprint
	app.register_blueprint(home_blueprint)

	from .auth import auth as auth_blueprint
	app.register_blueprint(auth_blueprint)

	from .member import member as member_blueprint
	app.register_blueprint(member_blueprint)

	from .payments import payments as payments_blueprint
	app.register_blueprint(payments_blueprint)

	return app
Exemplo n.º 29
0
def create_app():
    if getattr(sys, 'frozen', False):
        template_folder = os.path.join(os.path.realpath(__file__), 'templates')
        static_folder = os.path.join(os.path.realpath(__file__), 'static')
        app = Flask(__name__,
                    template_folder=template_folder,
                    static_folder=static_folder)
    else:
        app = Flask(__name__,
                    template_folder="templates",
                    static_folder="static")
    QRcode(app)  # enable qr codes generation
    specter = Specter(DATA_FOLDER)
    specter.check()
    # Attach specter instance so child views (e.g. hwi) can access it
    app.specter = specter
    app.register_blueprint(hwi_views, url_prefix='/hwi')
    with app.app_context():
        import controller
    return app
Exemplo n.º 30
0
def creat_app(config_name):
    app = Flask(__name__, static_folder='adminDashboard/base/static')
    app.config.from_object(config_by_name[config_name])
    app.config['GOOGLEMAPS_KEY'] = "AIzaSyBp1G6tb0v3JzSfcPtmKGwLI018Q-DL41E"
    GoogleMaps(app)
    db.init_app(app)
    cors.init_app(app)
    login_manager.init_app(app)
    bcrypt.init_app(app)
    rq.init_app(app)
    QRcode(app)
    # register blueprints

    # test
    app.register_blueprint(root)

    # Admin Dashboard blueprints
    app.register_blueprint(api_bl)
    app.register_blueprint(base_admin)
    app.register_blueprint(home_admin)
    app.register_blueprint(factory_admin)
    app.register_blueprint(company_admin)
    app.register_blueprint(driver_admin)
    app.register_blueprint(orders_admin)

    # Company Dashboard blueprint
    app.register_blueprint(home_company)
    app.register_blueprint(cars_company)
    app.register_blueprint(drivers_company)
    app.register_blueprint(orders_company)

    # Factory Dashboard blueprint
    app.register_blueprint(factory_blueprint)
    app.register_blueprint(orders_factory)
    app.register_blueprint(new_order_factory)

    r = Redis(os.getenv('REDIS_URL', 'redis://localhost:6379'))

    return app, r