Документация по PostgreSQL 9.4.1 | |||
---|---|---|---|
Пред. | Уровень выше | Глава 20. Роли базы данных | След. |
20.4. Безопасность функций и триггеров
Функции и триггеры дают возможность пользователям добавить на сервер программный код, который другие пользователи могут непреднамеренно выполнить. Таким образом, оба механизма позволяют относительно легко атаковать других пользователей, внедряя "троянских коней". Единственной реальной защитой может быть жёсткое ограничение круга лиц, имеющих право создавать функции.
Функции выполняются внутри серверного процесса с полномочиями пользователя операционной системы, запускающего сервер базы данных. Если используемый для функций язык программирования разрешает неконтролируемый доступ к памяти, то это даёт возможность изменить внутренние структуры данных сервера. Таким образом, помимо всего прочего, такие функции могут обойти ограничения доступа к системе. Языки программирования, допускающие такой доступ, считаются "недоверенными" и создавать функции на этих языках PostgreSQL разрешает только суперпользователям.
Пред. | Начало | След. |
Членство в роли | Уровень выше | Управление базами данных |
PostgreSQL 9.4.1 Documentation | |||
---|---|---|---|
Prev | Up | Chapter 20. Database Roles | Next |
20.4. Function and Trigger Security
Functions and triggers allow users to insert code into the backend server that other users might execute unintentionally. Hence, both mechanisms permit users to "Trojan horse" others with relative ease. The only real protection is tight control over who can define functions.
Functions run inside the backend server process with the operating system permissions of the database server daemon. If the programming language used for the function allows unchecked memory accesses, it is possible to change the server's internal data structures. Hence, among many other things, such functions can circumvent any system access controls. Function languages that allow such access are considered "untrusted", and PostgreSQL allows only superusers to create functions written in those languages.