!C99Shell v. 2.5 [PHP 8 Update] [24.05.2025]!

Software: Apache/2.4.41 (Ubuntu). PHP/8.0.30 

uname -a: Linux apirnd 5.4.0-204-generic #224-Ubuntu SMP Thu Dec 5 13:38:28 UTC 2024 x86_64 

uid=33(www-data) gid=33(www-data) groups=33(www-data) 

Safe-mode: OFF (not secure)

/var/www/html/main_file/vendor/phpoffice/phpspreadsheet/src/PhpSpreadsheet/Calculation/Financial/   drwxr-xr-x
Free 13.1 GB of 57.97 GB (22.61%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Self remove    Logout    


Viewing file:     TreasuryBill.php (5.82 KB)      -rw-r--r--
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php

namespace PhpOffice\PhpSpreadsheet\Calculation\Financial;

use 
PhpOffice\PhpSpreadsheet\Calculation\DateTimeExcel;
use 
PhpOffice\PhpSpreadsheet\Calculation\Exception;
use 
PhpOffice\PhpSpreadsheet\Calculation\Financial\Constants as FinancialConstants;
use 
PhpOffice\PhpSpreadsheet\Calculation\Functions;
use 
PhpOffice\PhpSpreadsheet\Calculation\Information\ExcelError;

class 
TreasuryBill
{
    
/**
     * TBILLEQ.
     *
     * Returns the bond-equivalent yield for a Treasury bill.
     *
     * @param mixed $settlement The Treasury bill's settlement date.
     *                                The Treasury bill's settlement date is the date after the issue date
     *                                    when the Treasury bill is traded to the buyer.
     * @param mixed $maturity The Treasury bill's maturity date.
     *                                The maturity date is the date when the Treasury bill expires.
     * @param mixed $discount The Treasury bill's discount rate
     *
     * @return float|string Result, or a string containing an error
     */
    
public static function bondEquivalentYield($settlement$maturity$discount)
    {
        
$settlement Functions::flattenSingleValue($settlement);
        
$maturity Functions::flattenSingleValue($maturity);
        
$discount Functions::flattenSingleValue($discount);

        try {
            
$settlement FinancialValidations::validateSettlementDate($settlement);
            
$maturity FinancialValidations::validateMaturityDate($maturity);
            
$discount FinancialValidations::validateFloat($discount);
        } catch (
Exception $e) {
            return 
$e->getMessage();
        }

        if (
$discount <= 0) {
            return 
ExcelError::NAN();
        }

        
$daysBetweenSettlementAndMaturity $maturity $settlement;
        
$daysPerYear Helpers::daysPerYear(
            
Functions::scalar(DateTimeExcel\DateParts::year($maturity)),
            
FinancialConstants::BASIS_DAYS_PER_YEAR_ACTUAL
        
);

        if (
$daysBetweenSettlementAndMaturity $daysPerYear || $daysBetweenSettlementAndMaturity 0) {
            return 
ExcelError::NAN();
        }

        return (
365 $discount) / (360 $discount $daysBetweenSettlementAndMaturity);
    }

    
/**
     * TBILLPRICE.
     *
     * Returns the price per $100 face value for a Treasury bill.
     *
     * @param mixed $settlement The Treasury bill's settlement date.
     *                                The Treasury bill's settlement date is the date after the issue date
     *                                    when the Treasury bill is traded to the buyer.
     * @param mixed $maturity The Treasury bill's maturity date.
     *                                The maturity date is the date when the Treasury bill expires.
     * @param mixed $discount The Treasury bill's discount rate
     *
     * @return float|string Result, or a string containing an error
     */
    
public static function price($settlement$maturity$discount)
    {
        
$settlement Functions::flattenSingleValue($settlement);
        
$maturity Functions::flattenSingleValue($maturity);
        
$discount Functions::flattenSingleValue($discount);

        try {
            
$settlement FinancialValidations::validateSettlementDate($settlement);
            
$maturity FinancialValidations::validateMaturityDate($maturity);
            
$discount FinancialValidations::validateFloat($discount);
        } catch (
Exception $e) {
            return 
$e->getMessage();
        }

        if (
$discount <= 0) {
            return 
ExcelError::NAN();
        }

        
$daysBetweenSettlementAndMaturity $maturity $settlement;
        
$daysPerYear Helpers::daysPerYear(
            
Functions::scalar(DateTimeExcel\DateParts::year($maturity)),
            
FinancialConstants::BASIS_DAYS_PER_YEAR_ACTUAL
        
);

        if (
$daysBetweenSettlementAndMaturity $daysPerYear || $daysBetweenSettlementAndMaturity 0) {
            return 
ExcelError::NAN();
        }

        
$price 100 * (- (($discount $daysBetweenSettlementAndMaturity) / 360));
        if (
$price 0.0) {
            return 
ExcelError::NAN();
        }

        return 
$price;
    }

    
/**
     * TBILLYIELD.
     *
     * Returns the yield for a Treasury bill.
     *
     * @param mixed $settlement The Treasury bill's settlement date.
     *                                The Treasury bill's settlement date is the date after the issue date when
     *                                    the Treasury bill is traded to the buyer.
     * @param mixed $maturity The Treasury bill's maturity date.
     *                                The maturity date is the date when the Treasury bill expires.
     * @param mixed $price The Treasury bill's price per $100 face value
     *
     * @return float|string
     */
    
public static function yield($settlement$maturity$price)
    {
        
$settlement Functions::flattenSingleValue($settlement);
        
$maturity Functions::flattenSingleValue($maturity);
        
$price Functions::flattenSingleValue($price);

        try {
            
$settlement FinancialValidations::validateSettlementDate($settlement);
            
$maturity FinancialValidations::validateMaturityDate($maturity);
            
$price FinancialValidations::validatePrice($price);
        } catch (
Exception $e) {
            return 
$e->getMessage();
        }

        
$daysBetweenSettlementAndMaturity $maturity $settlement;
        
$daysPerYear Helpers::daysPerYear(
            
Functions::scalar(DateTimeExcel\DateParts::year($maturity)),
            
FinancialConstants::BASIS_DAYS_PER_YEAR_ACTUAL
        
);

        if (
$daysBetweenSettlementAndMaturity $daysPerYear || $daysBetweenSettlementAndMaturity 0) {
            return 
ExcelError::NAN();
        }

        return ((
100 $price) / $price) * (360 $daysBetweenSettlementAndMaturity);
    }
}

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ Read-Only ]

:: Make Dir ::
 
[ Read-Only ]
:: Make File ::
 
[ Read-Only ]

:: Go Dir ::
 
:: Go File ::
 

--[ c99shell v. 2.5 [PHP 8 Update] [24.05.2025] | Generation time: 0.0164 ]--