mirror of
https://github.com/aljazceru/CTFd.git
synced 2025-12-17 05:54:19 +01:00
* Format Javascript and CSS files with `prettier`: `prettier --write 'CTFd/themes/**/*'` * Format Python with `black`: `black CTFd` & `black tests` * Travis now uses xenial instead of trusty.
23 lines
795 B
Python
23 lines
795 B
Python
from flask_restplus import Resource
|
|
from CTFd.models import Submissions
|
|
from CTFd.utils.decorators import admins_only
|
|
from CTFd.api.v1.statistics import statistics_namespace
|
|
from sqlalchemy import func
|
|
|
|
|
|
@statistics_namespace.route("/submissions/<column>")
|
|
class SubmissionPropertyCounts(Resource):
|
|
@admins_only
|
|
def get(self, column):
|
|
if column in Submissions.__table__.columns.keys():
|
|
prop = getattr(Submissions, column)
|
|
data = (
|
|
Submissions.query.with_entities(prop, func.count(prop))
|
|
.group_by(prop)
|
|
.all()
|
|
)
|
|
return {"success": True, "data": dict(data)}
|
|
else:
|
|
response = {"success": False, "errors": "That could not be found"}, 404
|
|
return response
|