2024-02-12 21:53:17 +11:00
|
|
|
import json
|
|
|
|
import account
|
|
|
|
import requests
|
|
|
|
import threading
|
|
|
|
import os
|
2024-03-15 14:59:07 +11:00
|
|
|
import time
|
2024-02-12 21:53:17 +11:00
|
|
|
|
|
|
|
APIKEY = os.environ.get("hsd_api")
|
|
|
|
ip = os.getenv("hsd_ip")
|
|
|
|
if ip is None:
|
|
|
|
ip = "localhost"
|
|
|
|
|
|
|
|
|
|
|
|
# Plugin Data
|
|
|
|
info = {
|
|
|
|
"name": "Automations",
|
|
|
|
"description": "This plugin will automatically renew domains, reveal and redeem bids.",
|
|
|
|
"version": "1.0",
|
|
|
|
"author": "Nathan.Woodburn/"
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
# Functions
|
|
|
|
functions = {
|
|
|
|
"automation":{
|
|
|
|
"name": "Function to automate",
|
|
|
|
"type": "dashboard",
|
|
|
|
"description": "This used type dashboard to trigger the function whenever you access the dashboard.",
|
|
|
|
"params": {},
|
|
|
|
"returns": {
|
|
|
|
"Status":
|
|
|
|
{
|
|
|
|
"name": "Status of the automation",
|
|
|
|
"type": "text"
|
|
|
|
}
|
|
|
|
}
|
2024-11-21 19:30:19 +11:00
|
|
|
},
|
|
|
|
"disable":{
|
|
|
|
"name": "Disable Automations",
|
|
|
|
"type": "default",
|
|
|
|
"description": "Disable Automations for this wallet",
|
|
|
|
"params": {},
|
|
|
|
"returns": {
|
|
|
|
"Status":
|
|
|
|
{
|
|
|
|
"name": "Status",
|
|
|
|
"type": "text"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
"enable":{
|
|
|
|
"name": "Enable Automations",
|
|
|
|
"type": "default",
|
|
|
|
"description": "Enable Automations for this wallet",
|
|
|
|
"params": {},
|
|
|
|
"returns": {
|
|
|
|
"Status":
|
|
|
|
{
|
|
|
|
"name": "Status",
|
|
|
|
"type": "text"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
"list":{
|
|
|
|
"name": "List Disabled Wallets",
|
|
|
|
"type": "default",
|
|
|
|
"description": "List wallets with automations disabled",
|
|
|
|
"params": {},
|
|
|
|
"returns": {
|
|
|
|
"wallets":
|
|
|
|
{
|
|
|
|
"name": "List of wallets",
|
|
|
|
"type": "list"
|
|
|
|
}
|
|
|
|
}
|
2024-02-12 21:53:17 +11:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-03-15 14:59:07 +11:00
|
|
|
started = False
|
2024-02-12 21:53:17 +11:00
|
|
|
|
|
|
|
# Main entry point only lets the main function run every 5 mins
|
|
|
|
def automation(params, authentication):
|
|
|
|
global started
|
2024-03-15 14:59:07 +11:00
|
|
|
|
2024-11-21 19:30:19 +11:00
|
|
|
wallet = authentication.split(":")[0]
|
|
|
|
if os.path.exists(f"user_data/{wallet}.autoRenew"):
|
|
|
|
return {"Status": "Automations disabled"}
|
|
|
|
|
2024-03-15 14:59:07 +11:00
|
|
|
if started:
|
2024-11-21 19:30:19 +11:00
|
|
|
return {"Status": "Automations running"}
|
|
|
|
started = True
|
|
|
|
|
2024-02-12 21:53:17 +11:00
|
|
|
threading.Thread(target=automations_background, args=(authentication,)).start()
|
2024-11-21 19:30:19 +11:00
|
|
|
return {"Status": "Starting Automations..."}
|
|
|
|
|
|
|
|
def disable(params, authentication):
|
|
|
|
# Create walletname file in user_data
|
|
|
|
wallet = authentication.split(":")[0]
|
|
|
|
with open(f"user_data/{wallet}.autoRenew", "w") as f:
|
|
|
|
f.write("disabled")
|
|
|
|
return {"Status": "Disabled Automations"}
|
|
|
|
|
|
|
|
def enable(params, authentication):
|
|
|
|
# Delete walletname file in user_data
|
|
|
|
wallet = authentication.split(":")[0]
|
|
|
|
if os.path.exists(f"user_data/{wallet}.autoRenew"):
|
|
|
|
os.remove(f"user_data/{wallet}.autoRenew")
|
|
|
|
|
|
|
|
return {"Status": "Enabled Automations"}
|
|
|
|
|
|
|
|
def list(params, authentication):
|
|
|
|
wallets = []
|
|
|
|
for file in os.listdir("user_data"):
|
|
|
|
if file.endswith(".autoRenew"):
|
|
|
|
wallets.append(file[:-10])
|
|
|
|
return {"wallets": wallets}
|
2024-02-12 21:53:17 +11:00
|
|
|
|
|
|
|
# Background function to run the automations
|
|
|
|
def automations_background(authentication):
|
2024-11-21 19:30:19 +11:00
|
|
|
|
2024-03-15 14:59:07 +11:00
|
|
|
while True:
|
|
|
|
# Get account details
|
|
|
|
account_name = account.check_account(authentication)
|
|
|
|
password = ":".join(authentication.split(":")[1:])
|
2024-02-12 21:53:17 +11:00
|
|
|
|
2024-03-15 14:59:07 +11:00
|
|
|
if account_name == False:
|
|
|
|
return {
|
|
|
|
"error": {
|
|
|
|
"message": "Invalid account"
|
|
|
|
}
|
2024-02-12 21:53:17 +11:00
|
|
|
}
|
2024-11-21 19:30:19 +11:00
|
|
|
|
|
|
|
if os.path.exists(f"user_data/{account_name}.autoRenew"):
|
|
|
|
print("Skipping Automations")
|
|
|
|
time.sleep(300)
|
|
|
|
continue
|
|
|
|
print("Running automations")
|
2024-03-15 14:59:07 +11:00
|
|
|
try:
|
|
|
|
# Try to select and login to the wallet
|
|
|
|
response = account.hsw.rpc_selectWallet(account_name)
|
|
|
|
if response['error'] is not None:
|
|
|
|
return
|
2024-11-21 19:30:19 +11:00
|
|
|
response = account.hsw.rpc_walletPassphrase(password,30)
|
2024-03-15 14:59:07 +11:00
|
|
|
if response['error'] is not None:
|
|
|
|
return
|
|
|
|
# Try to send the batch of all renew, reveal and redeem actions
|
|
|
|
requests.post(f"http://x:{APIKEY}@{ip}:12039",json={"method": "sendbatch","params": [[["RENEW"]]]})
|
|
|
|
requests.post(f"http://x:{APIKEY}@{ip}:12039",json={"method": "sendbatch","params": [[["REVEAL"]]]})
|
|
|
|
requests.post(f"http://x:{APIKEY}@{ip}:12039",json={"method": "sendbatch","params": [[["REDEEM"]]]})
|
|
|
|
except Exception as e:
|
|
|
|
print(e)
|
|
|
|
|
|
|
|
# Sleep for 5 mins before running again
|
|
|
|
time.sleep(300)
|