本文整理匯總了Python中tyggbot.models.db.DBManager.create_session方法的典型用法代碼示例。如果您正苦於以下問題:Python DBManager.create_session方法的具體用法?Python DBManager.create_session怎麽用?Python DBManager.create_session使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類tyggbot.models.db.DBManager
的用法示例。
在下文中一共展示了DBManager.create_session方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: create_stream_chunk
# 需要導入模塊: from tyggbot.models.db import DBManager [as 別名]
# 或者: from tyggbot.models.db.DBManager import create_session [as 別名]
def create_stream_chunk(self, status):
if self.current_stream_chunk is not None:
# There's already a stream chunk started!
session = DBManager.create_session(expire_on_commit=False)
self.current_stream_chunk.chunk_end = datetime.datetime.now()
session.add(self.current_stream_chunk)
session.commit()
session.close()
self.current_stream_chunk = None
session = DBManager.create_session(expire_on_commit=False)
stream_chunk = session.query(StreamChunk).filter_by(broadcast_id=status['broadcast_id']).one_or_none()
if stream_chunk is None:
log.info('Creating stream chunk, from create_stream_chunk')
stream_chunk = StreamChunk(self.current_stream, status['broadcast_id'], status['created_at'])
self.current_stream_chunk = stream_chunk
session.add(stream_chunk)
session.commit()
else:
log.info('We already have a stream chunk!')
self.current_stream_chunk = stream_chunk
session.expunge_all()
session.close()
self.current_stream.stream_chunks.append(stream_chunk)
示例2: decks_warrior
# 需要導入模塊: from tyggbot.models.db import DBManager [as 別名]
# 或者: from tyggbot.models.db.DBManager import create_session [as 別名]
def decks_warrior():
session = DBManager.create_session()
decks = session.query(Deck).filter_by(deck_class='warrior').order_by(Deck.last_used.desc(), Deck.first_used.desc()).all()
session.close()
return render_template('decks/by_class.html',
decks=decks,
deck_class='Warrior')
示例3: create_highlight
# 需要導入模塊: from tyggbot.models.db import DBManager [as 別名]
# 或者: from tyggbot.models.db.DBManager import create_session [as 別名]
def create_highlight(self, **options):
"""
Returns an error message (string) if something went wrong, otherwise returns True
"""
if self.online is False or self.current_stream_chunk is None:
return 'The stream is not online'
if self.current_stream_chunk.video_url is None:
return 'No video URL fetched for this chunk yet, try in 5 minutes'
try:
highlight = StreamChunkHighlight(self.current_stream_chunk, **options)
session = DBManager.create_session(expire_on_commit=False)
session.add(highlight)
session.add(self.current_stream_chunk)
session.commit()
session.close()
x = inspect(self.current_stream_chunk)
log.info('{0.transient} - {0.pending} - {0.persistent} - {0.detached}'.format(x))
x = inspect(highlight)
log.info('{0.transient} - {0.pending} - {0.persistent} - {0.detached}'.format(x))
x = inspect(self.current_stream)
log.info('{0.transient} - {0.pending} - {0.persistent} - {0.detached}'.format(x))
log.info(self.current_stream.id)
log.info(highlight.id)
log.info(self.current_stream_chunk.id)
except:
log.exception('uncaught exception in create_highlight')
return 'Unknown reason, ask pajlada'
return True
示例4: get_user
# 需要導入模塊: from tyggbot.models.db import DBManager [as 別名]
# 或者: from tyggbot.models.db.DBManager import create_session [as 別名]
def get_user(username):
session = DBManager.create_session()
user = session.query(User).filter_by(username=username).one_or_none()
if user is None:
return make_response(jsonify({'error': 'Not found'}), 404)
rank = session.query(func.Count(User.id)).filter(User.points > user.points).one()
rank = rank[0] + 1
session.close()
if user:
accessible_data = {
'id': user.id,
'username': user.username,
'username_raw': user.username_raw,
'points': user.points,
'rank': rank,
'level': user.level,
'last_seen': user.last_seen,
'last_active': user.last_active,
'subscriber': user.subscriber,
'num_lines': user.num_lines,
'minutes_in_chat_online': user.minutes_in_chat_online,
'minutes_in_chat_offline': user.minutes_in_chat_offline,
'banned': user.banned,
'ignored': user.ignored,
}
return jsonify(accessible_data)
return make_response(jsonify({'error': 'Not found'}), 404)
示例5: __init__
# 需要導入模塊: from tyggbot.models.db import DBManager [as 別名]
# 或者: from tyggbot.models.db.DBManager import create_session [as 別名]
def __init__(self, bot):
self.bot = bot
self.current_stream_chunk = None # should this even exist?
self.num_offlines = 0
self.first_offline = None
self.bot.execute_every(self.STATUS_CHECK_INTERVAL, self.refresh_stream_status)
self.bot.execute_every(self.VIDEO_URL_CHECK_INTERVAL, self.refresh_video_url)
"""
This will load the latest stream so we can post an accurate
"time since last online" figure.
"""
session = DBManager.create_session(expire_on_commit=False)
self.current_stream = session.query(Stream).filter_by(ended=False).order_by(Stream.stream_start.desc()).first()
self.last_stream = session.query(Stream).filter_by(ended=True).order_by(Stream.stream_end.desc()).first()
# if self.current_stream and len(self.current_stream.stream_chunks) > 0:
if self.current_stream:
# sorted_chunks = sorted(self.current_stream.stream_chunks, key=lambda x: x.chunk_start, reverse=True)
# self.current_stream_chunk = sorted_chunks[0]
self.current_stream_chunk = session.query(StreamChunk).filter_by(stream_id=self.current_stream.id).order_by(StreamChunk.chunk_start.desc()).first()
log.info('Set current stream chunk here to {0}'.format(self.current_stream_chunk))
session.expunge_all()
session.close()
示例6: __init__
# 需要導入模塊: from tyggbot.models.db import DBManager [as 別名]
# 或者: from tyggbot.models.db.DBManager import create_session [as 別名]
def __init__(self, bot):
self.db_session = DBManager.create_session()
self.messages = []
self.bot = bot
self.minute = 0
self.iterator = 0
self.bot.execute_every(60, self.tick)
示例7: points
# 需要導入模塊: from tyggbot.models.db import DBManager [as 別名]
# 或者: from tyggbot.models.db.DBManager import create_session [as 別名]
def points():
session = DBManager.create_session()
top_30_users = []
for user in session.query(User).order_by(User.points.desc())[:30]:
top_30_users.append(user)
session.close()
return render_template('points.html',
top_30_users=top_30_users)
示例8: decks
# 需要導入模塊: from tyggbot.models.db import DBManager [as 別名]
# 或者: from tyggbot.models.db.DBManager import create_session [as 別名]
def decks():
session = DBManager.create_session()
top_decks = []
for deck in session.query(Deck).order_by(Deck.last_used.desc(), Deck.first_used.desc())[:25]:
top_decks.append(deck)
session.close()
return render_template('decks/all.html',
top_decks=top_decks,
deck_class=None)
示例9: __init__
# 需要導入模塊: from tyggbot.models.db import DBManager [as 別名]
# 或者: from tyggbot.models.db.DBManager import create_session [as 別名]
def __init__(self, bot):
UserDict.__init__(self)
self.bot = bot
self.streamer = bot.streamer
self.db_session = DBManager.create_session()
self.custom_data = []
self.bttv_emote_manager = BTTVEmoteManager(self)
self.bot.execute_every(60 * 60 * 2, self.bot.action_queue.add, (self.bttv_emote_manager.update_emotes, ))
示例10: highlights
# 需要導入模塊: from tyggbot.models.db import DBManager [as 別名]
# 或者: from tyggbot.models.db.DBManager import create_session [as 別名]
def highlights():
session = DBManager.create_session()
streams = session.query(Stream).order_by(Stream.stream_start.desc()).all()
for stream in streams:
stream.stream_chunks = sorted(stream.stream_chunks, key=lambda x: x.chunk_start, reverse=True)
for stream_chunk in stream.stream_chunks:
stream_chunk.highlights = sorted(stream_chunk.highlights, key=lambda x: x.created_at, reverse=True)
session.close()
return render_template('highlights.html',
streams=streams)
示例11: remove_highlight
# 需要導入模塊: from tyggbot.models.db import DBManager [as 別名]
# 或者: from tyggbot.models.db.DBManager import create_session [as 別名]
def remove_highlight(self, id):
"""
Returns True if a highlight was removed, otherwise return False
"""
session = DBManager.create_session()
num_rows = session.query(StreamChunkHighlight).filter(StreamChunkHighlight.id == id).delete()
session.commit()
session.close()
return (num_rows == 1)
示例12: __init__
# 需要導入模塊: from tyggbot.models.db import DBManager [as 別名]
# 或者: from tyggbot.models.db.DBManager import create_session [as 別名]
def __init__(self, reactor, bot, target, message_limit, time_interval, num_of_conns=30):
self.db_session = DBManager.create_session()
self.reactor = reactor
self.bot = bot
self.message_limit = message_limit
self.time_interval = time_interval
self.num_of_conns = num_of_conns
self.whisper_thread = None
self.connlist = []
self.whispers = Queue()
self.maintenance_lock = False
示例13: stats
# 需要導入模塊: from tyggbot.models.db import DBManager [as 別名]
# 或者: from tyggbot.models.db.DBManager import create_session [as 別名]
def stats():
top_5_commands = sorted(bot_commands_list, key=lambda c: c.num_uses, reverse=True)[:5]
if 'linefarming' in modules:
session = DBManager.create_session()
top_5_line_farmers = session.query(User).order_by(User.num_lines.desc())[:5]
session.close()
else:
top_5_line_farmers = []
return render_template('stats.html',
top_5_commands=top_5_commands,
top_5_line_farmers=top_5_line_farmers)
示例14: highlight_id
# 需要導入模塊: from tyggbot.models.db import DBManager [as 別名]
# 或者: from tyggbot.models.db.DBManager import create_session [as 別名]
def highlight_id(date, highlight_id, highlight_title=None):
session = DBManager.create_session()
highlight = session.query(StreamChunkHighlight).filter_by(id=highlight_id).first()
if highlight is None:
session.close()
return render_template('highlight_404.html'), 404
else:
stream_chunk = highlight.stream_chunk
stream = stream_chunk.stream
session.close()
return render_template('highlight.html',
highlight=highlight,
stream_chunk=stream_chunk,
stream=stream)
示例15: update_highlight
# 需要導入模塊: from tyggbot.models.db import DBManager [as 別名]
# 或者: from tyggbot.models.db.DBManager import create_session [as 別名]
def update_highlight(self, id, **options):
"""
Returns True if a highlight was modified, otherwise return False
"""
if 'offset' in options:
options['highlight_offset'] = options.pop('offset')
session = DBManager.create_session()
num_rows = session.query(StreamChunkHighlight).filter(StreamChunkHighlight.id == id).update(options)
session.commit()
session.close()
return (num_rows == 1)