Skip to main content

Ads Management System for Django Framework

Project description

a Django Application to make it easy to add Simple (Image) Advertisements to your project.

Each Ad has a title, a URL to redirect to, an image to be displayed in the template as a link, a start & end dates, and a weight relative to other Ads in the same zone. The higher the weight, the more frequently the Ad will be displayed.

Each time an Ad is displayed an Impression will be saved to the database about it with session id and source ip address, and each time it will be clicked a click will be saved in the database about it with the same info.

Installation:

Install the package using pip:

pip install django-ads

Run django Migration to add tables to your database:

python manage.py migrate ads

Configuration:

Add 'ads' to your INSTALLED_APPS

Make sure django.template.context_processors.request is included in context_processors

TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'DIRS': [],
        'APP_DIRS': True,
        'OPTIONS': {
            'context_processors': [
                ...
                'django.template.context_processors.request',
                ...
            ],
        },
    },
]

Make sure django.contrib.sessions.middleware.SessionMiddleware is included to MIDDLEWARE_CLASSES/MIDDLEWARE

Prior to Django 1.10

MIDDLEWARE_CLASSES = [
    ...
    'django.contrib.sessions.middleware.SessionMiddleware',
    ...
]

Django 1.10 (new style)

MIDDLEWARE = [
    ...
    'django.contrib.sessions.middleware.SessionMiddleware',
    ...
]

Add the following to your settings file:

ADS_GOOGLE_ADSENSE_CLIENT = None  # 'ca-pub-xxxxxxxxxxxxxxxx'

ADS_ZONES = {
    'header': {
        'name': gettext('Header'),
        'ad_size': {
            'xs': '720x150',
            'sm': '800x90',
            'md': '800x90',
            'lg': '800x90',
            'xl': '800x90'
        },
        'google_adsense_slot': None,  # 'xxxxxxxxx',
        'google_adsense_format': None,  # 'auto'
    },
    'content': {
        'name': gettext('Content'),
        'ad_size': {
            'xs': '720x150',
            'sm': '800x90',
            'md': '800x90',
            'lg': '800x90',
            'xl': '800x90'
        },
        'google_adsense_slot': None,  # 'xxxxxxxxx',
        'google_adsense_format': None,  # 'auto'
    },
    'sidebar': {
        'name': gettext('Sidebar'),
        'ad_size': {
            'xs': '720x150',
            'sm': '800x90',
            'md': '800x90',
            'lg': '800x90',
            'xl': '800x90'
        }
    }
}

ADS_DEFAULT_AD_SIZE = '720x150'

ADS_DEVICES = (
    ('xs', _('Extra small devices')),
    ('sm', _('Small devices')),
    ('md', _('Medium devices (Tablets)')),
    ('lg', _('Large devices (Desktops)')),
    ('xl', _('Extra large devices (Large Desktops)')),
)

ADS_VIEWPORTS = {
    'xs': 'd-block img-fluid d-sm-none',
    'sm': 'd-none img-fluid d-sm-block d-md-none',
    'md': 'd-none img-fluid d-md-block d-lg-none',
    'lg': 'd-none img-fluid d-lg-block d-xl-none',
    'xl': 'd-none img-fluid d-xl-block',
}

Where each element in ADS_ZONES defines a zone that can be used in your templates to display ads. Each zone must have a name to be used in the admin interface when adding ads, and sizes to be used to display the ad images in templates.

This app has one template: ads/tags/render_ads_zone.html. It makes some assumptions:

  1. Your project uses Bootstrap (the visible-* and img-responsive CSS classes are used).

  2. If you are using Google AdSense‎, it is assumed that you have 'sekizai' in your INSTALLED_APPS and that your base template contains {% render_block "js" %}.

If either of the above assumptions will cause a problem in your project, feel free to override the template.

Create a URL pattern in your urls.py:

from django.conf.urls import include, url

urlpatterns = [
    ...
    url(r'^ads/', include('ads.urls')),
    ...
]

Usage:

Add Advertisers, Categories, and Ads using Django admin interface.

load ads_tags in your template:

{% load ads_tags %}

use render_ads_zone in your template where you want your ads to appear:

{% render_ads_zone 'zone_name' %}

use get_ads_count in your template to check if any zone has active ads.

{% get_ads_count 'zone1' as ads_count %}
{{ get_ads_count 'zone1,zone2,zone3' as ads_count %}

Changelog:

1.1.1 (2020-03-20):

  • remove @python_2_unicode_compatible (removed in Django 3.0)

1.1.0 (2019-07-28):

  • get_ads_count template tag added.

  • fixed setup dependency (django-js-reverse has been added).

1.0.0 (2019-03-26):

  • major change in functionality (switch to JS approach in rendering templates). You need jquery to be installed in frontend to use django-ads.

  • Note: templates/ads/tags/render_ads_zone.html has been changed. If you use a custom template, then please take a look at the new version.

0.2.1 (2018-07-26): (Special Thanks to @GabrielDumbrava )

  • get_zones_choices now return choices sorted based on key

  • Ad, Category, and Advertizer now stay on DB after deleting created_by user.

  • fix get_absolute_url in Ad model.

  • Add ad and ad__zone filters to impressions and clicks admin pages.

  • Fix clicks and impressions admin search.

0.2.1 (2018-02-05):

  • add long_description to setup.py

0.2.0 (2018-02-05): (Special Thanks to @ataylor32 )

  • add Django 2.0 support

  • add missing dependency (Pillow)

  • update README

0.1.8 (2017-06-24):

  • fix googleads script tags to load multiple ad units in the same page

0.1.7 (2017-06-24):

  • Please do not use this version

0.1.6 (2017-06-24):

  • fix django-sekizai dependency version

0.1.5 (2017-06-24):

  • add google adsense fallback

0.1.4 (2017-03-01):

  • get client ip address from HTTP_X_FORWARDED_FOR if it exists.

0.1.3 (2017-02-08):

  • remove dependency on easy-thumbnails.

  • add Image validation to validate image size on upload using Admin interface.

0.1.2 (2017-02-08):

  • add AdImage model to allow responsive ads.

0.1.1 (2016-12-20):

  • add missing templates directory.

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

django-ads-1.1.1.tar.gz (19.3 kB view details)

Uploaded Source

Built Distribution

django_ads-1.1.1-py3-none-any.whl (21.8 kB view details)

Uploaded Python 3

File details

Details for the file django-ads-1.1.1.tar.gz.

File metadata

  • Download URL: django-ads-1.1.1.tar.gz
  • Upload date:
  • Size: 19.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.43.0 CPython/3.8.2

File hashes

Hashes for django-ads-1.1.1.tar.gz
Algorithm Hash digest
SHA256 5833c7d5ad4470a3575d4ee88abb1b3a5cb5b53941993329c020f54e69f8eb1a
MD5 781a1018ec6d7b0aa3f38b174169fc33
BLAKE2b-256 6c6d4d9b1d7c3719cfd8591b950dcf112fef7afba169bf8cdc07719cf66c7ee7

See more details on using hashes here.

File details

Details for the file django_ads-1.1.1-py3-none-any.whl.

File metadata

  • Download URL: django_ads-1.1.1-py3-none-any.whl
  • Upload date:
  • Size: 21.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.43.0 CPython/3.8.2

File hashes

Hashes for django_ads-1.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 3df61a0dc94bef2e39d23aa04155695a4a39e56d73456191f36af70f6ea9ac77
MD5 1a669be5c110a77c7d8a91fe67fcc5f6
BLAKE2b-256 fa96360a00bedb169822463e8c9f311d129001986492ac9fff85409c6c2cb492

See more details on using hashes here.

Supported by

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