Added workarounds to fetch the complete item content
This commit is contained in:
parent
5f3f349006
commit
c07b81c5b9
|
@ -555,7 +555,7 @@ class Item extends BaseObject
|
||||||
// We cannot simply expand the condition to check for origin entries
|
// We cannot simply expand the condition to check for origin entries
|
||||||
// The condition needn't to be a simple array but could be a complex condition.
|
// The condition needn't to be a simple array but could be a complex condition.
|
||||||
// And we have to execute this query before the update to ensure to fetch the same data.
|
// And we have to execute this query before the update to ensure to fetch the same data.
|
||||||
$items = dba::select('item', ['id', 'origin', 'uri'], $condition);
|
$items = dba::select('item', ['id', 'origin', 'uri', 'plink'], $condition);
|
||||||
|
|
||||||
$content_fields = [];
|
$content_fields = [];
|
||||||
foreach (self::CONTENT_FIELDLIST as $field) {
|
foreach (self::CONTENT_FIELDLIST as $field) {
|
||||||
|
@ -579,7 +579,10 @@ class Item extends BaseObject
|
||||||
$rows = dba::affected_rows();
|
$rows = dba::affected_rows();
|
||||||
|
|
||||||
while ($item = dba::fetch($items)) {
|
while ($item = dba::fetch($items)) {
|
||||||
self::updateContent($content_fields, ['id' => $item['icid']]);
|
if (!empty($item['plink'])) {
|
||||||
|
$content_fields['plink'] = $item['plink'];
|
||||||
|
}
|
||||||
|
self::updateContent($content_fields, ['uri' => $item['uri']]);
|
||||||
Term::insertFromTagFieldByItemId($item['id']);
|
Term::insertFromTagFieldByItemId($item['id']);
|
||||||
Term::insertFromFileFieldByItemId($item['id']);
|
Term::insertFromFileFieldByItemId($item['id']);
|
||||||
self::updateThread($item['id']);
|
self::updateThread($item['id']);
|
||||||
|
@ -1033,6 +1036,7 @@ class Item extends BaseObject
|
||||||
|
|
||||||
// When there is no content then we don't post it
|
// When there is no content then we don't post it
|
||||||
if ($item['body'].$item['title'] == '') {
|
if ($item['body'].$item['title'] == '') {
|
||||||
|
logger('No body, no title.');
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1460,19 +1464,15 @@ class Item extends BaseObject
|
||||||
}
|
}
|
||||||
|
|
||||||
// Do we already have this content?
|
// Do we already have this content?
|
||||||
|
if (!dba::exists('item-content', ['uri' => $item['uri']])) {
|
||||||
|
dba::insert('item-content', $fields, true);
|
||||||
|
}
|
||||||
|
|
||||||
$item_content = dba::selectFirst('item-content', ['id'], ['uri' => $item['uri']]);
|
$item_content = dba::selectFirst('item-content', ['id'], ['uri' => $item['uri']]);
|
||||||
if (DBM::is_result($item_content)) {
|
if (DBM::is_result($item_content)) {
|
||||||
$item['icid'] = $item_content['id'];
|
$item['icid'] = $item_content['id'];
|
||||||
logger('Assigned content for URI '.$item['uri'].' ('.$item['icid'].')');
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
dba::insert('item-content', $fields);
|
|
||||||
|
|
||||||
$item['icid'] = dba::lastInsertId();
|
|
||||||
|
|
||||||
logger('Insert content for URI '.$item['uri'].' ('.$item['icid'].')');
|
logger('Insert content for URI '.$item['uri'].' ('.$item['icid'].')');
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1495,7 +1495,12 @@ class Item extends BaseObject
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
logger('Update content for id '.$condition['id']);
|
if (!empty($item['plink'])) {
|
||||||
|
$fields['plink'] = $item['plink'];
|
||||||
|
$fields['uri-plink-hash'] = hash('sha1', $item['plink']).hash('sha1', $condition['uri']);
|
||||||
|
}
|
||||||
|
|
||||||
|
logger('Update content for URI '.$condition['uri']);
|
||||||
|
|
||||||
dba::update('item-content', $fields, $condition, true);
|
dba::update('item-content', $fields, $condition, true);
|
||||||
}
|
}
|
||||||
|
@ -1523,6 +1528,15 @@ class Item extends BaseObject
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$fields = self::CONTENT_FIELDLIST;
|
||||||
|
$fields[] = 'author-link';
|
||||||
|
$fields[] = 'owner-link';
|
||||||
|
|
||||||
|
$content = self::selectFirst($fields, ['id' => $itemid]);
|
||||||
|
if (DBM::is_result($content)) {
|
||||||
|
$item = array_merge($item, $content);
|
||||||
|
}
|
||||||
|
|
||||||
unset($item['id']);
|
unset($item['id']);
|
||||||
unset($item['parent']);
|
unset($item['parent']);
|
||||||
unset($item['mention']);
|
unset($item['mention']);
|
||||||
|
@ -1646,6 +1660,15 @@ class Item extends BaseObject
|
||||||
|
|
||||||
$item = dba::selectFirst('item', [], ['id' => $itemid]);
|
$item = dba::selectFirst('item', [], ['id' => $itemid]);
|
||||||
|
|
||||||
|
$fields = self::CONTENT_FIELDLIST;
|
||||||
|
$fields[] = 'author-link';
|
||||||
|
$fields[] = 'owner-link';
|
||||||
|
|
||||||
|
$content = self::selectFirst($fields, ['id' => $itemid]);
|
||||||
|
if (DBM::is_result($content)) {
|
||||||
|
$item = array_merge($item, $content);
|
||||||
|
}
|
||||||
|
|
||||||
if (DBM::is_result($item) && ($item["allow_cid"] == '') && ($item["allow_gid"] == '') &&
|
if (DBM::is_result($item) && ($item["allow_cid"] == '') && ($item["allow_gid"] == '') &&
|
||||||
($item["deny_cid"] == '') && ($item["deny_gid"] == '')) {
|
($item["deny_cid"] == '') && ($item["deny_gid"] == '')) {
|
||||||
|
|
||||||
|
@ -1659,9 +1682,9 @@ class Item extends BaseObject
|
||||||
unset($item['origin']);
|
unset($item['origin']);
|
||||||
unset($item['starred']);
|
unset($item['starred']);
|
||||||
if ($item['uri'] == $item['parent-uri']) {
|
if ($item['uri'] == $item['parent-uri']) {
|
||||||
$item['contact-id'] = Contact::getIdForURL($item['owner-link']);
|
$item['contact-id'] = $item['owner-id'];
|
||||||
} else {
|
} else {
|
||||||
$item['contact-id'] = Contact::getIdForURL($item['author-link']);
|
$item['contact-id'] = $item['author-id'];
|
||||||
}
|
}
|
||||||
|
|
||||||
if (in_array($item['type'], ["net-comment", "wall-comment"])) {
|
if (in_array($item['type'], ["net-comment", "wall-comment"])) {
|
||||||
|
|
Loading…
Reference in a new issue