31 include_once
'class.ilMDBase.php';
38 $this->keyword = $a_keyword;
42 return $this->keyword;
46 if(is_object($lng_obj))
48 $this->keyword_language = $lng_obj;
53 return is_object($this->keyword_language) ? $this->keyword_language :
false;
57 return is_object($this->keyword_language) ? $this->keyword_language->getLanguageCode() :
false;
65 $fields[
'meta_keyword_id'] =
array(
'integer',$next_id = $ilDB->nextId(
'il_meta_keyword'));
67 if($this->db->insert(
'il_meta_keyword',$fields))
81 if($this->db->update(
'il_meta_keyword',
97 $query =
"DELETE FROM il_meta_keyword ".
98 "WHERE meta_keyword_id = ".$ilDB->quote($this->
getMetaId() ,
'integer');
122 include_once
'Services/MetaData/classes/class.ilMDLanguageItem.php';
126 $query =
"SELECT * FROM il_meta_keyword ".
127 "WHERE meta_keyword_id = ".$ilDB->quote($this->
getMetaId() ,
'integer');
159 static function _getIds($a_rbac_id,$a_obj_id,$a_parent_id,$a_parent_type)
163 $query =
"SELECT meta_keyword_id FROM il_meta_keyword ".
164 "WHERE rbac_id = ".$ilDB->quote($a_rbac_id ,
'integer').
" ".
165 "AND obj_id = ".$ilDB->quote($a_obj_id ,
'integer').
" ".
166 "AND parent_id = ".$ilDB->quote($a_parent_id ,
'integer').
" ".
167 "AND parent_type = ".$ilDB->quote($a_parent_type ,
'text').
" ".
168 "ORDER BY meta_keyword_id ";
173 $ids[] =
$row->meta_keyword_id;
175 return $ids ? $ids :
array();
190 global
$ilDB,$ilObjDataCache;
192 $query =
"SELECT keyword,keyword_language ".
193 "FROM il_meta_keyword ".
194 "WHERE rbac_id = ".$ilDB->quote($a_rbac_id ,
'integer').
" ".
195 "AND obj_id = ".$ilDB->quote($a_obj_id ,
'integer').
" ".
196 "AND obj_type = ".$ilDB->quote(
$a_type ,
'text').
" ";
202 $keywords[
$row->keyword_language][] =
$row->keyword;
205 return $keywords ? $keywords :
array();
221 $key_string[$lng_code] = implode(
",",$keywords);
223 return $key_string ? $key_string :
array();
239 foreach((
array) explode(
' ',$a_query) as $part)
245 $qs .= ($ilDB->like(
'keyword',
'text',$part).
' ');
250 $query =
"SELECT obj_id FROM il_meta_keyword ".
251 "WHERE rbac_id = ".$ilDB->quote($a_rbac_id,
'integer').
' '.
252 'AND obj_type = '.$ilDB->quote(
$a_type,
'text').
' '.
257 $query =
"SELECT obj_id FROM il_meta_keyword ".
258 'WHERE obj_type = '.$ilDB->quote(
$a_type,
'text').
' '.
265 $obj_ids[] =
$row->obj_id;
268 return (
array) $obj_ids;
283 $query =
"SELECT DISTINCT keyword FROM il_meta_keyword ".
284 'WHERE obj_type = '.$ilDB->quote(
$a_type,
'text').
' '.
285 'AND '.$ilDB->like(
'keyword',
'text',
'%'.trim($a_query).
'%').
' ';
289 $query .=
"AND rbac_id = ".$ilDB->quote($a_rbac_id,
'integer').
' ';
295 $kws[] =
$row->keyword;
307 public static function lookupKeywords($a_rbac_id, $a_obj_id, $a_return_ids =
false)
311 $query =
"SELECT * FROM il_meta_keyword ".
312 "WHERE rbac_id = ".$ilDB->quote($a_rbac_id,
'integer').
' '.
313 "AND obj_id = ".$ilDB->quote($a_obj_id,
'integer').
' ';
319 if(strlen(
$row->keyword))
321 $kws[] =
$row->keyword;
326 $kws[] =
$row->meta_keyword_id;
340 $new_keywords =
array();
341 foreach($a_keywords as
$lang => $keywords)
343 foreach($keywords as $keyword)
345 $keyword = trim($keyword);
346 if ($keyword !=
"" &&
347 !(is_array($new_keywords[
$lang]) && in_array($keyword, $new_keywords[$lang])))
349 $new_keywords[
$lang][] = $keyword;
358 $lang = $md_key->getKeywordLanguageCode();
361 if (is_array($new_keywords[
$lang]) &&
362 in_array($md_key->getKeyword(), $new_keywords[
$lang]))
364 unset($new_keywords[$lang]
365 [array_search($md_key->getKeyword(), $new_keywords[
$lang])]);
374 foreach ($new_keywords as
$lang => $key_arr)
376 foreach($key_arr as $keyword)
& getKeyword($a_keyword_id)
static _searchKeywords($a_query, $a_type, $a_rbac_id=0)
Search for objects by keywords.
static updateKeywords(ilMDGeneral $a_md_section, array $a_keywords)
Update keywords from input array.
setMetaId($a_meta_id, $a_read_data=true)
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)
for($i=1; $i<=count($kw_cases_sel); $i+=1) $lang
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.