Plugin copy

web-from-alpine
Terekhin Alexandr 5 years ago
parent 10ea221cc9
commit a9b6a253cc
  1. 46
      docker-compose.yml
  2. 50
      docker-compose.yml~
  3. 5
      redmine/Dockerfile
  4. 5
      redmine/Dockerfile~
  5. 7
      redmine/redmine_ldap_passwd/app/models/auth_source_ldap_passwd.rb
  6. 7
      redmine/redmine_ldap_passwd/config/locales/en.yml
  7. 5
      redmine/redmine_ldap_passwd/init.rb

@ -17,6 +17,7 @@ services:
# - db.env
volumes:
- redmine-files:/usr/src/redmine/files
- redmine-config:/usr/src/redmine/config
- redmine-logs:/var/log/redmine
depends_on:
- db
@ -43,6 +44,11 @@ volumes:
type: none
device: /tmp/docker/redmine-files
o: bind
redmine-config:
driver_opts:
type: none
device: /tmp/docker/redmine-config
o: bind
redmine-logs:
driver_opts:
type: none
@ -50,85 +56,45 @@ volumes:
o: bind
# openldap:
#
# #build: ./ldap
#
# image: osixia/openldap:1.4.0
#
# container_name: openldap
#
# restart: always
#
# environment:
#
# LDAP_LOG_LEVEL: "0x380"
#
# LDAP_ORGANISATION: "Example Inc."
#
# LDAP_DOMAIN: "example.org"
#
# LDAP_BASE_DN: ""
#
# LDAP_ADMIN_PASSWORD: "admin"
#
# LDAP_CONFIG_PASSWORD: "config"
#
# LDAP_READONLY_USER: "false"
#
# #LDAP_READONLY_USER_USERNAME: "readonly"
#
# #LDAP_READONLY_USER_PASSWORD: "readonly"
#
# LDAP_RFC2307BIS_SCHEMA: "false"
#
# LDAP_BACKEND: "mdb"
#
# LDAP_TLS: "true"
#
# LDAP_TLS_CRT_FILENAME: "ldap.crt"
#
# LDAP_TLS_KEY_FILENAME: "ldap.key"
#
# LDAP_TLS_DH_PARAM_FILENAME: "dhparam.pem"
#
# LDAP_TLS_CA_CRT_FILENAME: "ca.crt"
#
# LDAP_TLS_ENFORCE: "false"
#
# LDAP_TLS_CIPHER_SUITE: "SECURE256:+SECURE128:-VERS-TLS-ALL:+VERS-TLS1.2:-RSA:-DHE-DSS:-CAMELLIA-128-CBC:-CAMELLIA-256-CBC"
#
# LDAP_TLS_VERIFY_CLIENT: "never"
#
# LDAP_REPLICATION: "false"
#
# #LDAP_REPLICATION_CONFIG_SYNCPROV: "binddn="cn=admin,cn=config" bindmethod=simple credentials=$$LDAP_CONFIG_PASSWORD searchbase="cn=config" type=refreshAndPersist retry="60 +" timeout=1 starttls=critical"
#
# #LDAP_REPLICATION_DB_SYNCPROV: "binddn="cn=admin,$$LDAP_BASE_DN" bindmethod=simple credentials=$$LDAP_ADMIN_PASSWORD searchbase="$$LDAP_BASE_DN" type=refreshAndPersist interval=00:00:00:10 retry="60 +" timeout=1 starttls=critical"
#
# #LDAP_REPLICATION_HOSTS: "#PYTHON2BASH:['ldap://ldap.example.org','ldap://ldap2.example.org']"
#
# KEEP_EXISTING_CONFIG: "false"
#
# LDAP_REMOVE_CONFIG_AFTER_SETUP: "true"
#
# LDAP_SSL_HELPER_PREFIX: "ldap"
#
# tty: true
#
# stdin_open: true
#
# volumes:
#
# - /srv/docker/ldap/ldap:/var/lib/ldap
#
# - /srv/docker/ldap/slap.d:/etc/ldap/slapd.d
#
# - /srv/docker/ldap/certs:/container/service/slapd/assets/certs/
#
# ports:
#
# - "389:389"
#
# - "636:636"
#
# # For replication to work correctly, domainname and hostname must be

@ -17,6 +17,7 @@ services:
# - db.env
volumes:
- redmine-files:/usr/src/redmine/files
- redmine-config:/usr/src/redmine/config
- redmine-logs:/var/log/redmine
depends_on:
- db
@ -27,8 +28,8 @@ services:
restart: always
environment:
MYSQL_DATABASE: redmine
env_file:
- db.env
#env_file:
# - db.env
volumes:
- db:/var/lib/mysql
@ -43,6 +44,11 @@ volumes:
type: none
device: /tmp/docker/redmine-files
o: bind
redmine-config:
driver_opts:
type: none
device: /tmp/docker/redmine-config
o: bind
redmine-logs:
driver_opts:
type: none
@ -50,85 +56,45 @@ volumes:
o: bind
# openldap:
#
# #build: ./ldap
#
# image: osixia/openldap:1.4.0
#
# container_name: openldap
#
# restart: always
#
# environment:
#
# LDAP_LOG_LEVEL: "0x380"
#
# LDAP_ORGANISATION: "Example Inc."
#
# LDAP_DOMAIN: "example.org"
#
# LDAP_BASE_DN: ""
#
# LDAP_ADMIN_PASSWORD: "admin"
#
# LDAP_CONFIG_PASSWORD: "config"
#
# LDAP_READONLY_USER: "false"
#
# #LDAP_READONLY_USER_USERNAME: "readonly"
#
# #LDAP_READONLY_USER_PASSWORD: "readonly"
#
# LDAP_RFC2307BIS_SCHEMA: "false"
#
# LDAP_BACKEND: "mdb"
#
# LDAP_TLS: "true"
#
# LDAP_TLS_CRT_FILENAME: "ldap.crt"
#
# LDAP_TLS_KEY_FILENAME: "ldap.key"
#
# LDAP_TLS_DH_PARAM_FILENAME: "dhparam.pem"
#
# LDAP_TLS_CA_CRT_FILENAME: "ca.crt"
#
# LDAP_TLS_ENFORCE: "false"
#
# LDAP_TLS_CIPHER_SUITE: "SECURE256:+SECURE128:-VERS-TLS-ALL:+VERS-TLS1.2:-RSA:-DHE-DSS:-CAMELLIA-128-CBC:-CAMELLIA-256-CBC"
#
# LDAP_TLS_VERIFY_CLIENT: "never"
#
# LDAP_REPLICATION: "false"
#
# #LDAP_REPLICATION_CONFIG_SYNCPROV: "binddn="cn=admin,cn=config" bindmethod=simple credentials=$$LDAP_CONFIG_PASSWORD searchbase="cn=config" type=refreshAndPersist retry="60 +" timeout=1 starttls=critical"
#
# #LDAP_REPLICATION_DB_SYNCPROV: "binddn="cn=admin,$$LDAP_BASE_DN" bindmethod=simple credentials=$$LDAP_ADMIN_PASSWORD searchbase="$$LDAP_BASE_DN" type=refreshAndPersist interval=00:00:00:10 retry="60 +" timeout=1 starttls=critical"
#
# #LDAP_REPLICATION_HOSTS: "#PYTHON2BASH:['ldap://ldap.example.org','ldap://ldap2.example.org']"
#
# KEEP_EXISTING_CONFIG: "false"
#
# LDAP_REMOVE_CONFIG_AFTER_SETUP: "true"
#
# LDAP_SSL_HELPER_PREFIX: "ldap"
#
# tty: true
#
# stdin_open: true
#
# volumes:
#
# - /srv/docker/ldap/ldap:/var/lib/ldap
#
# - /srv/docker/ldap/slap.d:/etc/ldap/slapd.d
#
# - /srv/docker/ldap/certs:/container/service/slapd/assets/certs/
#
# ports:
#
# - "389:389"
#
# - "636:636"
#
# # For replication to work correctly, domainname and hostname must be

@ -1,5 +1,2 @@
FROM redmine:latest
#ARG REDMINE_DB_PASSWORD
#RUN echo "testarg=${REDMINE_DB_PASSWORD}"
#ENV REDMINE_DB_PASSWORD=${REDMINE_DB_PASSWORD}
ADD ./redmine_ldap_passwd/ /usr/share/redmine/plugins/
ADD --chown=999:999 ./redmine_ldap_passwd/ /usr/src/redmine/plugins/redmine_ldap_passwd/

@ -1,5 +1,2 @@
FROM redmine:latest
ARG REDMINE_DB_PASSWORD
RUN echo "testarg=${REDMINE_DB_PASSWORD}"
ENV REDMINE_DB_PASSWORD=${REDMINE_DB_PASSWORD}
ADD ./redmine_ldap_passwd/ /usr/share/redmine/plugins/
ADD ./redmine_ldap_passwd/ /usr/src/redmine/plugins/redmine_ldap_passwd/

@ -8,8 +8,10 @@ class AuthSourceLdapPasswd < AuthSourceLdap
attrs = get_user_dn(user.login, password)
if attrs && attrs[:dn]
if self.account && self.account.include?("$login")
ldap_con = initialize_ldap_con(self.account.sub("$login", Net::LDAP::DN.escape(user.login)), password)
defaults = Redmine::Plugin::registered_plugins[:redmine_ldap_passwd].settings[:default]
suua = Setting.plugin_redmine_ldap_passwd[:use_user_account].nil? ? defaults[:use_user_account] : Setting.plugin_redmine_ldap_passwd[:use_user_account]
if suua || ( self.account && self.account.include?("$login") )
ldap_con = initialize_ldap_con(suua ? Net::LDAP::DN.escape(user.login) : self.account.sub("$login", Net::LDAP::DN.escape(user.login)), password)
else
ldap_con = initialize_ldap_con(self.account, self.account_password)
end
@ -24,6 +26,7 @@ class AuthSourceLdapPasswd < AuthSourceLdap
return true
else
Rails.logger.info "Change password problem: #{result}."
return result
end
end

@ -1,3 +1,8 @@
en:
notice_new_password_and_confirmation_different: The new password is different from the confirmation password
notice_new_password_format: "1. The password should be at least seven characters long. 2. The password should contain characters from at least three of the following four categories: (a) English uppercase characters (A - Z) (b) English lowercase characters (a - z) (c) Base 10 digits (0 - 9) (d) Non-alphanumeric (For example: !, $, or %). 3. The password shouldn't contain three or more characters from the user's account name."
notice_new_password_format: "1. The password should be at least seven characters long. 2. The password should contain characters from at least three of the following four categories: (a) English uppercase characters (A - Z) (b) English lowercase characters (a - z) (c) Base 10 digits (0 - 9) (d) Non-alphanumeric (For example: !, $, or %). 3. The password shouldn't contain three or more characters from the user's account name."
notice_can_t_change_password: "Can`t change password."
notice_account_wrong_password: "Wrong password or username"
notice_new_password_must_be_different: "New password must be different."
notice_account_password_updated: "Account pasword updated."
setting_use_user_account: "Use current user acoount for LDAP:"

@ -11,6 +11,11 @@ Redmine::Plugin.register :redmine_ldap_passwd do
version '3.0.1'
url 'https://github.com/xeagle2/redmine_ldap_passwd'
author_url 'https://github.com/xeagle2'
settings :partial => 'settings/ldap_password',
:default => {
:use_user_account => true
}
end
require 'dispatcher' unless Rails::VERSION::MAJOR >= 3

Loading…
Cancel
Save