import { useRequest } from "vue-request"
import ogRequest from "../request"
import { useMonitorStore } from "../store/monitor"
import moment from "moment"

const monitorStore = useMonitorStore()

const { data, run: getDatabaseMetrics } = useRequest<Record<string, {data: string[], time: string[], name: string}[]>>(() => {
    const { rangeTime, time, instanceId, fixedRangeTime, tab } = monitorStore
    let start = 0
    let end = 0
    let step = 60
    if (tab === 1 && Array.isArray(fixedRangeTime) && fixedRangeTime.length === 2) {
        end = Math.floor(moment(fixedRangeTime[1]).valueOf() / 1000);
        start = Math.floor(moment(fixedRangeTime[0]).valueOf() / 1000);
        if (end - start < 2 * 60) {
            end = end - start > 60 ? start + 120 : start + 60
            start -= 60
        }
    } else {
        if (rangeTime > 0) {
            const _time = moment()
            end = Number.parseInt(`${_time.subtract(60 * rangeTime, 'second').toDate().getTime() / 1000}`)
            start = Number.parseInt(`${_time.subtract(rangeTime, 'hour').toDate().getTime() / 1000}`)
            step = 60 * rangeTime
        } else {
            start = Number.parseInt(`${time![0].getTime() / 1000}`)
            end = Number.parseInt(`${time![1].getTime() / 1000}`)
            step = Number.parseInt(`${(end - start) / 120}`)
        }
    }
    return ogRequest.get("/sql-diagnosis/api/v1/monitoring/database-metrics", {
        // id: 'ogbrench',
        id: instanceId,
        start,
        end,
        step: Math.max(60, step),
        type: "LINE",
    }) 
}, { manual: true })

watch(data, () => {
    if (monitorStore.tab === 0) {
        monitorStore.databaseData = data.value || {}
    } else {
        monitorStore.serverData = data.value || {}
    }
}, { deep: true })
export { getDatabaseMetrics }