當前位置: 首頁>>代碼示例>>Python>>正文


Python g.db方法代碼示例

本文整理匯總了Python中flask.g.db方法的典型用法代碼示例。如果您正苦於以下問題:Python g.db方法的具體用法?Python g.db怎麽用?Python g.db使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在flask.g的用法示例。


在下文中一共展示了g.db方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: update_protobuf_in_db

# 需要導入模塊: from flask import g [as 別名]
# 或者: from flask.g import db [as 別名]
def update_protobuf_in_db(table_name, msg, id):
    try:
        # If protobuf has an id field and it's uint64, make it a string
        id_field = msg.DESCRIPTOR.fields_by_name['id']
        if id_field.type == id_field.TYPE_UINT64:
            id = str(id)
    except AttributeError:
        pass
    cur = g.db.cursor()
    msg_dict = protobuf_to_dict(msg, type_callable_map=type_callable_map)
    columns = ', '.join(list(msg_dict.keys()))
    placeholders = ':'+', :'.join(list(msg_dict.keys()))
    setters = ', '.join('{}=:{}'.format(key, key) for key in msg_dict)
    query = 'UPDATE %s SET %s WHERE id=%s' % (table_name, setters, id)
    cur.execute(query, msg_dict)
    g.db.commit() 
開發者ID:zoffline,項目名稱:zwift-offline,代碼行數:18,代碼來源:zwift_offline.py

示例2: api_profiles_activities

# 需要導入模塊: from flask import g [as 別名]
# 或者: from flask.g import db [as 別名]
def api_profiles_activities(player_id):
    if request.method == 'POST':
        if not request.stream:
            return '', 400
        activity = activity_pb2.Activity()
        activity.ParseFromString(request.stream.read())
        activity.id = get_id('activity')
        insert_protobuf_into_db('activity', activity)
        return '{"id": %ld}' % activity.id, 200

    # request.method == 'GET'
    activities = activity_pb2.Activities()
    cur = g.db.cursor()
    # Select every column except 'fit' - despite being a blob python 3 treats it like a utf-8 string and tries to decode it
    cur.execute("SELECT id, player_id, f3, name, f5, f6, start_date, end_date, distance, avg_heart_rate, max_heart_rate, avg_watts, max_watts, avg_cadence, max_cadence, avg_speed, max_speed, calories, total_elevation, strava_upload_id, strava_activity_id, f23, fit_filename, f29, date FROM activity WHERE player_id = ?", (str(player_id),))
    for row in cur.fetchall():
        activity = activities.activities.add()
        row_to_protobuf(row, activity, exclude_fields=['fit'])

    return activities.SerializeToString(), 200


# For ghosts 
開發者ID:zoffline,項目名稱:zwift-offline,代碼行數:25,代碼來源:zwift_offline.py

示例3: setUp

# 需要導入模塊: from flask import g [as 別名]
# 或者: from flask.g import db [as 別名]
def setUp(self):
        # Init db
        self.engine, self.Session = models.get_working_db_for_tests()
        self.db = self.Session()
        self.db.begin()

        # Flask
        self.app = app = Flask(__name__)
        app.debug = app.testing = True
        app.json_encoder = DynamicJSONEncoder
        app.test_client_class = FlaskJsonClient

        ArticleView.route_as_view(app, 'articles', ('/article/', '/article/<int:id>'))
        GirlWatcherView.route_as_view(app, 'girlwatchers', ('/girlwatcher/', '/girlwatcher/<int:id>'))

        @app.before_request
        def db():
            g.db = self.db 
開發者ID:kolypto,項目名稱:py-mongosql,代碼行數:20,代碼來源:t5_crud_test.py

示例4: test_delete

# 需要導入模塊: from flask import g [as 別名]
# 或者: from flask.g import db [as 別名]
def test_delete(self):
        """ Test delete() """

        # Delete
        with self.app.test_client() as c:
            rv = c.delete('/article/10', json=None)
            art = rv['article']
            art.pop('comments', None)
            self.assertEqual(rv['article'], {
                'id': 10, 'uid': 1,
                'title': '10',
                'theme': None,
                'data': {'o': {'a': True}, 'rating': 5},
            })

            self.db.close()

            self.assertRaises(NoResultFound, c.get, '/article/10')  # really removed 
開發者ID:kolypto,項目名稱:py-mongosql,代碼行數:20,代碼來源:t5_crud_test.py

示例5: sql_query

# 需要導入模塊: from flask import g [as 別名]
# 或者: from flask.g import db [as 別名]
def sql_query(keyword):
    if not hasattr(g, 'db'):
        g.db = MySQLdb.connect(
                host    = conf.db_host,
                port    = conf.db_port,
                user    = conf.db_user,
                passwd  = conf.db_passwd,
                db      = conf.db_name,
                charset = 'utf8')
    c = g.db.cursor()

    sql = '''select title, type, answer from `erya` where title like %s limit 30'''
    c.execute(sql, ('%' + unicode(keyword) + '%', ))
    result = [dict(title = it[0], type = it[1], answer = it[2]) for it in c.fetchall()]
    return result

############################################################ 
開發者ID:hangim,項目名稱:erya,代碼行數:19,代碼來源:erya.py

示例6: get

# 需要導入模塊: from flask import g [as 別名]
# 或者: from flask.g import db [as 別名]
def get(self, project_name):
        if g.token and g.token["type"] == "user":
            project = g.db.execute_one_dict('''
                SELECT p.id, p.name, p.type, p.public, co.role AS userrole
                FROM project p
                LEFT JOIN collaborator co ON p.id = co.project_id AND co.user_id = %s
                WHERE p.name = %s
            ''', [g.token["user"]["id"], project_name])
        else:
            project = g.db.execute_one_dict('''
                SELECT id, name, type, public
                FROM project
                WHERE name = %s
            ''', [project_name])

        if not project:
            abort(404)

        return project 
開發者ID:SAP,項目名稱:InfraBox,代碼行數:21,代碼來源:projects.py

示例7: before_request

# 需要導入模塊: from flask import g [as 別名]
# 或者: from flask.g import db [as 別名]
def before_request():
    def release_db():
        db = getattr(g, 'db', None)
        if not db:
            return

        dbpool.put(db)
        g.db = None

    g.release_db = release_db

    g.db = dbpool.get()

    if app.config['OPA_ENABLED']:
        g.token = normalize_token(get_token())
        check_request_authorization() 
開發者ID:SAP,項目名稱:InfraBox,代碼行數:18,代碼來源:ibflask.py

示例8: check_job_belongs_to_project

# 需要導入模塊: from flask import g [as 別名]
# 或者: from flask.g import db [as 別名]
def check_job_belongs_to_project(f):
    @wraps(f)
    def decorated_function(*args, **kwargs):
        project_id = kwargs.get('project_id')
        job_id = kwargs.get('job_id')

        assert project_id
        assert job_id

        r = g.db.execute_one('''
            SELECT id
            FROM job
            WHERE id = %s AND project_id = %s
        ''', [job_id, project_id])

        if not r:
            logger.debug('job does not belong to project')
            abort(404)

        return f(*args, **kwargs)
    return decorated_function 
開發者ID:SAP,項目名稱:InfraBox,代碼行數:23,代碼來源:ibflask.py

示例9: enrich_job_token

# 需要導入模塊: from flask import g [as 別名]
# 或者: from flask.g import db [as 別名]
def enrich_job_token(token):
    if not ("job" in token and "id" in token["job"] and validate_uuid(token["job"]["id"])):
        raise LookupError('invalid job id')

    job_id = token["job"]["id"]

    r = g.db.execute_one('''
        SELECT state, project_id, name
        FROM job
        WHERE id = %s''', [job_id])

    if not r:
        raise LookupError('job not found')


    token['job']['state'] = r[0]
    token['job']['name'] = r[2]
    token['project'] = {}
    token['project']['id'] = r[1]
    return token 
開發者ID:SAP,項目名稱:InfraBox,代碼行數:22,代碼來源:ibflask.py

示例10: select_blogs_by_id_sql

# 需要導入模塊: from flask import g [as 別名]
# 或者: from flask.g import db [as 別名]
def select_blogs_by_id_sql(newsid):
    c = g.db.cursor()
    sql ="select  * from blog where newsid =%s" %(newsid)
    c.execute(sql)
    results=c.fetchone()
    index=results[0]
    sql ="select  * from blog where id< %d and id>%d" %(index,index-9)
    c.execute(sql)
    results=c.fetchall()
    blogs=[]
    blogjsonlist={}
    for index in range(8) :
        blogs.append(json.loads(results[7-index][2]))
   
    blogjsonlist['nextId']=results[0][1]
    blogjsonlist['newslist']=blogs
    blogs=json.dumps(blogjsonlist).decode("unicode-escape")
    return blogs 
開發者ID:SilenceDut,項目名稱:nbaplus-server,代碼行數:20,代碼來源:basesqlutil.py

示例11: validate_job_token

# 需要導入模塊: from flask import g [as 別名]
# 或者: from flask.g import db [as 別名]
def validate_job_token(token):
    job_id = token['job']['id']
    r = g.db.execute_one('''
        SELECT state, project_id, name
        FROM job
        WHERE id = %s''', [job_id])

    if not r:
        logger.warn('job not found')
        abort(401, 'Unauthorized')

    job_state = r[0]
    if job_state not in ('queued', 'running', 'scheduled'):
        logger.warn('job not in an active state')
        abort(401, 'Unauthorized')


    token['job']['state'] = r[0]
    token['job']['name'] = r[2]
    token['project'] = {}
    token['project']['id'] = r[1]
    g.token = token 
開發者ID:InfraBox,項目名稱:infrabox,代碼行數:24,代碼來源:ibflask.py

示例12: test_remove_blocked_users

# 需要導入模塊: from flask import g [as 別名]
# 或者: from flask.g import db [as 別名]
def test_remove_blocked_users(self, mock_request):
        """
        Check removing user from block list.
        """
        self.create_user_with_role(
            self.user.name, self.user.email, self.user.password, Role.admin)
        with self.app.test_client() as c:
            c.post("/account/login", data=self.create_login_form_data(self.user.email, self.user.password))
            blocked_user = BlockedUsers(1, "Bad user")
            g.db.add(blocked_user)
            g.db.commit()
            self.assertNotEqual(BlockedUsers.query.filter(BlockedUsers.comment == "Bad user").first(), None)
            c.post("/blocked_users", data=dict(user_id=1, remove=True))
            self.assertEqual(BlockedUsers.query.filter(BlockedUsers.user_id == 1).first(), None)
            with c.session_transaction() as session:
                flash_message = dict(session['_flashes']).get('message')
            self.assertEqual(flash_message, "User removed successfully.") 
開發者ID:CCExtractor,項目名稱:sample-platform,代碼行數:19,代碼來源:TestControllers.py

示例13: test_webhook_release

# 需要導入模塊: from flask import g [as 別名]
# 或者: from flask.g import db [as 別名]
def test_webhook_release(self, mock_request):
        """
        Check webhook release update CCExtractor Version for release.
        """
        with self.app.test_client() as c:
            # Full Release with version with 2.1
            data = {'action': 'published',
                    'release': {'prerelease': False, 'published_at': '2018-05-30T20:18:44Z', 'tag_name': 'v2.1'}}
            # one of ip address from GitHub web hook
            last_commit = GeneralData.query.filter(GeneralData.key == 'last_commit').first()
            # abcdefgh is the new commit after previous version defined in base.py
            last_commit.value = 'abcdefgh'
            g.db.commit()
            response = c.post(
                '/start-ci', environ_overrides=WSGI_ENVIRONMENT,
                data=json.dumps(data), headers=self.generate_header(data, 'release'))
            last_release = CCExtractorVersion.query.order_by(CCExtractorVersion.released.desc()).first()
            self.assertEqual(last_release.version, '2.1') 
開發者ID:CCExtractor,項目名稱:sample-platform,代碼行數:20,代碼來源:TestControllers.py

示例14: test_webhook_release_edited

# 需要導入模塊: from flask import g [as 別名]
# 或者: from flask.g import db [as 別名]
def test_webhook_release_edited(self, mock_request):
        """
        Check webhook action "edited" updates the specified version.
        """
        from datetime import datetime
        with self.app.test_client() as c:
            release = CCExtractorVersion('2.1', '2018-05-30T20:18:44Z', 'abcdefgh')
            g.db.add(release)
            g.db.commit()
            # Full Release with version with 2.1
            data = {'action': 'edited',
                    'release': {'prerelease': False, 'published_at': '2018-06-30T20:18:44Z', 'tag_name': 'v2.1'}}
            last_commit = GeneralData.query.filter(GeneralData.key == 'last_commit').first()
            # abcdefgh is the new commit after previous version defined in base.py
            last_commit.value = 'abcdefgh'
            g.db.commit()
            response = c.post(
                '/start-ci', environ_overrides=WSGI_ENVIRONMENT,
                data=json.dumps(data), headers=self.generate_header(data, 'release'))
            last_release = CCExtractorVersion.query.filter_by(version='2.1').first()
            self.assertEqual(last_release.released,
                             datetime.strptime('2018-06-30T20:18:44Z', '%Y-%m-%dT%H:%M:%SZ').date()) 
開發者ID:CCExtractor,項目名稱:sample-platform,代碼行數:24,代碼來源:TestControllers.py

示例15: test_webhook_release_deleted

# 需要導入模塊: from flask import g [as 別名]
# 或者: from flask.g import db [as 別名]
def test_webhook_release_deleted(self, mock_request):
        """
        Check webhook action "delete" removes the specified version.
        """
        with self.app.test_client() as c:
            release = CCExtractorVersion('2.1', '2018-05-30T20:18:44Z', 'abcdefgh')
            g.db.add(release)
            g.db.commit()
            # Delete full release with version with 2.1
            data = {'action': 'deleted',
                    'release': {'prerelease': False, 'published_at': '2018-05-30T20:18:44Z', 'tag_name': 'v2.1'}}
            last_commit = GeneralData.query.filter(GeneralData.key == 'last_commit').first()
            # abcdefgh is the new commit after previous version defined in base.py
            last_commit.value = 'abcdefgh'
            g.db.commit()
            response = c.post(
                '/start-ci', environ_overrides=WSGI_ENVIRONMENT,
                data=json.dumps(data), headers=self.generate_header(data, 'release'))
            last_release = CCExtractorVersion.query.order_by(CCExtractorVersion.released.desc()).first()
            self.assertNotEqual(last_release.version, '2.1') 
開發者ID:CCExtractor,項目名稱:sample-platform,代碼行數:22,代碼來源:TestControllers.py


注:本文中的flask.g.db方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。