2023-08-03 14:39:36 +03:00
# Использование разрешений LDAP в PostgreSQL
2018-02-07 01:19:54 +03:00
* http://github.com/larskanis/pg-ldap-sync
2023-08-03 14:39:36 +03:00
## ОПИСАНИЕ:
2018-02-07 01:19:54 +03:00
2023-08-03 14:39:36 +03:00
LDAP часто используется для централизованного управления пользователями и ролями в корпоративной среде.
PostgreSQL предлагает различные методы аутентификации, такие как LDAP, SSPI, GSSAPI или SSL.
Однако при любом методе пользователь должен уже существовать в базе данных, прежде чем аутентификация может быть использована.
В настоящее время не существует прямой авторизации пользователей базы данных по LDAP.
Поэтому роли и членство приходится администрировать дважды.
2018-02-07 01:19:54 +03:00
2023-08-03 14:39:36 +03:00
Данная программа позволяет решить эту проблему путем синхронизации пользователей, групп и их членства из LDAP в PostgreSQL.
Доступ к LDAP используется только для чтения.
Для синхронизации пользователей и групп `pg_ldap_sync` выдает соответствующие команды CREATE ROLE, DROP ROLE, GRANT и REVOKE.
2018-02-07 01:19:54 +03:00
2023-08-03 14:39:36 +03:00
Она предназначена для запуска в качестве cron-задания.
2018-02-07 01:19:54 +03:00
## FEATURES:
2023-08-03 14:39:36 +03:00
* Создание, удаление пользователей и групп, а также изменения в членстве синхронизируются из LDAP в PostgreSQL.
* Поддерживаются вложенные группы/роли
* Настраивается в конфигурационном файле YAML
* Возможность использования Active Directory в качестве LDAP-сервера
* Установка области видимости рассматриваемых пользователей/групп на стороне LDAP и PG
* Тестовый режим, не вносящий никаких изменений в СУБД
* Соединения между LDAP и PG могут быть защищены с помощью SSL/TLS
* NTLM и Kerberos аутентификация на LDAP-сервере
2018-02-07 01:19:54 +03:00
2023-08-03 14:39:36 +03:00
## ТРЕБОВАНИЯ:
2018-02-07 01:19:54 +03:00
2023-04-01 16:09:45 +03:00
* Ruby-2.0+
2023-08-03 14:39:36 +03:00
* LDAP-v3-сервер
* PostgreSQL-сервер v9.0+
2018-02-07 01:19:54 +03:00
2023-08-03 14:39:36 +03:00
## У С Т А Н О В К А :
2018-02-07 01:19:54 +03:00
2023-08-03 14:39:36 +03:00
Установить Ruby:
2018-02-07 01:19:54 +03:00
2023-08-03 14:39:36 +03:00
* под Windows: http://rubyinstaller.org
* на Debian/Ubuntu: `apt-get install ruby libpq-dev` .
2018-02-07 01:19:54 +03:00
2023-08-03 14:39:36 +03:00
Установите pg-ldap-sync и необходимые зависимости:
``sh
2018-02-07 01:19:54 +03:00
gem install pg-ldap-sync
```
2023-08-03 14:39:36 +03:00
### Установка из Git:
``sh
2023-07-26 12:59:33 +03:00
git clone https://github.com/fruworg/pg-ldap-sync.git
2018-02-07 01:19:54 +03:00
cd pg-ldap-sync
2023-08-03 14:39:36 +03:00
gem install bundler
bundle install
2018-03-14 12:04:56 +03:00
bundle exec rake install
2018-02-07 01:19:54 +03:00
```
2023-08-03 14:39:36 +03:00
## ИСПОЛЬЗОВАНИЕ:
2018-02-07 01:19:54 +03:00
2023-08-03 14:39:36 +03:00
Создать файл конфигурации на основе
[config/sample-config.yaml ](https://github.com/fruworg/pg-ldap-sync/blob/master/config/sample-config.yaml )
или еще лучше
[config/sample-config2.yaml ](https://github.com/fruworg/pg-ldap-sync/blob/master/config/sample-config2.yaml ).
2018-02-07 01:19:54 +03:00
2023-08-03 14:39:36 +03:00
Запустить в тестовом режиме:
``sh
2018-02-07 01:19:54 +03:00
pg_ldap_sync -c my_config.yaml -vv -t
```
2023-08-03 14:39:36 +03:00
Запуск в режиме модификации:
``sh
2018-02-07 01:19:54 +03:00
pg_ldap_sync -c my_config.yaml -vv
```
2023-08-03 14:39:36 +03:00
Рекомендуется не предоставлять права синхронизируемым пользователям на сервере PostgreSQL, а предоставлять права группам.
Это связано с тем, что операторы `DROP USER` , вызываемые при уходе пользователя, в противном случае терпят неудачу из-за наличия зависимых объектов.
Оператор `DROP GROUP` также не работает при наличии зависимых объектов, но группы, как правило, более стабильны и удаляются редко.
2023-04-01 16:09:45 +03:00
2023-08-03 14:39:36 +03:00
## Т Е С Т :
В каталоге `test` находится небольшой тестовый набор, который работает с внутренним LDAP-сервером и сервером PostgreSQL. Убедитесь, что команды `pg_ctl` , `initdb` и `psql` находятся в `PATH` следующим образом:
``sh
2018-02-07 01:19:54 +03:00
cd pg-ldap-sync
2023-08-03 14:39:36 +03:00
установить пакет
2018-03-14 12:04:56 +03:00
PATH=$PATH:/usr/lib/postgresql/10/bin/ bundle exec rake test
2018-02-07 01:19:54 +03:00
```
## ISSUES:
2023-08-03 14:39:36 +03:00
* В настоящее время нет возможности установить определенные атрибуты пользователя в PG на основе индивидуальных атрибутов в LDAP (срок действия и т.д.).
2018-02-07 01:19:54 +03:00
2023-08-03 14:39:36 +03:00
## Лицензия
2018-02-07 01:19:54 +03:00
2023-08-03 14:39:36 +03:00
Гем доступен с открытым исходным кодом на условиях [MIT License ](https://opensource.org/licenses/MIT ).