import datetime from tabulate import tabulate from exchangelib import HTMLBody from serenitas.utils.db2 import dbconn from serenitas.utils.exchange import ExchangeMessage from report_ops.misc import _recipients, _cc_recipients _account_alias = {"V0NSCLMSPT": "6MZ20049"} def email_fcm(em, d, fund): account = _account_alias.get(d["cash_account"], d["cash_account"]) match d["cp_code"]: case "BAMSNY": recipients = _recipients["BAML_FCM"] case "GOLDNY": recipients = _recipients["GS_FCM"] additional_instructions = f"Could you please instruct moves from DCS 057575201 to Futures {account} to settle this trade? " em.send_email( f"FX Details: {account} Trade Date: {d['trade_date']}", HTMLBody( f""" Hello,

Please see below details for an FX Spot Trade we did with the desk today for account {account}. {additional_instructions if 'additional_instructions' in locals() else ""}Please let me know if you need more information.

{to_tabulate(d)} """ ), to_recipients=recipients, cc_recipients=_cc_recipients[fund], ) def to_tabulate(d): if d["sell_currency"] == "USD": key1, key2 = "buy", "sell" else: key1, key2 = "sell", "buy" account = _account_alias.get(d["cash_account"], d["cash_account"]) line = [ account, d[f"{key1}_currency"], d[f"{key1}_amount"], d[f"{key2}_currency"], d["spot_rate"], d[f"{key2}_amount"], "Buy" if d["sell_currency"] == "USD" else "Sell", d["settle_date"], ] num_format = [("{0:,.2f}", 2), ("{0:.5f}", 4), ("{0:,.2f}", 5)] for f, i in num_format: line[i] = f.format(line[i]) t = tabulate( [line], headers=[ "account", "curr", "TotBal", "HomeCurrency", "fxRate", "convTotBal", "BuySell", "Value Date", ], tablefmt="unsafehtml", ) return t def main(trade_date, conn, fund, em): with conn.cursor() as c: c.execute( "SELECT spots.cash_account, buy_currency, sell_currency, buy_amount, sell_amount, spot_rate, settle_date, trade_date, spots.cp_code FROM spots " "LEFT JOIN accounts2 USING (cash_account) " "WHERE account_type in ('Fcm', 'Future') AND spots.cp_code in ('BAMSNY', 'GOLDNY') AND spots.trade_date =%s AND spots.fund=%s", (trade_date, fund), ) for rec in c: d = rec._asdict() email_fcm(em, d, fund) if __name__ == "__main__": import argparse parser = argparse.ArgumentParser() parser.add_argument( "date", nargs="?", type=datetime.date.fromisoformat, default=datetime.date.today(), help="working date", ) args = parser.parse_args() conn = dbconn("dawndb") em = ExchangeMessage() for fund in ( "SERCGMAST", "ISOSEL", "BOWDST", ): main(args.date, conn, fund, em)