Use pinax-pages instead
This commit is contained in:
parent
ba0bb84ad7
commit
a3c89ece12
9 changed files with 0 additions and 301 deletions
|
@ -1,25 +0,0 @@
|
|||
Content Management
|
||||
==================
|
||||
|
||||
The content management system allows organizers to create pages and page
|
||||
sections for a conference. You may want to have an entire page about a job
|
||||
fair, or may only want to have an editable section at the top of a tutorial
|
||||
schedule with some instructions for all of the tutorial attendees.
|
||||
|
||||
CMS App
|
||||
-------
|
||||
|
||||
The ``cms`` app provides functionality for creating wiki pages. These pages can
|
||||
be created using the django admin. The django admin form has controls for
|
||||
specifying:
|
||||
|
||||
* title
|
||||
* markup content
|
||||
* url path
|
||||
* tags
|
||||
* public or draft mode
|
||||
* publication date
|
||||
|
||||
Page content and title can also be edited directly at the url. The ``cms`` app
|
||||
uses the `django-reversion <http://django-reversion.readthedocs.org>`_ package,
|
||||
thus content is version controlled.
|
|
@ -1,2 +0,0 @@
|
|||
# @@@ Consider replacing with pinax-wiki [1]
|
||||
default_app_config = "symposion.cms.apps.CMSConfig"
|
|
@ -1,13 +0,0 @@
|
|||
from django.contrib import admin
|
||||
|
||||
import reversion
|
||||
|
||||
from .models import Page
|
||||
|
||||
|
||||
class PageAdmin(reversion.VersionAdmin):
|
||||
|
||||
pass
|
||||
|
||||
|
||||
admin.site.register(Page, PageAdmin)
|
|
@ -1,7 +0,0 @@
|
|||
from django.apps import AppConfig
|
||||
|
||||
|
||||
class CMSConfig(AppConfig):
|
||||
name = "symposion.cms"
|
||||
label = "symposion_cms"
|
||||
verbose_name = "Symposion CMS"
|
|
@ -1,21 +0,0 @@
|
|||
from django import forms
|
||||
|
||||
from markitup.widgets import MarkItUpWidget
|
||||
|
||||
from .models import Page
|
||||
|
||||
|
||||
class PageForm(forms.ModelForm):
|
||||
|
||||
class Meta:
|
||||
model = Page
|
||||
fields = ["title", "body", "path"]
|
||||
widgets = {
|
||||
"body": MarkItUpWidget(),
|
||||
"path": forms.HiddenInput(),
|
||||
}
|
||||
|
||||
|
||||
class FileUploadForm(forms.Form):
|
||||
|
||||
file = forms.FileField()
|
|
@ -1,10 +0,0 @@
|
|||
from django.utils import timezone
|
||||
|
||||
from django.db import models
|
||||
|
||||
|
||||
class PublishedPageManager(models.Manager):
|
||||
|
||||
def get_queryset(self):
|
||||
qs = super(PublishedPageManager, self).get_queryset()
|
||||
return qs.filter(publish_date__lte=timezone.now())
|
|
@ -1,79 +0,0 @@
|
|||
import datetime
|
||||
import os
|
||||
import re
|
||||
|
||||
from django.conf import settings
|
||||
from django.core.urlresolvers import reverse
|
||||
from django.core.exceptions import ValidationError
|
||||
from django.db import models
|
||||
from django.utils.encoding import python_2_unicode_compatible
|
||||
from django.utils.translation import ugettext_lazy as _
|
||||
|
||||
from markitup.fields import MarkupField
|
||||
|
||||
from taggit.managers import TaggableManager
|
||||
|
||||
import reversion
|
||||
|
||||
from .managers import PublishedPageManager
|
||||
|
||||
|
||||
@python_2_unicode_compatible
|
||||
class Page(models.Model):
|
||||
|
||||
STATUS_CHOICES = (
|
||||
(1, _("Draft")),
|
||||
(2, _("Public")),
|
||||
)
|
||||
|
||||
title = models.CharField(max_length=100)
|
||||
path = models.CharField(max_length=100, unique=True)
|
||||
body = MarkupField()
|
||||
status = models.IntegerField(choices=STATUS_CHOICES, default=2)
|
||||
publish_date = models.DateTimeField(default=datetime.datetime.now)
|
||||
created = models.DateTimeField(editable=False, default=datetime.datetime.now)
|
||||
updated = models.DateTimeField(editable=False, default=datetime.datetime.now)
|
||||
tags = TaggableManager(blank=True)
|
||||
|
||||
published = PublishedPageManager()
|
||||
|
||||
def __str__(self):
|
||||
return self.title
|
||||
|
||||
class Meta:
|
||||
verbose_name = _("page")
|
||||
verbose_name_plural = _("pages")
|
||||
|
||||
@models.permalink
|
||||
def get_absolute_url(self):
|
||||
return ("cms_page", [self.path])
|
||||
|
||||
@property
|
||||
def is_community(self):
|
||||
return self.path.lower().startswith("community/")
|
||||
|
||||
def save(self, *args, **kwargs):
|
||||
self.updated = datetime.datetime.now()
|
||||
super(Page, self).save(*args, **kwargs)
|
||||
|
||||
def clean_fields(self, exclude=None):
|
||||
super(Page, self).clean_fields(exclude)
|
||||
if not re.match(settings.SYMPOSION_PAGE_REGEX, self.path):
|
||||
raise ValidationError(
|
||||
{"path": [_("Path can only contain letters, numbers and hyphens and end with /")]})
|
||||
|
||||
|
||||
reversion.register(Page)
|
||||
|
||||
|
||||
def generate_filename(instance, filename):
|
||||
return filename
|
||||
|
||||
|
||||
class File(models.Model):
|
||||
|
||||
file = models.FileField(upload_to=generate_filename)
|
||||
created = models.DateTimeField(default=datetime.datetime.now)
|
||||
|
||||
def download_url(self):
|
||||
return reverse("file_download", args=[self.pk, os.path.basename(self.file.name).lower()])
|
|
@ -1,14 +0,0 @@
|
|||
from django.conf.urls import url, patterns
|
||||
|
||||
|
||||
PAGE_RE = r"(([\w-]{1,})(/[\w-]{1,})*)/"
|
||||
|
||||
urlpatterns = patterns(
|
||||
"symposion.cms.views",
|
||||
url(r"^files/$", "file_index", name="file_index"),
|
||||
url(r"^files/create/$", "file_create", name="file_create"),
|
||||
url(r"^files/(\d+)/([^/]+)$", "file_download", name="file_download"),
|
||||
url(r"^files/(\d+)/delete/$", "file_delete", name="file_delete"),
|
||||
url(r"^(?P<path>%s)_edit/$" % PAGE_RE, "page_edit", name="cms_page_edit"),
|
||||
url(r"^(?P<path>%s)$" % PAGE_RE, "page", name="cms_page"),
|
||||
)
|
|
@ -1,130 +0,0 @@
|
|||
from django.conf import settings
|
||||
from django.db import transaction
|
||||
from django.http import Http404, HttpResponse
|
||||
from django.shortcuts import render, redirect, get_object_or_404
|
||||
from django.views import static
|
||||
|
||||
from django.contrib.auth.decorators import login_required
|
||||
from .models import Page, File
|
||||
from .forms import PageForm, FileUploadForm
|
||||
|
||||
|
||||
def can_edit(page, user):
|
||||
if page and page.is_community:
|
||||
return True
|
||||
else:
|
||||
return user.has_perm("cms.change_page")
|
||||
|
||||
|
||||
def can_upload(user):
|
||||
if user.is_staff or user.is_superuser:
|
||||
return True
|
||||
return False
|
||||
|
||||
|
||||
def page(request, path):
|
||||
|
||||
try:
|
||||
page = Page.published.get(path=path)
|
||||
except Page.DoesNotExist:
|
||||
page = None
|
||||
|
||||
editable = can_edit(page, request.user)
|
||||
|
||||
if page is None:
|
||||
if editable:
|
||||
return redirect("cms_page_edit", path=path)
|
||||
else:
|
||||
raise Http404
|
||||
|
||||
return render(request, "cms/page_detail.html", {
|
||||
"page": page,
|
||||
"editable": editable,
|
||||
})
|
||||
|
||||
|
||||
@login_required
|
||||
def page_edit(request, path):
|
||||
|
||||
try:
|
||||
page = Page.published.get(path=path)
|
||||
except Page.DoesNotExist:
|
||||
page = None
|
||||
|
||||
if not can_edit(page, request.user):
|
||||
raise Http404
|
||||
|
||||
if request.method == "POST":
|
||||
form = PageForm(request.POST, instance=page)
|
||||
if form.is_valid():
|
||||
page = form.save(commit=False)
|
||||
page.path = path
|
||||
page.save()
|
||||
return redirect(page)
|
||||
else:
|
||||
print form.errors
|
||||
else:
|
||||
form = PageForm(instance=page, initial={"path": path})
|
||||
|
||||
return render(request, "cms/page_edit.html", {
|
||||
"path": path,
|
||||
"form": form
|
||||
})
|
||||
|
||||
|
||||
def file_index(request):
|
||||
if not can_upload(request.user):
|
||||
raise Http404
|
||||
|
||||
ctx = {
|
||||
"files": File.objects.all(),
|
||||
}
|
||||
return render(request, "cms/file_index.html", ctx)
|
||||
|
||||
|
||||
def file_create(request):
|
||||
if not can_upload(request.user):
|
||||
raise Http404
|
||||
|
||||
if request.method == "POST":
|
||||
form = FileUploadForm(request.POST, request.FILES)
|
||||
if form.is_valid():
|
||||
with transaction.commit_on_success():
|
||||
kwargs = {
|
||||
"file": form.cleaned_data["file"],
|
||||
}
|
||||
File.objects.create(**kwargs)
|
||||
return redirect("file_index")
|
||||
else:
|
||||
form = FileUploadForm()
|
||||
|
||||
ctx = {
|
||||
"form": form,
|
||||
}
|
||||
return render(request, "cms/file_create.html", ctx)
|
||||
|
||||
|
||||
def file_download(request, pk, *args):
|
||||
file = get_object_or_404(File, pk=pk)
|
||||
|
||||
if getattr(settings, "USE_X_ACCEL_REDIRECT", False):
|
||||
response = HttpResponse()
|
||||
response["X-Accel-Redirect"] = file.file.url
|
||||
# delete content-type to allow Gondor to determine the filetype and
|
||||
# we definitely don't want Django's default :-)
|
||||
del response["content-type"]
|
||||
else:
|
||||
response = static.serve(request, file.file.name, document_root=settings.MEDIA_ROOT)
|
||||
|
||||
return response
|
||||
|
||||
|
||||
def file_delete(request, pk):
|
||||
if not can_upload(request.user):
|
||||
raise Http404
|
||||
|
||||
file = get_object_or_404(File, pk=pk)
|
||||
if request.method == "POST":
|
||||
file.delete()
|
||||
# @@@ message
|
||||
return redirect("file_index")
|
Loading…
Reference in a new issue