[ADD]Framasoft Docker images for MyPads : Postgre94 and Etherpad
This commit is contained in:
commit
2c7f524904
16
framasoft/README.md
Normal file
16
framasoft/README.md
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
# Framasoft : etherpad + mypads && PG database
|
||||||
|
|
||||||
|
## Etherpad
|
||||||
|
|
||||||
|
Own Docker file approved (misses some plugins but not a real problem)
|
||||||
|
+ ATM static mypads settings.json
|
||||||
|
|
||||||
|
TODO: use ENV var to generate settings.json
|
||||||
|
|
||||||
|
## PG95
|
||||||
|
|
||||||
|
* Direct barman export ok
|
||||||
|
* Just need to replace .conf files from offocial docker image
|
||||||
|
* postgresql.conf
|
||||||
|
* pg_hba.conf
|
||||||
|
* pg_ident.conf
|
9
framasoft/framapg/Dockerfile
Normal file
9
framasoft/framapg/Dockerfile
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
# Stable version of etherpad doesn't support npm 2
|
||||||
|
FROM postgres:9.4
|
||||||
|
MAINTAINER Fabien Bourgeois <fabien@yaltik.com>
|
||||||
|
|
||||||
|
RUN chown -R postgres:postgres /var/lib/postgresql/data
|
||||||
|
RUN localedef -i de_DE -c -f UTF-8 -A /usr/share/locale/locale.alias fr_FR.UTF-8
|
||||||
|
ENV LANG fr_FR.utf8
|
||||||
|
|
||||||
|
EXPOSE 5432
|
30
framasoft/frametherpad/Dockerfile
Normal file
30
framasoft/frametherpad/Dockerfile
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
# Stable version of etherpad doesn't support npm 2
|
||||||
|
FROM debian:jessie
|
||||||
|
MAINTAINER Fabien Bourgeois <fabien@yaltik.com>
|
||||||
|
|
||||||
|
RUN apt-get update
|
||||||
|
RUN apt-get install -y --no-install-recommends \
|
||||||
|
gzip git curl python libssl-dev pkg-config build-essential unzip \
|
||||||
|
nodejs-legacy npm postgresql-client-9.4
|
||||||
|
RUN rm -r /var/lib/apt/lists/*
|
||||||
|
|
||||||
|
WORKDIR /opt/
|
||||||
|
|
||||||
|
ENV ETHERPAD_VERSION 1.5.7
|
||||||
|
|
||||||
|
RUN curl -SL \
|
||||||
|
https://github.com/ether/etherpad-lite/archive/${ETHERPAD_VERSION}.zip \
|
||||||
|
> etherpad.zip && unzip etherpad && rm etherpad.zip && \
|
||||||
|
mv etherpad-lite-${ETHERPAD_VERSION} etherpad-lite
|
||||||
|
|
||||||
|
WORKDIR etherpad-lite
|
||||||
|
|
||||||
|
RUN bin/installDeps.sh
|
||||||
|
RUN sed -i 's/^node/exec\ node/' bin/run.sh
|
||||||
|
RUN npm install ep_mypads
|
||||||
|
|
||||||
|
# VOLUME /opt/etherpad-lite/var
|
||||||
|
COPY settings.json settings.json
|
||||||
|
|
||||||
|
EXPOSE 9001
|
||||||
|
CMD ["bin/run.sh", "--root"]
|
216
framasoft/frametherpad/settings.json
Normal file
216
framasoft/frametherpad/settings.json
Normal file
@ -0,0 +1,216 @@
|
|||||||
|
/*
|
||||||
|
This file must be valid JSON. But comments are allowed
|
||||||
|
|
||||||
|
Please edit settings.json, not settings.json.template
|
||||||
|
|
||||||
|
To still commit settings without credentials you can
|
||||||
|
store any credential settings in credentials.json
|
||||||
|
*/
|
||||||
|
{
|
||||||
|
// Name your instance!
|
||||||
|
"title": "Etherpad",
|
||||||
|
|
||||||
|
// favicon default name
|
||||||
|
// alternatively, set up a fully specified Url to your own favicon
|
||||||
|
"favicon": "favicon.ico",
|
||||||
|
|
||||||
|
//IP and port which etherpad should bind at
|
||||||
|
"ip": "0.0.0.0",
|
||||||
|
"port" : 9001,
|
||||||
|
|
||||||
|
// Option to hide/show the settings.json in admin page, default option is set to true
|
||||||
|
"showSettingsInAdminPage" : true,
|
||||||
|
|
||||||
|
/*
|
||||||
|
// Node native SSL support
|
||||||
|
// this is disabled by default
|
||||||
|
//
|
||||||
|
// make sure to have the minimum and correct file access permissions set
|
||||||
|
// so that the Etherpad server can access them
|
||||||
|
|
||||||
|
"ssl" : {
|
||||||
|
"key" : "/path-to-your/epl-server.key",
|
||||||
|
"cert" : "/path-to-your/epl-server.crt",
|
||||||
|
"ca": ["/path-to-your/epl-intermediate-cert1.crt", "/path-to-your/epl-intermediate-cert2.crt"]
|
||||||
|
},
|
||||||
|
|
||||||
|
*/
|
||||||
|
|
||||||
|
//The Type of the database. You can choose between dirty, postgres, sqlite and mysql
|
||||||
|
//You shouldn't use "dirty" for for anything else than testing or development
|
||||||
|
//"dbType" : "dirty",
|
||||||
|
//"dbSettings" : { "filename" : "var/dirty.db" },
|
||||||
|
|
||||||
|
/* An Example of MySQL Configuration
|
||||||
|
"dbType" : "mysql",
|
||||||
|
"dbSettings" : {
|
||||||
|
"user" : "root",
|
||||||
|
"host" : "localhost",
|
||||||
|
"password": "",
|
||||||
|
"database": "store",
|
||||||
|
"charset" : "utf8mb4"
|
||||||
|
},
|
||||||
|
*/
|
||||||
|
"dbType" : "postgres",
|
||||||
|
"dbSettings" : {
|
||||||
|
"user" : "mypads",
|
||||||
|
"host" : "framapg",
|
||||||
|
"password": "1njohpqmcZ+mimtyMkn5",
|
||||||
|
"database": "mypads",
|
||||||
|
"port" : 5432
|
||||||
|
},
|
||||||
|
|
||||||
|
//the default text of a pad
|
||||||
|
"defaultPadText" : "Welcome to Etherpad!\n\nThis pad text is synchronized as you type, so that everyone viewing this page sees the same text. This allows you to collaborate seamlessly on documents!\n\nGet involved with Etherpad at http:\/\/etherpad.org\n",
|
||||||
|
|
||||||
|
/* Default Pad behavior, users can override by changing */
|
||||||
|
"padOptions": {
|
||||||
|
"noColors": false,
|
||||||
|
"showControls": true,
|
||||||
|
"showChat": true,
|
||||||
|
"showLineNumbers": true,
|
||||||
|
"useMonospaceFont": false,
|
||||||
|
"userName": false,
|
||||||
|
"userColor": false,
|
||||||
|
"rtl": false,
|
||||||
|
"alwaysShowChat": false,
|
||||||
|
"chatAndUsers": false,
|
||||||
|
"lang": "en-gb"
|
||||||
|
},
|
||||||
|
|
||||||
|
/* Should we suppress errors from being visible in the default Pad Text? */
|
||||||
|
"suppressErrorsInPadText" : false,
|
||||||
|
|
||||||
|
/* Users must have a session to access pads. This effectively allows only group pads to be accessed. */
|
||||||
|
"requireSession" : false,
|
||||||
|
|
||||||
|
/* Users may edit pads but not create new ones. Pad creation is only via the API. This applies both to group pads and regular pads. */
|
||||||
|
"editOnly" : false,
|
||||||
|
|
||||||
|
/* Users, who have a valid session, automatically get granted access to password protected pads */
|
||||||
|
"sessionNoPassword" : false,
|
||||||
|
|
||||||
|
/* if true, all css & js will be minified before sending to the client. This will improve the loading performance massivly,
|
||||||
|
but makes it impossible to debug the javascript/css */
|
||||||
|
"minify" : true,
|
||||||
|
|
||||||
|
/* How long may clients use served javascript code (in seconds)? Without versioning this
|
||||||
|
may cause problems during deployment. Set to 0 to disable caching */
|
||||||
|
"maxAge" : 21600, // 60 * 60 * 6 = 6 hours
|
||||||
|
|
||||||
|
/* This is the absolute path to the Abiword executable. Setting it to null, disables abiword.
|
||||||
|
Abiword is needed to advanced import/export features of pads*/
|
||||||
|
"abiword" : null,
|
||||||
|
|
||||||
|
/* This is the absolute path to the soffice executable. Setting it to null, disables LibreOffice exporting.
|
||||||
|
LibreOffice can be used in lieu of Abiword to export pads */
|
||||||
|
"soffice" : null,
|
||||||
|
|
||||||
|
/* This is the path to the Tidy executable. Setting it to null, disables Tidy.
|
||||||
|
Tidy is used to improve the quality of exported pads*/
|
||||||
|
"tidyHtml" : null,
|
||||||
|
|
||||||
|
/* Allow import of file types other than the supported types: txt, doc, docx, rtf, odt, html & htm */
|
||||||
|
"allowUnknownFileEnds" : true,
|
||||||
|
|
||||||
|
/* This setting is used if you require authentication of all users.
|
||||||
|
Note: /admin always requires authentication. */
|
||||||
|
"requireAuthentication" : false,
|
||||||
|
|
||||||
|
/* Require authorization by a module, or a user with is_admin set, see below. */
|
||||||
|
"requireAuthorization" : false,
|
||||||
|
|
||||||
|
/*when you use NginX or another proxy/ load-balancer set this to true*/
|
||||||
|
"trustProxy" : false,
|
||||||
|
|
||||||
|
/* Privacy: disable IP logging */
|
||||||
|
"disableIPlogging" : false,
|
||||||
|
|
||||||
|
/* Users for basic authentication. is_admin = true gives access to /admin.
|
||||||
|
If you do not uncomment this, /admin will not be available! */
|
||||||
|
"users": {
|
||||||
|
"admin": {
|
||||||
|
"password": "changeme1",
|
||||||
|
"is_admin": true
|
||||||
|
},
|
||||||
|
"user": {
|
||||||
|
"password": "changeme1",
|
||||||
|
"is_admin": false
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
// restrict socket.io transport methods
|
||||||
|
"socketTransportProtocols" : ["xhr-polling", "jsonp-polling", "htmlfile"],
|
||||||
|
|
||||||
|
// Allow Load Testing tools to hit the Etherpad Instance. Warning this will disable security on the instance.
|
||||||
|
"loadTest": false,
|
||||||
|
|
||||||
|
// Disable indentation on new line when previous line ends with some special chars (':', '[', '(', '{')
|
||||||
|
/*
|
||||||
|
"indentationOnNewLine": false,
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* The toolbar buttons configuration.
|
||||||
|
"toolbar": {
|
||||||
|
"left": [
|
||||||
|
["bold", "italic", "underline", "strikethrough"],
|
||||||
|
["orderedlist", "unorderedlist", "indent", "outdent"],
|
||||||
|
["undo", "redo"],
|
||||||
|
["clearauthorship"]
|
||||||
|
],
|
||||||
|
"right": [
|
||||||
|
["importexport", "timeslider", "savedrevision"],
|
||||||
|
["settings", "embed"],
|
||||||
|
["showusers"]
|
||||||
|
],
|
||||||
|
"timeslider": [
|
||||||
|
["timeslider_export", "timeslider_returnToPad"]
|
||||||
|
]
|
||||||
|
},
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* The log level we are using, can be: DEBUG, INFO, WARN, ERROR */
|
||||||
|
"loglevel": "INFO",
|
||||||
|
|
||||||
|
//Logging configuration. See log4js documentation for further information
|
||||||
|
// https://github.com/nomiddlename/log4js-node
|
||||||
|
// You can add as many appenders as you want here:
|
||||||
|
"logconfig" :
|
||||||
|
{ "appenders": [
|
||||||
|
{ "type": "console"
|
||||||
|
//, "category": "access"// only logs pad access
|
||||||
|
}
|
||||||
|
/*
|
||||||
|
, { "type": "file"
|
||||||
|
, "filename": "your-log-file-here.log"
|
||||||
|
, "maxLogSize": 1024
|
||||||
|
, "backups": 3 // how many log files there're gonna be at max
|
||||||
|
//, "category": "test" // only log a specific category
|
||||||
|
}*/
|
||||||
|
/*
|
||||||
|
, { "type": "logLevelFilter"
|
||||||
|
, "level": "warn" // filters out all log messages that have a lower level than "error"
|
||||||
|
, "appender":
|
||||||
|
{ Use whatever appender you want here }
|
||||||
|
}*/
|
||||||
|
/*
|
||||||
|
, { "type": "logLevelFilter"
|
||||||
|
, "level": "error" // filters out all log messages that have a lower level than "error"
|
||||||
|
, "appender":
|
||||||
|
{ "type": "smtp"
|
||||||
|
, "subject": "An error occured in your EPL instance!"
|
||||||
|
, "recipients": "bar@blurdybloop.com, baz@blurdybloop.com"
|
||||||
|
, "sendInterval": 300 // 60 * 5 = 5 minutes -- will buffer log messages; set to 0 to send a mail for every message
|
||||||
|
, "transport": "SMTP", "SMTP": { // see https://github.com/andris9/Nodemailer#possible-transport-methods
|
||||||
|
"host": "smtp.example.com", "port": 465,
|
||||||
|
"secureConnection": true,
|
||||||
|
"auth": {
|
||||||
|
"user": "foo@example.com",
|
||||||
|
"pass": "bar_foo"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}*/
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user