Skip to main content

Django app for aggregate some feeds from social networks.

Project description

emencia-django-social-aggregator

This app is an aggregator of social network.

A command script will recover data from social network/external site from Aggregator info that you specified into admin. It will stock them into database, like Ressource and you could manage them into admin. You could regroup Ressource by Feed and return them into JSON or HTML view.

Optionally you can use it as a plugin for django-cms if installed.

Requires

Install

In your settings.INSTALLED_APPS :

'taggit',
'socialaggregator',

Then import basic settings in your settings file :

from socialaggregator.settings import *

Usage

As a view

First, add this row in your urls.py :

url(r'^socialaggregator/', include('socialaggregator.urls')),

Then you will access to your feed ressources list as a HTML page with an url like this :

/socialaggregator/feed/sample/

Or you can use the JSON version :

/socialaggregator/feed/sample/?format=json

Also there is a view to display all resssources from all feeds :

/socialaggregator/

The default template use in these views comes from settings.EDSA_PLUGIN_TEMPLATE.

As a templatetag

The tag syntax is the following :

{% ressource_by_feed slug template_name %}

Where :

  • slug argument is a String containing the slug feed;

  • template_name is a String containing the template path to use, default to settings.EDSA_TAG_TEMPLATE;

So for example, load the templatetag and use the tag giving it the feed slug to use to list its ressources :

{% load socialaggregator_tags %}

<div class="row">
    {% ressource_by_feed 'parrot-apps-usa' %}
</div>

As a django-cms plugin

Just use the plugin named “Socialaggregator Feed Plugin” in your page with selecting the feed you want to list the ressources.

The default used template path comes from settings.EDSA_PLUGIN_TEMPLATE to display the feed ressources, change it in your project to use your own HTML layout.

Unified content datas

Because feeds can contains ressources from many social networks, a method get_unified_render exist on the Ressource model. The method use formatter loaded from the setting RESSOURCE_FORMATTER if defined, else it will load the default formatter socialaggregator.formatter.RessourceFormatterDefault.

The default formatter return a dict with an unified data scheme, so you can use it in your template without to test if a field is filled or not, etc.. This is optionnal, you can still directly use the ressource instance and play with its fields. You can use it like so :

{% for ressource_item in feed_ressources %}{% with ressource_item.get_unified_render as ressource %}
<li>
    {% if ressource.title %}<h2>{{ ressource.title }}</h2>{% endif %}
    {% if ressource.description %}<p>{{ ressource.description|safe|linebreaksbr }}</p>{% endif %}
</li>
{% endwith %}{% endfor %}

Note that the formatter is not automatically applied, so the JSON view output still return ressource instances serialized.

Changelog

0.2.3

  • Add ressource_by_feed template tag to display ressources from specified feed without any pagination;

  • Add EDSA_VIEW_TEMPLATE, EDSA_TAG_TEMPLATE, EDSA_PLUGIN_TEMPLATE settings and use them in view, tag and plugin;

  • Some cleaning on the default template for views;

0.2.2

  • Add Sphinx documentation in docs/;

0.2.1

  • Add new method on Ressource model to get unified content data;

0.2

  • Add optional django-cms plugin to display feed ressources, little changes on default view template;

0.1.dev

  • Initial release. Alpha version

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

emencia-django-socialaggregator-0.2.6.tar.gz (31.5 kB view details)

Uploaded Source

File details

Details for the file emencia-django-socialaggregator-0.2.6.tar.gz.

File metadata

File hashes

Hashes for emencia-django-socialaggregator-0.2.6.tar.gz
Algorithm Hash digest
SHA256 3b70e35573ac2c062d4a0950dc9942e098acceba701e0824f1f3e71d52ccd801
MD5 4c3526f17d0382a70f9aa4b759507b75
BLAKE2b-256 8dad34fc26535bce668b722f3f4e0c2f78e477ddc316c9bd07b38a8ad6dc3469

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page