You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

103 lines
3.5 KiB

<?php
/*********************************************************************************
** The contents of this file are subject to the vtiger CRM Public License Version 1.0
* ("License"); You may not use this file except in compliance with the License
* The Original Code is: vtiger CRM Open Source
* The Initial Developer of the Original Code is vtiger.
* Portions created by vtiger are Copyright (C) vtiger.
* All Rights Reserved.
*
********************************************************************************/
require_once('include/database/PearDatabase.php');
require_once('include/utils.php');
$vtigerpath = $_SERVER['REQUEST_URI'];
$vtigerpath = str_replace("/index.php?module=uploads&action=add2db", "", $vtigerpath);
$uploaddir = $root_directory ."/test/upload/" ;// set this to wherever
if(move_uploaded_file($_FILES["binFile"]["tmp_name"],$uploaddir.$_FILES["binFile"]["name"]))
{
$binFile = $_FILES['binFile']['name'];
$filename = basename($binFile);
$filetype= $_FILES['binFile']['type'];
$filesize = $_FILES['binFile']['size'];
if($filesize != 0)
{
$current_id = $adb->getUniqueID("crmentity");
$desc = $_REQUEST['txtDescription'];
$description = addslashes($desc);
$date_var = date('YmdHis');
$data = base64_encode(fread(fopen($uploaddir.$binFile, "r"), $filesize));
//$data = addslashes(fread(fopen($uploaddir.$binFile, "r"), $filesize));
$query = "insert into crmentity (crmid,smcreatorid,smownerid,setype,description,createdtime) values('";
$query .= $current_id."','".$current_user->id."','".$current_user->id."','".$_REQUEST['return_module'].' Attachment'."','".$description."','".$date_var."')";
$result = $adb->query($query);
$sql = "insert into attachments values(";
$sql .= $current_id.",'".$filename."','".$description."','".$filetype."','".$filesize."','".$adb->getEmptyBlob()."')";
$result = $adb->query($sql);
if($result!=false)
$result = $adb->updateBlob('attachments','attachmentcontents',"attachmentsid='".$current_id."' and name='".$filename."'",$data);
$crmid = $_REQUEST['return_id'];
$sql1 = "insert into seattachmentsrel values('";
$sql1 .= $crmid."','".$current_id."')";
$result = $adb->query($sql1);
header("Location: index.php?action=".$_REQUEST['return_action']."&module=".$_REQUEST['return_module']."&record=".$_REQUEST['return_id']."&filename=".$filename."");
}
else
{
include('themes/'.$theme.'/header.php');
$errormessage = "<font color='red'><B>Error Message<ul>
<li><font color='red'>Invalid file OR</font>
<li><font color='red'>File has no data</font>
</ul></B></font> <br>" ;
echo $errormessage;
deleteFile($uploaddir,$filename);
include "upload.php";
}
}
else
{
$errorCode = $_FILES['binFile']['error'];
if($errorCode == 4)
{
include('themes/'.$theme.'/header.php');
$errormessage = "<B><font color='red'>Kindly give a valid file for upload!</font></B> <br>" ;
echo $errormessage;
include "upload.php";
}
else if($errorCode == 2)
{
$errormessage = "<B><font color='red'>Sorry, the uploaded file exceeds the maximum filesize limit. Please try a file smaller than 1000000 bytes</font></B> <br>";
include('themes/'.$theme.'/header.php');
echo $errormessage;
include "upload.php";
//echo $errorCode;
}
else if($errorCode == 3 || $errorcode == '')
{
include('themes/'.$theme.'/header.php');
echo "<b><font color='red'>Problems in file upload. Please try again!</font></b><br>";
include "upload.php";
}
}
function deleteFile($dir,$filename)
{
unlink($dir.$filename);
}
?>