view docker/salut/Dockerfile @ 63:63abd824508c

schemas: added "architecture" section with "sat_simplified_overview" schema
author Goffi <goffi@goffi.org>
date Mon, 09 Nov 2015 12:29:38 +0100
parents 0e78c8a4626e
children 686a8c982c3f
line wrap: on
line source

###############################################################
#                                                             #
#                      Salut à Toi/salut                      #
#  This Dockerfile build a Salut directory prepared for SàT   #
# Salut à Toi is a multi-frontends multi-purposes XMPP client #
#                                                             #
###############################################################

FROM salutatoi/base:latest

MAINTAINER Goffi <goffi@goffi.org>

########
# BASE #
########

RUN apt-get clean

# This script launch Salut with domain and secret gotten from prosody container
# it make the configuration more easy
RUN echo '#!/usr/bin/env python2\n\
import os, xmlrpclib\n\
SALUT_PATH="/usr/share/sat_salut/"\n\
os.chdir("/home/sat")\n\
proxy = xmlrpclib.ServerProxy("http://prosody:9999/")\n\
for var in ("DOMAIN", "SAT_SALUT_SECRET"):\n\
    os.environ[var] = proxy.getenv(var)\n\
os.environ["PYTHONPATH"] = SALUT_PATH\n\
os.execlp("twistd", "twistd", "-ny", SALUT_PATH+"salut.tac")\n\
' > /usr/local/bin/salut && chmod 0555 /usr/local/bin/salut

WORKDIR /usr/share

RUN hg clone http://repos.goffi.org/salut sat_salut && chown -R sat:sat sat_salut

WORKDIR sat_salut

USER sat

# configuration is really basic in salut, we just use environment to set data
RUN sed -i 's/^xmppcomponent =.*$/import os\nxmppcomponent = Component("prosody", 5347, "salut."+os.getenv("DOMAIN"), os.getenv("SAT_SALUT_SECRET"))/' salut.tac

##########
# LAUNCH #
##########

ENTRYPOINT ["salut"]