PluginProbe ʕ •ᴥ•ʔ
EmbedPress – PDF Embedder, Embed PDF viewer, YouTube Videos, 3D FlipBook, Social feeds & more / 1.7.3
EmbedPress – PDF Embedder, Embed PDF viewer, YouTube Videos, 3D FlipBook, Social feeds & more v1.7.3
4.5.6 4.5.5 4.5.4 4.5.3 4.5.2 trunk 1.0.0 1.1.0 1.1.1 1.1.2 1.1.3 1.2.0 1.3.0 1.3.1 1.4.0 1.4.1 1.4.2 1.4.3 1.4.4 1.5.0 1.6.0 1.6.1 1.6.2 1.6.3 1.7.0 1.7.1 1.7.2 1.7.3 1.7.4 1.7.5 2.0.0 2.0.1 2.0.2 2.0.3 2.1.0 2.1.1 2.1.2 2.1.3 2.1.4 2.1.5 2.1.6 2.2.0 2.2.1 2.2.2 2.3.0 2.3.1 2.3.2 2.3.3 2.4.0 2.4.1 2.5.0 2.5.1 2.5.2 2.5.3 2.5.4 2.5.5 2.6.0 2.6.1 2.6.2 2.7.0 2.7.1 2.7.2 2.7.3 2.7.4 2.7.5 2.7.6 2.7.7 3.0.0 3.0.1 3.0.2 3.0.3 3.0.4 3.1.0 3.1.1 3.1.2 3.1.3 3.2.0 3.2.1 3.3.0 3.3.1 3.3.2 3.3.3 3.3.4 3.3.5 3.3.6 3.3.7 3.4.0 3.4.1 3.4.2 3.4.3 3.5.0 3.5.1 3.5.2 3.5.3 3.6.0 3.6.1 3.6.2 3.6.3 3.6.4 3.6.5 3.6.6 3.6.7 3.6.8 3.7.0 3.7.1 3.7.2 3.7.3 3.8.0 3.8.1 3.8.2 3.8.3 3.8.4 3.8.5 3.9.0 3.9.1 3.9.10 3.9.11 3.9.12 3.9.13 3.9.14 3.9.15 3.9.16 3.9.17 3.9.2 3.9.3 3.9.4 3.9.5 3.9.6 3.9.7 3.9.8 3.9.9 4.0.0 4.0.1 4.0.10 4.0.11 4.0.12 4.0.13 4.0.14 4.0.2 4.0.3 4.0.4 4.0.5 4.0.6 4.0.7 4.0.8 4.0.9 4.1.0 4.1.1 4.1.10 4.1.2 4.1.3 4.1.4 4.1.5 4.1.6 4.1.7 4.1.8 4.1.9 4.2.0 4.2.1 4.2.2 4.2.3 4.2.4 4.2.5 4.2.6 4.2.7 4.2.8 4.2.9 4.3.0 4.3.1 4.4.0 4.4.1 4.4.10 4.4.11 4.4.2 4.4.3 4.4.4 4.4.5 4.4.6 4.4.7 4.4.8 4.4.9 4.5.0 4.5.1
embedpress / EmbedPress / Loader.php
embedpress / EmbedPress Last commit date
Ends 9 years ago Plugins 9 years ago Providers 9 years ago AutoLoader.php 9 years ago Core.php 9 years ago Disabler.php 9 years ago Loader.php 9 years ago Shortcode.php 9 years ago Updater.php 9 years ago index.html 9 years ago
Loader.php
133 lines
1 <?php
2 namespace EmbedPress;
3
4 (defined('ABSPATH') && defined('EMBEDPRESS_IS_LOADED')) or die("No direct script access allowed.");
5
6 /**
7 * Entity responsible for maintaining and registering all hooks that power the plugin.
8 *
9 * @package EmbedPress
10 * @author PressShack <help@pressshack.com>
11 * @copyright Copyright (C) 2017 Open Source Training, LLC. All rights reserved.
12 * @license GPLv2 or later
13 * @since 1.0.0
14 */
15 class Loader
16 {
17 /**
18 * The array of actions registered with WordPress.
19 *
20 * @since 1.0.0
21 * @access protected
22 *
23 * @var array $actions The actions registered with WordPress to fire when the plugin loads.
24 */
25 protected $actions;
26
27 /**
28 * The array of filters registered with WordPress.
29 *
30 * @since 1.0.0
31 * @access protected
32 *
33 * @var array $filters The filters registered with WordPress to fire when the plugin loads.
34 */
35 protected $filters;
36
37 /**
38 * Initialize the collections used to maintain the actions and filters.
39 *
40 * @since 1.0.0
41 *
42 * @return void
43 */
44 public function __construct()
45 {
46 $this->actions = array();
47 $this->filters = array();
48 }
49
50 /**
51 * Add a new action to the collection to be registered with WordPress.
52 *
53 * @since 1.0.0
54 *
55 * @param string $hook The name of the WordPress action that is being registered.
56 * @param object $component A reference to the instance of the object on which the action is defined.
57 * @param string $callback The name of the function definition on the $component.
58 * @param int $priority Optional. he priority at which the function should be fired. Default is 10.
59 * @param int $accepted_args Optional. The number of arguments that should be passed to the $callback. Default is 1.
60 * @return void
61 */
62 public function add_action($hook, $component, $callback, $priority = 10, $accepted_args = 1)
63 {
64 $this->actions = $this->add($this->actions, $hook, $component, $callback, $priority, $accepted_args);
65 }
66
67 /**
68 * Add a new filter to the collection to be registered with WordPress.
69 *
70 * @since 1.0.0
71 *
72 * @param string $hook The name of the WordPress filter that is being registered.
73 * @param object $component A reference to the instance of the object on which the filter is defined.
74 * @param string $callback The name of the function definition on the $component.
75 * @param int $priority Optional. he priority at which the function should be fired. Default is 10.
76 * @param int $accepted_args Optional. The number of arguments that should be passed to the $callback. Default is 1.
77 * @return void
78 */
79 public function add_filter($hook, $component, $callback, $priority = 10, $accepted_args = 1)
80 {
81 $this->filters = $this->add($this->filters, $hook, $component, $callback, $priority, $accepted_args);
82 }
83
84 /**
85 * Method that is used to register the actions and hooks into a single collection.
86 *
87 * @since 1.0.0
88 * @access private
89 *
90 * @param array $hooks The collection of hooks that is being registered (that is, actions or filters).
91 * @param string $hook The name of the WordPress filter that is being registered.
92 * @param object $component A reference to the instance of the object on which the filter is defined.
93 * @param string $callback The name of the function definition on the $component.
94 * @param int $priority The priority at which the function should be fired.
95 * @param int $accepted_args The number of arguments that should be passed to the $callback.
96 * @return array The collection of actions and filters registered with WordPress.
97 */
98 private function add($hooks, $hook, $component, $callback, $priority, $accepted_args)
99 {
100 $hooks[] = array(
101 'hook' => $hook,
102 'component' => $component,
103 'callback' => $callback,
104 'priority' => $priority,
105 'accepted_args' => $accepted_args
106 );
107
108 return $hooks;
109 }
110
111 /**
112 * Register all required filters and actions with WordPress.
113 *
114 * @since 1.0.0
115 *
116 * @return void
117 */
118 public function run()
119 {
120 foreach ($this->filters as $hook) {
121 add_filter($hook['hook'], array(
122 $hook['component'], $hook['callback']
123 ), $hook['priority'], $hook['accepted_args']);
124 }
125
126 foreach ($this->actions as $hook) {
127 add_action($hook['hook'], array(
128 $hook['component'], $hook['callback']
129 ), $hook['priority'], $hook['accepted_args']);
130 }
131 }
132 }
133