PluginProbe ʕ •ᴥ•ʔ
VikAppointments Services Booking Calendar / trunk
VikAppointments Services Booking Calendar vtrunk
trunk 1.2.17 1.2.18 1.2.19
vikappointments / admin / controllers / configsmsapi.php
vikappointments / admin / controllers Last commit date
analytics.php 4 years ago apiban.php 4 years ago apilog.php 4 years ago apiplugin.php 4 years ago apiuser.php 4 years ago backup.php 4 years ago calendar.php 4 years ago city.php 4 years ago closure.php 1 month ago configapp.php 4 years ago configcldays.php 2 years ago configcron.php 4 years ago configemp.php 4 years ago configsmsapi.php 4 years ago configuration.php 1 month ago conversion.php 1 year ago country.php 4 years ago coupon.php 4 years ago coupongroup.php 4 years ago cronjob.php 2 years ago cronjoblog.php 4 years ago customer.php 4 months ago customf.php 1 year ago dashboard.php 4 years ago emplocwdays.php 4 years ago employee.php 1 year ago emprates.php 4 years ago export.php 4 years ago exportres.php 4 years ago file.php 4 months ago findreservation.php 1 month ago group.php 4 years ago import.php 4 years ago index.html 4 years ago invoice.php 1 month ago langcustomf.php 4 years ago langemployee.php 4 years ago langgroup.php 4 years ago langmedia.php 4 years ago langoption.php 4 years ago langoptiongroup.php 4 years ago langpackage.php 4 years ago langpackgroup.php 4 years ago langpayment.php 4 years ago langservice.php 4 years ago langstatuscode.php 4 years ago langsubscr.php 4 years ago langtax.php 4 years ago location.php 4 years ago mailtext.php 2 years ago makerecurrence.php 1 month ago media.php 4 years ago multiorder.php 4 years ago option.php 4 months ago optiongroup.php 4 years ago package.php 2 years ago packgroup.php 4 years ago packorder.php 1 year ago payment.php 4 years ago rate.php 4 years ago reportsemp.php 4 years ago reportsser.php 4 years ago reservation.php 1 month ago restriction.php 4 years ago review.php 4 years ago service.php 1 year ago serworkday.php 4 months ago state.php 4 years ago statuscode.php 4 years ago subscription.php 4 years ago subscrorder.php 4 years ago tag.php 4 years ago tax.php 4 years ago usernote.php 4 years ago waitinglist.php 4 years ago webhook.php 4 years ago wizard.php 1 year ago
configsmsapi.php
268 lines
1 <?php
2 /**
3 * @package VikAppointments
4 * @subpackage core
5 * @author E4J s.r.l.
6 * @copyright Copyright (C) 2021 E4J s.r.l. All Rights Reserved.
7 * @license http://www.gnu.org/licenses/gpl-2.0.html GNU/GPL
8 * @link https://vikwp.com
9 */
10
11 // No direct access
12 defined('ABSPATH') or die('No script kiddies please!');
13
14 VAPLoader::import('libraries.mvc.controllers.admin');
15
16 /**
17 * VikAppointments sms api configuration controller.
18 *
19 * @since 1.7
20 */
21 class VikAppointmentsControllerConfigsmsapi extends VAPControllerAdmin
22 {
23 /**
24 * Task used to save the record data set in the request.
25 * After saving, the user is redirected to the management
26 * page of the record that has been saved.
27 *
28 * @return boolean
29 */
30 public function save()
31 {
32 $app = JFactory::getApplication();
33 $input = $app->input;
34 $user = JFactory::getUser();
35
36 /**
37 * Added token validation.
38 *
39 * @since 1.7
40 */
41 if (!JSession::checkToken())
42 {
43 // back to main list, missing CSRF-proof token
44 $app->enqueueMessage(JText::translate('JINVALID_TOKEN'), 'error');
45 $this->cancel();
46
47 return false;
48 }
49
50 // check user permissions
51 if (!$user->authorise('core.access.config', 'com_vikappointments'))
52 {
53 // back to main list, not authorised to access the configuration
54 $app->enqueueMessage(JText::translate('JERROR_ALERTNOAUTHOR'), 'error');
55 $this->cancel();
56
57 return false;
58 }
59
60 $args = array();
61
62 ////////////////////////////////////////////////////
63 ///////////////////// SETTINGS /////////////////////
64 ////////////////////////////////////////////////////
65
66 // BASIC
67
68 $args['smsapi'] = $input->getString('smsapi');
69 $args['smsenabled'] = $input->getUint('smsenabled', 0);
70 $args['smsapiadminphone'] = $input->getString('smsapiadminphone');
71 $args['smsapito'] = array(
72 $input->getUint('smsapitocust', 0),
73 $input->getUint('smsapitoemp', 0),
74 $input->getUint('smsapitoadmin', 0),
75 );
76
77 // PARAMS
78
79 try
80 {
81 $args['smsapifields'] = array();
82
83 // get SMS driver configuration
84 $smsconfig = VAPApplication::getInstance()->getSmsConfig($args['smsapi']);
85
86 foreach ($smsconfig as $k => $p)
87 {
88 $args['smsapifields'][$k] = $input->get('smsparam_' . $k, '', 'string');
89 }
90 }
91 catch (Exception $e)
92 {
93 // SMS driver not supported
94 }
95
96 ////////////////////////////////////////////////////
97 //////////////////// TEMPLATES /////////////////////
98 ////////////////////////////////////////////////////
99
100 // CUSTOMER
101
102 $args['smstmplcust'] = array();
103 $args['smstmplcustmulti'] = array();
104
105 $sms_cust_tmpl = $input->get('smstmplcust', array(), 'array');
106
107 $languages = VikAppointments::getKnownLanguages();
108
109 for ($i = 0; $i < count($languages); $i++)
110 {
111 $args['smstmplcust'][$languages[$i]] = $sms_cust_tmpl[0][$i];
112 $args['smstmplcustmulti'][$languages[$i]] = $sms_cust_tmpl[1][$i];
113 }
114
115 // ADMINISTRATOR
116
117 $sms_admin_tmpl = $input->get('smstmpladmin', array(), 'array');
118
119 $args['smstmpladmin'] = $sms_admin_tmpl[0];
120 $args['smstmpladminmulti'] = $sms_admin_tmpl[1];
121
122 ////////////////////////////////////////////////////
123
124 // get configuration model
125 $config = $this->getModel();
126
127 // Save all configuration.
128 // Do not care of any errors.
129 $changed = $config->saveAll($args);
130
131 if ($changed)
132 {
133 // display generic successful message
134 $app->enqueueMessage(JText::translate('JLIB_APPLICATION_SAVE_SUCCESS'));
135 }
136
137 // redirect to configuration page
138 $this->cancel();
139
140 return true;
141 }
142
143 /**
144 * Redirects the users to the main records list.
145 *
146 * @return void
147 */
148 public function cancel()
149 {
150 $this->setRedirect('index.php?option=com_vikappointments&view=editconfigsmsapi');
151 }
152
153 /**
154 * AJAX end-point to load the configuration fields
155 * of the requested SMS API driver.
156 *
157 * @return void
158 */
159 public function driverfields()
160 {
161 $input = JFactory::getApplication()->input;
162
163 /**
164 * Added token validation.
165 *
166 * @since 1.7
167 */
168 if (!JSession::checkToken())
169 {
170 // missing CSRF-proof token
171 UIErrorFactory::raiseError(403, JText::translate('JINVALID_TOKEN'));
172 }
173
174 $driver = $input->getString('driver');
175
176 try
177 {
178 // access driver config through platform handler
179 $form = VAPApplication::getInstance()->getSmsConfig($driver);
180 }
181 catch (Exception $e)
182 {
183 // raise AJAX error, driver not found
184 UIErrorFactory::raiseError(404, JText::translate('VAPSMSESTIMATEERR1'));
185 }
186
187 $params = array();
188
189 // retrieve SMS driver configuration
190 $params = VikAppointments::getSmsApiFields();
191
192 // build display data
193 $data = array(
194 'fields' => $form,
195 'params' => $params,
196 'prefix' => 'smsparam_',
197 );
198
199 // render payment form
200 $html = JLayoutHelper::render('form.fields', $data);
201
202 // send JSON to caller
203 $this->sendJSON(json_encode($html));
204 }
205
206 /**
207 * AJAX end-point to estimate the remaining balance of
208 * the current SMS driver.
209 *
210 * @return void
211 */
212 public function apicredit()
213 {
214 $input = JFactory::getApplication()->input;
215
216 /**
217 * Added token validation.
218 *
219 * @since 1.7
220 */
221 if (!JSession::checkToken())
222 {
223 // missing CSRF-proof token
224 UIErrorFactory::raiseError(403, JText::translate('JINVALID_TOKEN'));
225 }
226
227 $driver = $input->getString('driver');
228
229 try
230 {
231 // access driver instance through platform handler
232 $api = VAPApplication::getInstance()->getSmsInstance($driver);
233 }
234 catch (Exception $e)
235 {
236 // raise AJAX error, driver not found
237 UIErrorFactory::raiseError(404, JText::translate('VAPSMSESTIMATEERR1'));
238 }
239
240 $phone = $input->get('phone', '', 'string');
241
242 if (empty($phone))
243 {
244 // use admin phone number
245 $phone = VAPFactory::getConfig()->get('smsapiadminphone');
246 }
247
248 // make sure the driver support an estimation feature
249 if (!method_exists($api, 'estimate'))
250 {
251 // raise AJAX error, estimate not supported
252 UIErrorFactory::raiseError(405, JText::translate('VAPSMSESTIMATEERR2'));
253 }
254
255 // try to estimate
256 $result = $api->estimate($phone, 'Sample');
257
258 if ($result->errorCode != 0)
259 {
260 // raise AJAX error, unable to estimate
261 UIErrorFactory::raiseError(500, JText::translate('VAPSMSESTIMATEERR3'));
262 }
263
264 // return the plain user credit
265 $this->sendJSON($result->userCredit);
266 }
267 }
268