Carlos Aguni

Highly motivated self-taught IT analyst. Always learning and ready to explore new skills. An eternal apprentice.


Boomtable Generics

13 Feb 2022 »
def gen_boomtable_generics(from_ms, to_ms):

    response = []
    row = []
    shield_warning = '<img src=""/>'
    shield_ok = '<img src=""/>'
    shield_bad = '<img src=""/>'
    status_error = '<img src=""/>'
    status_warning = '<img src=""/>'    status_ok = '<img src=""/>'
    dummy = '<img src=""/>'

    shields = [shield_warning, shield_ok, shield_bad]
    status = [status_ok, status_warning, status_error]
    for i in range(10):
        row.append({
            "name": f"EC2{i:02d}",
            "ip": f"10.0.0.{i}",
            "cpu": f"{random.randint(10,100)}%",
            "status": random.choice(status),
            "alert compliance": random.choice(shields),
        })
    
    df = pd.DataFrame(row)    
    cols = [i for i in list(df.columns) if i != "_value_"]
    ___ = " ;;; "
    for idy, c in enumerate(cols):
        response.append({
            "target": f"row000{___}col{idy:03d}{___}{c}",
            "datapoints": [[1, to_ms]],
        })
    for idx,doc in enumerate(df.to_dict('records')):
        idxref = f"{idx+1:03d}"
        val = doc.get("_value_", 1)
        for idy, c in enumerate(cols):
            idyref = f"{idy:03d}"
            cval = doc.get(c, '')
            response.append({
                "target": f"row{idxref}{___}col{idyref}{___}{cval}",
                "datapoints": [[val, to_ms]],
            })
    return response