diff --git a/gogs/.gitignore b/gogs/.gitignore new file mode 100644 index 0000000..3af0ccb --- /dev/null +++ b/gogs/.gitignore @@ -0,0 +1 @@ +/data diff --git a/gogs/Dockerfile b/gogs/Dockerfile new file mode 100644 index 0000000..e57181c --- /dev/null +++ b/gogs/Dockerfile @@ -0,0 +1,21 @@ +FROM flitter/init + +RUN apt-get update && apt-get install -y openssh-server sqlite3 libsqlite3-0 git wget unzip +RUN mkdir /gogs && cd /gogs && mkdir dl && cd dl + +RUN wget http://gogs.dn.qbox.me/gogs_v0.5.11_linux_amd64.zip -O /gogs/dl/gogs.zip +RUN cd /gogs && unzip /gogs/dl/gogs.zip && mv gogs install + +RUN mkdir /gogs/data/repos -p && useradd git --create-home && echo 'git:user' | chpasswd && chown -R git /gogs/data && chmod 777 /gogs/data/repos + +RUN mkdir -p /var/run/sshd + +ADD runit/ /etc/service +ADD gogs/ /gogs/install + +RUN chown -R git /gogs/install + +EXPOSE 3000 +EXPOSE 22 + +CMD /sbin/my_init diff --git a/gogs/Makefile b/gogs/Makefile new file mode 100644 index 0000000..1729c21 --- /dev/null +++ b/gogs/Makefile @@ -0,0 +1,5 @@ +build: + docker build -t gogs . + +run: + docker run --rm -it -v `pwd`/data:/gogs/data gogs diff --git a/gogs/README.markdown b/gogs/README.markdown new file mode 100644 index 0000000..38dfac0 --- /dev/null +++ b/gogs/README.markdown @@ -0,0 +1 @@ +# Gogs in Docker diff --git a/gogs/gogs/custom/conf/app.ini b/gogs/gogs/custom/conf/app.ini new file mode 100644 index 0000000..4ba3c56 --- /dev/null +++ b/gogs/gogs/custom/conf/app.ini @@ -0,0 +1,272 @@ +; App name that shows on every page title +APP_NAME = Gogs: Go Git Service +; Change it if you run locally +RUN_USER = git +; Either "dev", "prod" or "test", default is "dev" +RUN_MODE = dev + +[repository] +ROOT = /gogs/data/repos +SCRIPT_TYPE = bash + +[server] +PROTOCOL = http +DOMAIN = localhost +ROOT_URL = %(PROTOCOL)s://%(DOMAIN)s:%(HTTP_PORT)s/ +HTTP_ADDR = +HTTP_PORT = 3000 +SSH_PORT = 22 +; Disable CDN even in "prod" mode +OFFLINE_MODE = false +DISABLE_ROUTER_LOG = false +; Generate steps: +; $ cd path/to/gogs/custom/https +; $ ./gogs cert -ca=true -duration=8760h0m0s -host=myhost.example.com +; +; Or from a .pfx file exported from the Windows certificate store (do +; not forget to export the private key): +; $ openssl pkcs12 -in cert.pfx -out cert.pem -nokeys +; $ openssl pkcs12 -in cert.pfx -out key.pem -nocerts -nodes +CERT_FILE = custom/https/cert.pem +KEY_FILE = custom/https/key.pem +; Upper level of template and static file path +; default is the path where Gogs is executed +STATIC_ROOT_PATH = +; Application level GZIP support +ENABLE_GZIP = false +; Landing page for non-logged users, can be "home" or "explore" +LANDING_PAGE = home + +[database] +; Either "mysql", "postgres" or "sqlite3", it's your choice +DB_TYPE = sqlite3 +PATH = /gogs/data/gogs.db + +[admin] + +[security] +INSTALL_LOCK = false +; !!CHANGE THIS TO KEEP YOUR USER DATA SAFE!! +SECRET_KEY = !#@FDEWREWR&*( +; Auto-login remember days +LOGIN_REMEMBER_DAYS = 7 +COOKIE_USERNAME = gogs_awesome +COOKIE_REMEMBER_NAME = gogs_incredible +; Reverse proxy authentication header name of user name +REVERSE_PROXY_AUTHENTICATION_USER = X-WEBAUTH-USER + +[service] +ACTIVE_CODE_LIVE_MINUTES = 180 +RESET_PASSWD_CODE_LIVE_MINUTES = 180 +; User need to confirm e-mail for registration +REGISTER_EMAIL_CONFIRM = false +; Does not allow register and admin create account only +DISABLE_REGISTRATION = false +; User must sign in to view anything. +REQUIRE_SIGNIN_VIEW = false +; Cache avatar as picture +ENABLE_CACHE_AVATAR = false +; Mail notification +ENABLE_NOTIFY_MAIL = false +; More detail: https://github.com/gogits/gogs/issues/165 +ENABLE_REVERSE_PROXY_AUTHENTICATION = false +ENABLE_REVERSE_PROXY_AUTO_REGISTERATION = false + +[webhook] +; Cron task interval in minutes +TASK_INTERVAL = 1 +; Deliver timeout in seconds +DELIVER_TIMEOUT = 5 + +[mailer] +ENABLED = false +; Buffer length of channel, keep it as it is if you don't know what it is. +SEND_BUFFER_LEN = 10 +; Name displayed in mail title +SUBJECT = %(APP_NAME)s +; Mail server +; Gmail: smtp.gmail.com:587 +; QQ: smtp.qq.com:25 +; Note, if the port ends with "465", SMTPS will be used. Using STARTTLS on port 587 is recommended per RFC 6409. If the server supports STARTTLS it will always be used. +HOST = +; Do not verify the certificate of the server. Only use this for self-signed certificates +SKIP_VERIFY = +; Mail from address, RFC 5322. This can be just an email address, or the "Name" format +FROM = +; Mailer user name and password +USER = +PASSWD = + +[oauth] +ENABLED = false + +[oauth.github] +ENABLED = false +CLIENT_ID = +CLIENT_SECRET = +SCOPES = https://api.github.com/user +AUTH_URL = https://github.com/login/oauth/authorize +TOKEN_URL = https://github.com/login/oauth/access_token + +; Get client id and secret from +; https://console.developers.google.com/project +[oauth.google] +ENABLED = false +CLIENT_ID = +CLIENT_SECRET = +SCOPES = https://www.googleapis.com/auth/userinfo.email https://www.googleapis.com/auth/userinfo.profile +AUTH_URL = https://accounts.google.com/o/oauth2/auth +TOKEN_URL = https://accounts.google.com/o/oauth2/token + +[oauth.qq] +ENABLED = false +CLIENT_ID = +CLIENT_SECRET = +SCOPES = get_user_info +; QQ 互联 +AUTH_URL = https://graph.qq.com/oauth2.0/authorize +TOKEN_URL = https://graph.qq.com/oauth2.0/token + +[oauth.weibo] +ENABLED = false +CLIENT_ID = +CLIENT_SECRET = +SCOPES = all +AUTH_URL = https://api.weibo.com/oauth2/authorize +TOKEN_URL = https://api.weibo.com/oauth2/access_token + +[cache] +; Either "memory", "redis", or "memcache", default is "memory" +ADAPTER = memory +; For "memory" only, GC interval in seconds, default is 60 +INTERVAL = 60 +; For "redis" and "memcache", connection host address +; redis: `:6039` +; memcache: `127.0.0.1:11211` +HOST = + +[session] +; Either "memory", "file", "redis" or "mysql", default is "memory" +PROVIDER = memory +; Provider config options +; memory: not have any config yet +; file: session file path, e.g. `data/sessions` +; redis: config like redis server addr, poolSize, password, e.g. `127.0.0.1:6379,100,gogs` +; mysql: go-sql-driver/mysql dsn config string, e.g. `root:password@/session_table` +PROVIDER_CONFIG = data/sessions +; Session cookie name +COOKIE_NAME = i_like_gogits +; If you use session in https only, default is false +COOKIE_SECURE = false +; Enable set cookie, default is true +ENABLE_SET_COOKIE = true +; Session GC time interval, default is 86400 +GC_INTERVAL_TIME = 86400 +; Session life time, default is 86400 +SESSION_LIFE_TIME = 86400 + +[picture] +; The place to picture data, either "server" or "qiniu", default is "server" +SERVICE = server +AVATAR_UPLOAD_PATH = data/avatars +; Chinese users can choose "duoshuo" +GRAVATAR_SOURCE = gravatar +DISABLE_GRAVATAR = false + +[attachment] +; Whether attachments are enabled. Defaults to `true` +ENABLE = true +; Path for attachments. Defaults to `data/attachments` +PATH = data/attachments +; One or more allowed types, e.g. image/jpeg|image/png +ALLOWED_TYPES = image/jpeg|image/png +; Max size of each file. Defaults to 32MB +MAX_SIZE = 32 +; Max number of files per upload. Defaults to 10 +MAX_FILES = 10 + +[time] +; Specifies the format for fully outputed dates. Defaults to RFC1123 +; Special supported values are ANSIC, UnixDate, RubyDate, RFC822, RFC822Z, RFC850, RFC1123, RFC1123Z, RFC3339, RFC3339Nano, Kitchen, Stamp, StampMilli, StampMicro and StampNano +; For more information about the format see http://golang.org/pkg/time/#pkg-constants +FORMAT = + +[log] +ROOT_PATH = +; Either "console", "file", "conn", "smtp" or "database", default is "console" +; Use comma to separate multiple modes, e.g. "console, file" +MODE = console +; Buffer length of channel, keep it as it is if you don't know what it is. +BUFFER_LEN = 10000 +; Either "Trace", "Debug", "Info", "Warn", "Error", "Critical", default is "Trace" +LEVEL = Trace + +; For "console" mode only +[log.console] +LEVEL = + +; For "file" mode only +[log.file] +LEVEL = +; This enables automated log rotate(switch of following options), default is true +LOG_ROTATE = true +; Max line number of single file, default is 1000000 +MAX_LINES = 1000000 +; Max size shift of single file, default is 28 means 1 << 28, 256MB +MAX_SIZE_SHIFT = 28 +; Segment log daily, default is true +DAILY_ROTATE = true +; Expired days of log file(delete after max days), default is 7 +MAX_DAYS = 7 + +; For "conn" mode only +[log.conn] +LEVEL = +; Reconnect host for every single message, default is false +RECONNECT_ON_MSG = false +; Try to reconnect when connection is lost, default is false +RECONNECT = false +; Either "tcp", "unix" or "udp", default is "tcp" +PROTOCOL = tcp +; Host address +ADDR = + +; For "smtp" mode only +[log.smtp] +LEVEL = +; Name displayed in mail title, default is "Diagnostic message from serve" +SUBJECT = Diagnostic message from serve +; Mail server +HOST = +; Mailer user name and password +USER = +PASSWD = +; Receivers, can be one or more, e.g. ["1@example.com","2@example.com"] +RECEIVERS = + +; For "database" mode only +[log.database] +LEVEL = +; Either "mysql" or "postgres" +DRIVER = +; Based on xorm, e.g.: root:root@localhost/gogs?charset=utf8 +CONN = + +[git] +MAX_GIT_DIFF_LINES = 10000 +; Arguments for command 'git gc', e.g.: "--aggressive --auto" +; see more on http://git-scm.com/docs/git-gc/1.7.5 +GC_ARGS = + +; Git health check. +[git.fsck] +ENABLE = true +; Execution interval in hours. Default is 24. +INTERVAL = 24 +; Arguments for command 'git fsck', e.g.: "--unreachable --tags" +; see more on http://git-scm.com/docs/git-fsck/1.7.5 +ARGS = + +[i18n] +LANGS = en-US,zh-CN,zh-HK,de-DE,fr-CA,nl-NL,lv-LV +NAMES = English,简体中文,繁體中文,Deutsch,Français,Nederlands,Latviešu diff --git a/gogs/runit/gogs/run b/gogs/runit/gogs/run new file mode 100755 index 0000000..0e9c427 --- /dev/null +++ b/gogs/runit/gogs/run @@ -0,0 +1,4 @@ +#!/bin/sh + +cd /gogs/install +setuser git ./gogs web diff --git a/gogs/runit/sshd/run b/gogs/runit/sshd/run new file mode 100755 index 0000000..7f66492 --- /dev/null +++ b/gogs/runit/sshd/run @@ -0,0 +1,3 @@ +#!/bin/sh +set -e +exec /usr/sbin/sshd -D