salesagility_SuiteCRM/modules/Notes/Note.php

399 lines
13 KiB
PHP
Executable File

<?php
/**
*
* SugarCRM Community Edition is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004-2013 SugarCRM Inc.
*
* SuiteCRM is an extension to SugarCRM Community Edition developed by SalesAgility Ltd.
* Copyright (C) 2011 - 2018 SalesAgility Ltd.
*
* This program is free software; you can redistribute it and/or modify it under
* the terms of the GNU Affero General Public License version 3 as published by the
* Free Software Foundation with the addition of the following permission added
* to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED WORK
* IN WHICH THE COPYRIGHT IS OWNED BY SUGARCRM, SUGARCRM DISCLAIMS THE WARRANTY
* OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
* FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
* details.
*
* You should have received a copy of the GNU Affero General Public License along with
* this program; if not, see http://www.gnu.org/licenses or write to the Free
* Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
* 02110-1301 USA.
*
* You can contact SugarCRM, Inc. headquarters at 10050 North Wolfe Road,
* SW2-130, Cupertino, CA 95014, USA. or at email address contact@sugarcrm.com.
*
* The interactive user interfaces in modified source and object code versions
* of this program must display Appropriate Legal Notices, as required under
* Section 5 of the GNU Affero General Public License version 3.
*
* In accordance with Section 7(b) of the GNU Affero General Public License version 3,
* these Appropriate Legal Notices must retain the display of the "Powered by
* SugarCRM" logo and "Supercharged by SuiteCRM" logo. If the display of the logos is not
* reasonably feasible for technical reasons, the Appropriate Legal Notices must
* display the words "Powered by SugarCRM" and "Supercharged by SuiteCRM".
*/
if (!defined('sugarEntry') || !sugarEntry) {
die('Not A Valid Entry Point');
}
require_once __DIR__ . '/../../include/upload_file.php';
require_once __DIR__ . '/../../include/SugarObjects/templates/file/File.php';
// Note is used to store customer information.
#[\AllowDynamicProperties]
class Note extends File
{
public $field_name_map;
// Stored fields
public $id;
public $date_entered;
public $date_modified;
public $modified_user_id;
public $assigned_user_id;
public $created_by;
public $created_by_name;
public $modified_by_name;
public $description;
public $name;
public $filename;
// handle to an upload_file object
// used in emails
public $file;
public $embed_flag; // inline image flag
public $parent_type;
public $parent_id;
public $contact_id;
public $portal_flag;
public $parent_name;
public $contact_name;
public $contact_phone;
public $contact_email;
public $file_mime_type;
public $module_dir = "Notes";
public $default_note_name_dom = array('Meeting notes', 'Reminder');
public $table_name = "notes";
public $new_schema = true;
public $object_name = "Note";
public $importable = true;
// This is used to retrieve related fields from form posts.
public $additional_column_fields = array(
'contact_name',
'contact_phone',
'contact_email',
'parent_name',
'first_name',
'last_name'
);
public function __construct()
{
parent::__construct();
}
public function safeAttachmentName()
{
global $sugar_config;
//get position of last "." in file name
$file_ext_beg = strrpos((string) $this->filename, ".");
$file_ext = "";
//get file extension
if ($file_ext_beg !== false) {
$file_ext = substr((string) $this->filename, $file_ext_beg + 1);
}
//check to see if this is a file with extension located in "badext"
foreach ($sugar_config['upload_badext'] as $badExt) {
if (strtolower($file_ext) === strtolower($badExt)) {
//if found, then append with .txt and break out of lookup
$this->name = $this->name . ".txt";
$this->file_mime_type = 'text/';
$this->filename = $this->filename . ".txt";
break; // no need to look for more
}
}
}
/**
* overrides SugarBean's method.
* If a system setting is set, it will mark all related notes as deleted, and attempt to delete files that are
* related to those notes
* @param string id ID
*/
public function mark_deleted($id)
{
global $sugar_config;
if ($this->parent_type == 'Emails') {
if (isset($sugar_config['email_default_delete_attachments']) && $sugar_config['email_default_delete_attachments'] == true) {
$removeFile = "upload://$id";
if (file_exists($removeFile)) {
if (!unlink($removeFile)) {
$GLOBALS['log']->error("*** Could not unlink() file: [ {$removeFile} ]");
}
}
}
}
// delete note
parent::mark_deleted($id);
}
public function deleteAttachment($isduplicate = "false")
{
$removeFile = null;
if ($this->ACLAccess('edit')) {
if ($isduplicate == "true") {
return true;
}
$removeFile = "upload://{$this->id}";
}
if (file_exists($removeFile)) {
if (!unlink($removeFile)) {
$GLOBALS['log']->error("*** Could not unlink() file: [ {$removeFile} ]");
} else {
$this->uploadfile = '';
$this->filename = '';
$this->file_mime_type = '';
$this->file = '';
$this->save();
return true;
}
} else {
$this->uploadfile = '';
$this->filename = '';
$this->file_mime_type = '';
$this->file = '';
$this->save();
return true;
}
return false;
}
public function get_summary_text()
{
return (string)$this->name;
}
/**
* Returns the content as string or false if there is no attachment or it
* couldn't be located.
*
* @return bool|string
*/
public function getAttachmentContent()
{
$path = "upload://{$this->id}";
if (!file_exists($path)) {
return false;
}
return file_get_contents($path);
}
public function create_export_query($order_by, $where, $relate_link_join = '')
{
$custom_join = $this->getCustomJoin(true, true, $where);
$custom_join['join'] .= $relate_link_join;
$query = "SELECT notes.*, contacts.first_name, contacts.last_name, users.user_name as assigned_user_name ";
$query .= $custom_join['select'];
$query .= " FROM notes ";
$query .= " LEFT JOIN contacts ON notes.contact_id=contacts.id ";
$query .= " LEFT JOIN users ON notes.assigned_user_id=users.id ";
$query .= $custom_join['join'];
$where_auto = " notes.deleted=0 AND (contacts.deleted IS NULL OR contacts.deleted=0)";
if ($where != "") {
$query .= "where $where AND " . $where_auto;
} else {
$query .= "where " . $where_auto;
}
$order_by = $this->process_order_by($order_by);
if (empty($order_by)) {
$order_by = 'notes.name';
}
$query .= ' ORDER BY ' . $order_by;
return $query;
}
public function fill_in_additional_list_fields()
{
$this->fill_in_additional_detail_fields();
}
public function fill_in_additional_detail_fields()
{
parent::fill_in_additional_detail_fields();
//TODO: Seems odd we need to clear out these values so that list views don't show the previous rows value if current value is blank
$this->getRelatedFields(
'Contacts',
$this->contact_id,
array('name' => 'contact_name', 'phone_work' => 'contact_phone')
);
if (!empty($this->contact_name)) {
$emailAddress = new SugarEmailAddress();
$this->contact_email = $emailAddress->getPrimaryAddress(false, $this->contact_id, 'Contacts');
}
if (isset($this->contact_id) && $this->contact_id != '') {
$contact = BeanFactory::newBean('Contacts');
$contact->retrieve($this->contact_id);
if (isset($contact->id)) {
$this->contact_name = $contact->full_name;
}
}
}
public function get_list_view_data()
{
$note_fields = $this->get_list_view_array();
global $app_list_strings, $focus, $action, $currentModule, $mod_strings, $sugar_config;
if (isset($this->parent_type)) {
$note_fields['PARENT_MODULE'] = $this->parent_type;
}
if (!empty($this->filename)) {
if (file_exists("upload://{$this->id}")) {
$note_fields['FILENAME'] = $this->filename;
$note_fields['FILE_URL'] = UploadFile::get_upload_url($this);
}
}
if (isset($this->contact_id) && $this->contact_id != '') {
$contact = BeanFactory::newBean('Contacts');
$contact->retrieve($this->contact_id);
if (isset($contact->id)) {
$this->contact_name = $contact->full_name;
}
}
if (isset($this->contact_name)) {
$note_fields['CONTACT_NAME'] = $this->contact_name;
}
global $current_language;
$mod_strings = return_module_language($current_language, 'Notes');
$note_fields['STATUS'] = $mod_strings['LBL_NOTE_STATUS'];
return $note_fields;
}
public function listviewACLHelper()
{
$array_assign = parent::listviewACLHelper();
$is_owner = false;
$in_group = false; //SECURITY GROUPS
if (!empty($this->parent_name)) {
if (!empty($this->parent_name_owner)) {
global $current_user;
$is_owner = $current_user->id == $this->parent_name_owner;
}
/* BEGIN - SECURITY GROUPS */
//parent_name_owner not being set for whatever reason so we need to figure this out
else {
if (!empty($this->parent_type) && !empty($this->parent_id)) {
global $current_user;
$parent_bean = BeanFactory::getBean($this->parent_type, $this->parent_id);
if ($parent_bean !== false) {
$is_owner = $current_user->id == $parent_bean->assigned_user_id;
}
}
}
require_once("modules/SecurityGroups/SecurityGroup.php");
$in_group = SecurityGroup::groupHasAccess($this->parent_type, $this->parent_id, 'view');
/* END - SECURITY GROUPS */
}
/* BEGIN - SECURITY GROUPS */
/**
* if(!ACLController::moduleSupportsACL($this->parent_type) || ACLController::checkAccess($this->parent_type, 'view', $is_owner)) {
*/
if (!ACLController::moduleSupportsACL($this->parent_type) || ACLController::checkAccess(
$this->parent_type,
'view',
$is_owner,
'module',
$in_group
)
) {
/* END - SECURITY GROUPS */
$array_assign['PARENT'] = 'a';
} else {
$array_assign['PARENT'] = 'span';
}
$is_owner = false;
$in_group = false; //SECURITY GROUPS
if (!empty($this->contact_name)) {
if (!empty($this->contact_name_owner)) {
global $current_user;
$is_owner = $current_user->id == $this->contact_name_owner;
}
/* BEGIN - SECURITY GROUPS */
//contact_name_owner not being set for whatever reason so we need to figure this out
else {
global $current_user;
$parent_bean = BeanFactory::getBean('Contacts', $this->contact_id);
if ($parent_bean !== false) {
$is_owner = $current_user->id == $parent_bean->assigned_user_id;
}
}
require_once("modules/SecurityGroups/SecurityGroup.php");
$in_group = SecurityGroup::groupHasAccess('Contacts', $this->contact_id, 'view');
/* END - SECURITY GROUPS */
}
/* BEGIN - SECURITY GROUPS */
/**
* if( ACLController::checkAccess('Contacts', 'view', $is_owner)) {
*/
if (ACLController::checkAccess('Contacts', 'view', $is_owner, 'module', $in_group)) {
/* END - SECURITY GROUPS */
$array_assign['CONTACT'] = 'a';
} else {
$array_assign['CONTACT'] = 'span';
}
return $array_assign;
}
public function bean_implements($interface)
{
switch ($interface) {
case 'ACL':
return true;
case 'FILE':
return true;
}
return false;
}
}