From e8e8c8ee7bd8190265026f7c530176aa78c96a24 Mon Sep 17 00:00:00 2001 From: makefu Date: Wed, 17 Feb 2016 03:12:09 +0100 Subject: [PATCH] ma 2 mycube: standalone version based on uwsgi what a motherf*ckn pain --- 2configs/deployment/mycube.connector.one.nix | 46 ++++++++++++++++++++ 2configs/nginx/mycube.connector.one.nix | 28 ------------ 2 files changed, 46 insertions(+), 28 deletions(-) create mode 100644 2configs/deployment/mycube.connector.one.nix delete mode 100644 2configs/nginx/mycube.connector.one.nix diff --git a/2configs/deployment/mycube.connector.one.nix b/2configs/deployment/mycube.connector.one.nix new file mode 100644 index 0000000..6a32656 --- /dev/null +++ b/2configs/deployment/mycube.connector.one.nix @@ -0,0 +1,46 @@ +{ config, lib, pkgs, ... }: +# more than just nginx config but not enough to become a module +with config.krebs.lib; +let + hostname = config.krebs.build.host.name; + external-ip = head config.krebs.build.host.nets.internet.addrs4; + wsgi-sock = "${config.services.uwsgi.runDir}/uwsgi.sock"; +in { + services.redis.enable = true; + services.uwsgi = { + enable = true; + user = "nginx"; + plugins = [ "python2" ]; + instance = { + type = "emperor"; + vassals = { + mycube-flask = { + type = "normal"; + python2Packages = self: with self; [ pkgs.mycube-flask self.flask self.redis self.werkzeug self.jinja2 self.markupsafe itsdangerous ]; + socket = wsgi-sock; + }; + }; + }; + }; + + krebs.nginx = { + enable = mkDefault true; + servers = { + mybox-connector-one = { + listen = [ "${external-ip}:80" ]; + server-names = [ + "mycube.connector.one" + "mybox.connector.one" + ]; + locations = singleton (nameValuePair "/" '' + uwsgi_pass unix://${wsgi-sock}; + uwsgi_param UWSGI_CHDIR ${pkgs.mycube-flask}/${pkgs.python.sitePackages}; + uwsgi_param UWSGI_MODULE mycube.websrv; + uwsgi_param UWSGI_CALLABLE app; + + include ${pkgs.nginx}/conf/uwsgi_params; + ''); + }; + }; + }; +} diff --git a/2configs/nginx/mycube.connector.one.nix b/2configs/nginx/mycube.connector.one.nix deleted file mode 100644 index 209c376..0000000 --- a/2configs/nginx/mycube.connector.one.nix +++ /dev/null @@ -1,28 +0,0 @@ -{ config, lib, pkgs, ... }: - -with config.krebs.lib; -let - hostname = config.krebs.build.host.name; - external-ip = head config.krebs.build.host.nets.internet.addrs4; -in { - services.redis.enable = true; - - krebs.nginx = { - enable = mkDefault true; - servers = { - mybox-connector-one = { - listen = [ "${external-ip}:80" ]; - server-names = [ - "mycube.connector.one" - "mybox.connector.one" - ]; - locations = singleton (nameValuePair "/" '' - proxy_set_header Host $host; - proxy_set_header X-Real-IP $remote_addr; - proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; - proxy_pass http://localhost:8001/; - ''); - }; - }; - }; -}