package com.artfess.rescue.cloud.model;

import com.artfess.base.entity.BaseModel;
import com.artfess.base.entity.BizDelModel;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import com.fasterxml.jackson.annotation.JsonIgnore;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import lombok.EqualsAndHashCode;

import java.io.Serializable;
import java.time.LocalDateTime;

/**
 * 私有云资源使用情况表
 *
 * @company 阿特菲斯信息技术有限公司
 * @author 管理员
 * @since 2024-08-12
 */
@ApiModel(value="BizCloudApplyUseDetailed对象", description="私有云资源使用情况表")
@TableName("biz_cloud_apply_use_detailed")
@Data
@EqualsAndHashCode(callSuper = true)
public class BizCloudApplyUseDetailed extends BizDelModel<BizCloudApplyUseDetailed> {

    private static final long serialVersionUID = 1L;

    @ApiModelProperty(value = "主键ID")
    @TableId(value = "ID_", type = IdType.ASSIGN_ID)
    private String id;

    @ApiModelProperty(value = "云资源申请ID	")
    @TableField("PRIVATE_CLOUD_APPLY_ID_")
    private String privateCloudApplyId;

    @ApiModelProperty(value = "资源所属云平台【使用字典，1：XSKY，2：Zstack】")
    @TableField("CLOUD_TYPE_")
    private Integer cloudType;

    @ApiModelProperty(value = "资源类型，1：分配前，2：分配后】")
    @TableField("USE_TYPE")
    private Integer useType;

    @ApiModelProperty(value = "CPU共计（核）")
    @TableField("CPU_NUM_TOTAL_")
    private Integer cpuNumTotal;

    @ApiModelProperty(value = "CPU已用（核）")
    @TableField("CPU_NUM_USE_")
    private Integer cpuNumUse;

    @ApiModelProperty(value = "CPU使用率（CPU已用/CPU共计×100，保留两位小数向下取整）")
    @TableField("CPU_NUM_USE_RATE_")
    private Float cpuNumUseRate;

    @ApiModelProperty(value = "内存容量共计（TB）")
    @TableField("MEMORY_CAPACITY_TOTAL_")
    private Float memoryCapacityTotal;

    @ApiModelProperty(value = "内存容量已用（TB）")
    @TableField("MEMORY_CAPACITY_USE_")
    private Float memoryCapacityUse;

    @ApiModelProperty(value = "内存使用率（内存已用/内存共计×100，保留两位小数向下取整）")
    @TableField("MEMORY_CAPACITY_USE_RATE_")
    private Float memoryCapacityUseRate;

    @ApiModelProperty(value = "存储容量共计（TB）")
    @TableField("STORAGE_CAPACITY_TOTAL_")
    private Float storageCapacityTotal;

    @ApiModelProperty(value = "存储容量已用（TB）")
    @TableField("STORAGE_CAPACITY_USE_")
    private Float storageCapacityUse;

    @ApiModelProperty(value = "存储容量使用率（存储已用/存储共计×100，保留两位小数向下取整）")
    @TableField("STORAGE_CAPACITY_USE_RATE_")
    private Float storageCapacityUseRate;

    @ApiModelProperty(value = "创建人ID")
    @TableField("CREATE_BY_")
    private String createBy;

    @ApiModelProperty(value = "创建人组织名称")
    @TableField("CREATE_ORG_NAME_")
    private String createOrgName;

    @ApiModelProperty(value = "创建人单位ID")
    @TableField("CREATE_COMPANY_ID_")
    private String createCompanyId;

    @ApiModelProperty(value = "创建人单位名称")
    @TableField("CREATE_COMPANY_NAME_")
    private String createCompanyName;

    @ApiModelProperty(value = "创建人姓名")
    @TableField("CREATE_NAME_")
    private String createName;

    @ApiModelProperty(value = "创建人组织ID")
    @TableField("CREATE_ORG_ID_")
    private String createOrgId;

    @ApiModelProperty(value = "创建时间")
    @TableField("CREATE_TIME_")
    private LocalDateTime createTime;

    @ApiModelProperty(value = "更新人ID")
    @TableField("UPDATE_BY_")
    private String updateBy;

    @ApiModelProperty(value = "更新人姓名")
    @TableField("UPDATE_NAME_")
    private String updateName;

    @ApiModelProperty(value = "更新人单位名称")
    @TableField("UPDATE_COMPANY_NAME_")
    private String updateCompanyName;

    @ApiModelProperty(value = "更新人单位ID")
    @TableField("UPDATE_COMPANY_ID_")
    private String updateCompanyId;

    @ApiModelProperty(value = "更新人组织ID")
    @TableField("UPDATE_ORG_ID_")
    private String updateOrgId;

    @ApiModelProperty(value = "更新人组织名称")
    @TableField("UPDATE_ORG_NAME_")
    private String updateOrgName;

    @ApiModelProperty(value = "更新时间")
    @TableField("UPDATE_TIME_")
    private LocalDateTime updateTime;

    @ApiModelProperty(value = "最后更新时间戳")
    @TableField("LAST_TIME_")
    private Long lastTime;

    @ApiModelProperty(value = "是否已删，1已删除，0未删除")
    @TableField("IS_DELE_")
    private String isDele;

    @ApiModelProperty(value = "版本号")
    @TableField("VERSION_")
    private Long version;

    @ApiModelProperty(value = "租户ID")
    @TableField("TENANT_ID_")
    private String tenantId;

    @Override
    public String toString() {
        return "BizCloudApplyUseDetailed{" +
            "id=" + id +
            ", privateCloudApplyId=" + privateCloudApplyId +
            ", cloudType=" + cloudType +
            ", useType=" + useType +
            ", cpuNumTotal=" + cpuNumTotal +
            ", cpuNumUse=" + cpuNumUse +
            ", cpuNumUseRate=" + cpuNumUseRate +
            ", memoryCapacityTotal=" + memoryCapacityTotal +
            ", memoryCapacityUse=" + memoryCapacityUse +
            ", memoryCapacityUseRate=" + memoryCapacityUseRate +
            ", storageCapacityTotal=" + storageCapacityTotal +
            ", storageCapacityUse=" + storageCapacityUse +
            ", storageCapacityUseRate=" + storageCapacityUseRate +
            ", createBy=" + createBy +
            ", createOrgName=" + createOrgName +
            ", createCompanyId=" + createCompanyId +
            ", createCompanyName=" + createCompanyName +
            ", createName=" + createName +
            ", createOrgId=" + createOrgId +
            ", createTime=" + createTime +
            ", updateBy=" + updateBy +
            ", updateName=" + updateName +
            ", updateCompanyName=" + updateCompanyName +
            ", updateCompanyId=" + updateCompanyId +
            ", updateOrgId=" + updateOrgId +
            ", updateOrgName=" + updateOrgName +
            ", updateTime=" + updateTime +
            ", lastTime=" + lastTime +
            ", isDele=" + isDele +
            ", version=" + version +
            ", tenantId=" + tenantId +
        "}";
    }
}
