Merge pull request #13378 from micmac1/maria-faker
mariadb: use fakeroot instead of postinst script
This commit is contained in:
commit
c774203060
1 changed files with 8 additions and 18 deletions
|
@ -9,7 +9,7 @@ include $(TOPDIR)/rules.mk
|
||||||
|
|
||||||
PKG_NAME:=mariadb
|
PKG_NAME:=mariadb
|
||||||
PKG_VERSION:=10.4.13
|
PKG_VERSION:=10.4.13
|
||||||
PKG_RELEASE:=2
|
PKG_RELEASE:=3
|
||||||
|
|
||||||
PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.gz
|
PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.gz
|
||||||
PKG_SOURCE_URL := \
|
PKG_SOURCE_URL := \
|
||||||
|
@ -541,6 +541,12 @@ define BuildPlugin
|
||||||
$(call Package/mariadb/Default)
|
$(call Package/mariadb/Default)
|
||||||
TITLE:=mariadb-server plugin
|
TITLE:=mariadb-server plugin
|
||||||
DEPENDS:=mariadb-server $(patsubst +%,+PACKAGE_mariadb-server-plugin-$(subst _,-,$(1)):%,$(2))
|
DEPENDS:=mariadb-server $(patsubst +%,+PACKAGE_mariadb-server-plugin-$(subst _,-,$(1)):%,$(2))
|
||||||
|
ifeq ($(1),auth_pam)
|
||||||
|
# Directory "auth_pam_tool_dir" is installed with mode 0750 and is only
|
||||||
|
# accessible by root and the group mariadb. This way mariadb can access
|
||||||
|
# the SUID binary "auth_pam_tool" contained within while others cannot.
|
||||||
|
FILE_MODES:=/usr/lib/mariadb/plugin/auth_pam_tool_dir:root:mariadb:0750
|
||||||
|
endif
|
||||||
endef
|
endef
|
||||||
define Package/mariadb-server-plugin-$(subst _,-,$(1))/description
|
define Package/mariadb-server-plugin-$(subst _,-,$(1))/description
|
||||||
$(call Package/mariadb/description/Default)
|
$(call Package/mariadb/description/Default)
|
||||||
|
@ -552,7 +558,7 @@ This package provides the $(1) plugin.
|
||||||
$(INSTALL_DIR) $$(1)$(PLUGIN_DIR)
|
$(INSTALL_DIR) $$(1)$(PLUGIN_DIR)
|
||||||
$(call Package/mariadb/install/plugin,$$(1),$(1))
|
$(call Package/mariadb/install/plugin,$$(1),$(1))
|
||||||
ifeq ($(1),auth_pam)
|
ifeq ($(1),auth_pam)
|
||||||
$(INSTALL_DIR) -m0750 $$(1)$(PLUGIN_DIR)/auth_pam_tool_dir
|
$(INSTALL_DIR) $$(1)$(PLUGIN_DIR)/auth_pam_tool_dir
|
||||||
$(INSTALL_SUID) \
|
$(INSTALL_SUID) \
|
||||||
$(PKG_INSTALL_DIR)$(PLUGIN_DIR)/auth_pam_tool_dir/auth_pam_tool \
|
$(PKG_INSTALL_DIR)$(PLUGIN_DIR)/auth_pam_tool_dir/auth_pam_tool \
|
||||||
$$(1)$(PLUGIN_DIR)/auth_pam_tool_dir
|
$$(1)$(PLUGIN_DIR)/auth_pam_tool_dir
|
||||||
|
@ -574,22 +580,6 @@ endif
|
||||||
$$(eval $$(call BuildPackage,mariadb-server-plugin-$(subst _,-,$(1))))
|
$$(eval $$(call BuildPackage,mariadb-server-plugin-$(subst _,-,$(1))))
|
||||||
endef
|
endef
|
||||||
|
|
||||||
# Directory "auth_pam_tool_dir" is installed with '-m0750' above and
|
|
||||||
# contains SUID binary "auth_pam_tool". Below post-install script
|
|
||||||
# changes the group of "auth_pam_tool_dir" to mariadb, so user mariadb
|
|
||||||
# can access the folder (and the SUID binary). The script only changes
|
|
||||||
# the group if the directory is currently owned by "root:root".
|
|
||||||
define Package/mariadb-server-plugin-auth-pam/postinst
|
|
||||||
#!/bin/sh
|
|
||||||
if [ -z "$${IPKG_INSTROOT}" ]; then
|
|
||||||
dir="/usr/lib/mariadb/plugin/auth_pam_tool_dir"
|
|
||||||
if ! [ -L "$$dir" ] && [ -d "$$dir" ] && [ -O "$$dir" ] && [ -G "$$dir" ]; then
|
|
||||||
chown :mariadb "$$dir"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
exit 0
|
|
||||||
endef
|
|
||||||
|
|
||||||
$(eval $(call HostBuild))
|
$(eval $(call HostBuild))
|
||||||
$(eval $(call BuildPackage,mariadb-client))
|
$(eval $(call BuildPackage,mariadb-client))
|
||||||
$(eval $(call BuildPackage,mariadb-client-base))
|
$(eval $(call BuildPackage,mariadb-client-base))
|
||||||
|
|
Loading…
Reference in a new issue