mirror of
https://github.com/minetest/contentdb.git
synced 2025-01-24 06:51:29 +01:00
Add edit and delete screenshot
This commit is contained in:
parent
8cf5c7204f
commit
53df124973
@ -74,6 +74,32 @@ title: Ranks and Permissions
|
|||||||
<th>✓</th> <!-- admin -->
|
<th>✓</th> <!-- admin -->
|
||||||
<th>✓</th>
|
<th>✓</th>
|
||||||
</tr>
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td>Add/Delete Screenshot</td>
|
||||||
|
<th>✓</th> <!-- new -->
|
||||||
|
<th></th>
|
||||||
|
<th>✓</th> <!-- member -->
|
||||||
|
<th></th>
|
||||||
|
<th>✓</th> <!-- editor -->
|
||||||
|
<th>✓</th>
|
||||||
|
<th>✓</th> <!-- moderator -->
|
||||||
|
<th>✓</th>
|
||||||
|
<th>✓</th> <!-- admin -->
|
||||||
|
<th>✓</th>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td>Approve Screenshot</td>
|
||||||
|
<th></th> <!-- new -->
|
||||||
|
<th></th>
|
||||||
|
<th>✓</th> <!-- member -->
|
||||||
|
<th></th>
|
||||||
|
<th>✓</th> <!-- editor -->
|
||||||
|
<th>✓</th>
|
||||||
|
<th>✓</th> <!-- moderator -->
|
||||||
|
<th>✓</th>
|
||||||
|
<th>✓</th> <!-- admin -->
|
||||||
|
<th>✓</th>
|
||||||
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td>Approve EditRequest</td>
|
<td>Approve EditRequest</td>
|
||||||
<th></th> <!-- new -->
|
<th></th> <!-- new -->
|
||||||
|
@ -65,6 +65,8 @@ class Permission(enum.Enum):
|
|||||||
DELETE_PACKAGE = "DELETE_PACKAGE"
|
DELETE_PACKAGE = "DELETE_PACKAGE"
|
||||||
CHANGE_AUTHOR = "CHANGE_AUTHOR"
|
CHANGE_AUTHOR = "CHANGE_AUTHOR"
|
||||||
MAKE_RELEASE = "MAKE_RELEASE"
|
MAKE_RELEASE = "MAKE_RELEASE"
|
||||||
|
ADD_SCREENSHOTS = "ADD_SCREENSHOTS"
|
||||||
|
APPROVE_SCREENSHOT = "APPROVE_SCREENSHOT"
|
||||||
APPROVE_RELEASE = "APPROVE_RELEASE"
|
APPROVE_RELEASE = "APPROVE_RELEASE"
|
||||||
APPROVE_NEW = "APPROVE_NEW"
|
APPROVE_NEW = "APPROVE_NEW"
|
||||||
CHANGE_RELEASE_URL = "CHANGE_RELEASE_URL"
|
CHANGE_RELEASE_URL = "CHANGE_RELEASE_URL"
|
||||||
@ -393,7 +395,7 @@ class Package(db.Model):
|
|||||||
isOwner = user == self.author
|
isOwner = user == self.author
|
||||||
|
|
||||||
# Members can edit their own packages, and editors can edit any packages
|
# Members can edit their own packages, and editors can edit any packages
|
||||||
if perm == Permission.MAKE_RELEASE:
|
if perm == Permission.MAKE_RELEASE or perm == Permission.ADD_SCREENSHOTS:
|
||||||
return isOwner or user.rank.atLeast(UserRank.EDITOR)
|
return isOwner or user.rank.atLeast(UserRank.EDITOR)
|
||||||
|
|
||||||
if perm == Permission.EDIT_PACKAGE or perm == Permission.APPROVE_CHANGES:
|
if perm == Permission.EDIT_PACKAGE or perm == Permission.APPROVE_CHANGES:
|
||||||
@ -401,7 +403,7 @@ class Package(db.Model):
|
|||||||
|
|
||||||
# Editors can change authors, approve new packages, and approve releases
|
# Editors can change authors, approve new packages, and approve releases
|
||||||
elif perm == Permission.CHANGE_AUTHOR or perm == Permission.APPROVE_NEW \
|
elif perm == Permission.CHANGE_AUTHOR or perm == Permission.APPROVE_NEW \
|
||||||
or perm == Permission.APPROVE_RELEASE:
|
or perm == Permission.APPROVE_RELEASE or perm == Permission.APPROVE_SCREENSHOT:
|
||||||
return user.rank.atLeast(UserRank.EDITOR)
|
return user.rank.atLeast(UserRank.EDITOR)
|
||||||
|
|
||||||
# Moderators can delete packages
|
# Moderators can delete packages
|
||||||
@ -452,6 +454,14 @@ class PackageScreenshot(db.Model):
|
|||||||
package_id = db.Column(db.Integer, db.ForeignKey("package.id"))
|
package_id = db.Column(db.Integer, db.ForeignKey("package.id"))
|
||||||
title = db.Column(db.String(100), nullable=False)
|
title = db.Column(db.String(100), nullable=False)
|
||||||
url = db.Column(db.String(100), nullable=False)
|
url = db.Column(db.String(100), nullable=False)
|
||||||
|
approved = db.Column(db.Boolean, nullable=False, default=False)
|
||||||
|
|
||||||
|
|
||||||
|
def getEditURL(self):
|
||||||
|
return url_for("edit_screenshot_page",
|
||||||
|
author=self.package.author.username,
|
||||||
|
name=self.package.name,
|
||||||
|
id=self.id)
|
||||||
|
|
||||||
def getThumbnailURL(self):
|
def getThumbnailURL(self):
|
||||||
return self.url # TODO
|
return self.url # TODO
|
||||||
|
@ -252,6 +252,7 @@ def importRepoScreenshot(id):
|
|||||||
urllib.request.urlretrieve(urlmaker.getScreenshotURL(), imagePath)
|
urllib.request.urlretrieve(urlmaker.getScreenshotURL(), imagePath)
|
||||||
|
|
||||||
ss = PackageScreenshot()
|
ss = PackageScreenshot()
|
||||||
|
ss.approved = True
|
||||||
ss.package = package
|
ss.package = package
|
||||||
ss.title = "screenshot.png"
|
ss.title = "screenshot.png"
|
||||||
ss.url = "/uploads/" + filename
|
ss.url = "/uploads/" + filename
|
||||||
|
22
app/templates/packages/screenshot_edit.html
Normal file
22
app/templates/packages/screenshot_edit.html
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
{% extends "base.html" %}
|
||||||
|
|
||||||
|
{% block title %}
|
||||||
|
Add a screenshot | {{ package.title }}
|
||||||
|
{% endblock %}
|
||||||
|
|
||||||
|
{% block content %}
|
||||||
|
{% from "macros/forms.html" import render_field, render_submit_field %}
|
||||||
|
<form method="POST" action="" enctype="multipart/form-data">
|
||||||
|
{{ form.hidden_tag() }}
|
||||||
|
|
||||||
|
{{ render_field(form.title) }}
|
||||||
|
{{ render_field(form.delete) }}
|
||||||
|
|
||||||
|
{% if package.checkPerm(current_user, "APPROVE_SCREENSHOT") %}
|
||||||
|
{{ render_field(form.approved) }}
|
||||||
|
{% else %}
|
||||||
|
<p>Approved: {{ screenshot.approved }}</p>
|
||||||
|
{% endif %}
|
||||||
|
{{ render_submit_field(form.submit) }}
|
||||||
|
</form>
|
||||||
|
{% endblock %}
|
@ -42,7 +42,7 @@
|
|||||||
<ul class="screenshot_list">
|
<ul class="screenshot_list">
|
||||||
{% for ss in package.screenshots %}
|
{% for ss in package.screenshots %}
|
||||||
<li>
|
<li>
|
||||||
<a href="{{ ss.url }}">
|
<a href="{% if package.checkPerm(current_user, 'ADD_SCREENSHOTS') %}{{ ss.getEditURL() }}{% else %}{{ ss.url }}{% endif %}">
|
||||||
<img src="{{ ss.getThumbnailURL() }}" alt="{{ ss.title }}" />
|
<img src="{{ ss.getThumbnailURL() }}" alt="{{ ss.title }}" />
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
|
@ -36,9 +36,10 @@ def admin_page():
|
|||||||
return redirect(url_for("check_task", id=task.id, r=url_for("user_list_page")))
|
return redirect(url_for("check_task", id=task.id, r=url_for("user_list_page")))
|
||||||
elif action == "importscreenshots":
|
elif action == "importscreenshots":
|
||||||
packages = Package.query \
|
packages = Package.query \
|
||||||
|
.filter_by(soft_deleted=False) \
|
||||||
.outerjoin(PackageScreenshot, Package.id==PackageScreenshot.package_id) \
|
.outerjoin(PackageScreenshot, Package.id==PackageScreenshot.package_id) \
|
||||||
.filter(PackageScreenshot.id==None) \
|
.filter(PackageScreenshot.id==None) \
|
||||||
.filter_by(soft_deleted=False).all()
|
.all()
|
||||||
for package in packages:
|
for package in packages:
|
||||||
importRepoScreenshot.delay(package.id)
|
importRepoScreenshot.delay(package.id)
|
||||||
|
|
||||||
|
@ -152,7 +152,7 @@ def create_edit_package_page(author=None, name=None):
|
|||||||
package = Package.query.filter_by(name=form["name"].data, author_id=author.id).first()
|
package = Package.query.filter_by(name=form["name"].data, author_id=author.id).first()
|
||||||
if package is not None:
|
if package is not None:
|
||||||
if package.soft_deleted:
|
if package.soft_deleted:
|
||||||
package.delete()
|
Package.query.filter_by(name=form["name"].data, author_id=author.id).delete()
|
||||||
else:
|
else:
|
||||||
flash("Package already exists!", "error")
|
flash("Package already exists!", "error")
|
||||||
return redirect(url_for("create_edit_package_page"))
|
return redirect(url_for("create_edit_package_page"))
|
||||||
|
@ -32,11 +32,18 @@ class CreateScreenshotForm(FlaskForm):
|
|||||||
fileUpload = FileField("File Upload", [InputRequired()])
|
fileUpload = FileField("File Upload", [InputRequired()])
|
||||||
submit = SubmitField("Save")
|
submit = SubmitField("Save")
|
||||||
|
|
||||||
|
|
||||||
|
class EditScreenshotForm(FlaskForm):
|
||||||
|
title = StringField("Title/Caption", [Optional()])
|
||||||
|
approved = BooleanField("Is Approved")
|
||||||
|
delete = BooleanField("Delete")
|
||||||
|
submit = SubmitField("Save")
|
||||||
|
|
||||||
@app.route("/packages/<author>/<name>/screenshots/new/", methods=["GET", "POST"])
|
@app.route("/packages/<author>/<name>/screenshots/new/", methods=["GET", "POST"])
|
||||||
@login_required
|
@login_required
|
||||||
@is_package_page
|
@is_package_page
|
||||||
def create_screenshot_page(package):
|
def create_screenshot_page(package, id=None):
|
||||||
if not package.checkPerm(current_user, Permission.MAKE_RELEASE):
|
if not package.checkPerm(current_user, Permission.ADD_SCREENSHOTS):
|
||||||
return redirect(package.getDetailsURL())
|
return redirect(package.getDetailsURL())
|
||||||
|
|
||||||
# Initial form class from post data and default data
|
# Initial form class from post data and default data
|
||||||
@ -58,3 +65,40 @@ def create_screenshot_page(package):
|
|||||||
return redirect(package.getDetailsURL())
|
return redirect(package.getDetailsURL())
|
||||||
|
|
||||||
return render_template("packages/screenshot_new.html", package=package, form=form)
|
return render_template("packages/screenshot_new.html", package=package, form=form)
|
||||||
|
|
||||||
|
@app.route("/packages/<author>/<name>/screenshots/<id>/edit/", methods=["GET", "POST"])
|
||||||
|
@login_required
|
||||||
|
@is_package_page
|
||||||
|
def edit_screenshot_page(package, id):
|
||||||
|
screenshot = PackageScreenshot.query.get(id)
|
||||||
|
if screenshot is None or screenshot.package != package:
|
||||||
|
abort(404)
|
||||||
|
|
||||||
|
canEdit = package.checkPerm(current_user, Permission.ADD_SCREENSHOTS)
|
||||||
|
canApprove = package.checkPerm(current_user, Permission.APPROVE_SCREENSHOT)
|
||||||
|
if not (canEdit or canApprove):
|
||||||
|
return redirect(package.getDetailsURL())
|
||||||
|
|
||||||
|
clearNotifications(screenshot.getEditURL())
|
||||||
|
|
||||||
|
# Initial form class from post data and default data
|
||||||
|
form = EditScreenshotForm(formdata=request.form, obj=screenshot)
|
||||||
|
if request.method == "POST" and form.validate():
|
||||||
|
if canEdit and form["delete"].data:
|
||||||
|
PackageScreenshot.query.filter_by(id=id).delete()
|
||||||
|
|
||||||
|
else:
|
||||||
|
wasApproved = screenshot.approved
|
||||||
|
|
||||||
|
if canEdit:
|
||||||
|
screenshot.title = form["title"].data
|
||||||
|
|
||||||
|
if canApprove:
|
||||||
|
screenshot.approved = form["approved"].data
|
||||||
|
else:
|
||||||
|
screenshot.approved = wasApproved
|
||||||
|
|
||||||
|
db.session.commit()
|
||||||
|
return redirect(package.getDetailsURL())
|
||||||
|
|
||||||
|
return render_template("packages/screenshot_edit.html", package=package, screenshot=screenshot, form=form)
|
||||||
|
28
migrations/versions/fa12fadbdb40_.py
Normal file
28
migrations/versions/fa12fadbdb40_.py
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
"""empty message
|
||||||
|
|
||||||
|
Revision ID: fa12fadbdb40
|
||||||
|
Revises: c4152f4240ed
|
||||||
|
Create Date: 2018-05-25 18:46:54.039870
|
||||||
|
|
||||||
|
"""
|
||||||
|
from alembic import op
|
||||||
|
import sqlalchemy as sa
|
||||||
|
|
||||||
|
|
||||||
|
# revision identifiers, used by Alembic.
|
||||||
|
revision = 'fa12fadbdb40'
|
||||||
|
down_revision = 'c4152f4240ed'
|
||||||
|
branch_labels = None
|
||||||
|
depends_on = None
|
||||||
|
|
||||||
|
|
||||||
|
def upgrade():
|
||||||
|
# ### commands auto generated by Alembic - please adjust! ###
|
||||||
|
op.add_column('package_screenshot', sa.Column('approved', sa.Boolean(), nullable=False, server_default=True))
|
||||||
|
# ### end Alembic commands ###
|
||||||
|
|
||||||
|
|
||||||
|
def downgrade():
|
||||||
|
# ### commands auto generated by Alembic - please adjust! ###
|
||||||
|
op.drop_column('package_screenshot', 'approved')
|
||||||
|
# ### end Alembic commands ###
|
Loading…
Reference in New Issue
Block a user