diff --git a/.github/workflows/upload_to_dune.yml b/.github/workflows/upload_to_dune.yml new file mode 100644 index 0000000..4f079de --- /dev/null +++ b/.github/workflows/upload_to_dune.yml @@ -0,0 +1,33 @@ +name: Upload CSVs to Dune on Commit + +on: + push: + branches: + - main + paths: + - 'queries/**' + +jobs: + build: + runs-on: ubuntu-latest + + steps: + - uses: actions/checkout@v2 + + - uses: actions/setup-python@v4 + with: + python-version: '3.9' + + - name: Log directory structure + run: | + pwd + ls -R + + - name: pip requirements + run: pip install -r requirements.txt + + - name: Update all queries from Dune, by overwriting queries with repo query text + env: + DUNE_API_KEY: ${{ secrets.DUNE_API_KEY }} + DUNE_API_BASE_URL: ${{ secrets.DUNE_API_BASE_URL }} + run: python -u scripts/upload_to_dune.py diff --git a/queries/queries.yml b/queries/queries.yml index 4c240ef..a276af1 100644 --- a/queries/queries.yml +++ b/queries/queries.yml @@ -1,3 +1,2 @@ query_ids: - - 2615782 - - 2615781 \ No newline at end of file + - 123456 \ No newline at end of file diff --git a/queries/sudoswap_v2_collections_summar___2615781.sql b/queries/sudoswap_v2_collections_summar___2615781.sql deleted file mode 100644 index a1c16bc..0000000 --- a/queries/sudoswap_v2_collections_summar___2615781.sql +++ /dev/null @@ -1,220 +0,0 @@ --- part of a query repo --- query name: Sudoswap V2 Collections Summary --- query link: https://dune.com/queries/2615781 - - -WITH - pairs_created as ( - SELECT - * - FROM query_2615780 - ), - - --we also need to get token balance of each pair currently - erc721_balances as ( - SELECT - contract_address as nft_contract_address - -- , array_agg(tokenId) as tokenids_held - , count(*) as tokens_held - FROM ( - SELECT - row_number() OVER (partition by contract_address, tokenId order by evt_block_number desc, evt_index desc) as last_held - , * - FROM erc721_ethereum.evt_Transfer tr - where tr.contract_address IN (select distinct nft_contract_address from pairs_created) --get last holders for all nft contracts (need to include erc1155 later) - ) a - WHERE last_held = 1 - AND a.to IN (SELECT pool_address FROM pairs_created) --keep only tokens held by pairs - GROUP BY 1 - ), - - erc1155_balances as ( - with t_in as ( - SELECT - to as pool - , contract_address - , token_id - , sum(amount) as transferred_in - FROM nft.transfers - WHERE blockchain = 'ethereum' - and token_standard = 'erc1155' - and to IN (SELECT pool_address FROM pairs_created) - group by 1,2,3 - ) - - , t_out as ( - SELECT - "from" as pool - , contract_address - , token_id - , sum(amount) as transferred_out - FROM nft.transfers - WHERE blockchain = 'ethereum' - and token_standard = 'erc1155' - and "from" IN (SELECT pool_address FROM pairs_created) - group by 1,2,3 - ) - - SELECT - pc.nft_contract_address - , sum(t_in.transferred_in - COALESCE(t_out.transferred_out,cast(0 as uint256))) as tokens_held - FROM t_in - LEFT JOIN t_out ON t_in.pool = t_out.pool AND t_in.contract_address = t_out.contract_address AND t_in.token_id = t_out.token_id - JOIN pairs_created pc ON pc.pool_address = t_in.pool - group by 1 - ), - - --we need eth_balances for liquidity tracking purposes - eth_balances as ( - WITH eth_in as ( - SELECT - tr.to as holder_address - , SUM(tr.value/1e18) as eth_funded - FROM ethereum.traces tr - WHERE tr.block_time > timestamp '2022-04-23' - AND tr.success=true - AND tr.type='call' - AND (tr.call_type NOT IN ('delegatecall', 'callcode', 'staticcall') OR tr.call_type IS null) - AND tr.to IN (SELECT pool_address FROM pairs_created) - GROUP BY 1 - ), - - eth_out as ( - SELECT - tr."from" as holder_address - , SUM(tr.value/1e18) as eth_spent - FROM ethereum.traces tr - WHERE tr.block_time > timestamp '2022-04-23' - AND tr.success=true - AND tr.type='call' - AND (tr.call_type NOT IN ('delegatecall', 'callcode', 'staticcall') OR tr.call_type IS null) - AND tr."from" IN (SELECT pool_address FROM pairs_created) - GROUP BY 1 - ) - - SELECT - pc.nft_contract_address - , SUM(COALESCE(eth_funded,0) - COALESCE(eth_spent, 0)) as eth_balance - FROM eth_in - LEFT JOIN eth_out ON eth_in.holder_address = eth_out.holder_address - JOIN pairs_created pc ON pc.pool_address = eth_in.holder_address - WHERE COALESCE(eth_funded,0) - COALESCE(eth_spent, 0) > 0 --for some reason some balances are calculated negative. - GROUP BY 1 - ), - - erc20_balances as ( - WITH erc20_in as ( - SELECT - tr.to as holder - , contract_address - , SUM(cast(tr.value as double)) as token_funded - FROM erc20_ethereum.evt_Transfer tr - WHERE tr.to IN (SELECT pool_address FROM pairs_created) - -- AND contract_address IN (SELECT address FROM valid_tokens) - GROUP BY 1,2 - ), - - erc20_out as ( - SELECT - tr."from" as holder - , contract_address - , SUM(cast(tr.value as double)) as token_spent - FROM erc20_ethereum.evt_Transfer tr - WHERE tr."from" IN (SELECT pool_address FROM pairs_created) - -- AND contract_address IN (SELECT address FROM valid_tokens) - GROUP BY 1,2 - ) - - , contract_balance_sum as ( - SELECT - pc.nft_contract_address - , tk.symbol as symbol - , erc20_in.contract_address - , sum(token_funded/pow(10,COALESCE(tk.decimals,18)) - COALESCE(token_spent, 0)/pow(10,COALESCE(tk.decimals,18))) as tokens_held - FROM erc20_in - LEFT JOIN erc20_out ON erc20_in.holder = erc20_out.holder - LEFT JOIN tokens.erc20 tk ON tk.contract_address = erc20_in.contract_address - JOIN pairs_created pc ON pc.pool_address = erc20_in.holder - WHERE COALESCE(token_funded,0) - COALESCE(token_spent, 0) > 0 --due to overflow, some balances are calculated negative. - AND blockchain = 'ethereum' - group by 1,2,3 - ) - - SELECT - nft_contract_address - , array_agg(json_object('token':COALESCE(symbol,cast(contract_address as varchar)), 'balance': round(tokens_held,4))) as tokens_held - FROM contract_balance_sum - group by 1 - ), - - trading_totals as ( - SELECT - nft_contract_address - , nft_name - , sum(amount_usd) as usd_volume - -- get 7 day volume - , sum(number_of_items) as nfts_traded - , sum(trade_fee_amount_usd) as trade_fee_amount_usd - , sum(case when block_time >= now() - interval '7' day then amount_usd else 0 end) as last_7_days - , sum(case when block_time >= now() - interval '7' day then trade_fee_amount_usd else 0 end) as last_7_days_fees - , sum(protocol_fee_amount_usd) as protocol_fee_amount_usd - FROM dune.dune.result_sudoswap_v_2_trades - GROUP BY 1,2 - ), - - last_price as ( - SELECT - nft_contract_address - , amount_usd - FROM ( - SELECT - * - , row_number() OVER (partition by nft_contract_address order by block_time desc) as rn - FROM dune.dune.result_sudoswap_v_2_trades - WHERE amount_usd is not null - ) a - WHERE rn = 1 - ), - - all_collections_cleaned as ( - SELECT - pc.* - , nft.name as nft_name - , COALESCE(bal_721.tokens_held,0) as nfts_721 --buyable liquidity - , COALESCE(bal_1155.tokens_held,cast(0 as uint256)) as nfts_1155 --buyable liquidity - , COALESCE(bal_20.tokens_held,array['0']) as erc20_balances --fix logic using transform agg later - , COALESCE(eth_bal.eth_balance,0) as eth_liq --sellable liquidity - FROM ( - SELECT - nft_contract_address - , count(distinct pool_address) as num_pairs - FROM pairs_created - GROUP BY 1 - ) pc - LEFT JOIN erc721_balances bal_721 ON bal_721.nft_contract_address = pc.nft_contract_address - LEFT JOIN erc1155_balances bal_1155 ON bal_1155.nft_contract_address = pc.nft_contract_address - LEFT JOIN erc20_balances bal_20 ON bal_20.nft_contract_address = pc.nft_contract_address - LEFT JOIN eth_balances eth_bal ON eth_bal.nft_contract_address = pc.nft_contract_address - LEFT JOIN tokens.nft nft ON nft.blockchain = 'ethereum' and nft.contract_address = pc.nft_contract_address - ) - -SELECT - CONCAT(' swap now! ') as s_link - , CONCAT('',COALESCE(acc.nft_name, cast(acc.nft_contract_address as varchar),'')) as collection - , num_pairs - , '||' as split - , spot.amount_usd as last_spot - , COALESCE(trade.last_7_days, 0) as last_7_days - , COALESCE(trade.usd_volume, 0) as usd_volume - , COALESCE(trade.nfts_traded, cast(0 as uint256)) as nfts_traded - , COALESCE(trade.trade_fee_amount_usd, 0) as trade_fee_amount_usd - , COALESCE(trade.protocol_fee_amount_usd, 0) as protocol_fee_amount_usd - , '||' as split_2 - , nfts_721 - , nfts_1155 - , erc20_balances - , eth_liq -FROM all_collections_cleaned acc -LEFT JOIN trading_totals trade ON trade.nft_contract_address = acc.nft_contract_address -LEFT JOIN last_price spot ON spot.nft_contract_address = acc.nft_contract_address -ORDER BY last_7_days DESC \ No newline at end of file diff --git a/queries/sudoswap_v2_trends___2615782.sql b/queries/sudoswap_v2_trends___2615782.sql deleted file mode 100644 index 074a982..0000000 --- a/queries/sudoswap_v2_trends___2615782.sql +++ /dev/null @@ -1,14 +0,0 @@ --- part of a query repo --- query name: Sudoswap V2 Trends --- query link: https://dune.com/queries/2615782 - - -SELECT -date_trunc('week', block_time) as week -, pool_type as col -, count(*) as trades -, sum(amount_usd) as usd_volume -, count(distinct tx_from) as traders -, sum(protocol_fee_amount_usd + trade_fee_amount_usd + royalty_fee_amount_usd) as all_fees -FROM dune.dune.result_sudoswap_v_2_trades -group by 1,2 \ No newline at end of file diff --git a/requirements.txt b/requirements.txt index ad76048..6888d99 100644 --- a/requirements.txt +++ b/requirements.txt @@ -1,4 +1,4 @@ -dune-client==1.3.0 +dune-client pyyaml python-dotenv pandas \ No newline at end of file diff --git a/scripts/push_to_dune.py b/scripts/push_to_dune.py index 71b1932..86357e2 100644 --- a/scripts/push_to_dune.py +++ b/scripts/push_to_dune.py @@ -36,13 +36,14 @@ with open(file_path, 'r', encoding='utf-8') as file: text = file.read() - # Update existing file - dune.update_query( - query.base.query_id, - # All parameters below are optional - query_sql=text, - ) - print('SUCCESS: updated query {} to dune'.format(query.base.query_id)) - + try: + # Update existing file + dune.update_query( + query.base.query_id, + query_sql=text, + ) + print('SUCCESS: updated query {} to dune'.format(query.base.query_id)) + except Exception as e: + print('ERROR: {}'.format(str(e))) #likely API permission errors else: print('ERROR: file not found, query id {}'.format(query.base.query_id)) diff --git a/scripts/upload_to_dune.py b/scripts/upload_to_dune.py new file mode 100644 index 0000000..5ec4e36 --- /dev/null +++ b/scripts/upload_to_dune.py @@ -0,0 +1,33 @@ +import os +from dune_client.client import DuneClient +from dotenv import load_dotenv +import sys +import codecs +import os + +# Set the default encoding to UTF-8 +sys.stdout = codecs.getwriter("utf-8")(sys.stdout.detach()) + +dotenv_path = os.path.join(os.path.dirname(__file__), '..', '.env') +load_dotenv(dotenv_path) + +dune = DuneClient.from_env() + +uploads_path = os.path.join(os.path.dirname(__file__), '..', 'uploads') +files = os.listdir(uploads_path) + +for file in files: + if not file.endswith(".csv"): + continue + file_name = file.split(".")[0].lower().replace(' ', '_') + with open(os.path.join(uploads_path, file), 'r') as file: + try: + table = dune.upload_csv( + data=str(file.read()), + table_name=file_name, + is_private=False + ) + print(f'uploaded table "{file_name}"') + except Exception as e: + print(f"An error occurred while uploading the CSV: {str(e)}") + diff --git a/uploads/FEDFUNDS.csv b/uploads/FEDFUNDS.csv new file mode 100644 index 0000000..d063ea3 --- /dev/null +++ b/uploads/FEDFUNDS.csv @@ -0,0 +1,206 @@ +DATE,FEDFUNDS +2007-01-01,5.25 +2007-02-01,5.26 +2007-03-01,5.26 +2007-04-01,5.25 +2007-05-01,5.25 +2007-06-01,5.25 +2007-07-01,5.26 +2007-08-01,5.02 +2007-09-01,4.94 +2007-10-01,4.76 +2007-11-01,4.49 +2007-12-01,4.24 +2008-01-01,3.94 +2008-02-01,2.98 +2008-03-01,2.61 +2008-04-01,2.28 +2008-05-01,1.98 +2008-06-01,2.00 +2008-07-01,2.01 +2008-08-01,2.00 +2008-09-01,1.81 +2008-10-01,0.97 +2008-11-01,0.39 +2008-12-01,0.16 +2009-01-01,0.15 +2009-02-01,0.22 +2009-03-01,0.18 +2009-04-01,0.15 +2009-05-01,0.18 +2009-06-01,0.21 +2009-07-01,0.16 +2009-08-01,0.16 +2009-09-01,0.15 +2009-10-01,0.12 +2009-11-01,0.12 +2009-12-01,0.12 +2010-01-01,0.11 +2010-02-01,0.13 +2010-03-01,0.16 +2010-04-01,0.20 +2010-05-01,0.20 +2010-06-01,0.18 +2010-07-01,0.18 +2010-08-01,0.19 +2010-09-01,0.19 +2010-10-01,0.19 +2010-11-01,0.19 +2010-12-01,0.18 +2011-01-01,0.17 +2011-02-01,0.16 +2011-03-01,0.14 +2011-04-01,0.10 +2011-05-01,0.09 +2011-06-01,0.09 +2011-07-01,0.07 +2011-08-01,0.10 +2011-09-01,0.08 +2011-10-01,0.07 +2011-11-01,0.08 +2011-12-01,0.07 +2012-01-01,0.08 +2012-02-01,0.10 +2012-03-01,0.13 +2012-04-01,0.14 +2012-05-01,0.16 +2012-06-01,0.16 +2012-07-01,0.16 +2012-08-01,0.13 +2012-09-01,0.14 +2012-10-01,0.16 +2012-11-01,0.16 +2012-12-01,0.16 +2013-01-01,0.14 +2013-02-01,0.15 +2013-03-01,0.14 +2013-04-01,0.15 +2013-05-01,0.11 +2013-06-01,0.09 +2013-07-01,0.09 +2013-08-01,0.08 +2013-09-01,0.08 +2013-10-01,0.09 +2013-11-01,0.08 +2013-12-01,0.09 +2014-01-01,0.07 +2014-02-01,0.07 +2014-03-01,0.08 +2014-04-01,0.09 +2014-05-01,0.09 +2014-06-01,0.10 +2014-07-01,0.09 +2014-08-01,0.09 +2014-09-01,0.09 +2014-10-01,0.09 +2014-11-01,0.09 +2014-12-01,0.12 +2015-01-01,0.11 +2015-02-01,0.11 +2015-03-01,0.11 +2015-04-01,0.12 +2015-05-01,0.12 +2015-06-01,0.13 +2015-07-01,0.13 +2015-08-01,0.14 +2015-09-01,0.14 +2015-10-01,0.12 +2015-11-01,0.12 +2015-12-01,0.24 +2016-01-01,0.34 +2016-02-01,0.38 +2016-03-01,0.36 +2016-04-01,0.37 +2016-05-01,0.37 +2016-06-01,0.38 +2016-07-01,0.39 +2016-08-01,0.40 +2016-09-01,0.40 +2016-10-01,0.40 +2016-11-01,0.41 +2016-12-01,0.54 +2017-01-01,0.65 +2017-02-01,0.66 +2017-03-01,0.79 +2017-04-01,0.90 +2017-05-01,0.91 +2017-06-01,1.04 +2017-07-01,1.15 +2017-08-01,1.16 +2017-09-01,1.15 +2017-10-01,1.15 +2017-11-01,1.16 +2017-12-01,1.30 +2018-01-01,1.41 +2018-02-01,1.42 +2018-03-01,1.51 +2018-04-01,1.69 +2018-05-01,1.70 +2018-06-01,1.82 +2018-07-01,1.91 +2018-08-01,1.91 +2018-09-01,1.95 +2018-10-01,2.19 +2018-11-01,2.20 +2018-12-01,2.27 +2019-01-01,2.40 +2019-02-01,2.40 +2019-03-01,2.41 +2019-04-01,2.42 +2019-05-01,2.39 +2019-06-01,2.38 +2019-07-01,2.40 +2019-08-01,2.13 +2019-09-01,2.04 +2019-10-01,1.83 +2019-11-01,1.55 +2019-12-01,1.55 +2020-01-01,1.55 +2020-02-01,1.58 +2020-03-01,0.65 +2020-04-01,0.05 +2020-05-01,0.05 +2020-06-01,0.08 +2020-07-01,0.09 +2020-08-01,0.10 +2020-09-01,0.09 +2020-10-01,0.09 +2020-11-01,0.09 +2020-12-01,0.09 +2021-01-01,0.09 +2021-02-01,0.08 +2021-03-01,0.07 +2021-04-01,0.07 +2021-05-01,0.06 +2021-06-01,0.08 +2021-07-01,0.10 +2021-08-01,0.09 +2021-09-01,0.08 +2021-10-01,0.08 +2021-11-01,0.08 +2021-12-01,0.08 +2022-01-01,0.08 +2022-02-01,0.08 +2022-03-01,0.20 +2022-04-01,0.33 +2022-05-01,0.77 +2022-06-01,1.21 +2022-07-01,1.68 +2022-08-01,2.33 +2022-09-01,2.56 +2022-10-01,3.08 +2022-11-01,3.78 +2022-12-01,4.10 +2023-01-01,4.33 +2023-02-01,4.57 +2023-03-01,4.65 +2023-04-01,4.83 +2023-05-01,5.06 +2023-06-01,5.08 +2023-07-01,5.12 +2023-08-01,5.33 +2023-09-01,5.33 +2023-10-01,5.33 +2023-11-01,5.33 +2023-12-01,5.33 +2024-01-01,5.33