NAME
Finance::StockAccount::Transaction
SYNOPSIS
my $ftr = Finance::StockAccount::Stock->new({
symbol => 'FTR',
exchange => 'NASDAQ',
});
my $st = Finance::StockAccount::Transaction->new({
date => $dt,
action => Finance::StockAccount::Transaction::SELL,
stock => $ftr,
quantity => 42,
price => 7.11,
commission => 8.95,
regulatoryFees => 0.01,
});
print $st->price(), "\n"; # prints number 7.11
PROPERTIES
These are the public properties of a StockAccount::Transaction object:
date # 'presumed' DateTime object. See http://datetime.perl.org/wiki/datetime/dashboard and discussion below.
action # One of module constants BUY, SELL, SHORT, COVER
stock # A Finance::StockAccount::Stock object
quantity # How many shares were bought or sold, e.g. 100 or 5.
price # Numeric representation of price, e.g. 4.65 instead of the string '$4.65'.
commission # Numeric representation of commission in same currency, e.g. 8.95 instead of the string '$8.95'.
regulatoryFees # Numeric representation of the regulatory fees, see section on "Regulatory Fees" below.
otherFees # Numeric aggregation of any other fees not included in commission and regulatory fees.
Any public property can be instantiated in the new
method, set with a method matching the name of the property, such as $st-
date($dt)>, or set with the set
method, e.g. $st-
set({date => $dt})>, as specified further in the method description below.
Public properties can also be retrieved by the same method matching the name of the property when no parameter is passed, e.g. $st-
date()>. Or by the get
method with a string naming the property, e.g. $st-
get('price')>.
All properties can also be read or written directly with a hash dereference. Some people don't consider this good object-oriented practice, but I won't stop you if that's what you want to do. E.g. $st-
{date} = $dt> or $st-
{price}>.
REGULATORY FEES
In the United States the Securities and Exchange Commission imposes regulatory fees on stock brokers or dealers. Instead of paying these with their profits, these for-profit companies often pass these fees onto their customers directly. The regulatoryFees
property could be used for similar purposes in other jurisdictions.
See http://www.sec.gov/answers/sec31.htm for more information.