|Pinry| ======= The open-source core of Pinry, a tiling image board system for people who want to save, tag, and share images, videos and webpages in an easy to skim through format. For more information visit `getpinry.com`_. Feature ----------------- - Image fetch and online preview - Tagging system for Pin - Browser Extension: `Chrome `_ and `Firefox `_ - multi-user support - Both public and private is supported Setup Guide for users -------------------------- Please use docker to install `pinry `_ Developers or users who are familiar with python/nginx could setup Pinry with following guide : ) Quick Start for Developers ---------------------------- You need only three following lines to initialize your pinry:: make bootstrap make serve Now the development server has been running, enjoy : ) Upgrade from old version -------------------------- Our currently version is 2.x, If you are old user of Pinry, please follow document below to upgrade to 2.x. For source code users: Read our `online doc `_ about how to upgrade to 2.x For docker users, please contact us for help: ) Requirements ------------ Pinry is built on top of Django and optimized to run on a Linux environment. However we have gotten Pinry to work on Windows and Mac as well but it may require some extra digging around configuration. Pinry's Python requirements are all in the ``Pipfile`` file. You can easily install these using pipenv, to get pipenv, if you already have Python and pip, run python ``pip install pipenv``. Testing ------- We have many tests built into Pinry to ensure that changes don't break anything. If you are live dangerously and have cutting edge new Pinry features first you can use our master branch for your own instance. We recommend using our tags/versions though. To run Pinry's tests inside the Pinry repo run:: pipenv install --dev --three pipenv run python manage.py test Docker ------ Follow the steps below to install Pinry locally or on any server. This process installs the minimal requirements to run Pinry. For development requirements and procedures, see testing above. Current docker configuration will just mount source code directory to docker app directory and run any codes existed in current git branch, you may also add "local_settings.py" to customize settings without changing settings file in `pinry/settings`. - Install the requirements: - Docker - Docker Compose - Set any custom configuration options you need and run:: cp docker-compose.example.yml docker-compose.yml # edit docker-compose.yml and change the secret-key, # don't forget to backup this config file. docker-compose up -d - If you want to run Pinry with current user in docker:: ./start_docker_with_current_user.sh [-d] - Bootstrap the database(optional):: docker-compose exec web python3 manage.py migrate --settings=pinry.settings.docker **Note** : No static file server configured, your should configure nginx or other server to serve static files from ./static Linting ------- So everything isn't a mess:: pipenv run flake8 --exclude=migrations Contributors ------------ The core contributors for Pinry have been/currently are: * Isaac Bythewood * Krzysztof Klimonda * Lapo Luchini * Ji Qu For a full list of contributors check out the `GitHub Contributors Graph`_. .. Links .. |Pinry| image:: https://raw.github.com/pinry/pinry/master/logo.png .. _getpinry.com: http://getpinry.com/ .. _docker-pinry GitHub repository: https://github.com/pinry/docker-pinry .. _GitHub Contributors Graph: https://github.com/pinry/pinry/graphs/contributors