Add set up releases wizard

This commit is contained in:
rubenwardy 2020-12-15 21:22:17 +00:00
parent 14a67b99ba
commit c8406b45d4
8 changed files with 139 additions and 59 deletions

@ -319,17 +319,6 @@ def create_edit(author=None, name=None):
if package.type == PackageType.TXP: if package.type == PackageType.TXP:
package.license = package.media_license package.license = package.media_license
# Dependency.query.filter_by(depender=package).delete()
# deps = Dependency.SpecToList(package, form.harddep_str.data, mpackage_cache)
# for dep in deps:
# dep.optional = False
# db.session.add(dep)
# deps = Dependency.SpecToList(package, form.softdep_str.data, mpackage_cache)
# for dep in deps:
# dep.optional = True
# db.session.add(dep)
if wasNew and package.type == PackageType.MOD: if wasNew and package.type == PackageType.MOD:
m = MetaPackage.GetOrCreate(package.name, {}) m = MetaPackage.GetOrCreate(package.name, {})
package.provides.append(m) package.provides.append(m)
@ -344,13 +333,14 @@ def create_edit(author=None, name=None):
db.session.commit() # save db.session.commit() # save
next_url = package.getDetailsURL()
if wasNew and package.repo is not None: if wasNew and package.repo is not None:
task = importRepoScreenshot.delay(package.id) importRepoScreenshot.delay(package.id)
next_url = url_for("tasks.check", id=task.id, r=next_url)
next_url = package.getDetailsURL()
if wasNew and ("WTFPL" in package.license.name or "WTFPL" in package.media_license.name): if wasNew and ("WTFPL" in package.license.name or "WTFPL" in package.media_license.name):
next_url = url_for("flatpage", path="help/wtfpl", r=next_url) next_url = url_for("flatpage", path="help/wtfpl", r=next_url)
elif wasNew:
next_url = package.getSetupReleasesURL()
return redirect(next_url) return redirect(next_url)

@ -252,29 +252,60 @@ def delete_release(package, id):
class PackageUpdateConfigFrom(FlaskForm): class PackageUpdateConfigFrom(FlaskForm):
trigger = SelectField("Trigger", [InputRequired()], choices=PackageUpdateTrigger.choices(), coerce=PackageUpdateTrigger.coerce, trigger = SelectField("Trigger", [InputRequired()], choices=PackageUpdateTrigger.choices(), coerce=PackageUpdateTrigger.coerce,
default=PackageUpdateTrigger.COMMIT) default=PackageUpdateTrigger.COMMIT)
make_release = BooleanField("Create Release") action = SelectField("Action", [InputRequired()], choices=[("notification", "Notification"), ("make_release", "Create Release")], default="make_release")
submit = SubmitField("Save") submit = SubmitField("Save Settings")
disable = SubmitField("Disable")
@bp.route("/packages/<author>/<name>/update-config/", methods=["GET", "POST"]) @bp.route("/packages/<author>/<name>/update-config/", methods=["GET", "POST"])
@login_required @login_required
@is_package_page @is_package_page
def update_config(package): def update_config(package):
package.update_config = package.update_config or PackageUpdateConfig()
if not package.checkPerm(current_user, Permission.MAKE_RELEASE): if not package.checkPerm(current_user, Permission.MAKE_RELEASE):
return redirect(package.getDetailsURL()) abort(403)
if not package.repo:
flash("Please add a Git repository URL in order to set up automatic releases", "danger")
return redirect(package.getEditURL())
form = PackageUpdateConfigFrom(obj=package.update_config) form = PackageUpdateConfigFrom(obj=package.update_config)
if request.method == "GET" and package.update_config:
form.action.data = "make_release" if package.update_config.make_release else "notification"
if form.validate_on_submit(): if form.validate_on_submit():
flash("Changed update configuration", "success") if form.disable.data:
form.populate_obj(package.update_config) flash("Deleted update configuration", "success")
if package.update_config:
db.session.delete(package.update_config)
else:
if package.update_config is None:
package.update_config = PackageUpdateConfig()
db.session.add(package.update_config) db.session.add(package.update_config)
form.populate_obj(package.update_config)
package.update_config.make_release = form.action.data == "make_release"
check_for_updates.delay() check_for_updates.delay()
db.session.commit() db.session.commit()
if not form.disable.data and package.releases.count() == 0:
flash("Now, please create an initial release", "success")
return redirect(package.getCreateReleaseURL())
return redirect(package.getDetailsURL()) return redirect(package.getDetailsURL())
return render_template("packages/update_config.html", package=package, form=form) return render_template("packages/update_config.html", package=package, form=form)
@bp.route("/packages/<author>/<name>/setup-releases/")
@login_required
@is_package_page
def setup_releases(package):
if not package.checkPerm(current_user, Permission.MAKE_RELEASE):
abort(403)
if package.update_config:
return redirect(package.getUpdateConfigURL())
return render_template("packages/release_wizard.html", package=package)

@ -514,6 +514,10 @@ class Package(db.Model):
return url_for("packages.update_config", return url_for("packages.update_config",
author=self.author.username, name=self.name) author=self.author.username, name=self.name)
def getSetupReleasesURL(self):
return url_for("packages.setup_releases",
author=self.author.username, name=self.name)
def getDownloadURL(self): def getDownloadURL(self):
return url_for("packages.download", return url_for("packages.download",
author=self.author.username, name=self.name) author=self.author.username, name=self.name)

@ -177,10 +177,9 @@
</div> </div>
{%- endmacro %} {%- endmacro %}
{% macro render_submit_field(field, label=None, tabindex=None) -%} {% macro render_submit_field(field, label=None, tabindex=None, class_=None) -%}
{% if not label %}{% set label=field.label.text %}{% endif %} {% if not label %}{% set label=field.label.text %}{% endif %}
{#<button type="submit" class="form-control btn btn-default btn-primary">{{label}}</button>#} {#<button type="submit" class="form-control btn btn-default btn-primary">{{label}}</button>#}
<input type="submit" value="{{label}}" class="btn btn-primary" <input type="submit" name="{{ field.name }}" value="{{ label }}" class="{{ class_ or 'btn btn-primary' }}"
{% if tabindex %}tabindex="{{ tabindex }}"{% endif %} {% if tabindex %}tabindex="{{ tabindex }}"{% endif %}>
>
{%- endmacro %} {%- endmacro %}

@ -16,17 +16,15 @@
{% set level = "warning" %} {% set level = "warning" %}
{% if package.releases.count() == 0 %} {% if package.releases.count() == 0 %}
{% set message %} {% set message %}
<h4 class="alert-heading">Release Required</h4>
{% if package.checkPerm(current_user, "MAKE_RELEASE") %} {% if package.checkPerm(current_user, "MAKE_RELEASE") %}
<p>You need to create a release before this package can be approved.</p> {% if package.update_config %}
<p> <a class="btn btn-sm btn-warning float-right" href="{{ package.getCreateReleaseURL() }}">Create first release</a>
A release is a single downloadable version of your {{ package.type.value | lower }}.
You need to create releases even if you use a rolling release development cycle,
as Minetest needs them to check for updates.
</p>
<a class="btn" href="{{ package.getCreateReleaseURL() }}">Create Release</a>
{% else %} {% else %}
A release is required before this package can be approved. <a class="btn btn-sm btn-warning float-right" href="{{ package.getSetupReleasesURL() }}">Set up releases</a>
{% endif %}
{{ _("You need to create a release before this package can be approved.") }}
{% else %}
{{ _("A release is required before this package can be approved.") }}
{% endif %} {% endif %}
{% endset %} {% endset %}

@ -1,27 +1,27 @@
{% extends "base.html" %} {% extends "base.html" %}
{% block title %} {% block title %}
Create a release | {{ package.title }} {{ _("Create a release") }} - {{ package.title }}
{% endblock %} {% endblock %}
{% block content %} {% block content %}
<h1>{{ _("Create a release") }}</h1>
{% if not (package.repo and package.update_config) %}
<p class="alert alert-info mb-4"> <p class="alert alert-info mb-4">
<a class="float-right btn btn-sm btn-info" href="{{ url_for('flatpage', path='help/release_webhooks') }}">{{ _("Learn more") }}</a> {% if package.repo %}
{% if package.checkPerm(current_user, "APPROVE_RELEASE") and package.getIsOnGitHub() %} <a class="float-right btn btn-sm btn-info" href="{{ package.getSetupReleasesURL() }}">{{ _("Set up") }}</a>
<a class="float-right btn btn-sm btn-info mr-2" href="{{ url_for('github.setup_webhook', pid=package.id) }}">{{ _("Setup webhook") }}</a>
<i class="fas fa-info mr-2"></i> <i class="fas fa-info mr-2"></i>
{{ _("Create releases automatically when you push commits or tags to GitHub, using a webhook or the API.") }} {{ _("You can create releases automatically when you push commits or tags to your repository.") }}
{% elif package.repo %}
<i class="fas fa-info mr-2"></i>
{{ _("You can create releases automatically when you push commits or tags to your repository, using a webhook or the API.") }}
{% else %} {% else %}
<a class="float-right btn btn-sm btn-info" href="{{ package.getEditURL() }}">{{ _("Add Git repo") }}</a>
<i class="fas fa-info mr-2"></i> <i class="fas fa-info mr-2"></i>
{{ _("Using git will allow you to create releases automatically when you push code or tags.") }} {{ _("Using Git would allow you to create releases automatically when you push code or tags.") }}
{% endif %} {% endif %}
</p> </p>
{% endif %}
{% from "macros/forms.html" import render_field, render_submit_field, render_radio_field %} {% from "macros/forms.html" import render_field, render_submit_field, render_radio_field %}
<form method="POST" action="" enctype="multipart/form-data"> <form method="POST" action="" enctype="multipart/form-data">

@ -0,0 +1,46 @@
{% extends "base.html" %}
{% block title %}
{{ _("How do you want to create releases?") }}
{% endblock %}
{% block content %}
<h1>{{ self.title() }}</h1>
<p>
{{ _("A release is a single downloadable version of your %(title)s.", title=package.type.value.lower()) }}
{{ _("You need to create releases even if you use a rolling release development cycle, as Minetest needs them to check for updates.") }}
</p>
{% if package.repo %}
<p>
{{ _("When you push a commit or tag to your Git repository, ContentDB can create a new release automatically.") }}
{{ _("ContentDB will check your Git repository at 2am UTC every day, but you can use webhooks or the API for faster updates.") }}
</p>
<p>
{{ _("This can be changed later.") }}
</p>
<p class="mt-5">
<a class="btn btn-primary" href="{{ package.getUpdateConfigURL() }}">Set up automatic releases</a>
<a class="btn btn-secondary ml-2" href="{{ package.getCreateReleaseURL() }}">Create releases manually</a>
<a class="btn btn-secondary ml-2" href="{{ package.getDetailsURL() }}">Later</a>
</p>
{% else %}
<p>
{{ _("Using Git would allow you to create releases automatically when you push code or tags.") }}
{{ _("Unfortunately, you will otherwise need to create a release manually.") }}
</p>
<p>
{{ _("This can be changed later.") }}
</p>
<p class="mt-5">
<a class="btn btn-primary" href="{{ package.getEditURL() }}">Add Git repo</a>
<a class="btn btn-secondary ml-2" href="{{ package.getCreateReleaseURL() }}">Create releases manually</a>
<a class="btn btn-secondary ml-2" href="{{ package.getDetailsURL() }}">Later</a>
</p>
{% endif %}
{% endblock %}

@ -1,29 +1,41 @@
{% extends "base.html" %} {% extends "base.html" %}
{% block title %} {% block title %}
Configure Update Detection | {{ package.title }} {{ _("Configure Automatic Releases") }} - {{ package.title }}
{% endblock %} {% endblock %}
{% block content %} {% block content %}
<h1>{{ _("Configure Update Detection") }}</h1> <h1>{{ _("Configure Automatic Releases") }}</h1>
<p>
{{ _("When you push a change to your Git repository, ContentDB can create a new release automatically.") }}
</p>
<p> <p>
{{ _("ContentDB will poll your Git repository at 2am UTC every day.") }} {{ _("ContentDB will poll your Git repository at 2am UTC every day.") }}
{{ _("You should consider using webhooks or the API for faster rollouts.") }} {{ _("You should consider using webhooks or the API for faster rollouts.") }}
</p> </p>
{% if package.checkPerm(current_user, "APPROVE_RELEASE") and package.getIsOnGitHub() %}
<p class="alert alert-info mb-4">
<a class="float-right btn btn-sm btn-info" href="{{ url_for('flatpage', path='help/release_webhooks') }}">{{ _("Learn more") }}</a>
<a class="float-right btn btn-sm btn-info mr-2" href="{{ url_for('github.setup_webhook', pid=package.id) }}">{{ _("Setup webhook") }}</a>
<i class="fas fa-info mr-2"></i>
{{ _("Create releases faster by using a webhook.") }}
</p>
{% endif %}
{% from "macros/forms.html" import render_field, render_submit_field, render_checkbox_field %} {% from "macros/forms.html" import render_field, render_submit_field, render_checkbox_field %}
<form method="POST" action=""> <form method="POST" action="">
{{ form.hidden_tag() }} {{ form.hidden_tag() }}
<h3>Triggers</h3> {{ render_field(form.trigger, class_="mt-5") }}
{{ render_field(form.trigger) }} {{ render_field(form.action) }}
<h3 class="mt-5">Actions</h3>
{{ render_checkbox_field(form.make_release) }}
<p class="mt-5"> <p class="mt-5">
{{ render_submit_field(form.submit) }} {{ render_submit_field(form.submit) }}
{{ render_submit_field(form.disable, class_="btn btn-secondary ml-2") }}
</p> </p>
</form> </form>
{% endblock %} {% endblock %}