forked from GNUsocial/gnu-social
Fix for attachment "h bug": posting a shortened link to an oembed-able resource that has been previously used in the system would incorrectly save "h" as the item's type and title.
This commit is contained in:
parent
4741683298
commit
f02cb7c718
@ -67,7 +67,14 @@ class File extends Memcached_DataObject
|
|||||||
return $att;
|
return $att;
|
||||||
}
|
}
|
||||||
|
|
||||||
function saveNew($redir_data, $given_url) {
|
/**
|
||||||
|
* Save a new file record.
|
||||||
|
*
|
||||||
|
* @param array $redir_data lookup data eg from File_redirection::where()
|
||||||
|
* @param string $given_url
|
||||||
|
* @return File
|
||||||
|
*/
|
||||||
|
function saveNew(array $redir_data, $given_url) {
|
||||||
$x = new File;
|
$x = new File;
|
||||||
$x->url = $given_url;
|
$x->url = $given_url;
|
||||||
if (!empty($redir_data['protected'])) $x->protected = $redir_data['protected'];
|
if (!empty($redir_data['protected'])) $x->protected = $redir_data['protected'];
|
||||||
|
@ -81,7 +81,13 @@ class File_oembed extends Memcached_DataObject
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function saveNew($data, $file_id) {
|
/**
|
||||||
|
* Save embedding info for a new file.
|
||||||
|
*
|
||||||
|
* @param array $data lookup data as from File_redirection::where
|
||||||
|
* @param int $file_id
|
||||||
|
*/
|
||||||
|
function saveNew(array $data, $file_id) {
|
||||||
$file_oembed = new File_oembed;
|
$file_oembed = new File_oembed;
|
||||||
$file_oembed->file_id = $file_id;
|
$file_oembed->file_id = $file_id;
|
||||||
$file_oembed->version = $data->version;
|
$file_oembed->version = $data->version;
|
||||||
|
@ -115,11 +115,45 @@ class File_redirection extends Memcached_DataObject
|
|||||||
return $ret;
|
return $ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check if this URL is a redirect and return redir info.
|
||||||
|
* If a File record is present for this URL, it is not considered a redirect.
|
||||||
|
* If a File_redirection record is present for this URL, the recorded target is returned.
|
||||||
|
*
|
||||||
|
* If no File or File_redirect record is present, the URL is hit and any
|
||||||
|
* redirects are followed, up to 10 levels or until a protected URL is
|
||||||
|
* reached.
|
||||||
|
*
|
||||||
|
* @param string $in_url
|
||||||
|
* @return mixed one of:
|
||||||
|
* string - target URL, if this is a direct link or a known redirect
|
||||||
|
* array - redirect info if this is an *unknown* redirect:
|
||||||
|
* associative array with the following elements:
|
||||||
|
* code: HTTP status code
|
||||||
|
* redirects: count of redirects followed
|
||||||
|
* url: URL string of final target
|
||||||
|
* type (optional): MIME type from Content-Type header
|
||||||
|
* size (optional): byte size from Content-Length header
|
||||||
|
* time (optional): timestamp from Last-Modified header
|
||||||
|
*/
|
||||||
function where($in_url) {
|
function where($in_url) {
|
||||||
$ret = File_redirection::_redirectWhere_imp($in_url);
|
$ret = File_redirection::_redirectWhere_imp($in_url);
|
||||||
return $ret;
|
return $ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Shorten a URL with the current user's configured shortening
|
||||||
|
* options, if applicable.
|
||||||
|
*
|
||||||
|
* If it cannot be shortened or the "short" URL is longer than the
|
||||||
|
* original, the original is returned.
|
||||||
|
*
|
||||||
|
* If the referenced item has not been seen before, embedding data
|
||||||
|
* may be saved.
|
||||||
|
*
|
||||||
|
* @param string $long_url
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
function makeShort($long_url) {
|
function makeShort($long_url) {
|
||||||
|
|
||||||
$canon = File_redirection::_canonUrl($long_url);
|
$canon = File_redirection::_canonUrl($long_url);
|
||||||
@ -141,11 +175,20 @@ class File_redirection extends Memcached_DataObject
|
|||||||
// store it
|
// store it
|
||||||
$file = File::staticGet('url', $long_url);
|
$file = File::staticGet('url', $long_url);
|
||||||
if (empty($file)) {
|
if (empty($file)) {
|
||||||
|
// Check if the target URL is itself a redirect...
|
||||||
$redir_data = File_redirection::where($long_url);
|
$redir_data = File_redirection::where($long_url);
|
||||||
$file = File::saveNew($redir_data, $long_url);
|
if (is_array($redir_data)) {
|
||||||
$file_id = $file->id;
|
// We haven't seen the target URL before.
|
||||||
if (!empty($redir_data['oembed']['json'])) {
|
// Save file and embedding data about it!
|
||||||
File_oembed::saveNew($redir_data['oembed']['json'], $file_id);
|
$file = File::saveNew($redir_data, $long_url);
|
||||||
|
$file_id = $file->id;
|
||||||
|
if (!empty($redir_data['oembed']['json'])) {
|
||||||
|
File_oembed::saveNew($redir_data['oembed']['json'], $file_id);
|
||||||
|
}
|
||||||
|
} else if (is_string($redir_data)) {
|
||||||
|
// The file is a known redirect target.
|
||||||
|
$file = File::staticGet('url', $redir_data);
|
||||||
|
$file_id = $file->id;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
$file_id = $file->id;
|
$file_id = $file->id;
|
||||||
|
Loading…
Reference in New Issue
Block a user