2010-12-02 23:34:41 +00:00
|
|
|
<?php
|
|
|
|
|
/**
|
|
|
|
|
* users_ViewPhoto.php
|
2012-10-17 18:13:05 -04:00
|
|
|
*
|
2010-12-02 23:34:41 +00:00
|
|
|
* ProcessMaker Open Source Edition
|
|
|
|
|
* Copyright (C) 2004 - 2008 Colosa Inc.23
|
2012-10-17 18:13:05 -04:00
|
|
|
*
|
2010-12-02 23:34:41 +00:00
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
|
* it under the terms of the GNU Affero General Public License as
|
|
|
|
|
* published by the Free Software Foundation, either version 3 of the
|
|
|
|
|
* License, or (at your option) any later version.
|
|
|
|
|
*
|
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
2012-10-17 18:13:05 -04:00
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
2010-12-02 23:34:41 +00:00
|
|
|
* GNU Affero General Public License for more details.
|
2012-10-17 18:13:05 -04:00
|
|
|
*
|
2010-12-02 23:34:41 +00:00
|
|
|
* You should have received a copy of the GNU Affero General Public License
|
2012-10-17 18:13:05 -04:00
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
*
|
|
|
|
|
* For more information, contact Colosa Inc, 2566 Le Jeune Rd.,
|
2010-12-02 23:34:41 +00:00
|
|
|
* Coral Gables, FL, 33134, USA, or email info@colosa.com.
|
|
|
|
|
*/
|
2012-10-17 18:13:05 -04:00
|
|
|
if (($RBAC_Response = $RBAC->userCanAccess( "PM_LOGIN" )) != 1)
|
|
|
|
|
return $RBAC_Response;
|
2010-12-02 23:34:41 +00:00
|
|
|
|
2012-10-17 18:13:05 -04:00
|
|
|
$direction = PATH_IMAGES_ENVIRONMENT_USERS . $uid = (isset( $_SESSION['CURRENT_USER'] ) ? $_SESSION['CURRENT_USER'] : $_SESSION['USER_LOGGED']) . ".gif";
|
2010-12-02 23:34:41 +00:00
|
|
|
// header('Pragma: ');
|
|
|
|
|
// header('Cache-Control: cache');
|
|
|
|
|
|
|
|
|
|
|
2012-10-17 18:13:05 -04:00
|
|
|
if (! file_exists( $direction )) {
|
|
|
|
|
$direction = PATH_HOME . 'public_html/images/user.gif';
|
|
|
|
|
}
|
|
|
|
|
G::sendHeaders( $direction );
|
2010-12-02 23:34:41 +00:00
|
|
|
|
2012-10-17 18:13:05 -04:00
|
|
|
DumpHeaders( $direction );
|
2010-12-02 23:34:41 +00:00
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* This function is verified to work with Netscape and the *very latest*
|
|
|
|
|
* version of IE. I don't know if it works with Opera, but it should now.
|
|
|
|
|
*/
|
2012-10-17 18:13:05 -04:00
|
|
|
function DumpHeaders ($filename)
|
2010-12-02 23:34:41 +00:00
|
|
|
{
|
|
|
|
|
|
|
|
|
|
global $root_path;
|
|
|
|
|
|
2012-10-17 18:13:05 -04:00
|
|
|
if (! $filename)
|
|
|
|
|
return;
|
2010-12-02 23:34:41 +00:00
|
|
|
|
|
|
|
|
$HTTP_USER_AGENT = $_SERVER['HTTP_USER_AGENT'];
|
|
|
|
|
|
|
|
|
|
$isIE = 0;
|
|
|
|
|
|
2012-10-17 18:13:05 -04:00
|
|
|
if (strstr( $HTTP_USER_AGENT, 'compatible; MSIE ' ) !== false && strstr( $HTTP_USER_AGENT, 'Opera' ) === false) {
|
2010-12-02 23:34:41 +00:00
|
|
|
$isIE = 1;
|
|
|
|
|
}
|
|
|
|
|
|
2012-10-17 18:13:05 -04:00
|
|
|
if (strstr( $HTTP_USER_AGENT, 'compatible; MSIE 6' ) !== false && strstr( $HTTP_USER_AGENT, 'Opera' ) === false) {
|
2010-12-02 23:34:41 +00:00
|
|
|
$isIE6 = 1;
|
|
|
|
|
}
|
|
|
|
|
|
2012-10-17 18:13:05 -04:00
|
|
|
$aux = preg_replace( '[^-a-zA-Z0-9\.]', '_', $filename );
|
|
|
|
|
$aux = explode( '_', $aux );
|
|
|
|
|
$downloadName = $aux[count( $aux ) - 1];
|
|
|
|
|
// $downloadName = $filename;
|
|
|
|
|
|
2010-12-02 23:34:41 +00:00
|
|
|
|
|
|
|
|
//$downloadName = ereg_replace('[^-a-zA-Z0-9\.]', '_', $filename);
|
|
|
|
|
|
|
|
|
|
|
2012-10-17 18:13:05 -04:00
|
|
|
if ($isIE && ! isset( $isIE6 )) {
|
|
|
|
|
// http://support.microsoft.com/support/kb/articles/Q182/3/15.asp
|
|
|
|
|
// Do not have quotes around filename, but that applied to
|
|
|
|
|
// "attachment"... does it apply to inline too?
|
2010-12-02 23:34:41 +00:00
|
|
|
|
|
|
|
|
|
2012-10-17 18:13:05 -04:00
|
|
|
// This combination seems to work mostly. IE 5.5 SP 1 has
|
|
|
|
|
// known issues (see the Microsoft Knowledge Base)
|
|
|
|
|
header( "Content-Disposition: inline; filename=$downloadName" );
|
|
|
|
|
|
|
|
|
|
// This works for most types, but doesn't work with Word files
|
|
|
|
|
header( "Content-Type: application/download; name=\"$downloadName\"" );
|
|
|
|
|
|
|
|
|
|
//header("Content-Type: $type0/$type1; name=\"$downloadName\"");
|
|
|
|
|
//header("Content-Type: application/x-msdownload; name=\"$downloadName\"");
|
|
|
|
|
//header("Content-Type: application/octet-stream; name=\"$downloadName\"");
|
|
|
|
|
} else {
|
|
|
|
|
header( "Content-Disposition: attachment; filename=\"$downloadName\"" );
|
|
|
|
|
header( "Content-Type: application/octet-stream; name=\"$downloadName\"" );
|
2010-12-02 23:34:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//$filename = PATH_UPLOAD . "$filename";
|
2012-10-17 18:13:05 -04:00
|
|
|
readfile( $filename );
|
2010-12-02 23:34:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//G::header2( "location: /files/" .$_SESSION['ENVIRONMENT']. "/" .$appid, $filename);
|
2012-10-17 18:13:05 -04:00
|
|
|
|