summaryrefslogtreecommitdiff
path: root/bin/taler-merchant-demos
blob: 9cc7516f2dc254c382a1406745eb66ab370ce890 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
#!/usr/bin/env python3

##
# This file is part of TALER
# (C) 2017 INRIA
#
# TALER is free software; you can redistribute it and/or
# modify it under the terms of the GNU Affero General Public
# License as published by the Free Software Foundation; either
# version 3, or (at your option) any later version.
#
# TALER is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty
# of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
# See the GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public
# License along with TALER; see the file COPYING.  If not,
# see <http://www.gnu.org/licenses/>
#
#  @author Florian Dold
#  @file Standalone script to run the blog.

import click
import logging
import argparse
import sys
import os
import site
from taler.util.talerconfig import TalerConfig

LOGGER = logging.getLogger(__name__)
# No perfect match to our logging format, but good enough ...
UWSGI_LOGFMT = "%(ltime) %(proto) %(method) %(uri) %(proto) => %(status)"

##
# This function interprets the 'serve-uwsgi' subcommand.
# The effect is to launch the blog UWSGI service.  This
# type of service is usually used when the HTTP blog interface
# is accessed via a reverse proxy (like Nginx, for example).
#
# @param command line options.
def handle_serve_uwsgi(config, whichShop):
    serve_uwsgi = config[whichShop]["uwsgi_serve"].value_string(required=True).lower()
    params = ["uwsgi", "uwsgi",
              "--master",
              "--die-on-term",
              "--log-format", UWSGI_LOGFMT,
              "--module", "talermerchantdemos.{}:app".format(whichShop),
              "--cache2", "name=paid_articles,items=500"]
    if serve_uwsgi == "tcp":
        port = config[whichShop]["uwsgi_port"].value_int(required=True)
        spec = ":%d" % (port,)
        params.extend(["--socket", spec])
    elif serve_uwsgi == "unix":
        spec = config[whichShop]["uwsgi_unixpath"].value_filename(required=True)
        mode = config[whichShop]["uwsgi_unixpath_mode"].value_filename(required=True)
        params.extend(["--socket", spec])
        params.extend(["--chmod-socket="+mode])
        os.makedirs(os.path.dirname(spec), exist_ok=True)
    logging.info("launching uwsgi with argv %s", params[1:])
    try:
        os.execlp(*params)
    except:
        sys.stderr.write("Failed to start uwsgi. Please make sure to install uwsgi for Python3.")
        sys.exit(1)

##
# This function interprets the 'serve-http' subcommand.
# The effect it to launch the blog HTTP service.
#
# @param args command line options.
def handle_serve_http(config, whichShop, port=None):
    if port is None:
        port = config[whichShop]["http_port"].value_int(required=True)
    spec = ":%d" % (port,)
    try:
        os.execlp("uwsgi", "uwsgi",
                  "--master",
                  "--die-on-term",
                  "--log-format", UWSGI_LOGFMT,
                  "--http", spec,
                  "--module", "talermerchantdemos.{}:app".format(whichShop))
    except:
        sys.stderr.write("Failed to start uwsgi. Please make sure to install uwsgi for Python3.")
        sys.exit(1)

@click.command("Global shop launcher")
@click.option("--config", help="Configuration file", required=False)
@click.option("--serve-http", help="Serve via HTTP", is_flag=True, required=False)
@click.option("--port", help="HTTP port to serve (if not given, it's picked from config)", required=False, type=int)
@click.option("--serve-uwsgi", help="Serve via UWSGI (default)", required=False)
@click.argument("which-shop")
def demos(config, serve_http, port, serve_uwsgi, which_shop):
    """
    WHICHSHOP is one of: blog, donations, or survey.
    """
    if config:
        os.environ["TALER_CONFIG_FILE"] = config
    config_obj = TalerConfig.from_file(os.environ.get("TALER_CONFIG_FILE"))
    if serve_http: # port was given
        handle_serve_http(config_obj, which_shop, port)
    else:
        handle_serve_uwsgi(config_obj, which_shop)

demos()