How to correctly categorize transactions
It is important to recognize the different categories of transactions used in CryptoTaxCalculator as they each have different tax implications. CryptoTaxCalculator attempts to automatically map transactions back to categories that make sense from a traditional accounting perspective.
To better understand these different categories, this article will provide an overview of each transaction category and their tax implications:
Incoming/Outgoing
These are the default categories that are used if we are unable to auto-categorize the transaction or make an accurate assumption as to what the category should be. To be on the safe side, an incoming transaction is marked as Incoming, as it is considered as a transfer of the underlying asset (from a tax perspective).
Similarly, an outgoing transaction is marked as an Outgoing as it is considered as a transfer of the asset, which will not trigger a capital gains tax event. If we are not sure if it is either an incoming or outgoing transaction, we will assign the Unknown category and you should update the category accordingly.
The Incoming and Outgoing transaction types will also impact the balance remaining for the particular wallet/exchange/account; an incoming transaction will increase the account balance remaining, and an outgoing transaction will decrease this. They, however, do NOT change the Overall Balance as they can be between your wallets/exchanges/accounts or not. So we don't change your overall balance before they are categorized accordingly. The Unknown transaction type will not affect the balance remaining.
Buy
A 'Buy' transaction represents the acquisition of the underlying asset (i.e. the purchase of the cryptocurrency). It used to calculate the cost basis for future cryptocurrency sales. This does not trigger a capital gains tax event.
Sell
A 'Sell' transaction represents the disposal of the underlying asset (i.e. the sale of the cryptocurrency). As a result, this sale triggers a capital gains tax event. The capital gain/loss is calculated based on the cost base of the asset (the price of the asset at the time of acquisition + any additional fees incurred due to the acquisition/disposal of the asset) and the value of the asset at the time of sale.
Specifically, the capital gain/loss is the 'received amount' minus the 'cost base'.
Send/Receive
A 'Send' or 'Receive' transaction is used to represent the movement of an asset between different wallets, exchanges or accounts, where you maintain control of the underlying asset. As you do not 'dispose' of the asset, this transaction type does not trigger a capital gains tax event.
Example:
- Sending cryptocurrency from an online exchange to your hardware wallet.
- Receiving cryptocurrency from an online exchange to your hardware wallet.
- Depositing cryptocurrency to a staking contract where you maintain ownership of the asset.
- Withdrawing cryptocurrency from staking contract where you have maintained ownership of the asset.
Transfer
If our auto-matching transfer algorithm has been able to link together a 'Send' and 'Receive' transaction together, then it will be marked as a 'Transfer'. Criteria for being auto-matched includes, but is not limited to:
- the 'Send' and 'Receive' transaction occurs less than 1 hour apart,
- the underlying cryptocurrency transferred is the same,
- the underlying quantity and valuation is similar (taking into account any fees paid) for both the 'Send' and 'Receive'.
Example: You import data from Exchange A, which has a 'withdrawal' of 1 BTC. Additionally, you import data from Exchange B, which has a 'deposit' of 1 BTC. Both transactions occur within a 15 minute time frame. As a result, our algorithm will group these two separate transactions together as a 'Transfer'.
Chain Split
A 'Chain Split' transaction is used if you acquired a new cryptocurrency as a result of a chain split (such as Bitcoin Cash being received by Bitcoin holders). There is no income or capital gains tax event at the time of receiving the new cryptocurrency. The new cryptocurrency received will have a cost basis of $0 for future trades.
Please note you must take care to determine which of the underlying assets is the 'continuation' of the original chain and which is the 'new' chain.
Airdrop
An 'Airdrop' transaction is used if you acquired cryptocurrency as a result of an airdrop.
If you have chosen to Treat airdrops as income in your tax settings, proceeds from airdrops would not trigger an immediate capital gains taxable event but would be classified as income and trigger an income tax event. Any future sale of the cryptocurrency is a capital gain event with a cost basis the same as the income price.
Example: You are airdropped 1 yearn.finance when its price is $100/YFI, and you sell a week later when the price is $10,000/YFI. Your income is $100 and capital gains is $10,000 - $100 = $9,900.
If you have chosen not to Treat airdrops as income in your tax settings, proceeds from airdrops would be treated as a "zero cost buy" and will not trigger an income or capital gains tax event, upon their receipt. You will however, trigger a capital gains tax event when you dispose of the airdropped coins.
Example: You are airdropped 1 yearn.finance when its price is $100/YFI, and you sell a week later when the price is $10,000/YFI. Your income is $0 and capital gains is $10,000 - $0 = $10,000.
Mining
A 'Mining' transaction is used if you acquired cryptocurrency as a result of mining activities as a hobby (e.g. BTC mining). Any cryptocurrency you receive as a result of your mining will be considered a new asset with a cost base of zero. This means that if you sell or trade them, you’ll incur a capital gain equal to the total amount received.
Example: You mined 1 bitcoin when its price is $1,000/BTC, your cost base is zero. If you sell six months later when the price is $5,000/BTC, your capital gains are $5,000.
Interest
An 'Interest' transaction is used if you acquired cryptocurrency as a result of interest-bearing activities which don't suit any of the other categories (e.g. earnings from lending, DEFI yield farming, high-interest cryptocurrency savings account, etc. Note - Liquidity Pool Tokens (LPTs) do not count as income and are normal trade/crypto-crypto swaps (buy/sell)). Proceeds from interest do not trigger an immediate capital gains taxable event but are classified as income; any future sale of the cryptocurrency is a capital gain event with a cost basis the same as the income price.
Example: If you received 100 Sushi when its price is $10/SUSHI, you sell one month later when the price is $1/SUSHI, your income is $1,000 and capital loss is $900.
Income
An 'Income' transaction is used if you receive cryptocurrency through a salary, wage or other form of general income (including referrals, completing surveys, etc). Proceeds are classified as income, based on the price when the transaction occurs. Any future sale of the crypto is a capital gain event with a cost basis the same as the income price.
Personal Use
A 'Personal Use' transaction is used if you have disposed of cryptocurrency for the purpose of purchasing goods or services.
Lost/Stolen
A 'Lost' or 'Stolen' transaction is used if you have lost cryptocurrency or have had it stolen (e.g. 'rugged' by scammers). This will trigger a capital loss tax event, where the loss = ($0 - the cost base of the cryptocurrency).
Gift
A 'Gift' transaction is used if you have received cryptocurrency as a gift. Similar to a 'Buy' transaction type, the capital gain/loss is calculated based on the price at sale and price when the gift is received. Receiving cryptocurrency as a gift does not trigger a capital gains or income tax event.
Fee
A 'Fee' transaction is used if you have disposed of cryptocurrency to cover the cost of fees generated as a result of other transactions.
Example:
- Fees paid when withdrawing cryptocurrency from a centralized exchange to your personal wallet.
- Gas fees paid during on-chain Ethereum swaps when interacting with decentralized exchanges. You can read more details about Ethereum gas fees here: https://cryptotaxcalculator.io/guides/eth-gas-fees-tax
Cashback
A 'Cashback' transaction is used if you have acquired cryptocurrency as a cashback (e.g. credit card cashback). Classified similar to a 'Buy' transaction type (the cost base at the time of acquisition), this transaction type does not trigger an income event.
Ignore In/Out
An 'Ignore In' or 'Ignore Out' transaction is used for ignoring a particular transaction from tax and balance calculations. This is a useful 'soft' alternative to deleting a transaction.
Failed In/Out
A 'Failed In' or 'Failed Out' transaction is used for marking failed transactions (whether in or out). The transaction itself will be ignored from tax calculations, but any fees incurred from creating the transaction will be accounted for."
Example:
- You tried to send ETH to someone during a period of high network congestion and you ran out of gas.
Realized Profit/Loss
A 'Realized Profit' or 'Realized Loss' transaction is used for when you have realized a profit or loss (respectively) on an for margin, futures, derivates, etc. type trades, where a profit or a loss has been realized on the trade. Proceeds from these trades count are classified as income.
Loan
A 'Loan' is when you receive crypto or fiat as a result of providing collateral.
Loan Fee
A 'Loan Fee' transaction represents a fee or interest paid to maintain an open loan position. This can be associated with margin, futures, CFD, derivates, etc. types of trades, as well as standard loans.
Loan Repayment
A 'Loan Repayment' transaction is used when repaying the collateral on a loan. This is separate to any fees or interests charged for maintaining the loan. The disposal of cryptocurrency can trigger a capital gain (or loss) on the difference from your purchase price.
Liquidate
A 'Liquidate' transaction is used when the lending platform has liquidated your collateral to cover their losses if a loan is not paid back or due to price volatility. This liquidation can create result in a realized capital gain (or loss) event.
Fiat Deposit/Withdrawal
A 'Fiat Deposit' or 'Fiat Withdrawal' transaction is used when you deposit or withdrawal fiat currency into or out of a fiat onramp exchange.
Example:
- Depositing fiat onto an exchange from your credit card.
- Withdrawing fiat from an exchange into your bank account.
The information provided on this website is general in nature and is not tax, accounting or legal advice. It has been prepared without taking into account your objectives, financial situation or needs. Before acting on this information, you should consider the appropriateness of the information having regard to your own objectives, financial situation and needs and seek professional advice. Cryptotaxcalculator disclaims all and any guarantees, undertakings and warranties, expressed or implied, and is not liable for any loss or damage whatsoever (including human or computer error, negligent or otherwise, or incidental or Consequential Loss or damage) arising out of, or in connection with, any use or reliance on the information or advice in this website. The user must accept sole responsibility associated with the use of the material on this site, irrespective of the purpose for which such use or results are applied. The information in this website is no substitute for specialist advice.