1: <?php
  2: 
  3:   4:   5:   6:   7:   8:   9:  10:  11: 
 12: 
 13: 
 14: defined('CON_FRAMEWORK') || die('Illegal call: Missing framework initialization - request aborted.');
 15: 
 16:  17:  18:  19:  20:  21:  22:  23:  24:  25:  26:  27:  28:  29:  30:  31:  32:  33:  34:  35:  36:  37:  38: 
 39: class SolrRightBottomPage extends cGuiPage {
 40: 
 41:      42:  43:  44: 
 45:     private $_clientOptions;
 46: 
 47:      48:  49: 
 50:     public function __construct() {
 51: 
 52:         global $action;
 53: 
 54:         parent::__construct('right_bottom', Solr::getName());
 55: 
 56:         $this->addStyle('smoothness/jquery-ui-1.8.20.custom.css');
 57:         $this->addStyle('right_bottom.css');
 58:         $this->addScript('right_bottom.js');
 59: 
 60:         $this->set('s', 'CONTENIDO', cRegistry::getBackendSessionId());
 61: 
 62:         $this->set('s', 'I18N_CLIENT_OPTIONS', Solr::i18n('CLIENT_OPTIONS'));
 63:         $this->set('s', 'I18N_OPTION', Solr::i18n('OPTION'));
 64:         $this->set('s', 'I18N_VALUE', Solr::i18n('VALUE'));
 65:         $this->set('s', 'I18N_DESCRIPTION', Solr::i18n('DESCRIPTION'));
 66:         $this->set('s', 'I18N_DESCR_HOSTNAME', Solr::i18n('DESCR_HOSTNAME'));
 67:         $this->set('s', 'I18N_DESCR_PORT', Solr::i18n('DESCR_PORT'));
 68:         $this->set('s', 'I18N_DESCR_PATH', Solr::i18n('DESCR_PATH'));
 69:         $this->set('s', 'I18N_DESCR_LOGIN', Solr::i18n('DESCR_LOGIN'));
 70:         $this->set('s', 'I18N_DESCR_PASSWORD', Solr::i18n('DESCR_PASSWORD'));
 71:         $this->set('s', 'I18N_DESCR_SECURE', Solr::i18n('DESCR_SECURE'));
 72:         $this->set('s', 'I18N_DESCR_TIMEOUT', Solr::i18n('DESCR_TIMEOUT'));
 73:         $this->set('s', 'I18N_DESCR_WT', Solr::i18n('DESCR_WT'));
 74:         $this->set('s', 'I18N_DESCR_PROXY_HOST', Solr::i18n('DESCR_PROXY_HOST'));
 75:         $this->set('s', 'I18N_DESCR_PROXY_PORT', Solr::i18n('DESCR_PROXY_PORT'));
 76:         $this->set('s', 'I18N_DESCR_PROXY_LOGIN', Solr::i18n('DESCR_PROXY_LOGIN'));
 77:         $this->set('s', 'I18N_DESCR_PROXY_PASSWORD', Solr::i18n('DESCR_PROXY_PASSWORD'));
 78:         $this->set('s', 'I18N_DESCR_SSL_CERT', Solr::i18n('DESCR_SSL_CERT'));
 79:         $this->set('s', 'I18N_DESCR_SSL_KEY', Solr::i18n('DESCR_SSL_KEY'));
 80:         $this->set('s', 'I18N_DESCR_SSL_KEYPASSWORD', Solr::i18n('DESCR_SSL_KEYPASSWORD'));
 81:         $this->set('s', 'I18N_DESCR_SSL_CAINFO', Solr::i18n('DESCR_SSL_CAINFO'));
 82:         $this->set('s', 'I18N_DESCR_SSL_CAPATH', Solr::i18n('DESCR_SSL_CAPATH'));
 83:         $this->set('s', 'I18N_DESCR_RELOAD', Solr::i18n('DESCR_RELOAD'));
 84:         $this->set('s', 'I18N_DESCR_REINDEX', Solr::i18n('DESCR_REINDEX'));
 85: 
 86:         
 87:         $this->_clientOptions = Solr::getClientOptions();
 88:         $this->set('s', 'HOSTNAME', $this->_clientOptions['hostname']);
 89:         $this->set('s', 'PORT', $this->_clientOptions['port']);
 90:         $this->set('s', 'PATH', $this->_clientOptions['path']);
 91:         $this->set('s', 'LOGIN', $this->_clientOptions['login']);
 92:         $this->set('s', 'PASSWORD', $this->_clientOptions['password']);
 93:         $this->set('s', 'SECURE', 'true' == $this->_clientOptions['secure'] ? 'checked="checked"' : '');
 94:         $this->set('s', 'TIMEOUT', $this->_clientOptions['timeout']);
 95:         $this->set('s', 'WT', $this->_clientOptions['wt']);
 96:         $this->set('s', 'PROXY_HOST', $this->_clientOptions['proxy_host']);
 97:         $this->set('s', 'PROXY_PORT', $this->_clientOptions['proxy_port']);
 98:         $this->set('s', 'PROXY_LOGIN', $this->_clientOptions['proxy_login']);
 99:         $this->set('s', 'PROXY_PASSWORD', $this->_clientOptions['proxy_password']);
100:         $this->set('s', 'SSL_CERT', $this->_clientOptions['ssl_cert']);
101:         $this->set('s', 'SSL_KEY', $this->_clientOptions['ssl_key']);
102:         $this->set('s', 'SSL_KEYPASSWORD', $this->_clientOptions['ssl_keypassword']);
103:         $this->set('s', 'SSL_CAINFO', $this->_clientOptions['ssl_cainfo']);
104:         $this->set('s', 'SSL_CAPATH', $this->_clientOptions['ssl_capath']);
105: 
106:         
107:         $validClientOptions = true;
108:         $validClientOptions &= array_key_exists('hostname', $this->_clientOptions);
109:         $validClientOptions &= array_key_exists('port', $this->_clientOptions);
110:         $validClientOptions &= array_key_exists('path', $this->_clientOptions);
111:         $validClientOptions &= array_key_exists('login', $this->_clientOptions);
112:         $validClientOptions &= array_key_exists('password', $this->_clientOptions);
113:         $this->set('s', 'DISABLED_RELOAD', $validClientOptions ? '' : 'disabled="disabled"');
114:         $this->set('s', 'DISABLED_REINDEX', $validClientOptions ? '' : 'disabled="disabled"');
115: 
116:         
117:         try {
118:             $this->_dispatch($action);
119:         } catch (InvalidArgumentException $e) {
120:             $cGuiNotification = new cGuiNotification();
121:             $notification = $cGuiNotification->returnNotification(cGuiNotification::LEVEL_ERROR, $e->getMessage());
122:             $this->set('s', 'notification', $notification);
123:         }
124:     }
125: 
126:     127: 128: 129: 130: 131: 
132:     protected function _dispatch($action) {
133:         global $area;
134: 
135:         
136:         $perm = cRegistry::getPerm();
137:         if (!$perm->have_perm_area_action($area, $action)) {
138:             throw new IllegalStateException('no permissions');
139:         }
140: 
141:         if (NULL === $action) {
142:             $this->set('s', 'notification', '');
143:             $this->set('s', 'content', '');
144:             return;
145:         }
146: 
147:         
148:         try {
149:             switch ($action) {
150:                 case 'store_client_options':
151:                     $this->set('s', 'notification', $this->_storeClientOptions());
152:                     break;
153:                 case 'reload':
154:                     $this->set('s', 'notification', $this->_reload());
155:                     break;
156:                 case 'reindex':
157:                     $this->set('s', 'notification', $this->_reindex());
158:                     break;
159:                 default:
160:                     throw new InvalidArgumentException('unknown action ' . $action);
161:             }
162:         } catch (Exception $e) {
163:             $notification = Solr::notifyException($e);
164:         }
165:     }
166: 
167:     168: 169: 170: 
171:     private function _storeClientOptions() {
172:         $settings = 'secure,hostname,port,path,wt,login,password,timeout,';
173:         $settings .= 'proxy_host,proxy_port,proxy_login,proxy_password,';
174:         $settings .= 'ssl_cert,ssl_key,ssl_keypassword,ssl_cainfo,ssl_capath';
175:         foreach (explode(',', $settings) as $setting) {
176:             $value = $_POST[$setting];
177:             if (0 < strlen(trim($value))) {
178:                 setSystemProperty('solr', $setting, $value);
179:             } else {
180:                 
181:                 
182:                 deleteSystemProperty('solr', $setting);
183:             }
184:         }
185:         $cGuiNotification = new cGuiNotification();
186:         return $cGuiNotification->returnNotification(cGuiNotification::LEVEL_INFO, 'client options were stored');
187:     }
188: 
189:     190: 191: 192: 193: 194: 195: 196: 197: 198: 
199:     private function _reload() {
200: 
201:         
202:         
203:         $url = 'http://';
204:         $url .= $this->_clientOptions['login'] . ':' . $this->_clientOptions['password'] . '@';
205:         $url .= $this->_clientOptions['hostname'] . ':' . $this->_clientOptions['port'];
206:         $url .= '/solr/admin/cores?' . http_build_query(array(
207:                     'action' => 'RELOAD',
208:                     'core' => array_pop(explode('/', $this->_clientOptions['path']))
209:         ));
210: 
211:         
212:         $ch = curl_init();
213: 
214:         $data = false;
215:         if (false !== $ch) {
216: 
217:             $opt = array(
218:                 
219:                 CURLOPT_URL => $url,
220:                 
221:                 CURLOPT_HTTPGET => true,
222:                 
223:                 
224:                 CURLOPT_USERAGENT => 'CONTENIDO Solr Plugin v1.0',
225:                 
226:                 
227:                 CURLOPT_TIMEOUT_MS => 5000,
228:                 
229:                 
230:                 CURLOPT_CONNECTTIMEOUT_MS => 5000,
231:                 
232:                 CURLOPT_RETURNTRANSFER => 1,
233:                 
234:                 CURLOPT_HEADER => false
235:             );
236: 
237:             curl_setopt_array($ch, $opt);
238: 
239:             
240:             $data = curl_exec($ch);
241: 
242:             
243:             $curlInfo = curl_getinfo($ch);
244: 
245:             
246:             curl_close($ch);
247: 
248:             if (200 !== (int) $curlInfo['http_code']) {
249:                 $msg = 'HTTP status code ' . $curlInfo['http_code'];
250:                 
251:                 
252:                 $msg .= "\n(complete cUrl-Info:";
253:                 foreach ($curlInfo as $key => $value) {
254:                     $msg .= "\n\t" . $key . ' => ' . $value;
255:                 }
256:                 $msg .= "\n)";
257: 
258:                 throw new cException($msg);
259:             }
260:         }
261: 
262:         if (false === $data) {
263:             throw new cException('server did not answer');
264:         }
265: 
266:         $cGuiNotification = new cGuiNotification();
267:         return $cGuiNotification->returnNotification(cGuiNotification::LEVEL_INFO, 'core was reloaded');
268:     }
269: 
270:     271: 272: 273: 
274:     private function _reindex() {
275: 
276:         $cfg = cRegistry::getConfig();
277: 
278:         
279:         $db = cRegistry::getDb();
280:         $db->query("-- SolrRightBottomPage->_reindex()
281:             SELECT
282:                 art.idclient
283:                 , art_lang.idlang
284:                 , cat_art.idcat
285:                 , cat_lang.idcatlang
286:                 , art_lang.idart
287:                 , art_lang.idartlang
288:             FROM
289:                 `{$cfg[tab][art_lang]}` AS art_lang
290:             INNER JOIN
291:                 `{$cfg[tab][art]}` AS art
292:             ON
293:                 art_lang.idart = art.idart
294:             INNER JOIN
295:                 `{$cfg[tab][cat_art]}` AS cat_art
296:             ON
297:                 art_lang.idart = cat_art.idart
298:             INNER JOIN
299:                 `{$cfg[tab][cat_lang]}` AS cat_lang
300:             ON
301:                 cat_art.idcat = cat_lang.idcat
302:                 AND art_lang.idlang = cat_lang.idlang
303:             ORDER BY
304:                 art_lang.idartlang
305:             ;");
306: 
307:         $articleIds = array();
308:         while ($db->nextRecord()) {
309:             array_push($articleIds, array(
310:                 'idclient' => $db->f('idclient'),
311:                 'idlang' => $db->f('idlang'),
312:                 'idcat' => $db->f('idcat'),
313:                 'idcatlang' => $db->f('idcatlang'),
314:                 'idart' => $db->f('idart'),
315:                 'idartlang' => $db->f('idartlang')
316:             ));
317:         }
318: 
319:         $indexer = new SolrIndexer($articleIds);
320:         $indexer->updateArticles();
321: 
322:         $cGuiNotification = new cGuiNotification();
323:         return $cGuiNotification->returnNotification(cGuiNotification::LEVEL_INFO, 'core was reindexed');
324:     }
325: 
326: }
327: