CORE-POS/IS4C

View on GitHub
fannie/modules/plugins2.0/GiveUsMoneyPlugin/reports/GumPeopleReport.php

Summary

Maintainability
B
5 hrs
Test Coverage
<?php
/*******************************************************************************

    Copyright 2013 Whole Foods Co-op

    This file is part of IT CORE.

    IT CORE is free software; you can redistribute it and/or modify
    it under the terms of the GNU General Public License as published by
    the Free Software Foundation; either version 2 of the License, or
    (at your option) any later version.

    IT CORE 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 General Public License for more details.

    You should have received a copy of the GNU General Public License
    in the file license.txt along with IT CORE; if not, write to the Free Software
    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA

*********************************************************************************/

include(dirname(__FILE__).'/../../../../config.php');
if (!class_exists('FannieAPI')) {
    include(__DIR__ . '/../../../../classlib2.0/FannieAPI.php');
}

/**
*/
class GumPeopleReport extends FannieReportPage 
{
    public $discoverable = false; // access is very restricted; no need to list
                                  // as an available report

    protected $must_authenticate = true;
    protected $auth_classes = array('GiveUsMoney');

    protected $required_fields = array();
    protected $report_headers = array('Mem#', 'First Name', 'Last Name', 'Loan Date', 'Principal', 'Interest Rate', 'Term (Months)', 
                                    'Maturity Date', 'MaturityAmount', 'C Shares', 'Loan Paid Date', 'Check Number', 'Tax ID'); 

    public function preprocess()
    {
        $this->header = 'Active Loan Report';
        $this->title = 'Active Loan Report';

        return parent::preprocess();
    }
    
    public function fetch_report_data()
    {
        global $FANNIE_PLUGIN_SETTINGS, $FANNIE_OP_DB;
        $dbc = FannieDB::get($FANNIE_PLUGIN_SETTINGS['GiveUsMoneyDB']);

        // compound interest calculation is MySQL-specific
        $query = 'SELECT c.CardNo AS card_no,
                    c.FirstName, 
                    c.LastName,
                    m.street,
                    m.city,
                    m.state,
                    m.zip,
                    l.loanDate,
                    CASE WHEN l.principal IS NULL THEN 0 ELSE l.principal END as principal,
                    CASE WHEN l.termInMonths IS NULL THEN 0 ELSE l.termInMonths END as termInMonths,
                    CASE WHEN l.termInMonths IS NULL THEN \'\' ELSE DATE_ADD(loanDate, INTERVAL termInMonths MONTH) END as maturityDate,
                    CASE WHEN l.interestRate IS NULL THEN 0 ELSE l.interestRate END as interestRate,
                    CASE WHEN e.shares IS NULL THEN 0 ELSE e.shares END as shares,
                    CASE WHEN l.principal IS NULL THEN 0
                        ELSE principal * POW(1+interestRate, DATEDIFF(DATE_ADD(loanDate, INTERVAL termInMonths MONTH), loanDate)/365.25)
                    END as maturityAmount,
                    l.gumLoanAccountID,
                    i.maskedTaxIdentifier,
                    i.encryptedTaxIdentifier
                  FROM ' . $FANNIE_OP_DB . $dbc->sep() . 'custdata AS c
                        LEFT JOIN ' . FannieDB::fqn('meminfo', 'op') . ' AS m ON c.CardNo=m.card_no
                        LEFT JOIN GumLoanAccounts AS l 
                            ON l.card_no=c.CardNo AND c.personNum=1
                        LEFT JOIN (
                            SELECT card_no, SUM(shares) as shares
                            FROM GumEquityShares
                            GROUP BY card_no
                        ) AS e ON c.cardNo=e.card_no AND c.personNum=1
                        LEFT JOIN GumTaxIdentifiers AS i ON i.card_no = c.CardNo
                  WHERE 
                    (l.card_no IS NOT NULL
                    AND l.principal > 0)
                    OR e.card_no IS NOT NULL
                  ORDER BY l.card_no, l.loanDate';
        $result = $dbc->query($query);

        $payoffP = $dbc->prepare("
            SELECT p.*
            FROM GumLoanPayoffMap AS m
                INNER JOIN GumPayoffs AS p ON m.gumPayoffID=p.gumPayoffID
            WHERE m.gumLoanAccountID=?
            ORDER BY m.gumPayoffID DESC");

        $data = array();
        while($row = $dbc->fetch_row($result)) {
            $record = array(
               $row['card_no'],
               $row['LastName'],
               $row['FirstName'],
               $row['street'],
               $row['city'],
               $row['state'],
               $row['zip'],
               ($row['loanDate'] == '' ? 'n/a' : date('Y-m-d', strtotime($row['loanDate']))),
               sprintf('%.2f', $row['principal']), 
               sprintf('%.2f', $row['interestRate'] * 100), 
               $row['termInMonths'],
               ($row['maturityDate'] == '' ? 'n/a' : date('Y-m-d', strtotime($row['maturityDate']))),
               sprintf('%.2f', $row['maturityAmount']),
               $row['shares'],
            );
            if ($row['gumLoanAccountID']) {
                $paid = $dbc->getRow($payoffP, array($row['gumLoanAccountID']));    
                if ($paid && $paid['checkIssued']) {
                    list($issue,) = explode(' ', $paid['issueDate'], 2);
                    $record[] = $issue;
                    $record[] = $paid['checkNumber'];
                } else {
                    $record[] = 'n/a';
                    $record[] = 'n/a';
                }
            } else {
                $record[] = 'n/a';
                $record[] = 'n/a';
            }
            $ssn = 'xxx-xx-' . $row['maskedTaxIdentifier'];
            if (false) {
                $key = file_get_contents('/path/to/key');
                $privkey = openssl_pkey_get_private($key);
                $try = openssl_private_decrypt($row['encryptedTaxIdentifier'], $decrypted, $privkey);
                if ($try) $ssn = $decrypted;
            }
            $record[] = $ssn;
            $data[] = $record;
        }

        return $data;
    }

    public function calculate_footers($data)
    {
        $sum = 0.0;
        $c = 0.0;
        $mat = 0.0;
        foreach($data as $row) {
            $sum += $row[4];
            $mat += $row[8];
            $c += $row[9];
        }

        return array('Total', '', '', '', sprintf('%.2f', $sum), '', '', '', sprintf('%.2f', $mat), sprintf('%.2f', $c), '', '');
    }

    public function form_content()
    {
        return '<!-- no need -->';
    }

}

FannieDispatch::conditionalExec();