31include_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(
81 array(
"meta_keyword_id" => array(
'integer',$this->
getMetaId()))
89 public function delete()
94 $query =
"DELETE FROM il_meta_keyword " .
95 "WHERE meta_keyword_id = " . $ilDB->quote($this->
getMetaId(),
'integer');
106 return array(
'rbac_id' => array(
'integer',$this->
getRBACId()),
107 'obj_id' => array(
'integer', $this->
getObjId()),
108 'obj_type' => array(
'text', $this->
getObjType()),
110 'parent_id' => array(
'integer', $this->
getParentId()),
111 'keyword' => array(
'text', $this->
getKeyword()),
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 !=
"") {
An exception for terminatinating execution or to throw for unit testing.
setMetaId($a_meta_id, $a_read_data=true)
setParentType($a_parent_type)
& getKeyword($a_keyword_id)
static _getIds($a_rbac_id, $a_obj_id, $a_parent_id, $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.
static _getKeywordsByLanguage($a_rbac_id, $a_obj_id, $a_type)
Get keywords by language.
static _getMatchingKeywords($a_query, $a_type, $a_rbac_id=0)
Search for keywords.
static updateKeywords(ilMDGeneral $a_md_section, array $a_keywords)
Update keywords from input array.
setKeywordLanguage(&$lng_obj)
static _searchKeywords($a_query, $a_type, $a_rbac_id=0)
Search for objects by keywords.
static stripSlashes($a_str, $a_strip_html=true, $a_allow="")
strip slashes if magic qoutes is enabled
if(!array_key_exists('StateId', $_REQUEST)) $id
foreach($_POST as $key=> $value) $res