This repository has been archived on 2023-12-11. You can view files and clone it, but cannot push or open issues or pull requests.
pgls/README.md

94 lines
5.1 KiB
Markdown
Raw Normal View History

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