mirror of
https://github.com/minetest/contentdb.git
synced 2025-01-10 15:07:35 +01:00
Add API to create screenshots
This commit is contained in:
parent
64a897b52f
commit
509f03ce65
@ -14,18 +14,19 @@
|
|||||||
# You should have received a copy of the GNU Affero General Public License
|
# You should have received a copy of the GNU Affero General Public License
|
||||||
# along with this program. If not, see <https://www.gnu.org/licenses/>.
|
# along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
from flask import request, jsonify, current_app, abort
|
||||||
from flask import *
|
|
||||||
from flask_login import current_user, login_required
|
from flask_login import current_user, login_required
|
||||||
|
from sqlalchemy.sql.expression import func
|
||||||
|
|
||||||
|
from app import csrf
|
||||||
|
from app.markdown import render_markdown
|
||||||
|
from app.models import Tag, PackageState, PackageType, Package, db, PackageRelease, Tags, Permission, ForumTopic, MinetestRelease, APIToken
|
||||||
|
from app.querybuilder import QueryBuilder
|
||||||
|
from app.utils import is_package_page
|
||||||
from . import bp
|
from . import bp
|
||||||
from .auth import is_api_authd
|
from .auth import is_api_authd
|
||||||
from .support import error, api_create_vcs_release, api_create_zip_release
|
from .support import error, api_create_vcs_release, api_create_zip_release, api_create_screenshot
|
||||||
from app import csrf
|
|
||||||
from app.models import *
|
|
||||||
from app.utils import is_package_page
|
|
||||||
from app.markdown import render_markdown
|
|
||||||
from app.querybuilder import QueryBuilder
|
|
||||||
from sqlalchemy.sql.expression import func
|
|
||||||
|
|
||||||
@bp.route("/api/packages/")
|
@bp.route("/api/packages/")
|
||||||
def packages():
|
def packages():
|
||||||
@ -230,3 +231,25 @@ def create_release(token, package):
|
|||||||
error(400, "Missing 'file' in multipart body")
|
error(400, "Missing 'file' in multipart body")
|
||||||
|
|
||||||
return api_create_zip_release(token, package, data["title"], file)
|
return api_create_zip_release(token, package, data["title"], file)
|
||||||
|
|
||||||
|
|
||||||
|
@bp.route("/api/packages/<author>/<name>/screenshots/new/", methods=["POST"])
|
||||||
|
@csrf.exempt
|
||||||
|
@is_package_page
|
||||||
|
@is_api_authd
|
||||||
|
def create_screenshot(token: APIToken, package: Package):
|
||||||
|
if not token:
|
||||||
|
error(401, "Authentication needed")
|
||||||
|
|
||||||
|
if not package.checkPerm(token.owner, Permission.ADD_SCREENSHOTS):
|
||||||
|
error(403, "You do not have the permission to create screenshots")
|
||||||
|
|
||||||
|
data = request.form
|
||||||
|
if "title" not in data:
|
||||||
|
error(400, "Title is required in the POST data")
|
||||||
|
|
||||||
|
file = request.files.get("file")
|
||||||
|
if file is None:
|
||||||
|
error(400, "Missing 'file' in multipart body")
|
||||||
|
|
||||||
|
return api_create_screenshot(token, package, data["title"], file)
|
||||||
|
@ -17,7 +17,8 @@
|
|||||||
|
|
||||||
from flask import jsonify, abort, make_response, url_for
|
from flask import jsonify, abort, make_response, url_for
|
||||||
from app.logic.releases import LogicError, do_create_vcs_release, do_create_zip_release
|
from app.logic.releases import LogicError, do_create_vcs_release, do_create_zip_release
|
||||||
from app.models import APIToken, Package, MinetestRelease
|
from app.logic.screenshots import do_create_screenshot
|
||||||
|
from app.models import APIToken, Package, MinetestRelease, PackageScreenshot
|
||||||
|
|
||||||
|
|
||||||
def error(code: int, msg: str):
|
def error(code: int, msg: str):
|
||||||
@ -56,3 +57,15 @@ def api_create_zip_release(token: APIToken, package: Package, title: str, file,
|
|||||||
"task": url_for("tasks.check", id=rel.task_id),
|
"task": url_for("tasks.check", id=rel.task_id),
|
||||||
"release": rel.getAsDictionary()
|
"release": rel.getAsDictionary()
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
|
def api_create_screenshot(token: APIToken, package: Package, title: str, file):
|
||||||
|
if not token.canOperateOnPackage(package):
|
||||||
|
error(403, "API token does not have access to the package")
|
||||||
|
|
||||||
|
ss : PackageScreenshot = run_safe(do_create_screenshot, token.owner, package, title, file)
|
||||||
|
|
||||||
|
return jsonify({
|
||||||
|
"success": True,
|
||||||
|
"screenshot": ss.getAsDictionary()
|
||||||
|
})
|
||||||
|
@ -69,6 +69,22 @@ curl https://content.minetest.net/api/packages/username/name/releases/new/ \
|
|||||||
-F title="My Release" -F file=@path/to/file.zip
|
-F title="My Release" -F file=@path/to/file.zip
|
||||||
```
|
```
|
||||||
|
|
||||||
|
### Screenshots
|
||||||
|
|
||||||
|
* POST `/api/packages/<username>/<name>/screenshots/new/` (Create)
|
||||||
|
* Requires authentication.
|
||||||
|
* Body is multipart form data.
|
||||||
|
* `title`: human-readable name for the screenshot, shown as a caption and alt text.
|
||||||
|
* `file`: multipart file to upload, like `<input type=file>`.
|
||||||
|
|
||||||
|
Example:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
curl https://content.minetest.net/api/packages/username/name/screenshots/new/ \
|
||||||
|
-H "Authorization: Bearer YOURTOKEN" \
|
||||||
|
-F title="My Release" -F file=@path/to/screnshot.png
|
||||||
|
```
|
||||||
|
|
||||||
### Topics
|
### Topics
|
||||||
|
|
||||||
* GET `/api/topics/` - Supports [Package Queries](#package-queries), and the following two options:
|
* GET `/api/topics/` - Supports [Package Queries](#package-queries), and the following two options:
|
||||||
|
Loading…
Reference in New Issue
Block a user