mirror of
https://github.com/aljazceru/CTFd.git
synced 2025-12-17 22:14:25 +01:00
2.3.0 / 2020-02-17
==================
**General**
* During setup, admins can register their email address with the CTFd LLC newsletter for news and updates
* Fix editting hints from the admin panel
* Allow admins to insert HTML code directly into the header and footer (end of body tag) of pages. This replaces and supercedes the custom CSS feature.
* The `views.custom_css` route has been removed.
* Admins can now customize the content of outgoing emails and inject certain variables into email content.
* The `manage.py` script can now manipulate the CTFd Configs table via the `get_config` and `set_config` commands. (e.g. `python manage.py get_config ctf_theme` and `python manage.py set_config ctf_theme core`)
**Themes**
* Themes should now reference the `theme_header` and `theme_footer` configs instead of the `views.custom_css` endpoint to allow for user customizations. See the `base.html` file of the core theme.
**Plugins**
* Make `ezq` functions available to `CTFd.js` under `CTFd.ui.ezq`
**Miscellaneous**
* Python imports sorted with `isort` and import order enforced
* Black formatter running on a majority of Python code
58 lines
1.6 KiB
Python
58 lines
1.6 KiB
Python
from flask import request
|
|
from flask_restplus import Namespace, Resource
|
|
|
|
from CTFd.cache import clear_standings
|
|
from CTFd.models import Awards, db
|
|
from CTFd.schemas.awards import AwardSchema
|
|
from CTFd.utils.decorators import admins_only
|
|
|
|
awards_namespace = Namespace("awards", description="Endpoint to retrieve Awards")
|
|
|
|
|
|
@awards_namespace.route("")
|
|
class AwardList(Resource):
|
|
@admins_only
|
|
def post(self):
|
|
req = request.get_json()
|
|
schema = AwardSchema()
|
|
|
|
response = schema.load(req, session=db.session)
|
|
if response.errors:
|
|
return {"success": False, "errors": response.errors}, 400
|
|
|
|
db.session.add(response.data)
|
|
db.session.commit()
|
|
|
|
response = schema.dump(response.data)
|
|
db.session.close()
|
|
|
|
# Delete standings cache because awards can change scores
|
|
clear_standings()
|
|
|
|
return {"success": True, "data": response.data}
|
|
|
|
|
|
@awards_namespace.route("/<award_id>")
|
|
@awards_namespace.param("award_id", "An Award ID")
|
|
class Award(Resource):
|
|
@admins_only
|
|
def get(self, award_id):
|
|
award = Awards.query.filter_by(id=award_id).first_or_404()
|
|
response = AwardSchema().dump(award)
|
|
if response.errors:
|
|
return {"success": False, "errors": response.errors}, 400
|
|
|
|
return {"success": True, "data": response.data}
|
|
|
|
@admins_only
|
|
def delete(self, award_id):
|
|
award = Awards.query.filter_by(id=award_id).first_or_404()
|
|
db.session.delete(award)
|
|
db.session.commit()
|
|
db.session.close()
|
|
|
|
# Delete standings cache because awards can change scores
|
|
clear_standings()
|
|
|
|
return {"success": True}
|