{% endif %}
diff --git a/mediagoblin/user_pages/routing.py b/mediagoblin/user_pages/routing.py
index bf9f12ab..1283355a 100644
--- a/mediagoblin/user_pages/routing.py
+++ b/mediagoblin/user_pages/routing.py
@@ -29,6 +29,8 @@ user_routes = [
controller="mediagoblin.user_pages.views:media_home"),
Route('mediagoblin.edit.edit_media', "/{user}/m/{media}/edit/",
controller="mediagoblin.edit.views:edit_media"),
+ Route('mediagoblin.confirm.confirm_delete', "/{user}/m/{media}/confirm/",
+ controller="mediagoblin.confirm.views:confirm_delete"),
Route('mediagoblin.user_pages.atom_feed', '/{user}/atom/',
controller="mediagoblin.user_pages.views:atom_feed"),
Route('mediagoblin.user_pages.media_post_comment',
diff --git a/mediagoblin/user_pages/views.py b/mediagoblin/user_pages/views.py
index 3677c134..bb789f42 100644
--- a/mediagoblin/user_pages/views.py
+++ b/mediagoblin/user_pages/views.py
@@ -129,7 +129,7 @@ def media_post_comment(request):
comment = request.db.MediaComment()
comment['media_entry'] = ObjectId(request.matchdict['media'])
comment['author'] = request.user['_id']
- comment['content'] = request.POST['comment_content']
+ comment['content'] = unicode(request.POST['comment_content'])
comment['content_html'] = cleaned_markdown_conversion(comment['content'])
From ae4feecfc20b6c7daf54e7822dc85dba6ac0f2eb Mon Sep 17 00:00:00 2001
From: Mark Holmquist
Date: Mon, 22 Aug 2011 03:35:44 -0700
Subject: [PATCH 2/3] * Fix bad commit (oops!) * Delete works now
---
mediagoblin/confirm/__init__.py | 17 ++++++
mediagoblin/confirm/forms.py | 26 +++++++++
mediagoblin/confirm/lib.py | 24 ++++++++
mediagoblin/confirm/routing.py | 21 +++++++
mediagoblin/confirm/views.py | 56 +++++++++++++++++++
.../mediagoblin/confirm/confirm_delete.html | 40 +++++++++++++
6 files changed, 184 insertions(+)
create mode 100644 mediagoblin/confirm/__init__.py
create mode 100644 mediagoblin/confirm/forms.py
create mode 100644 mediagoblin/confirm/lib.py
create mode 100644 mediagoblin/confirm/routing.py
create mode 100644 mediagoblin/confirm/views.py
create mode 100644 mediagoblin/templates/mediagoblin/confirm/confirm_delete.html
diff --git a/mediagoblin/confirm/__init__.py b/mediagoblin/confirm/__init__.py
new file mode 100644
index 00000000..a8eeb5ed
--- /dev/null
+++ b/mediagoblin/confirm/__init__.py
@@ -0,0 +1,17 @@
+# GNU MediaGoblin -- federated, autonomous media hosting
+# Copyright (C) 2011 Free Software Foundation, Inc
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see .
+
+
diff --git a/mediagoblin/confirm/forms.py b/mediagoblin/confirm/forms.py
new file mode 100644
index 00000000..4529528b
--- /dev/null
+++ b/mediagoblin/confirm/forms.py
@@ -0,0 +1,26 @@
+# GNU MediaGoblin -- federated, autonomous media hosting
+# Copyright (C) 2011 Free Software Foundation, Inc
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see .
+
+
+import wtforms
+
+from mediagoblin.util import fake_ugettext_passthrough as _
+
+class ConfirmDeleteForm(wtforms.Form):
+ confirm = wtforms.RadioField('Confirm',
+ default='False',
+ choices=[('False', 'No, I made a mistake!'),
+ ('True', 'Yes, delete it!')])
diff --git a/mediagoblin/confirm/lib.py b/mediagoblin/confirm/lib.py
new file mode 100644
index 00000000..2efc3735
--- /dev/null
+++ b/mediagoblin/confirm/lib.py
@@ -0,0 +1,24 @@
+# GNU MediaGoblin -- federated, autonomous media hosting
+# Copyright (C) 2011 Free Software Foundation, Inc
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see .
+
+
+def may_delete_media(request, media):
+ """Check, if the request's user may edit the media details"""
+ if media['uploader'] == request.user['_id']:
+ return True
+ if request.user['is_admin']:
+ return True
+ return False
diff --git a/mediagoblin/confirm/routing.py b/mediagoblin/confirm/routing.py
new file mode 100644
index 00000000..d8c1ef22
--- /dev/null
+++ b/mediagoblin/confirm/routing.py
@@ -0,0 +1,21 @@
+# GNU MediaGoblin -- federated, autonomous media hosting
+# Copyright (C) 2011 Free Software Foundation, Inc
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see .
+
+
+from routes.route import Route
+
+confirm_routes = [
+]
diff --git a/mediagoblin/confirm/views.py b/mediagoblin/confirm/views.py
new file mode 100644
index 00000000..a4a63582
--- /dev/null
+++ b/mediagoblin/confirm/views.py
@@ -0,0 +1,56 @@
+# GNU MediaGoblin -- federated, autonomous media hosting
+# Copyright (C) 2011 Free Software Foundation, Inc
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see .
+
+import uuid
+
+from webob import exc
+from string import split
+
+from mediagoblin import messages
+from mediagoblin import mg_globals
+from mediagoblin.util import (
+ render_to_response, redirect, clean_html, convert_to_tag_list_of_dicts,
+ media_tags_as_string, cleaned_markdown_conversion)
+from mediagoblin.util import pass_to_ugettext as _
+from mediagoblin.confirm import forms
+from mediagoblin.confirm.lib import may_delete_media
+from mediagoblin.decorators import require_active_login, get_user_media_entry
+
+
+@get_user_media_entry
+@require_active_login
+def confirm_delete(request, media):
+ if not may_delete_media(request, media):
+ return exc.HTTPForbidden()
+
+ form = forms.ConfirmDeleteForm(request.POST)
+
+ if request.method == 'POST' and form.validate():
+ if request.POST.get('confirm') == 'True':
+ username = media.uploader()['username']
+ media.delete()
+ return redirect(request, "mediagoblin.user_pages.user_home",
+ user=username)
+ else:
+ return redirect(request, "mediagoblin.user_pages.media_home",
+ user=media.uploader()['username'],
+ media=media['slug'])
+
+ return render_to_response(
+ request,
+ 'mediagoblin/confirm/confirm_delete.html',
+ {'media': media,
+ 'form': form})
diff --git a/mediagoblin/templates/mediagoblin/confirm/confirm_delete.html b/mediagoblin/templates/mediagoblin/confirm/confirm_delete.html
new file mode 100644
index 00000000..ada89d5d
--- /dev/null
+++ b/mediagoblin/templates/mediagoblin/confirm/confirm_delete.html
@@ -0,0 +1,40 @@
+{#
+# GNU MediaGoblin -- federated, autonomous media hosting
+# Copyright (C) 2011 Free Software Foundation, Inc
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program. If not, see .
+#}
+{% extends "mediagoblin/base.html" %}
+
+{% import "/mediagoblin/utils/wtforms.html" as wtforms_util %}
+
+{% block mediagoblin_content %}
+
+
+{% endblock %}
From 46df0297e029c075a2c28b0c31490c560c99158c Mon Sep 17 00:00:00 2001
From: Joar Wandborg
Date: Mon, 29 Aug 2011 00:42:55 +0200
Subject: [PATCH 3/3] Added notice that deletion of a media entry is
*permanent*
---
.../templates/mediagoblin/confirm/confirm_delete.html | 8 ++++++++
1 file changed, 8 insertions(+)
diff --git a/mediagoblin/templates/mediagoblin/confirm/confirm_delete.html b/mediagoblin/templates/mediagoblin/confirm/confirm_delete.html
index ada89d5d..67d45811 100644
--- a/mediagoblin/templates/mediagoblin/confirm/confirm_delete.html
+++ b/mediagoblin/templates/mediagoblin/confirm/confirm_delete.html
@@ -31,6 +31,14 @@
Really delete {{ title }}?
{%- endtrans %}
+
+
+ {%- trans -%}
+ If you choose yes, the media entry will be deleted permanently.
+ {%- endtrans %}
+
+