Giter Site home page Giter Site logo

carmenkow / cmsplugin-contact Goto Github PK

View Code? Open in Web Editor NEW

This project forked from maccesch/cmsplugin-contact

0.0 0.0 0.0 173 KB

Extendable contact plugin for django-cms with spam protection and i18n

License: BSD 2-Clause "Simplified" License

Python 95.60% HTML 4.40%

cmsplugin-contact's Introduction

Django CMS Contact Form Plugin

Contact form plugin for Django CMS with spam protection and i18n.

The message entered by the web user is turned into an email which is sent to the email address configured for the specific plugin instance.

Spam protection is provided by either ReCAPTCHA (free) or Akismet (free for personal use). Visit the respective website to obtain the keys required to activate the protection method of your choice.

Dependencies

Python Libs

If you decide to use the ReCAPTCHA spam protection method you need to install the python library django-nocaptcha-recaptcha

If you use Akismet for spam protection akismet is needed. You also need to set your domain url in django admin in the section "sites".

All libraries can be installed using pip.

It is recommended but not required to use South. Again it can be easily installed using pip.

Installation

Download

From PyPI

You can simply type into a terminal pip install cmsplugin-contact.

Manually

You can download a zip archive of the latest development version from GitHub. Unzip the file you downloaded. Then go in your terminal and cd into the unpacked folder. Then type python setup.py install in your terminal.

Setup

Put 'cmsplugin_contact' in your INSTALLED_APPS section in settings.py. Don't forget to syncdb your database or migrate if you're using South.

Put 'cmsplugin_contact.middleware.ForceResponseMiddleware' in your MIDDLEWARE_CLASSES section in settings.py.

Settings

DEFAULT_FROM_EMAIL

The email address that is used to send the message is picked up from DEFAULT_FROM_EMAIL Django setting. Additionally, the Reply-To: header is set to the user-supplied email address.

Sending the message using the user-supplied address to set From: header of the email is currently not supported. This is because many servers will reject emails that use From: addresses not registered with that server. Some servers may also strip the Reply-To: header. For this, the user-supplied email address is also added to the body of the message.

RECAPTCHA_PUBLIC_KEY and RECAPTCHA_PRIVATE_KEY

If you don't want to enter the ReCATPCHA keys in the admin interface you can provide them through these settings.

AKISMET_API_KEY

The same as for ReCAPTCHA goes fo Akismet.

CMSPLUGIN_CONTACT_FORMS

Default:

(
    ('cmsplugin_contact.forms.ContactForm', _('default')),
)

You can use your custom ContactForm, just add a new tuple with the class path and name pretty name to show for your user.

If you want to steal using the default ContactForm, do like this in your settings:

(
    ('cmsplugin_contact.forms.ContactForm', _('default')),
    ('my_app.forms.MyContactForm', _('My form')),
)

In your custom form, you can set what template you want to use, like this:

class MyContactForm(Form):
    ...
    template = 'path/to/my_contact_template.html'

Editors

The default editor is WYMEditor like in Django CMS. The plugin respects the USE_TINYMCE setting of Django CMS. Please see Django CMS docs for more information on how to use TinyMCE. If you have the package 'djangocms_text_ckeditor' in your INSTALLES_APPS CKEditor is used.

Extending

See examples/cmsplugin_custom_contact how to subclass cmsplugin_contact and add custom fields into it. You can override properties of the subclassed ContactPlugin and use your own templates and classes.

Signals

Email sent

After the contact email has been sent a signal is fired. You can use it like this:

from django.dispatch import receiver
from cmsplugin_contact.cms_plugins import email_sent


@receiver(email_sent)
def handle_signal(sender, **kwargs):
    print kwargs['data']

cmsplugin-contact's People

Contributors

maccesch avatar mitar avatar ebertti avatar lacrymology avatar m000 avatar genbit avatar okfish avatar yohanboniface avatar mactory avatar arkanister avatar xdml avatar d3ph avatar william-gr avatar tpresthus avatar stefanocrosta avatar rfleschenberg avatar masarliev avatar itbabu avatar julsam avatar gfavre avatar fsbraun avatar ikresoft avatar dylanncordel avatar dsh2dsh avatar bounder avatar atiberghien avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.