Add farm and worker names to HiveOS configuration
Signed-off-by: Julien Riou <julien@riou.xyz>
This commit is contained in:
parent
8cfb8fabf8
commit
c4a4b6f787
4 changed files with 39 additions and 34 deletions
|
@ -6,3 +6,4 @@
|
||||||
data_format = "json"
|
data_format = "json"
|
||||||
tagexclude = ["url"]
|
tagexclude = ["url"]
|
||||||
tag_keys = ["name", "id"]
|
tag_keys = ["name", "id"]
|
||||||
|
|
||||||
|
|
|
@ -35,31 +35,52 @@ class HiveAPI:
|
||||||
self.session = session
|
self.session = session
|
||||||
self.base_url = 'https://api2.hiveos.farm/api/v2'
|
self.base_url = 'https://api2.hiveos.farm/api/v2'
|
||||||
self.farms = {}
|
self.farms = {}
|
||||||
for farm_id in self.fetch_farms():
|
for farm in self.fetch_farms():
|
||||||
self.farms[farm_id] = self.fetch_workers(farm_id=farm_id)
|
self.farms[farm] = self.fetch_workers(farm_id=farm.number)
|
||||||
|
|
||||||
def fetch_farms(self):
|
def fetch_farms(self):
|
||||||
r = self.session.get(f'{self.base_url}/farms')
|
r = self.session.get(f'{self.base_url}/farms')
|
||||||
r.raise_for_status()
|
r.raise_for_status()
|
||||||
farms = r.json().get('data')
|
farms = r.json().get('data')
|
||||||
if farms:
|
if farms:
|
||||||
return [f.get('id') for f in farms]
|
return [Farm(number=f['id'], name=f['name']) for f in farms]
|
||||||
|
|
||||||
def fetch_workers(self, farm_id):
|
def fetch_workers(self, farm_id):
|
||||||
r = self.session.get(f'{self.base_url}/farms/{farm_id}/workers')
|
r = self.session.get(f'{self.base_url}/farms/{farm_id}/workers')
|
||||||
r.raise_for_status()
|
r.raise_for_status()
|
||||||
workers = r.json().get('data')
|
workers = r.json().get('data')
|
||||||
if workers:
|
if workers:
|
||||||
return [w.get('id') for w in workers]
|
return [Worker(number=w['id'], farm_id=farm_id, name=w['name']) for w in workers]
|
||||||
|
|
||||||
|
|
||||||
|
class Farm:
|
||||||
|
def __init__(self, number, name):
|
||||||
|
self.number = number
|
||||||
|
self.name = name
|
||||||
|
|
||||||
|
def __repr__(self):
|
||||||
|
return f'<Farm #{self.number}({self.name})>'
|
||||||
|
|
||||||
|
|
||||||
|
class Worker:
|
||||||
|
def __init__(self, number, farm_id, name):
|
||||||
|
self.number = number
|
||||||
|
self.farm_id = farm_id
|
||||||
|
self.name = name
|
||||||
|
|
||||||
|
def __repr__(self):
|
||||||
|
return f'<Worker #{self.number}({self.name}@Farm#{self.farm_id})>'
|
||||||
|
|
||||||
|
|
||||||
def create_farm_configuration(farm_id):
|
def create_farm_configuration(farm_id):
|
||||||
return create_configuration(template_name='farm.conf.j2', template_variables={'farm_id': farm_id})
|
template_variables = {'farm_id': farm_id}
|
||||||
|
return create_configuration(template_name='farm.conf.j2', template_variables=template_variables)
|
||||||
|
|
||||||
|
|
||||||
def create_worker_configuration(farm_id, worker_id):
|
def create_worker_configuration(farm_id, farm_name, worker_id, worker_name):
|
||||||
return create_configuration(template_name='worker.conf.j2',
|
template_variables = {'farm_id': farm_id, 'farm_name': farm_name, 'worker_id': worker_id,
|
||||||
template_variables={'farm_id': farm_id, 'worker_id': worker_id})
|
'worker_name': worker_name}
|
||||||
|
return create_configuration(template_name='worker.conf.j2', template_variables=template_variables)
|
||||||
|
|
||||||
|
|
||||||
def create_configuration(template_name, template_variables):
|
def create_configuration(template_name, template_variables):
|
||||||
|
@ -84,12 +105,13 @@ def main():
|
||||||
api = HiveAPI(token=token)
|
api = HiveAPI(token=token)
|
||||||
|
|
||||||
configurations = []
|
configurations = []
|
||||||
for farm_id in api.farms:
|
for farm in api.farms:
|
||||||
logger.info(f'generating configuration for farm {farm_id}')
|
logger.info(f"generating configuration for farm {farm}")
|
||||||
configurations.append(create_farm_configuration(farm_id=farm_id))
|
configurations.append(create_farm_configuration(farm_id=farm.number))
|
||||||
for worker_id in api.farms[farm_id]:
|
for worker in api.farms[farm]:
|
||||||
logger.info(f'generating configuration for worker {worker_id}')
|
logger.info(f'generating configuration for worker {worker}')
|
||||||
configurations.append(create_worker_configuration(farm_id=farm_id, worker_id=worker_id))
|
configurations.append(create_worker_configuration(farm_id=farm.number, farm_name=farm.name,
|
||||||
|
worker_id=worker.number, worker_name=worker.name))
|
||||||
|
|
||||||
logger.info('writing configuration to file')
|
logger.info('writing configuration to file')
|
||||||
with open('hiveos.conf', 'w') as fd:
|
with open('hiveos.conf', 'w') as fd:
|
||||||
|
|
|
@ -1,20 +0,0 @@
|
||||||
[[inputs.http]]
|
|
||||||
name_override = "hiveos_farm"
|
|
||||||
urls = ["https://api2.hiveos.farm/api/v2/farms/418240"]
|
|
||||||
headers = {"Content-Type" = "application/json"}
|
|
||||||
headers = {"Authorization" = "Bearer ${HIVEOS_TOKEN}"}
|
|
||||||
data_format = "json"
|
|
||||||
tagexclude = ["url"]
|
|
||||||
tag_keys = ["name", "id"]
|
|
||||||
[[inputs.http]]
|
|
||||||
name_override = "hiveos_gpu"
|
|
||||||
urls = ["https://api2.hiveos.farm/api/v2/farms/418240/workers/1150566"]
|
|
||||||
headers = {"Content-Type" = "application/json"}
|
|
||||||
headers = {"Authorization" = "Bearer ${HIVEOS_TOKEN}"}
|
|
||||||
data_format = "json"
|
|
||||||
tagexclude = ["url"]
|
|
||||||
tag_keys = ["bus_number"]
|
|
||||||
json_query = "gpu_stats"
|
|
||||||
[inputs.http.tags]
|
|
||||||
farm_id = "418240"
|
|
||||||
worker_id = "1150566"
|
|
|
@ -9,5 +9,7 @@
|
||||||
json_query = "gpu_stats"
|
json_query = "gpu_stats"
|
||||||
[inputs.http.tags]
|
[inputs.http.tags]
|
||||||
farm_id = "{{farm_id}}"
|
farm_id = "{{farm_id}}"
|
||||||
|
farm_name = "{{farm_name}}"
|
||||||
worker_id = "{{worker_id}}"
|
worker_id = "{{worker_id}}"
|
||||||
|
worker_name = "{{worker_name}}"
|
||||||
|
|
||||||
|
|
Reference in a new issue