diff options
author | till <till@php.net> | 2008-02-14 01:33:02 +0000 |
---|---|---|
committer | till <till@php.net> | 2008-02-14 01:33:02 +0000 |
commit | 734584e2fe9da38246fe6c59671ef1f0c0e41859 (patch) | |
tree | 01b88e2b043a2893fc2f4fc0a86eeb241ec2a44b /program/include/rcube_shared.inc | |
parent | 50c7535072aeaa843b8ece23374057f110e43ee7 (diff) |
* mime_content_type() is unavailable in PHP5 and breaks sending emails with attachments
* implemented rc_mime_content_type() with file_info-failover
* added svn:ignore for phpinfo.php ;-)
Diffstat (limited to 'program/include/rcube_shared.inc')
-rw-r--r-- | program/include/rcube_shared.inc | 39 |
1 files changed, 38 insertions, 1 deletions
diff --git a/program/include/rcube_shared.inc b/program/include/rcube_shared.inc index 267914736..bec254661 100644 --- a/program/include/rcube_shared.inc +++ b/program/include/rcube_shared.inc @@ -674,5 +674,42 @@ function strrstr($haystack, $needle) } } +/** + * A method to guess the mime_type of an attachment. + * + * @param string $path Path to the file. + * @param string $failover Mime type supplied for failover. + * + * @return string + * @author Till Klampaeckel <till@php.net> + * @see http://de2.php.net/manual/en/ref.fileinfo.php + * @see http://de2.php.net/mime_content_type + */ +function rc_mime_content_type($path, $failover = 'unknown/unknown') +{ + global $CONFIG; + + $mime_magic = $CONFIG['mime_magic']; + + if (function_exists('mime_content_type')) { + return mime_content_type($path); + } + if (!extension_loaded('fileinfo')) { + if (!dl('fileinfo.' . PHP_SHLIB_SUFFIX)) { + return $failover; + } + } + $finfo = finfo_open(FILEINFO_MIME, $mime_magic); + if (!$finfo) { + return $failover; + } + $mime_type = finfo_file($finfo,$path); + if (!$mime_type) { + return $failover; + } + finfo_close($finfo); + + return $mime_type; +} -?> +?>
\ No newline at end of file |