summaryrefslogtreecommitdiff
path: root/app/links
diff options
context:
space:
mode:
Diffstat (limited to 'app/links')
-rw-r--r--app/links/admin.py28
-rw-r--r--app/links/detail_urls.py8
-rw-r--r--app/links/models.py28
-rw-r--r--app/links/retriever.py104
-rw-r--r--app/links/sync_links.py11
5 files changed, 76 insertions, 103 deletions
diff --git a/app/links/admin.py b/app/links/admin.py
index 2c73c76..68efe9e 100644
--- a/app/links/admin.py
+++ b/app/links/admin.py
@@ -1,14 +1,30 @@
from django.contrib import admin
-
from links.models import Link
+
class LinkAdmin(admin.ModelAdmin):
list_display = ('title', 'rating', 'pub_date', 'status')
- search_fields = ['title','description','url']
+ search_fields = ['title', 'description', 'url']
list_filter = ['rating', 'status']
fieldsets = (
- (None, {'fields': ('title','url','description','rating')}),
- ('Details', {'fields': ('screen_url', 'pub_date', 'link_id', 'tags', 'status'), 'classes': 'collapse'}),
+ (None, {
+ 'fields': (
+ 'title',
+ 'url',
+ 'description',
+ 'rating'
+ )
+ }),
+ ('Details', {
+ 'fields': (
+ 'screen_url',
+ 'pub_date',
+ 'link_id',
+ 'tags',
+ 'status'
+ ),
+ 'classes': 'collapse'
+ }),
)
-
-admin.site.register(Link, LinkAdmin) \ No newline at end of file
+
+admin.site.register(Link, LinkAdmin)
diff --git a/app/links/detail_urls.py b/app/links/detail_urls.py
index b629f3e..9c76a7f 100644
--- a/app/links/detail_urls.py
+++ b/app/links/detail_urls.py
@@ -4,11 +4,7 @@ from django.views.generic.detail import DetailView
from links.models import Link
-detail_dict = {
- 'queryset': Link.objects.filter(status__exact=1),
-}
urlpatterns = patterns('',
- (r'^$', RedirectView.as_view(url="/links/1/")),
- (r'^(?P<object_id>\d+)/$', DetailView.as_view(model=Link,template_name='details/link.html')),
+ (r'^$', RedirectView.as_view(url="/links/1/")),
+ (r'^(?P<object_id>\d+)/$', DetailView.as_view(model=Link, template_name='details/link.html')),
)
-
diff --git a/app/links/models.py b/app/links/models.py
index 4c3e59d..c6b502c 100644
--- a/app/links/models.py
+++ b/app/links/models.py
@@ -2,7 +2,7 @@ import datetime
from django.db import models
from django.contrib.sitemaps import Sitemap
from django.contrib.syndication.views import Feed
-from taggit.managers import TaggableManager
+from taggit.managers import TaggableManager
RATINGS = (
('1', "1 Star"),
@@ -12,8 +12,7 @@ RATINGS = (
('5', "5 Stars"),
)
-DEBUG = 1
-
+
class Link(models.Model):
link_id = models.CharField(max_length=60, blank=True, null=True)
title = models.CharField(max_length=400)
@@ -31,29 +30,29 @@ class Link(models.Model):
class Meta:
ordering = ['-pub_date']
-
+
def __unicode__(self):
return self.title
-
+
def get_absolute_url(self):
return self.url
-
+
def get_model_name(self):
return 'link'
-
+
def get_previous_published(self):
return self.get_previous_by_pub_date(status__exact=1)
-
+
def get_next_published(self):
return self.get_next_by_pub_date(status__exact=1)
-
-
+
def get_thumbnail_url(self):
- return "http://images.luxagraf.net/magnolia_thumbs/%s" %(self.screen_url)
+ return "http://images.luxagraf.net/magnolia_thumbs/%s" % (self.screen_url)
+
def comment_period_open(self):
return self.enable_comments and datetime.datetime.today() - datetime.timedelta(30) <= self.pub_date
-
-
+
+
class LinkSitemap(Sitemap):
changefreq = "never"
priority = 0.4
@@ -63,7 +62,8 @@ class LinkSitemap(Sitemap):
def lastmod(self, obj):
return obj.pub_date
-
+
+
class LatestLinks(Feed):
title = "Luxagraf: Links"
link = "http://ma.gnolia.com/people/luxagraf/bookmarks"
diff --git a/app/links/retriever.py b/app/links/retriever.py
index bcbc8fa..9e7aae5 100644
--- a/app/links/retriever.py
+++ b/app/links/retriever.py
@@ -5,15 +5,33 @@ from django.template.defaultfilters import striptags
from django.core.mail import EmailMessage
from django.conf import settings
-
-from utils.strutils import safestr,unquotehtml
from links.models import Link
-from utils import pinboard
+# https://github.com/mgan59/python-pinboard/
+import pinboard
+
+
+def safestr(s):
+ """
+ Safely corerce *anything* to a string. If the object can't be str'd, an
+ empty string will be returned.
+
+ You can (and I do) use this for really crappy unicode handling, but it's
+ a bit like killing a mosquito with a bazooka.
+ """
+ if s is None:
+ return ""
+ if isinstance(s, unicode):
+ return s.encode('ascii', 'xmlcharrefreplace')
+ else:
+ try:
+ return str(s)
+ except:
+ return ""
+
def sync_pinboard_links():
"""
sync bookmarks from my pinboard account
-
dependancies: python-pinboard https://github.com/mgan59/python-pinboard/
"""
p = pinboard.open(settings.PIN_USER, settings.PIN_PASS)
@@ -22,17 +40,17 @@ def sync_pinboard_links():
for link in links:
try:
#check to see if link exists
- row = Link.objects.get(link_id=safestr(link['hash']))
+ row = Link.objects.get(link_id=safestr(link['hash']))
except ObjectDoesNotExist:
l, created = Link.objects.get_or_create(
- title = link['description'],
- link_id = safestr(link['hash']),
- url = safestr(link['href']),
- description = safestr(link['extended']),
- rating = "3",
- pub_date = datetime.datetime.strptime(link['time'], "%Y-%m-%dT%H:%M:%SZ"),
- status = 0
- )
+ title=link['description'],
+ link_id=safestr(link['hash']),
+ url=safestr(link['href']),
+ description=safestr(link['extended']),
+ rating="3",
+ pub_date=datetime.datetime.strptime(link['time'], "%Y-%m-%dT%H:%M:%SZ"),
+ status=0
+ )
print l.title
if created:
print l.title
@@ -40,72 +58,14 @@ def sync_pinboard_links():
l.tags.add(t)
email_link(l)
-'''
-def sync_delicious_links(*args, **kwargs):
- b = delicious.get_all(settings.DELICIOUS_USER, settings.DELICIOUS_PASS)
- dupe = False
- for post in b:
- taglist = []
- try:
- row = Link.objects.get(magnolia_id=safestr(post['hash']))
- # If the row exists already, set the dupe flag
- dupe = True
- except ObjectDoesNotExist:
- #f = copy_file(safestr(post.findtext('screenshot')), safestr(info['id']))
- #fake the image since delicious doesn't offer them
- local_image_url = "%s/%s.jpg" %(safestr(datetime.datetime.today().strftime("%b").lower()), safestr(post['hash']))
- tags = str(post['tag']).split(" ")
- for tag in tags:
- taglist.append(tag)
- for tag in taglist:
- if tag == '2lux':
- status = 1
- break
- else:
- status = 0
- descr = markdown.markdown(unquotehtml(safestr(post['extended'])), safe_mode = False)
- l, created = Link.objects.get_or_create(
- title = post['description'],
- magnolia_id = safestr(post['hash']),
- url = safestr(post['href']),
- description = descr,
- screen_url = local_image_url,
- #fake the rating since delicious doesn't offer such things
- rating = "3",
- pub_date = datetime.datetime.strptime(post['time'], "%Y-%m-%dT%H:%M:%SZ"),
- status = status,
- enable_comments = True,
- tags = ", ".join(t for t in taglist if t != "2lux")
- )
-
- email_link(l)
- if l.status == 1:
- pass
- #post_to_tumblr(l)
- #send_to_deliciousfb(l)
- if(dupe):
- break
-
-
-'''
def email_link(link):
"""
Sends an imported link to Gmail (never hurts to have backups)
"""
subject = link.title
- body = "%s\n\n%s\n\n\nvisit site:%s\n" %(link.title, link.description, link.url)
+ body = "%s\n\n%s\n\n\nvisit site:%s\n" % (link.title, link.description, link.url)
msg = EmailMessage(subject, striptags(body), 'sng@luxagraf.net', ['luxagraf+links@gmail.com'])
msg.send()
msg = EmailMessage(subject, striptags(body), 'sng@luxagraf.net', ['sng+links@luxagraf.net'])
msg.send()
-
-'''
-def send_to_delicious(link):
- del_tags = ''
- tags = link.tags.split(',')
- for tag in tags:
- del_tags += tag.strip().replace(' ','_')+' '
- delicious.add(settings.DELICIOUS_USER, settings.DELICIOUS_PASS, link.url, link.title, tags = del_tags, extended = striptags(link.description), dt =safestr(link.pub_date), replace="no")
-
-'''
diff --git a/app/links/sync_links.py b/app/links/sync_links.py
index cd1373d..b61395c 100644
--- a/app/links/sync_links.py
+++ b/app/links/sync_links.py
@@ -1,12 +1,13 @@
-import sys, os
+import sys
+import os
from os.path import dirname, abspath
-PROJECT_ROOT = abspath(dirname(dirname(dirname(__file__))))+'/'
+PROJECT_ROOT = abspath(dirname(dirname(dirname(__file__)))) + '/'
#PROJECT_ROOT = abspath(dirname(dirname(__file__)))
print PROJECT_ROOT
sys.path.append(PROJECT_ROOT)
-sys.path.append(PROJECT_ROOT+'/app')
-sys.path.append(PROJECT_ROOT+'/app/lib')
-sys.path.append(PROJECT_ROOT+'/config')
+sys.path.append(PROJECT_ROOT + '/app')
+sys.path.append(PROJECT_ROOT + '/app/lib')
+sys.path.append(PROJECT_ROOT + '/config')
sys.path.append('/home/luxagraf/apps/venv/bin/python2.7/')
os.environ['DJANGO_SETTINGS_MODULE'] = 'settings.settings'
from links import retriever