Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

django-apollo-forms

Package Overview
Dependencies
Maintainers
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

django-apollo-forms

Simple CMS for forms

  • 2.2.0
  • PyPI
  • Socket score

Maintainers
1

What Apollo Is

At Morgan & Morgan, the development team builds lots of forms. A lot. While most of the heavy lifting for form management was done for us by the marketing platform, Hubspot, there were some major gaps that forced us to consider a switch:

  1. Cost. Our Hubspot license was > $50,000 yearly where the only utility came from the form management tooling.
  2. Lack of flexibility. While defining basic validation rules and field layouts was OK, doing anything more complex (e.g. email blacklists, geo-based submission filtering, etc.) was impossible. In fact, since their switch to React rendered forms, custom validation in a Hubspot form doesn't work at all.
  3. Lack of control. The Hubspot JS library is 300kb+ in size before gzip and sets short-term cache expiration headers. Why? It's hard to say without access to the unminified source.
    more than 300kb
  4. Lack of transparency. Hubspot provides Salesforce syncing out of the box. However, having a highly customized Salesforce Org, our Hubspot sync process was anything but straightforward.

With these problems in mind, we built Apollo as a solution.

Apollo is a Django application which - in conjunction with the Icarus Javascript Library - aims to act as a plug-and-play solution for the busy engineer. In addition to providing a management interface for building form fields, designing forms, and viewing form submissions, Apollo makes the assumption that it should make no assumptions about domain specific requirements of the host application. Thus, it decouples form management from submission processing, leaving the job of reacting to events within the host. To facilitate this architecture, Apollo opts for a Pub/Sub design, notifying listeners on key events:

  • form submitted
  • form submission validated
  • form submission error

See more details on signals in the signals reference

Why Apollo

  1. It is - and always will be - free and open source
  2. Plug-and-play architecture
  3. Utility in a wide variety of use case
  4. Integration with native Django permissions, allowing for role assignment when delegating API / form builder access.

Installation

pip install django-apollo-forms

# add the App to the list of INSTALLED_APPS
INSTALLED_APPS = {
  ...  
  'django_filters',
  'rest_framework',
  'rest_framework_swagger', # optional, creates browsable API docs
  'apollo',
  ...
}

# run the migrations to generate DB tables
python manage.py makemigrations apollo
python manage.py migrate apollo

# collectstatic to generate the static files for the form builder interface
python manage.py collectstatic

Customization

You can customize the behavior of Apollo by overriding the defaults of the APOLLO variable in your settings.py. Below are the parameters which may be controlled in this setting.

ParameterDefaultDescription
BUILDER_ROOT_PREFIX""The path at which the Apollo form builder is mounted in the host application
BUILDER_REQUIRES_IS_STAFFTrueIf True, then only users with is_staff permissions can access the form builder
DOWNLOAD_REQUIRES_IS_STAFFTrueIf True, then only users with is_staff permissions can download form submissions
API_ROOT/apiThe path to the API root on the server
API_VERSIONv1The Apollo API version
ICARUS_THEMES_URL//static.forthepeople.com/engineering/icarus/v1.0-latest/themesLocation where icarus themes are located
SUBMISSION_EMAIL_FROMNoneEmail address to send submission notifications from
EXTERNAL_HOOKS_SIGNAL_ONLYTrueIf True, then we we do not send webhooks notifications, only trigger a signal
DEFAULT_FORM_SUBMISSION_SERIALIZERapollo.api.v1.serializers.FormSubmissionSerializerDotted path to a serializer class to use for FormSubmission objects

Example

APOLLO = {
    "BUILDER_ROOT_PREFIX": "/apollo"
}

Features

Setup field templates for your forms. These define the default configurations for fields and can be overridden on a per-form basis.


Step-by-step form builder interface.


Powerful layout creator with the ability to apply different layouts for desktop and mobile screens.


Form Usage

When it comes to actually using the forms built by Apollo, you have two options:

  1. Use the Icarus Javascript Library (Recommended)
  2. DIY.

If you decide to pursue (2), you'll want to consult the Browsable API, mounted at /<API_ROOT>/<API_VERSION>/docs for details on authentication, request format, and available resources.

Development

Getting Started

Bringing up a new dev environment should be fairly straightforward. Run docker-compose up -d to bring up a complete development environment.

Building Releases

Create a virtualenv then run pip install -r requirements.txt in order to install versioning utilities. Run bumpversion <SEMVER> to create a buildable version then push upstream to trigger CI.

FAQs


Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc