You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

146 lines
5.0 KiB
Python

4 years ago
from json import loads as json_loads
from json import dumps as json_dumps
from datetime import timedelta
from redis import Redis
from requests import get as r_get
from flask import current_app
4 years ago
from app.library.coingecko import get_market_data
from app.library.monero import wallet
from app.library.digitalocean import do
from app import config
class Cache(object):
def __init__(self):
self.redis = Redis(host=config.CACHE_HOST, port=config.CACHE_PORT)
def store_data(self, item_name, expiration_minutes, data):
4 years ago
current_app.logger.info(f'SET - {item_name} - expires in {expiration_minutes} minutes')
4 years ago
self.redis.setex(
item_name,
timedelta(minutes=expiration_minutes),
value=data
)
def get_tor_url(self, codename):
key_name = f'node_{codename}_tor_url'
data = self.redis.get(key_name)
if data:
current_app.logger.info(f'HIT - {key_name}')
return data
else:
current_app.logger.info(f'MISS - {key_name}')
try:
dns = f'{codename}.node.{config.DO_DOMAIN}'
url = f'https://{dns}/tor/'
r = r_get(url, timeout=6)
if r.text:
data = r.text.strip()
self.store_data(key_name, 86400, data)
else:
data = ''
return data
except:
return {'error': 'true'}
4 years ago
def get_info(self, codename):
key_name = f'node_{codename}_info'
data = self.redis.get(key_name)
if data:
current_app.logger.info(f'HIT - {key_name}')
4 years ago
return json_loads(data)
else:
4 years ago
current_app.logger.info(f'MISS - {key_name}')
4 years ago
try:
dns = f'{codename}.node.{config.DO_DOMAIN}'
url = f'http://{dns}:18081/get_info'
r = r_get(url, timeout=6)
data = r.json()
self.store_data(key_name, 30, json_dumps(data))
4 years ago
return data
except:
return {'error': 'true'}
def get_transfers(self, account_idx):
key_name = f'wallet_txes_{account_idx}'
data = self.redis.get(key_name)
if data:
current_app.logger.info(f'HIT - {key_name}')
4 years ago
return json_loads(data)
else:
4 years ago
current_app.logger.info(f'MISS - {key_name}')
4 years ago
txes = wallet.get_transfers(account_idx)
4 years ago
self.store_data(key_name, 2, json_dumps(txes))
4 years ago
return txes
def get_balances(self, account_idx, atomic=True):
if atomic:
extra = '_atomic'
else:
extra = ''
key_name = f'wallet_balances_{account_idx}{extra}'
data = self.redis.get(key_name)
if data:
current_app.logger.info(f'HIT - {key_name}')
4 years ago
return json_loads(data)
else:
4 years ago
current_app.logger.info(f'MISS - {key_name}')
4 years ago
balances = wallet.balances(account_idx, atomic)
data = {'balance': balances[0], 'unlocked': balances[1]}
self.store_data(key_name, 2, json_dumps(data))
4 years ago
return data
def show_droplet(self, droplet_id):
if droplet_id is None:
return None
4 years ago
key_name = f'droplet_{droplet_id}'
data = self.redis.get(key_name)
if data:
current_app.logger.info(f'HIT - {key_name}')
4 years ago
return json_loads(data)
else:
4 years ago
current_app.logger.info(f'MISS - {key_name}')
4 years ago
droplet = do.show_droplet(droplet_id)
self.store_data(key_name, 120, json_dumps(droplet))
return droplet
def show_volume(self, volume_id):
key_name = f'volume_{volume_id}'
data = self.redis.get(key_name)
if data:
current_app.logger.info(f'HIT - {key_name}')
4 years ago
return json_loads(data)
else:
4 years ago
current_app.logger.info(f'MISS - {key_name}')
4 years ago
volume = do.show_volume(volume_id)
self.store_data(key_name, 120, json_dumps(volume))
return volume
def get_coin_price(self, cur='usd'):
key_name = f'xmr_price_{cur}'
data = self.redis.get(key_name)
if data:
current_app.logger.info(f'HIT - {key_name}')
4 years ago
return float(data.decode())
else:
4 years ago
current_app.logger.info(f'MISS - {key_name}')
4 years ago
d = get_market_data()
amt = d['market_data']['current_price'][cur]
self.store_data(key_name, 5, amt)
return amt
def get_transfer_data(self, subaddress_index):
key_name = f'xmr_wallet_{subaddress_index}_txes'
data = self.redis.get(key_name)
if data:
current_app.logger.info(f'HIT - {key_name}')
4 years ago
return json_loads(data)
else:
4 years ago
current_app.logger.info(f'MISS - {key_name}')
4 years ago
wallet.get_transfers(subaddress_index)
self.store_data(key_name, 2, json_dumps(data))
return data
cache = Cache()