+
+
+def map_captimes_data(request):
+ map_id = int(request.matchdict['id'])
+
+ current_page = request.params.get('page', 1)
+
+ try:
+ mmap = DBSession.query(Map).filter_by(map_id=map_id).one()
+
+ mct_q = DBSession.query(PlayerCaptime.fastest_cap, PlayerCaptime.create_dt,
+ PlayerCaptime.player_id, PlayerCaptime.game_id,
+ Game.server_id, Server.name.label('server_name'),
+ PlayerGameStat.nick.label('player_nick')).\
+ filter(PlayerCaptime.map_id==map_id).\
+ filter(PlayerCaptime.game_id==Game.game_id).\
+ filter(PlayerCaptime.map_id==Map.map_id).\
+ filter(Game.server_id==Server.server_id).\
+ filter(PlayerCaptime.player_id==PlayerGameStat.player_id).\
+ filter(PlayerCaptime.game_id==PlayerGameStat.game_id).\
+ order_by(expr.asc(PlayerCaptime.fastest_cap))
+
+ except Exception as e:
+ raise httpexceptions.HTTPNotFound
+
+ map_captimes = Page(mct_q, current_page, items_per_page=20, url=page_url)
+
+ map_captimes.items = [MapCapTime(row) for row in map_captimes.items]
+
+ return {
+ 'map_id':map_id,
+ 'map':mmap,
+ 'captimes':map_captimes,
+ }
+
+def map_captimes(request):
+ return map_captimes_data(request)
+
+def map_captimes_json(request):
+ current_page = request.params.get('page', 1)
+ data = map_captimes_data(request)
+
+ return {
+ "map": data["map"].to_dict(),
+ "captimes": [e.to_dict() for e in data["captimes"].items],
+ "page": current_page,
+ }