Skip to content

Latest commit

 

History

History
161 lines (116 loc) · 3.66 KB

README.md

File metadata and controls

161 lines (116 loc) · 3.66 KB

Paper-Hub

An easy way to read and share papers for scientific research

Quick Start

  1. Prepare virtual environment (venv):

    python -m venv .venv
    . .venv/bin/activate
    pip install -U -r requirements.txt
  2. Prepare static files:

    python manage.py collectstatic
  3. Establish database

    python manage.py migrate
  4. Run Server

    python manage.py runserver

Run on Apache HTTP Server

  1. Configure Apache (take '/var/www/paper-hub.cn/' as example):

    WSGIApplicationGroup %{GLOBAL}
    WSGIDaemonProcess paperhub python-home=/var/www/paper-hub.cn/.venv python-path=/var/www/paper-hub.cn
    WSGIProcessGroup paperhub
    WSGIScriptAlias / /var/www/paper-hub.cn/mysite/wsgi.py
    WSGIPassAuthorization On
    <Directory /var/www/paper-hub.cn/mysite/>
        <Files wsgi.py>
            Require all granted
        </Files>
    </Directory>
    Alias /static /var/www/paper-hub.cn/static_root
    <Directory /var/www/paper-hub.cn/static_root/>
        Options -Indexes
        Require all granted
    </Directory>
  2. Configure server side for mini program

    $ cat .env
    OPENAI_API_KEY=sk-xxxxxx
    OPENAI_PROXY_URL=xxxxxx
    
    WX_APP_ID=wxxxxx
    WX_SECRET=xxxxxx
    WX_DEBUG=False
    
    WEB_APP_ID=wxxxxx
    WEB_APP_SECRET=xxxxxx
    WEB_DOMAIN=paper-hub.cn
    
    AZURE_KEY=xxxxxx
    AZURE_ENDPOINT=https://api.cognitive.microsofttranslator.com
    AZURE_LOCATION=eastus
    AZURE_PATH=/translate
    
    PUBMED_DIR=/path/to/pubmed/
    
    DB_NAME=xxxx
    DB_USER=xxxx
    DB_PASSWORD=xxxx
    DB_HOST=xxxx
    
    DEV_DB_NAME=xxxx
    DEV_DB_USER=xxxx
    DEV_DB_PASSWORD=xxxx
    DEV_DB_HOST=xxxx
    
    LOCAL_DB_NAME=xxxx
    LOCAL_DB_USER=xxxx
    LOCAL_DB_PASSWORD=xxxx
    LOCAL_DB_HOST=xxxx
    
    DJANGO_ENV=production # production / development / local / sqlite

How to setup a development environment (Optional)

  1. Start Django application locally.

    # run this command in a separated terminal
    . .venv/bin/activate
    python manage.py runserver
  2. Use SSH start to reverse tunnel (take 'paper-hub.cn' as an example).

    # run this command in another new terminal
    ssh -nNT -R *:8000:localhost:8000 paper-hub.cn

    This will map 8000 port on remote server to 8000 port on local machine.

    On remote server, /etc/ssh/sshd_config should set the option:

    GatewayPorts yes
  3. Configure Apache on remote server.

    <VirtualHost *:8443>
        ...
        SSLEngine on
        SSLCertificateFile /path/to/.../fullchain.pem
        SSLCertificateKeyFile /path/to/.../privkey.pem
    
        ProxyPass / http://127.0.0.1:8000/
        ProxyPassReverse / http://127.0.0.1:8000/
        ...
    </VirtualHost>
    </IfModule>

    This will open 8443 port as https server, and map the request/response to 8000 on remote server.

  4. After all these, port 8443 on the remote server could be accessed as https://paper-hub.cn:8443/, which could be set as a safe domain in Mini Program development.

FAQ

  1. Q: How do I configure a SOCKS5 proxy server when installing packages with pip?

    A: Before calling pip install, define the environment variable ALL_PROXY:

    export ALL_PROXY=socks5://xxx.xxx.xxx.xxx:1090
  2. Q: What should I do if I encounter the following error during installation:

    ERROR: Could not install packages due to an OSError: Missing dependencies for SOCKS support.
    

    A: You need to remove the proxy configuration first, install the PySocks package, and then use the proxy again:

    pip install PySocks