KGRKJGETMRETU895U-589TY5MIGM5JGB5SDFESFREWTGR54TY
Server : Apache/2.4.62
System : FreeBSD fbsdweb2.web.rcn.net 14.1-RELEASE FreeBSD 14.1-RELEASE releng/14.1-n267679-10e31f0946d8 GENERIC amd64
User : www ( 80)
PHP Version : 8.3.8
Disable Function : NONE
Directory :  /domains/irtiweb/CATS/src/OpenCATS/Entity/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : /domains/irtiweb/CATS/src/OpenCATS/Entity/CompanyRepository.php
<?php
namespace OpenCATS\Entity;
use OpenCATS\Entity\Company;

include_once('./lib/History.php');

class CompanyRepository
{
    private $databaseConnection;
    
    function __construct(\DatabaseConnection $databaseConnection)
    {
        $this->databaseConnection = $databaseConnection;
    }
    
    function persist(Company $company, \History $history)
    {
        $sql = sprintf(
            "INSERT INTO company (
                name,
                address,
                city,
                state,
                zip,
                phone1,
                phone2,
                fax_number,
                url,
                key_technologies,
                is_hot,
                notes,
                entered_by,
                owner,
                site_id,
                date_created,
                date_modified
            )
            VALUES (
                %s,
                %s,
                %s,
                %s,
                %s,
                %s,
                %s,
                %s,
                %s,
                %s,
                %s,
                %s,
                %s,
                %s,
                %s,
                NOW(),
                NOW()
            )",
            $this->databaseConnection->makeQueryString($company->getName()),
            $this->databaseConnection->makeQueryString($company->getAddress()),
            $this->databaseConnection->makeQueryString($company->getCity()),
            $this->databaseConnection->makeQueryString($company->getState()),
            $this->databaseConnection->makeQueryString($company->getZipCode()),
            $this->databaseConnection->makeQueryString($company->getPhoneNumberOne()),
            $this->databaseConnection->makeQueryString($company->getPhoneNumberTwo()),
            $this->databaseConnection->makeQueryString($company->getFaxNumber()),
            $this->databaseConnection->makeQueryString($company->getUrl()),
            $this->databaseConnection->makeQueryString($company->getKeyTechnologies()),
            ($company->isHot() ? '1' : '0'),
            $this->databaseConnection->makeQueryString($company->getNotes()),
            $this->databaseConnection->makeQueryInteger($company->getEnteredBy()),
            $this->databaseConnection->makeQueryInteger($company->getOwner()),
            $company->getSiteId()
        );
        if ($result = $this->databaseConnection->query($sql)) {
            $companyId = $this->databaseConnection->getLastInsertID();
            // FIXME: History should be split in HistoryService and History (Entity)
            // Also, the action of saving a history should not be explicitely done 
            // by each Entity Service, but instead, each Entity Service should 
            // dispatch a hook and the History Service should listen to all 
            // hooks and persist the History entities.
            // That way, the code is more mantainable as not all Entities need to
            // be aware of History and vice-versa
            $history->storeHistoryNew(DATA_ITEM_COMPANY, $companyId);
            return $companyId;
        } else {
            throw new CompanyRepositoryException('errorPersistingCompany');
        }
    }
    
    // FIXME: Consolidate with Search.php code
    function findByName($siteId, $companyName)
    {
        $wildCardString = str_replace('*', '%', $companyName) . '%';
        $wildCardString = $this->databaseConnection->makeQueryString($wildCardString);
        
        $sql = sprintf(
            "SELECT
                company.company_id AS companyID,
                company.name AS name,
                company.city AS city,
                company.state AS state,
                company.phone1 AS phone1,
                company.url AS url,
                company.key_technologies AS keyTechnologies,
                company.is_hot AS isHot,
                DATE_FORMAT(
                    company.date_created, '%%m-%%d-%%y'
                ) AS dateCreated,
                DATE_FORMAT(
                    company.date_modified, '%%m-%%d-%%y'
                ) AS dateModified,
                owner_user.first_name AS ownerFirstName,
                owner_user.last_name AS ownerLastName
            FROM
                company
            LEFT JOIN user AS owner_user
                ON company.owner = owner_user.user_id
            WHERE
                company.name LIKE %s
            AND
                company.site_id = %s
            ORDER BY
                %s %s",
            $wildCardString,
            $siteId,
            'company.name',
            'ASC'
        );
        return $this->databaseConnection->getAllAssoc($sql);
    }
}

Anon7 - 2021