diff --git a/bdp-kompass.php b/bdp-kompass.php index b126413..d5cc9cc 100644 --- a/bdp-kompass.php +++ b/bdp-kompass.php @@ -65,4 +65,4 @@ function enqueue_custom_password_js() { ]); } -#add_action( 'after_setup_theme', 'register_custom_theme_directory' ); +add_action( 'after_setup_theme', 'kompass_after_setup_theme' ); diff --git a/changelog b/changelog index 9a9bbb2..dd71608 100644 --- a/changelog +++ b/changelog @@ -1,7 +1,7 @@

Version 4.3.8

Version 4.3.7

diff --git a/includes/pre_requires.php b/includes/pre_requires.php index 5c0a4af..6cedbae 100644 --- a/includes/pre_requires.php +++ b/includes/pre_requires.php @@ -3,5 +3,6 @@ require_once (ABSPATH . '/wp-admin/includes/plugin.php'); require_once (ABSPATH . '/wp-admin/includes/class-wp-filesystem-base.php'); require_once (ABSPATH . '/wp-admin/includes/class-wp-filesystem-direct.php'); require_once (ABSPATH . '/wp-includes/pluggable.php'); +require_once (ABSPATH . '/wp-includes/capabilities.php'); require_once (ABSPATH . '/wp-admin/includes/template.php'); -require_once (ABSPATH . '/wp-admin/includes/file.php'); \ No newline at end of file +require_once (ABSPATH . '/wp-admin/includes/file.php'); diff --git a/includes/roles.php b/includes/roles.php new file mode 100644 index 0000000..dd4dd8b --- /dev/null +++ b/includes/roles.php @@ -0,0 +1,102 @@ + true, // Die Rolle kann Beiträge lesen + 'edit_posts' => true, // Die Rolle kann Beiträge bearbeiten + 'delete_posts' => true, // Die Rolle kann Beiträge löschen + 'publish_posts' => true, // Die Rolle kann Beiträge veröffentlichen + // Weitere Berechtigungen können nach Bedarf hinzugefügt werden + ); + + // Rolle hinzufügen + add_role( 'stafue', 'Stammesführung', kompass_get_capa_stafue() ); + add_role( 'grufue', 'Gruppenführung', kompass_get_capa_grufue() ); + add_role( 'aktionsleitung', 'Aktionsleitung', kompass_get_capa_aktionsleitung() ); + add_role( 'author', 'Redakteur', kompass_get_capa_editor() ); + + $role = get_role( 'administrator' ); + foreach (kompass_get_capa_stafue() as $capability => $value) { + $role->add_cap( $capability ); + } + } + +function kompass_get_capa_stafue() : array +{ + return array_merge( + [ + 'create_groups' => true, + 'delete_groups' => true, + 'edit_groups' => true, + 'delete_teilis' => true, + 'move_teilis' => true, + 'create_events' => true, + ], kompass_get_capa_aktionsleitung(), kompass_get_capa_grufue(), kompass_get_capa_editor()); +} + + + +function kompass_get_capa_aktionsleitung() : array +{ + return [ + 'create_event_teilis' => true, + 'edit_event_teilis' => true, + 'delete_event_teilis' => true, + 'send_event_mails' => true, + ]; +} + + function kompass_get_capa_grufue() : array + { + return [ + 'create_teilis' => true, + 'edit_teilis' => true, + 'send_mails' => true + ]; + } + + + function kompass_get_capa_editor() : array + { + return [ + 'moderate_comments' => true, + 'manage_categories' => true, + 'manage_links' => true, + 'upload_files' => true, + 'unfiltered_html' => true, + 'edit_posts' => true, + 'edit_others_posts' => true, + 'edit_published_posts' => true, + 'publish_posts' => true, + 'edit_pages' => true, + 'read' => true, + 'level_7' => true, + 'level_6' => true, + 'level_5' => true, + 'level_4' => true, + 'level_3' => true, + 'level_2' => true, + 'level_1' => true, + 'level_0' => true, + 'edit_others_pages' => true, + 'edit_published_pages' => true, + 'publish_pages' => true, + 'delete_pages' => true, + 'delete_others_pages' => true, + 'delete_published_pages' => true, + 'delete_posts' => true, + 'delete_others_posts' => true, + 'delete_published_posts' => true, + 'delete_private_posts' => true, + 'edit_private_posts' => true, + 'read_private_posts' => true, + 'delete_private_pages' => true, + 'edit_private_pages' => true, + 'read_private_pages' => true, + + ]; + } \ No newline at end of file diff --git a/includes/setup.php b/includes/setup.php index 8e420bb..2ded9b0 100644 --- a/includes/setup.php +++ b/includes/setup.php @@ -13,8 +13,10 @@ require_once dirname(__FILE__) . '/update.class.php'; require_once BDP_LV_PLUGIN_DIR . 'includes/FileAccess.class.php'; require_once BDP_LV_PLUGIN_DIR . 'includes/WpConfigEditor.class.php'; +require_once (BDP_LV_PLUGIN_DIR . '/includes/roles.php'); require_once (BDP_LV_PLUGIN_DIR . '/includes/filters.php'); + require_once (BDP_LV_PLUGIN_DIR . '/lib/ics-parser/Event.php'); require_once (BDP_LV_PLUGIN_DIR . '/lib/ics-parser/ICal.php'); @@ -37,6 +39,12 @@ function bdp_kompass_load_plugin_textdomain() { } +function kompass_after_setup_theme() +{ + setup_site_roles(); + #register_custom_theme_directory(); + +} $loginHandler = new LoginHandler();