1+ <?php
2+
3+ /*
4+ Copyright (c) 2009, Till Brehm, projektfarm Gmbh
5+ All rights reserved.
6+
7+ Redistribution and use in source and binary forms, with or without modification,
8+ are permitted provided that the following conditions are met:
9+
10+ * Redistributions of source code must retain the above copyright notice,
11+ this list of conditions and the following disclaimer.
12+ * Redistributions in binary form must reproduce the above copyright notice,
13+ this list of conditions and the following disclaimer in the documentation
14+ and/or other materials provided with the distribution.
15+ * Neither the name of ISPConfig nor the names of its contributors
16+ may be used to endorse or promote products derived from this software without
17+ specific prior written permission.
18+
19+ THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
20+ ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
21+ WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
22+ IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
23+ INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
24+ BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
25+ DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
26+ OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
27+ NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
28+ EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29+ */
30+
31+ class dns_module {
32+
33+ var $ module_name = 'dns_module ' ;
34+ var $ class_name = 'dns_module ' ;
35+ var $ actions_available = array ( 'dns_soa_insert ' ,
36+ 'dns_soa_update ' ,
37+ 'dns_soa_delete ' ,
38+ 'dns_rr_insert ' ,
39+ 'dns_rr_update ' ,
40+ 'dns_rr_delete ' );
41+
42+ //* This function is called during ispconfig installation to determine
43+ // if a symlink shall be created for this plugin.
44+ function onInstall () {
45+ global $ conf ;
46+
47+ return true ;
48+
49+ }
50+
51+ /*
52+ This function is called when the module is loaded
53+ */
54+
55+ function onLoad () {
56+ global $ app ;
57+
58+ /*
59+ Annonce the actions that where provided by this module, so plugins
60+ can register on them.
61+ */
62+
63+ $ app ->plugins ->announceEvents ($ this ->module_name ,$ this ->actions_available );
64+
65+ /*
66+ As we want to get notified of any changes on several database tables,
67+ we register for them.
68+
69+ The following function registers the function "functionname"
70+ to be executed when a record for the table "dbtable" is
71+ processed in the sys_datalog. "classname" is the name of the
72+ class that contains the function functionname.
73+ */
74+
75+ $ app ->modules ->registerTableHook ('dns_soa ' ,$ this ->module_name ,'process ' );
76+ $ app ->modules ->registerTableHook ('dns_rr ' ,$ this ->module_name ,'process ' );
77+
78+ }
79+
80+ /*
81+ This function is called when a change in one of the registered tables is detected.
82+ The function then raises the events for the plugins.
83+ */
84+
85+ function process ($ tablename ,$ action ,$ data ) {
86+ global $ app ;
87+
88+ switch ($ tablename ) {
89+ case 'dns_soa ' :
90+ if ($ action == 'i ' ) $ app ->plugins ->raiseEvent ('dns_soa_insert ' ,$ data );
91+ if ($ action == 'u ' ) $ app ->plugins ->raiseEvent ('dns_soa_update ' ,$ data );
92+ if ($ action == 'd ' ) $ app ->plugins ->raiseEvent ('dns_soa_delete ' ,$ data );
93+ break ;
94+ case 'dns_rr ' :
95+ if ($ action == 'i ' ) $ app ->plugins ->raiseEvent ('dns_rr_insert ' ,$ data );
96+ if ($ action == 'u ' ) $ app ->plugins ->raiseEvent ('dns_rr_update ' ,$ data );
97+ if ($ action == 'd ' ) $ app ->plugins ->raiseEvent ('dns_rr_delete ' ,$ data );
98+ break ;
99+ } // end switch
100+ } // end function
101+
102+
103+ } // end class
104+
105+ ?>
0 commit comments