Skip to content

Latest commit

 

History

History
158 lines (109 loc) · 4.21 KB

README.md

File metadata and controls

158 lines (109 loc) · 4.21 KB

notaliens.com

A website for show casing pyramid powered sites and the hackers that use it!

The site is a combination of these namespaced packages: - notaliens.core: Shared templates, assets, and base classes - notaliens.identity: Authentication and Sessions - notaliens.people: The section of the site that manages the list of Pyramid developers and their user profiles - notaliens.sites: The section of the site dedicated to managing the list of Pyramid powered websites - notaliens.jobs: The section of the website dedicated to posting and searching for Pyramid jobs

We are written with Python 3.3 and Python 2.7 in mind.

Features

We should have a mix of features that are similar to http://djangosites.org and http://people.djangoproject.com/

People

  • Developers should be able to register accounts, list their basic profile information such as github, twitter, and linked in, along with their location and if they are looking for work. They should also be able to tag themselves for what type of technology they work with.

Sites

  • Registered users should be able to add 'sites' that are powered by Pyramid. This will include adding screenshots, tags for type of site, URL, should have stats about backend db (pgsql, redis, etc), what server is used (nginx, gunicorn), OS, and released version. What spoken language it is in.

Jobs

  • This will be for people to post up jobs that are pyramid related

Getting Started

$ easy_install -U setuptools
$ python bootstrap.py

Before running buildout, you need to make sure you have postgresql installed.

Fedora

$ sudo yum install postgresql-server postgresql-devel
$ sudo su - postgres
$ initdb
$ exit
$ sudo systemctl start postgresql.service

Ubuntu

$ sudo apt-get install postgresql libpq-dev python-dev
$ sudo apt-get install libtiff4-dev libjpeg8-dev zlib1g-dev libfreetype6-dev liblcms1-dev libwebp-dev

Finally

$ sudo su - postgres
$ createuser notaliens -P
$ createdb notaliens -O notaliens
$ exit
$ mkvirtualenv notaliens
$ cdvirtualenv
$ mkdir src
$ cd src
$ git clone [email protected]:sontek/notaliens.com.git
$ cd notaliens.com
$ pip install -e .
$ notaliens_update_geoip development.ini
$ notaliens_create_db development.ini
$ notaliens_update_geoip_csv development.ini
$ notaliens_rebuild_index development.ini

Running the application server:

$ bin/pserve notaliens/development.ini

Running the task queue worker:

$ bin/notaliens_task_queue notaliens/development.ini

We also have support for caching SQL queries via redis and using elasticsearch for full text search, so use your distro to install those if you would like to take advantage of those features.

You will notice on the view timings that we are running at about 30-40ms per view, this is not an accurate number because we enable the debugtoolbar by default.

With the toolbar off we average around 10-15ms per view request.

Elastic Search

To test the elastic search:

Profile Schema:

curl -XGET 'http://127.0.0.1:9200/users/_mapping?pretty=1'

All profiles:

curl -XGET 'http://127.0.0.1:9200/users/_search?pretty=1'

Filter Profile:

curl -XGET 'http://127.0.0.1:9200/users/user/_search?q=first_name:john&pretty=1'

Or for more advanced querying:

curl -XPOST 'http://127.0.0.1:9200/usres/user/_search?pretty=true' -d'
{
    "query":{
        "term" : {
            "first_name" :"john"
        }   
    }
}
'

For geo location queries:

curl -XPOST 'http://127.0.0.1:9200/users/user/_search?pretty=true' -d'
{
    "query": {
        "filtered" : {
            "filter" : {
                "geo_distance" : {
                    "distance" : "12km",
                    "location" : {
                        "lat" : 37.4644,
                        "lon" : -122.2267
                    }
                }
            }
        }
    }
}
'

Hacking

To run our tests you can do:

$ bin/py.test notaliens/tests

To get code coverage:

$ bin/py.test --cov-report term-missing --cov notaliens