mirror of
https://github.com/minetest/contentdb.git
synced 2025-01-10 15:07:35 +01:00
Improve reviews API
This commit is contained in:
parent
bd25a8d601
commit
da41fb5738
@ -15,16 +15,18 @@
|
|||||||
# 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 typing import List
|
from typing import List
|
||||||
|
|
||||||
|
import flask_sqlalchemy
|
||||||
from flask import request, jsonify, current_app
|
from flask import request, jsonify, current_app
|
||||||
from flask_login import current_user, login_required
|
from flask_login import current_user, login_required
|
||||||
|
from sqlalchemy.orm import subqueryload, joinedload
|
||||||
from sqlalchemy.sql.expression import func
|
from sqlalchemy.sql.expression import func
|
||||||
|
|
||||||
from app import csrf
|
from app import csrf
|
||||||
from app.markdown import render_markdown
|
from app.markdown import render_markdown
|
||||||
from app.models import Tag, PackageState, PackageType, Package, db, PackageRelease, Permission, ForumTopic, \
|
from app.models import Tag, PackageState, PackageType, Package, db, PackageRelease, Permission, ForumTopic, \
|
||||||
MinetestRelease, APIToken, PackageScreenshot, License, ContentWarning, User, PackageReview
|
MinetestRelease, APIToken, PackageScreenshot, License, ContentWarning, User, PackageReview, Thread
|
||||||
from app.querybuilder import QueryBuilder
|
from app.querybuilder import QueryBuilder
|
||||||
from app.utils import is_package_page, get_int_or_abort
|
from app.utils import is_package_page, get_int_or_abort, url_set_query, abs_url, isYes
|
||||||
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, api_create_screenshot, api_order_screenshots, api_edit_package
|
from .support import error, api_create_vcs_release, api_create_zip_release, api_create_screenshot, api_order_screenshots, api_edit_package
|
||||||
@ -375,8 +377,31 @@ def list_reviews(package):
|
|||||||
@bp.route("/api/reviews/")
|
@bp.route("/api/reviews/")
|
||||||
@cors_allowed
|
@cors_allowed
|
||||||
def list_all_reviews():
|
def list_all_reviews():
|
||||||
reviews = PackageReview.query.all()
|
page = get_int_or_abort(request.args.get("page"), 1)
|
||||||
return jsonify([review.getAsDictionary(True) for review in reviews])
|
num = min(get_int_or_abort(request.args.get("n"), 100), 100)
|
||||||
|
|
||||||
|
query = PackageReview.query
|
||||||
|
query = query.options(joinedload(PackageReview.author), joinedload(PackageReview.package))
|
||||||
|
|
||||||
|
if request.args.get("author"):
|
||||||
|
query = query.join(User).filter(User.username == request.args.get("author"))
|
||||||
|
|
||||||
|
if request.args.get("is_positive"):
|
||||||
|
query = query.filter(PackageReview.recommends == isYes(request.args.get("is_positive")))
|
||||||
|
|
||||||
|
q = request.args.get("q")
|
||||||
|
if q:
|
||||||
|
query = query.filter(PackageReview.thread.has(Thread.title.ilike(f"%{q}%")))
|
||||||
|
|
||||||
|
pagination: flask_sqlalchemy.Pagination = query.paginate(page, num, True)
|
||||||
|
return jsonify({
|
||||||
|
"page": pagination.page,
|
||||||
|
"urls": {
|
||||||
|
"previous": abs_url(url_set_query(page=page - 1)) if page > 1 else None,
|
||||||
|
"next": abs_url(url_set_query(page=page + 1)) if pagination.next_num else None,
|
||||||
|
},
|
||||||
|
"reviews": [review.getAsDictionary(True) for review in pagination.items],
|
||||||
|
})
|
||||||
|
|
||||||
|
|
||||||
@bp.route("/api/scores/")
|
@bp.route("/api/scores/")
|
||||||
|
@ -237,8 +237,16 @@ curl -X POST https://content.minetest.net/api/packages/username/name/screenshots
|
|||||||
* `created_at`: iso timestamp
|
* `created_at`: iso timestamp
|
||||||
* `votes`: dictionary with `helpful` and `unhelpful`,
|
* `votes`: dictionary with `helpful` and `unhelpful`,
|
||||||
* GET `/api/reviews/` (List)
|
* GET `/api/reviews/` (List)
|
||||||
* Above, but for all packages.
|
* Returns a paginated response. This is a dictionary with `page`, `url`, and `items`.
|
||||||
* Each review has a `package` dictionary with `type`, `author` and `name`
|
* `page`: page number, integer from 1 to max
|
||||||
|
* `url`: dictionary containing `next` and `previous`
|
||||||
|
* `items`: array of review dictionaries, like above.
|
||||||
|
* Each review also has a `package` dictionary with `type`, `author` and `name`
|
||||||
|
* Query arguments:
|
||||||
|
* `page`: page number, integer from 1 to max
|
||||||
|
* `n`: number of results per page, max 100
|
||||||
|
* `author`: filter by review author username
|
||||||
|
* `q`: filter by title (exact match, case insensitive, no fulltext search)
|
||||||
|
|
||||||
Example:
|
Example:
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user