diff --git a/app/models.py b/app/models.py index 518ffc85..2f853370 100644 --- a/app/models.py +++ b/app/models.py @@ -73,6 +73,7 @@ class User(db.Model, UserMixin): # Content packages = db.relationship("Package", backref="author", lazy="dynamic") + requests = db.relationship("EditRequest", backref="author", lazy="dynamic") def __init__(self, username): import datetime @@ -104,6 +105,19 @@ class PackageType(enum.Enum): def coerce(cls, item): return item if type(item) == PackageType else PackageType[item] + +class PackagePropertyKey(enum.Enum): + name = "name" + title = "title" + shortDesc = "shortDesc" + desc = "desc" + type = "type" + repo = "repo" + website = "website" + issueTracker = "issueTracker" + forums = "forums" + + class Package(db.Model): id = db.Column(db.Integer, primary_key=True) @@ -127,6 +141,10 @@ class Package(db.Model): releases = db.relationship("PackageRelease", backref="package", lazy="dynamic", order_by=db.desc("package_release_releaseDate")) + + requests = db.relationship("EditRequest", backref="package", + lazy="dynamic") + def getAsDictionary(self, base_url): return { "name": self.name, @@ -224,6 +242,37 @@ class PackageRelease(db.Model): def __init__(self): self.releaseDate = datetime.now() +class EditRequest(db.Model): + id = db.Column(db.Integer, primary_key=True) + + package_id = db.Column(db.Integer, db.ForeignKey("package.id")) + author_id = db.Column(db.Integer, db.ForeignKey("user.id")) + + title = db.Column(db.String(100), nullable=False) + desc = db.Column(db.String(1000), nullable=True) + + + changes = db.relationship("EditRequestChange", backref="request", + lazy="dynamic") + + def applyAll(self, package): + for change in self.changes: + change.apply(package) + +class EditRequestChange(db.Model): + id = db.Column(db.Integer, primary_key=True) + + request_id = db.Column(db.Integer, db.ForeignKey("edit_request.id")) + key = db.Column(db.Enum(PackagePropertyKey), nullable=False) + + # TODO: make diff instead + oldValue = db.Column(db.Text, nullable=False) + newValue = db.Column(db.Text, nullable=False) + + def apply(self, package): + prop = PackagePropertyKey[self.key] + + # Setup Flask-User db_adapter = SQLAlchemyAdapter(db, User) # Register the User model user_manager = UserManager(db_adapter, app) # Initialize Flask-User diff --git a/app/templates/packages/create_editrequest.html b/app/templates/packages/create_editrequest.html new file mode 100644 index 00000000..d0c592a3 --- /dev/null +++ b/app/templates/packages/create_editrequest.html @@ -0,0 +1,29 @@ +{% extends "base.html" %} + +{% block title %} + {{ package.title or "Create Package" }} +{% endblock %} + +{% block content %} + {% from "macros/forms.html" import render_field, render_submit_field %} +
+{% endblock %} diff --git a/app/views/packages.py b/app/views/packages.py index 311ef107..a314d79b 100644 --- a/app/views/packages.py +++ b/app/views/packages.py @@ -127,16 +127,16 @@ def package_download_page(type, author, name): class PackageForm(FlaskForm): - name = StringField("Name", [InputRequired(), Length(1, 20), Regexp("^[a-z0-9_]", 0, "Lower case letters (a-z), digits (0-9), and underscores (_) only")]) - title = StringField("Title", [InputRequired(), Length(3, 50)]) - shortDesc = StringField("Short Description", [InputRequired(), Length(1,200)]) - desc = TextAreaField("Long Description", [Optional(), Length(0,10000)]) - type = SelectField("Type", [InputRequired()], choices=PackageType.choices(), coerce=PackageType.coerce, default=PackageType.MOD) - repo = StringField("Repo URL", [Optional(), URL()]) - website = StringField("Website URL", [Optional(), URL()]) + name = StringField("Name", [InputRequired(), Length(1, 20), Regexp("^[a-z0-9_]", 0, "Lower case letters (a-z), digits (0-9), and underscores (_) only")]) + title = StringField("Title", [InputRequired(), Length(3, 50)]) + shortDesc = StringField("Short Description", [InputRequired(), Length(1,200)]) + desc = TextAreaField("Long Description", [Optional(), Length(0,10000)]) + type = SelectField("Type", [InputRequired()], choices=PackageType.choices(), coerce=PackageType.coerce, default=PackageType.MOD) + repo = StringField("Repo URL", [Optional(), URL()]) + website = StringField("Website URL", [Optional(), URL()]) issueTracker = StringField("Issue Tracker URL", [Optional(), URL()]) - forums = IntegerField("Forum Topic ID", [InputRequired(), NumberRange(0,999999)]) - submit = SubmitField("Save") + forums = IntegerField("Forum Topic ID", [InputRequired(), NumberRange(0,999999)]) + submit = SubmitField("Save") @menu.register_menu(app, ".new", "Create", order=21, visible_when=lambda: current_user.is_authenticated) @app.route("/new/", methods=["GET", "POST"]) @@ -186,20 +186,80 @@ def approve_package_page(type=None, author=None, name=None): return redirect(package.getDetailsURL()) + +class EditRequestForm(PackageForm): + edit_title = StringField("Edit Title", [InputRequired(), Length(1, 100)]) + edit_desc = TextField("Edit Description", [Optional()]) + +class UnresolvedPackage(Package): + edit_title = "" + edit_desc = "" + + +@app.route("/