bbgo_origin/pkg/accounting/pnl/report.go

85 lines
3.0 KiB
Go
Raw Normal View History

2020-10-16 02:21:37 +00:00
package pnl
2020-09-19 01:05:06 +00:00
import (
2021-12-05 16:47:41 +00:00
"encoding/json"
2020-09-19 01:05:06 +00:00
"strconv"
"time"
2021-12-04 18:16:48 +00:00
"github.com/c9s/bbgo/pkg/fixedpoint"
2020-10-16 02:21:37 +00:00
log "github.com/sirupsen/logrus"
2020-09-19 01:05:06 +00:00
"github.com/slack-go/slack"
2020-10-11 08:46:15 +00:00
"github.com/c9s/bbgo/pkg/slack/slackstyle"
"github.com/c9s/bbgo/pkg/types"
2020-09-19 01:05:06 +00:00
)
2020-10-16 02:21:37 +00:00
type AverageCostPnlReport struct {
2021-12-05 16:46:50 +00:00
LastPrice float64 `json:"lastPrice"`
StartTime time.Time `json:"startTime"`
Symbol string `json:"symbol"`
Market types.Market `json:"market"`
2020-09-19 01:05:06 +00:00
2021-12-05 16:46:50 +00:00
NumTrades int `json:"numTrades"`
Profit fixedpoint.Value `json:"profit"`
NetProfit fixedpoint.Value `json:"netProfit"`
UnrealizedProfit fixedpoint.Value `json:"unrealizedProfit"`
AverageCost float64 `json:"averageCost,omitempty"`
BuyVolume float64 `json:"buyVolume,omitempty"`
SellVolume float64 `json:"sellVolume,omitempty"`
FeeInUSD float64 `json:"feeInUSD,omitempty"`
Stock float64 `json:"stock,omitempty"`
CurrencyFees map[string]float64 `json:"currencyFees,omitempty"`
2020-09-19 01:05:06 +00:00
}
2021-12-05 16:47:41 +00:00
func (report *AverageCostPnlReport) JSON() ([]byte, error) {
return json.MarshalIndent(report, "", " ")
}
2020-10-16 02:21:37 +00:00
func (report AverageCostPnlReport) Print() {
2020-11-10 06:18:27 +00:00
log.Infof("TRADES SINCE: %v", report.StartTime)
log.Infof("NUMBER OF TRADES: %d", report.NumTrades)
2021-12-05 16:46:50 +00:00
log.Infof("AVERAGE COST: %s", types.USD.FormatMoneyFloat64(report.AverageCost))
2020-11-10 06:18:27 +00:00
log.Infof("TOTAL BUY VOLUME: %f", report.BuyVolume)
log.Infof("TOTAL SELL VOLUME: %f", report.SellVolume)
log.Infof("STOCK: %f", report.Stock)
2021-12-04 18:16:48 +00:00
// FIXME:
// log.Infof("FEE (USD): %f", report.FeeInUSD)
2021-12-05 16:46:50 +00:00
log.Infof("CURRENT PRICE: %s", types.USD.FormatMoneyFloat64(report.LastPrice))
2020-11-10 06:18:27 +00:00
log.Infof("CURRENCY FEES:")
2020-09-19 01:05:06 +00:00
for currency, fee := range report.CurrencyFees {
2020-10-16 02:21:37 +00:00
log.Infof(" - %s: %f", currency, fee)
2020-09-19 01:05:06 +00:00
}
2021-12-04 18:16:48 +00:00
log.Infof("PROFIT: %s", types.USD.FormatMoneyFloat64(report.Profit.Float64()))
log.Infof("UNREALIZED PROFIT: %s", types.USD.FormatMoneyFloat64(report.UnrealizedProfit.Float64()))
2020-09-19 01:05:06 +00:00
}
2020-10-16 02:21:37 +00:00
func (report AverageCostPnlReport) SlackAttachment() slack.Attachment {
2020-10-09 07:59:33 +00:00
var color = slackstyle.Red
2020-09-19 01:05:06 +00:00
if report.UnrealizedProfit > 0 {
color = slackstyle.Green
}
return slack.Attachment{
Title: report.Symbol + " Profit and Loss report",
Text: "Profit " + types.USD.FormatMoney(report.Profit),
Color: color,
// Pretext: "",
// Text: "",
Fields: []slack.AttachmentField{
{Title: "Profit", Value: types.USD.FormatMoney(report.Profit)},
{Title: "Unrealized Profit", Value: types.USD.FormatMoney(report.UnrealizedProfit)},
2021-12-05 16:46:50 +00:00
{Title: "Current Price", Value: report.Market.FormatPrice(report.LastPrice), Short: true},
{Title: "Average Cost", Value: report.Market.FormatPrice(report.AverageCost), Short: true},
2021-12-04 18:16:48 +00:00
// FIXME:
// {Title: "Fee (USD)", Value: types.USD.FormatMoney(report.FeeInUSD), Short: true},
2020-09-19 01:05:06 +00:00
{Title: "Stock", Value: strconv.FormatFloat(report.Stock, 'f', 8, 64), Short: true},
{Title: "Number of Trades", Value: strconv.Itoa(report.NumTrades), Short: true},
},
Footer: report.StartTime.Format(time.RFC822),
FooterIcon: "",
}
}