31 include_once
'class.ilMDBase.php';
38 $this->keyword = $a_keyword;
42 return $this->keyword;
46 if (is_object($lng_obj)) {
47 $this->keyword_language = $lng_obj;
52 return is_object($this->keyword_language) ? $this->keyword_language :
false;
56 return is_object($this->keyword_language) ? $this->keyword_language->getLanguageCode() :
false;
64 $fields[
'meta_keyword_id'] =
array(
'integer',$next_id = $ilDB->nextId(
'il_meta_keyword'));
66 if ($this->db->insert(
'il_meta_keyword', $fields)) {
78 if ($this->db->update(
89 public function delete()
94 $query =
"DELETE FROM il_meta_keyword " .
95 "WHERE meta_keyword_id = " . $ilDB->quote($this->
getMetaId(),
'integer');
119 include_once
'Services/MetaData/classes/class.ilMDLanguageItem.php';
122 $query =
"SELECT * FROM il_meta_keyword " .
123 "WHERE meta_keyword_id = " . $ilDB->quote($this->
getMetaId(),
'integer');
157 public static function _getIds($a_rbac_id, $a_obj_id, $a_parent_id, $a_parent_type)
161 $query =
"SELECT meta_keyword_id FROM il_meta_keyword " .
162 "WHERE rbac_id = " . $ilDB->quote($a_rbac_id,
'integer') .
" " .
163 "AND obj_id = " . $ilDB->quote($a_obj_id,
'integer') .
" " .
164 "AND parent_id = " . $ilDB->quote($a_parent_id,
'integer') .
" " .
165 "AND parent_type = " . $ilDB->quote($a_parent_type,
'text') .
" " .
166 "ORDER BY meta_keyword_id ";
170 $ids[] =
$row->meta_keyword_id;
172 return $ids ? $ids :
array();
187 global
$ilDB,$ilObjDataCache;
189 $query =
"SELECT keyword,keyword_language " .
190 "FROM il_meta_keyword " .
191 "WHERE rbac_id = " . $ilDB->quote($a_rbac_id,
'integer') .
" " .
192 "AND obj_id = " . $ilDB->quote($a_obj_id,
'integer') .
" " .
193 "AND obj_type = " . $ilDB->quote(
$a_type,
'text') .
" ";
197 $keywords[
$row->keyword_language][] =
$row->keyword;
200 return $keywords ? $keywords :
array();
215 $key_string[$lng_code] = implode(
",", $keywords);
217 return $key_string ? $key_string :
array();
233 foreach ((
array) explode(
' ', $a_query) as $part) {
237 $qs .= ($ilDB->like(
'keyword',
'text', $part) .
' ');
241 $query =
"SELECT obj_id FROM il_meta_keyword " .
242 "WHERE rbac_id = " . $ilDB->quote($a_rbac_id,
'integer') .
' ' .
243 'AND obj_type = ' . $ilDB->quote(
$a_type,
'text') .
' ' .
246 $query =
"SELECT obj_id FROM il_meta_keyword " .
247 'WHERE obj_type = ' . $ilDB->quote(
$a_type,
'text') .
' ' .
253 $obj_ids[] =
$row->obj_id;
256 return (
array) $obj_ids;
271 $query =
"SELECT DISTINCT keyword FROM il_meta_keyword " .
272 'WHERE obj_type = ' . $ilDB->quote(
$a_type,
'text') .
' ' .
273 'AND ' . $ilDB->like(
'keyword',
'text',
'%' . trim($a_query) .
'%') .
' ';
276 $query .=
"AND rbac_id = " . $ilDB->quote($a_rbac_id,
'integer') .
' ';
281 $kws[] =
$row->keyword;
293 public static function lookupKeywords($a_rbac_id, $a_obj_id, $a_return_ids =
false)
297 $query =
"SELECT * FROM il_meta_keyword " .
298 "WHERE rbac_id = " . $ilDB->quote($a_rbac_id,
'integer') .
' ' .
299 "AND obj_id = " . $ilDB->quote($a_obj_id,
'integer') .
' ';
302 if (!$a_return_ids) {
303 if (strlen(
$row->keyword)) {
304 $kws[] =
$row->keyword;
307 $kws[] =
$row->meta_keyword_id;
321 $new_keywords =
array();
322 foreach ($a_keywords as
$lang => $keywords) {
323 foreach ((
array) $keywords as $keyword) {
324 $keyword = trim($keyword);
325 if ($keyword !=
"" &&
326 !(is_array($new_keywords[
$lang]) && in_array($keyword, $new_keywords[$lang]))) {
327 $new_keywords[
$lang][] = $keyword;
335 $lang = $md_key->getKeywordLanguageCode();
338 if (is_array($new_keywords[
$lang]) &&
339 in_array($md_key->getKeyword(), $new_keywords[
$lang])) {
340 unset($new_keywords[$lang]
341 [array_search($md_key->getKeyword(), $new_keywords[
$lang])]);
348 foreach ($new_keywords as
$lang => $key_arr) {
349 foreach ($key_arr as $keyword) {
350 if ($keyword !=
"") {
& getKeyword($a_keyword_id)
static _searchKeywords($a_query, $a_type, $a_rbac_id=0)
Search for objects by keywords.
if(!array_key_exists('StateId', $_REQUEST)) $id
static updateKeywords(ilMDGeneral $a_md_section, array $a_keywords)
Update keywords from input array.
setMetaId($a_meta_id, $a_read_data=true)
foreach($_POST as $key=> $value) $res
setKeywordLanguage(&$lng_obj)
static stripSlashes($a_str, $a_strip_html=true, $a_allow="")
strip slashes if magic qoutes is enabled
Create styles array
The data for the language used.
static _getMatchingKeywords($a_query, $a_type, $a_rbac_id=0)
Search for keywords.
static _getKeywordsByLanguage($a_rbac_id, $a_obj_id, $a_type)
Get keywords by language.
static _getIds($a_rbac_id, $a_obj_id, $a_parent_id, $a_parent_type)
setParentType($a_parent_type)
static lookupKeywords($a_rbac_id, $a_obj_id, $a_return_ids=false)
Lookup Keywords.
static _getKeywordsByLanguageAsString($a_rbac_id, $a_obj_id, $a_type)
Get keywords by language as string.