Skip to content

Latest commit

 

History

History
108 lines (84 loc) · 3.98 KB

README.md

File metadata and controls

108 lines (84 loc) · 3.98 KB

geodjango-project-template

A template for a Django project. It's simply project that was created with django 1.6.2 project with a lot of tweaks, usually things that we, at Magnet.cl do in all projects.

Requirements

  • Python 2.7: This project was tested using python 2.7
  • Node: This project uses node for bower, less and jade.

Get the code

Create a new repository in github for your django project. Clone your repository into your computer. Add the django-project-template github repo as a remote repository:

  • git remote add template git@github.com:magnet-cl/django-project-template.git Pull the code from the project template
  • git pull template master (there may be conflicts with your README.md file, fix them and continue) Push to your own repo
  • git push origin master Now you have your own django project in your repository

Quickstart

After you obtain the code, run the quick start script. It should install all the dependencies you need to start the project. Then you need to Configure your database settings in the project/local_settings.py file.

  • ./quickstart.sh

You can reset the database (drop if created, create, sync and load fixtures) with:

  • ./reset.sh

Basic Sturcture

Base:

Base is the first application of this project. It's function is to provide the base for all other apps in your project. This is the place where you put abstract model classes that are used throughout your project.

  • Custom models:

    • BaseModel: An abstract django model that all your models should inherit from. Contains the following methods
      • update(self, *kwargs): updates in the database the fields you pass in the keyword arguments
      • to_dict(self, fields=None, exclude=None): using the calling django object, this method returns a dict with the model attributes. If the fields parameter is passed, only the specified attributes are included in the dict. By the contrary, if the exclude parameter is passed, then the excluded attributes will not be return in the dict.
  • Fixtures: Fixtures with an admin user

  • Admin: A basic configuration for the admin

Users:

* User: Custom user model that inherits form
  django.contrib.auth.models.User. This enables easy customization like
  adding new fieds or new methods. 
   * Simple email system to send templated emails.
   * Custom Backend for email authentication instead of username
     authentication

Features

Bootstrap 3 integration

Since We have been using bootstrap 3 for all our projects, we made that all templates in the project are written for bootstrap 3.

Also, the project compiles the source code for bootstrap 3 from less. This is done so a rapid customization can be made of your site's style. The source code for less is in base/static/css/bootstrap/

Bootstrap 3 admin

bootstrap-admin==0.3.0 Since We have been using bootstrap 3 for all our project, we made that all templates in the project are written for bootstrap 3.

  • bootstrap admin
  • captcha login
  • bower integration

Fabric

It includes basic fabric tasks. These tasks are described later.

Fabric tasks

In order to use fabric to deploy a gunicorn+nginx configuration you must set the following variables at fabfile/config.py:

  • env.server_root_dir: Remote path of deployment.
  • env.server_git_url: Your git repository.
  • env.server_domain: Server domain of target server. (optional)
  • env.hosts: Default host used by fabric. (optional)

and add a private ssh key file (id_rsa) to fabfile/templates named ssh_key. This file will be put in the remote server as the default ssh key for the remote user.

To get a list of the available tasks run: fab -l.

Make sure to run the following task before any other task in any of the these formats:

  • fab config.set_host: Uses the host specified in env.hosts and magnet as user.
  • fab config.set_host:examplehost: Manually specify host.
  • fab config.set_host:examplehost,user: Manually specify host and user.