mirror of
https://github.com/kovidgoyal/calibre.git
synced 2025-06-23 15:30:45 -04:00
IGN:...
This commit is contained in:
parent
b094f3bbb9
commit
2b935b720b
@ -6,7 +6,6 @@ Gustavo Picón
|
|||||||
fjlib.py
|
fjlib.py
|
||||||
"""
|
"""
|
||||||
|
|
||||||
from django.conf import settings
|
|
||||||
from django.db import connection
|
from django.db import connection
|
||||||
from django.core.paginator import Paginator, InvalidPage
|
from django.core.paginator import Paginator, InvalidPage
|
||||||
from django.http import Http404
|
from django.http import Http404
|
||||||
@ -125,7 +124,6 @@ def get_extra_content(site, sfeeds_ids, ctx):
|
|||||||
ctx['feeds'] = []
|
ctx['feeds'] = []
|
||||||
ctx['last_modified'] = '??'
|
ctx['last_modified'] = '??'
|
||||||
ctx['site'] = site
|
ctx['site'] = site
|
||||||
ctx['media_url'] = settings.MEDIA_URL
|
|
||||||
|
|
||||||
def get_posts_tags(object_list, sfeeds_obj, user_id, tag_name):
|
def get_posts_tags(object_list, sfeeds_obj, user_id, tag_name):
|
||||||
""" Adds a qtags property in every post object in a page.
|
""" Adds a qtags property in every post object in a page.
|
||||||
|
@ -11,7 +11,7 @@ from django.utils import feedgenerator
|
|||||||
from django.shortcuts import render_to_response
|
from django.shortcuts import render_to_response
|
||||||
from django.http import HttpResponse
|
from django.http import HttpResponse
|
||||||
from django.utils.cache import patch_vary_headers
|
from django.utils.cache import patch_vary_headers
|
||||||
from django.template import Context, loader
|
from django.template import RequestContext, loader
|
||||||
|
|
||||||
from calibre.www.apps.feedjack import models, fjlib, fjcache
|
from calibre.www.apps.feedjack import models, fjlib, fjcache
|
||||||
|
|
||||||
@ -58,7 +58,7 @@ def blogroll(request, btype):
|
|||||||
template = loader.get_template('feedjack/%s.xml' % btype)
|
template = loader.get_template('feedjack/%s.xml' % btype)
|
||||||
ctx = {}
|
ctx = {}
|
||||||
fjlib.get_extra_content(site, sfeeds_ids, ctx)
|
fjlib.get_extra_content(site, sfeeds_ids, ctx)
|
||||||
ctx = Context(ctx)
|
ctx = RequestContext(request, ctx)
|
||||||
response = HttpResponse(template.render(ctx) , \
|
response = HttpResponse(template.render(ctx) , \
|
||||||
mimetype='text/xml; charset=utf-8')
|
mimetype='text/xml; charset=utf-8')
|
||||||
|
|
||||||
@ -138,7 +138,7 @@ def mainview(request, tag=None, user=None):
|
|||||||
sfeeds_ids))
|
sfeeds_ids))
|
||||||
|
|
||||||
response = render_to_response('feedjack/%s/post_list.html' % \
|
response = render_to_response('feedjack/%s/post_list.html' % \
|
||||||
(site.template), ctx)
|
(site.template), ctx, context_instance=RequestContext(request))
|
||||||
|
|
||||||
# per host caching, in case the cache middleware is enabled
|
# per host caching, in case the cache middleware is enabled
|
||||||
patch_vary_headers(response, ['Host'])
|
patch_vary_headers(response, ['Host'])
|
||||||
|
@ -1,29 +1,12 @@
|
|||||||
Test
|
Test
|
||||||
=====
|
=====
|
||||||
|
|
||||||
|
Calibre planet can be run either in development mode or deployment mode. For testing,
|
||||||
|
it should be run in development mode as follows:
|
||||||
|
|
||||||
* Install django
|
* Install django
|
||||||
* Run ``python manage.py syncdb`` to create database in /tmp/planet.db
|
* ``cd test && ./test``
|
||||||
* Run ``python manage.py runserver``
|
|
||||||
* Goto `http://localhost:8000/admin` and create Feeds, Sites and Subscribers
|
|
||||||
* Planet is at `http://localhost:8000`
|
* Planet is at `http://localhost:8000`
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
Update feeds by running::
|
|
||||||
|
|
||||||
DJANGO_SETTINGS_MODULE=calibre.www.planet.settings feedjack_update.py
|
|
||||||
|
|
||||||
Deploy
|
|
||||||
=======
|
|
||||||
|
|
||||||
* Add settings for deployment environment to settings.py
|
|
||||||
* In particular setup caching
|
|
||||||
|
|
||||||
* Run python manage.py syncdb
|
|
||||||
* Add super user when asked
|
|
||||||
|
|
||||||
* Setup Apache
|
|
||||||
|
|
||||||
* Goto /admin and add feeds
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
from calibre.www.settings import DEBUG, TEMPLATE_DEBUG, ADMINS, MANAGERS, \
|
from calibre.www.settings import DEBUG, TEMPLATE_DEBUG, ADMINS, MANAGERS, \
|
||||||
TEMPLATE_LOADERS, TEMPLATE_DIRS, MIDDLEWARE_CLASSES, MEDIA_ROOT, \
|
TEMPLATE_LOADERS, TEMPLATE_DIRS, MIDDLEWARE_CLASSES, MEDIA_ROOT, \
|
||||||
MEDIA_URL, ADMIN_MEDIA_PREFIX
|
MEDIA_URL, ADMIN_MEDIA_PREFIX, TEMPLATE_CONTEXT_PROCESSORS
|
||||||
|
|
||||||
if not DEBUG:
|
if not DEBUG:
|
||||||
MEDIA_URL = 'http://planet.calibre-ebook.com/site_media/'
|
MEDIA_URL = 'http://planet.calibre-ebook.com/site_media/'
|
||||||
|
BIN
src/calibre/www/planet/test/planet.db
Normal file
BIN
src/calibre/www/planet/test/planet.db
Normal file
Binary file not shown.
4
src/calibre/www/planet/test/test.sh
Executable file
4
src/calibre/www/planet/test/test.sh
Executable file
@ -0,0 +1,4 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
cp planet.db /tmp
|
||||||
|
cd ..
|
||||||
|
python manage.py runserver
|
4
src/calibre/www/publish.sh
Executable file
4
src/calibre/www/publish.sh
Executable file
@ -0,0 +1,4 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
ssh divok bzr up /usr/local/calibre
|
||||||
|
ssh divok /etc/init.d/apache2 graceful
|
@ -75,6 +75,12 @@ else:
|
|||||||
'/usr/local/calibre/src/calibre/www/templates',
|
'/usr/local/calibre/src/calibre/www/templates',
|
||||||
)
|
)
|
||||||
|
|
||||||
|
TEMPLATE_CONTEXT_PROCESSORS = (
|
||||||
|
"django.core.context_processors.auth",
|
||||||
|
"django.core.context_processors.debug",
|
||||||
|
"django.core.context_processors.i18n",
|
||||||
|
"django.core.context_processors.media"
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
body {
|
body {
|
||||||
font-family: sansserif;
|
font-family: sansserif;
|
||||||
background-color: #eeeeee;
|
background-color: #f6f6f6;
|
||||||
}
|
}
|
||||||
|
|
||||||
img {
|
img {
|
||||||
@ -12,6 +12,7 @@ img {
|
|||||||
border-bottom: 1px solid black;
|
border-bottom: 1px solid black;
|
||||||
margin-bottom: 20px;
|
margin-bottom: 20px;
|
||||||
height: 100px;
|
height: 100px;
|
||||||
|
background-color: #d6d6d6;
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -117,9 +117,8 @@ div.post-content {
|
|||||||
border-right: 1px dotted #ccc;
|
border-right: 1px dotted #ccc;
|
||||||
}
|
}
|
||||||
div.post-content li {
|
div.post-content li {
|
||||||
margin: 0;
|
|
||||||
padding: 0;
|
|
||||||
line-height: 130%;
|
line-height: 130%;
|
||||||
|
margin-bottom: 0.6em;
|
||||||
}
|
}
|
||||||
div.post-content table{
|
div.post-content table{
|
||||||
border: 0;
|
border: 0;
|
||||||
|
@ -7,14 +7,15 @@
|
|||||||
-->
|
-->
|
||||||
<head>
|
<head>
|
||||||
<title>{% block title %}calibre - E-book management{% endblock %}</title>
|
<title>{% block title %}calibre - E-book management{% endblock %}</title>
|
||||||
<link rel="stylesheet" type="text/css" href="{{ media_url }}/styles/base.css" />
|
<link rel="stylesheet" type="text/css" href="{{ MEDIA_URL }}/styles/base.css" />
|
||||||
|
<link rel="icon" type="image/x-icon" href="/favicon.ico" />
|
||||||
{% block extra_header %} {% endblock %}
|
{% block extra_header %} {% endblock %}
|
||||||
</head>
|
</head>
|
||||||
|
|
||||||
<body>
|
<body>
|
||||||
<div id="_header">
|
<div id="_header">
|
||||||
<h1>
|
<h1>
|
||||||
<img id="_logo" alt="calibre" src="{{ media_url }}/img/logo.png" />
|
<img id="_logo" alt="calibre" src="{{ MEDIA_URL }}/img/logo.png" />
|
||||||
{% block header_text %}e-book management{% endblock %}
|
{% block header_text %}e-book management{% endblock %}
|
||||||
</h1>
|
</h1>
|
||||||
</div>
|
</div>
|
||||||
@ -26,7 +27,7 @@
|
|||||||
{% block footer_text %}
|
{% block footer_text %}
|
||||||
Created by Kovid Goyal.
|
Created by Kovid Goyal.
|
||||||
Powered by <a href="http://www.djangoproject.com">
|
Powered by <a href="http://www.djangoproject.com">
|
||||||
<img alt="Django" src="{{ media_url }}/img/button-django.png"/>
|
<img alt="Django" src="{{ MEDIA_URL }}/img/button-django.png"/>
|
||||||
</a>
|
</a>
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
</div>
|
</div>
|
||||||
|
@ -4,8 +4,8 @@
|
|||||||
{% block header_text %}Planet{% endblock %}
|
{% block header_text %}Planet{% endblock %}
|
||||||
|
|
||||||
{% block extra_header %}
|
{% block extra_header %}
|
||||||
<link rel="stylesheet" type="text/css" href="{{ media_url }}/styles/planet.css" />
|
<link rel="stylesheet" type="text/css" href="{{ MEDIA_URL }}/styles/planet.css" />
|
||||||
<link rel="stylesheet" type="text/css" href="{{ media_url }}/styles/codebox.css" />
|
<link rel="stylesheet" type="text/css" href="{{ MEDIA_URL }}/styles/codebox.css" />
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
|
|
||||||
{% block content %}
|
{% block content %}
|
||||||
@ -31,10 +31,10 @@
|
|||||||
</div> <!-- end paginate -->
|
</div> <!-- end paginate -->
|
||||||
|
|
||||||
<div id="buttons">
|
<div id="buttons">
|
||||||
<a href="{{ site.url }}/feed/rss/" title="RSS 2.0 feed"><img src="{{ media_url }}/img/button-rss.png"/></a> •
|
<a href="{{ site.url }}/feed/rss/" title="RSS 2.0 feed"><img src="{{ MEDIA_URL }}/img/button-rss.png"/></a> •
|
||||||
<a href="{{ site.url }}/feed/atom/" title="Atom 1.0 feed"><img src="{{ media_url }}/img/button-atom.png"/></a> •
|
<a href="{{ site.url }}/feed/atom/" title="Atom 1.0 feed"><img src="{{ MEDIA_URL }}/img/button-atom.png"/></a> •
|
||||||
<a href="{{ site.url }}/opml/" title="OPML"><img src="{{ media_url }}/img/button-opml.png"/></a> •
|
<a href="{{ site.url }}/opml/" title="OPML"><img src="{{ MEDIA_URL }}/img/button-opml.png"/></a> •
|
||||||
<a href="{{ site.url }}/foaf/" title="FOAF"><img src="{{ media_url }}/img/button-foaf.png"/></a>
|
<a href="{{ site.url }}/foaf/" title="FOAF"><img src="{{ MEDIA_URL }}/img/button-foaf.png"/></a>
|
||||||
</div> <!-- end buttons -->
|
</div> <!-- end buttons -->
|
||||||
|
|
||||||
<div id="post_list">
|
<div id="post_list">
|
||||||
@ -50,7 +50,7 @@
|
|||||||
<div class="avatar">
|
<div class="avatar">
|
||||||
<a href="{{ item.feed.link }}">
|
<a href="{{ item.feed.link }}">
|
||||||
<img
|
<img
|
||||||
src="{{ media_url }}/img/faces/{{ item.subscriber.shortname}}.png" alt="" />
|
src="{{ MEDIA_URL }}/img/faces/{{ item.subscriber.shortname}}.png" alt="" />
|
||||||
<br/>
|
<br/>
|
||||||
<span class="url">{{ item.feed.title }}</span>
|
<span class="url">{{ item.feed.title }}</span>
|
||||||
</a>
|
</a>
|
||||||
@ -90,7 +90,7 @@
|
|||||||
Planet Calibre is a window into the world, work and lives of Calibre developers and contributors.
|
Planet Calibre is a window into the world, work and lives of Calibre developers and contributors.
|
||||||
</p>
|
</p>
|
||||||
<p style="text-align:left">
|
<p style="text-align:left">
|
||||||
If you have a question or would like your blog added to the feed. Please email
|
If you have a question or would like your blog added to the planet, please email
|
||||||
<a href="mailto:kovid@kovidgoyal.net">Kovid Goyal</a>.
|
<a href="mailto:kovid@kovidgoyal.net">Kovid Goyal</a>.
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
@ -151,7 +151,7 @@ title="feed (last modified: {{ feed.feed.last_modified }})"
|
|||||||
title="feed"
|
title="feed"
|
||||||
{% endif %}
|
{% endif %}
|
||||||
>
|
>
|
||||||
<img src="{{ media_url }}/img/feed.png" alt="feed"></a>
|
<img src="{{ MEDIA_URL }}/img/feed.png" alt="feed"></a>
|
||||||
<a class="nombre" href="{{ site.url }}/user/{{ feed.feed.id }}"
|
<a class="nombre" href="{{ site.url }}/user/{{ feed.feed.id }}"
|
||||||
title="{{ feed.feed.title }}">{{ feed.name }}</a></li>
|
title="{{ feed.feed.title }}">{{ feed.name }}</a></li>
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user