Monarch Money API for Python
Project description
Monarch Money
Python library for accessing Monarch Money data.
Installation
From Source Code
Clone this repository from Git
git clone https://github.com/hammem/monarchmoney.git
Via pip
pip install monarchmoney
Instantiate & Login
There are two ways to use this library: interactive and non-interactive.
Interactive
If you're using this library in something like iPython or Jupyter, you can run an interactive-login which supports multi-factor authentication:
mm = MonarchMoney()
await mm.interactive_login()
This will prompt you for the email, password and, if needed, the multi-factor token.
Non-interactive
For a non-interactive session, you'll need to create an instance and login:
mm = MonarchMoney()
mm.login(email, password)
This may throw a RequireMFAException
. If it does, you'll need to get a multi-factor token and call the following method:
mm.multi_factor_authenticate(email, password, multi_factor_code)
Alternatively, you can provide the MFA Secret Key. The MFA Secret Key is found when setting up the MFA in Monarch Money by going to Settings -> Security -> Enable MFA -> and copy the "Two-factor text code". Then provide it in the login() method:
await mm.login(
email=email,
password=password,
save_session=False,
use_saved_session=False,
mfa_secret_key=mfa_secret_key,
)
Accessing Data
As of writing this README, the following methods are supported:
Non-Mutating Methods
get_accounts
- gets all the accounts linked to Monarch Moneyget_account_holdings
- gets all of the securities in a brokerage or similar type of accountget_account_type_options
- all account types and their subtypes available in Monarch Money-get_budgets
— all the budgets and the corresponding actual amountsget_subscription_details
- gets the Monarch Money account's status (e.g. paid or trial)get_transactions_summary
- gets the transaction summary data from the transactions pageget_transactions
- gets transaction data, defaults to returning the last 100 transactions; can also be searched by date rangeget_transaction_categories
- gets all of the categories configured in the accountget_transaction_category_groups
all category groups configured in the account-get_transaction_details
- gets detailed transaction data for a single transactionget_transaction_splits
- gets transaction splits for a single transactionget_transaction_tags
- gets all of the tags configured in the accountget_cashflow
- gets cashflow data (by category, category group, merchant and a summary)get_cashflow_summary
- gets cashflow summary (income, expense, savings, savings rate)is_accounts_refresh_complete
- gets the status of a running account refresh
Mutating Methods
delete_transaction_category
- deletes a category for transactionsdelete_transaction_categories
- deletes a list of transaction categories for transactionsrequest_accounts_refresh
- requests a synchronization / refresh of all accounts linked to Monarch Money. This is a non-blocking call. If the user wants to check on the status afterwards, they must callis_accounts_refresh_complete
.request_accounts_refresh_and_wait
- requests a synchronization / refresh of all accounts linked to Monarch Money. This is a blocking call and will not return until the refresh is complete or no longer running.create_transaction
- creates a transaction with the given attributesupdate_transaction
- modifies one or more attributes for an existing transactiondelete_transaction
- deletes a given transaction by the provided transaction idupdate_transaction_splits
- modifies how a transaction is split (or not)set_budget_amount
- sets a budget's value to the given amount (date allowed, will only apply to month specified by default). A zero amount value will "unset" or "clear" the budget for the given category.create_manual_account
- creates a new manual account
Contributing
Any and all contributions -- code, documentation, feature requests, feedback -- are welcome!
If you plan to submit up a pull request, you can expect a timely review. There aren't any strict requirements around the environment you need to configure aside from using Black to auto-format the code. An action is configured in this repo to run against all PRs and merges and will block them from being committed.
FAQ
How do I use this API if I login to Monarch via Google?
If you currently use Google or 'Continue with Google' to access your Monarch account, you'll need to set a password to leverage this API. You can set a password on your Monarch account by going to your security settings.
Don't forget to use a password unique to your Monarch account and to enable multi-factor authentication!
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file monarchmoney-0.1.8.tar.gz
.
File metadata
- Download URL: monarchmoney-0.1.8.tar.gz
- Upload date:
- Size: 16.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/4.0.2 CPython/3.11.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 9dbaf3e65fe004b5ef387378239bf352f3d9c1667e9047f3dc8405dc772c679c |
|
MD5 | f5e75db78ccec194029652315afb3835 |
|
BLAKE2b-256 | 44fb316e3086ab26e13559b59d74315c9fe2c8fa3b6f2a25196ddc59b93d4729 |
File details
Details for the file monarchmoney-0.1.8-py2.py3-none-any.whl
.
File metadata
- Download URL: monarchmoney-0.1.8-py2.py3-none-any.whl
- Upload date:
- Size: 15.0 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/4.0.2 CPython/3.11.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2657dc89231ab7316b9c5ab41e8773b6271645f3717a778cec4431ffe9082573 |
|
MD5 | 6a2d838d7eb1c1dc59f7f6e570575510 |
|
BLAKE2b-256 | a3ac914b11f8036b2139a31d139f5e3d6cbee983ae8a9c4b7883e2152d7725f3 |