Skip to content
website.component.ts 10.7 KiB
Newer Older
wangqinghua's avatar
wangqinghua committed
import {Component, EventEmitter, OnInit, Output} from '@angular/core';
wangqinghua's avatar
wangqinghua committed
import {OverAllService} from '../../overAll/overAll.service';
import {NzMessageService} from 'ng-zorro-antd';
wangqinghua's avatar
wangqinghua committed

@Component({
    selector: 'smart-website',
    templateUrl: './website.component.html',
wangqinghua's avatar
wangqinghua committed
    styles: [
            `
            .middle {
                height: 39px;
                line-height: 39px;
            }

            .modal-footer-btn {
                margin: 10px 0;
                text-align: center;
            }

            .trigger-class {
                border: 1px solid #ddd;
                padding: 10px;
                margin: 10px;
            }
        `
    ]
wangqinghua's avatar
wangqinghua committed
})
export class WebsiteComponent implements OnInit {

wangqinghua's avatar
wangqinghua committed
    @Output() done = new EventEmitter<any>();
wangqinghua's avatar
wangqinghua committed
    isVisible = false;
wangqinghua's avatar
wangqinghua committed
    isOkLoading = false;
wangqinghua's avatar
wangqinghua committed
    title;
wangqinghua's avatar
wangqinghua committed
    tabNum = 0;
wangqinghua's avatar
wangqinghua committed
    indexNo = 1;
wangqinghua's avatar
wangqinghua committed

    validateForm;
    steps = [];
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    constructor(private overAllSer: OverAllService, private message: NzMessageService) {
wangqinghua's avatar
wangqinghua committed
    }

    ngOnInit() {
wangqinghua's avatar
wangqinghua committed
        this.initForm();
    }

wangqinghua's avatar
wangqinghua committed
    initForm() {
wangqinghua's avatar
wangqinghua committed
        this.tabNum = 0;
wangqinghua's avatar
wangqinghua committed
        this.steps = [
            {
wangqinghua's avatar
wangqinghua committed
                name: '',
                url: '',
                status_codes: 200,
                posts: '',
                no: this.indexNo,
                timeout: '15',
                follow_redirects: '1',
                conditionList: [],
                condition: '',
                faultConditionList: [],
                faultCondition: '',
                show: false
wangqinghua's avatar
wangqinghua committed
            }
        ];
wangqinghua's avatar
wangqinghua committed
        this.validateForm = {
wangqinghua's avatar
wangqinghua committed
            name: '',
wangqinghua's avatar
wangqinghua committed
            delay: '',
            retries: '',
            http_proxy: '',
            ssl_cert_file: '',
            ssl_key_file: '',
            ssl_key_password: '',
wangqinghua's avatar
wangqinghua committed
            steps: this.steps,
        };
wangqinghua's avatar
wangqinghua committed
    }

    showAddModal() {
        this.title = '添加网站监测';
        this.isVisible = true;
    }

wangqinghua's avatar
wangqinghua committed
    showEditModal(id) {
        this.title = '编辑网站监测';
wangqinghua's avatar
wangqinghua committed
        this.isVisible = true;
wangqinghua's avatar
wangqinghua committed
        this.overAllSer.findWeb(id).subscribe(
wangqinghua's avatar
wangqinghua committed
            (res) => {
                if (res.errCode == 10000) {
                    res.data.steps.forEach(e => {
                        e.follow_redirects += '';
                    });
wangqinghua's avatar
wangqinghua committed
                    this.validateForm = res.data;
                    this.steps = res.data.steps;
wangqinghua's avatar
wangqinghua committed
                    this.viewtrigger();
wangqinghua's avatar
wangqinghua committed
                }
            }
wangqinghua's avatar
wangqinghua committed
        );
    }

    //回显阈值
    viewtrigger() {
        this.steps.forEach(e => {
            if (e.condition) {
                e.condition = ' and ' + e.condition;
                let strCon = e.condition.split(' ');
                let arrCon = [];
                let andArrCon = [];
                strCon.forEach((value) => {
                    if (value.length > 0) {
                        if (value == 'and' || value == 'or') {
                            andArrCon.push(value);
                        } else {
                            const index = value.indexOf('}');
                            if (value.indexOf('0.0.0.0:web.test.time') > -1) {   //响应时间
                                const obj1 = {
                                    time: '0',
                                    equal: value[index + 1],
                                    value: value.substr(index + 2, value.length),
                                };
                                arrCon.push(obj1);
                            }
                            if (value.indexOf('0.0.0.0:web.test.rspcode') > -1) {   //响应代码
                                const obj2 = {
                                    time: '1',
                                    equal: value[index + 1],
                                    value: value.substr(index + 2, value.length),
                                };
                                arrCon.push(obj2);
                            }
                        }
                    }
                });
                arrCon.forEach((value, index) => {
                    value.and = ' ' + andArrCon[index] + ' ';
                });
                e.conditionList = arrCon;
            }else{
                e.condition = '';
                e.conditionList = [];
            }
            if (e.faultCondition) {
                e.faultCondition = ' and ' +e.faultCondition;
                let strFau = e.faultCondition.split(' ');
                let arrFau = [];
                let andArrFau = [];
                strFau.forEach((value) => {
                    if (value.length > 0) {
                        if (value == 'and' || value == 'or') {
                            andArrFau.push(value);
                        } else {
                            const index = value.indexOf('}');
                            if (value.indexOf('0.0.0.0:web.test.time') > -1) {   //响应时间
                                const obj1 = {
                                    time: '0',
                                    equal: value[index + 1],
                                    value: value.substr(index + 2, value.length),
                                };
                                arrFau.push(obj1);
                            }
                            if (value.indexOf('0.0.0.0:web.test.rspcode') > -1) {   //响应代码
                                const obj2 = {
                                    time: '1',
                                    equal: value[index + 1],
                                    value: value.substr(index + 2, value.length),
                                };
                                arrFau.push(obj2);
                            }
                        }
                    }
                });
                arrFau.forEach((value, index) => {
                    value.and = ' ' + andArrFau[index] + ' ';
                });
                e.faultConditionList = arrFau;
            }else{
                e.faultCondition = '';
                e.faultConditionList = [];
            }
        });
wangqinghua's avatar
wangqinghua committed
    }

    handleOk() {
wangqinghua's avatar
wangqinghua committed
        if (!this.validateForm.name) {
            this.message.error('请输入网站名称');
wangqinghua's avatar
wangqinghua committed
            return false;
        }
wangqinghua's avatar
wangqinghua committed
        if (!this.validateForm.delay) {
            this.message.error('请输入更新间隔');
wangqinghua's avatar
wangqinghua committed
            return false;
        }
wangqinghua's avatar
wangqinghua committed
        this.isOkLoading = true;

        this.getCondition();

        if (this.title == '添加网站监测') {
wangqinghua's avatar
wangqinghua committed
            this.create();
wangqinghua's avatar
wangqinghua committed
        } else {
wangqinghua's avatar
wangqinghua committed
            this.update();
        }
    }

    //创建
wangqinghua's avatar
wangqinghua committed
    create() {
wangqinghua's avatar
wangqinghua committed
        this.overAllSer.createWebscenario(this.validateForm).subscribe(
wangqinghua's avatar
wangqinghua committed
            (res) => {
                if (res.errCode == 10000) {
wangqinghua's avatar
wangqinghua committed
                    this.message.success('添加成功');
wangqinghua's avatar
wangqinghua committed
                    this.isVisible = false;
                    this.done.emit();
wangqinghua's avatar
wangqinghua committed
                    this.initForm();
wangqinghua's avatar
wangqinghua committed
                } else {
wangqinghua's avatar
wangqinghua committed
                    this.message.error(res.errMsg);
wangqinghua's avatar
wangqinghua committed
                }
wangqinghua's avatar
wangqinghua committed
                this.isOkLoading = false;
wangqinghua's avatar
wangqinghua committed
            }
wangqinghua's avatar
wangqinghua committed
        );
wangqinghua's avatar
wangqinghua committed
    }

    //更新
wangqinghua's avatar
wangqinghua committed
    update() {
wangqinghua's avatar
wangqinghua committed
        this.overAllSer.updateWebscenario(this.validateForm).subscribe(
wangqinghua's avatar
wangqinghua committed
            (res) => {
                if (res.errCode == 10000) {
wangqinghua's avatar
wangqinghua committed
                    this.message.success('保存成功');
wangqinghua's avatar
wangqinghua committed
                    this.isVisible = false;
                    this.done.emit();
                    this.initForm();
wangqinghua's avatar
wangqinghua committed
                } else {
wangqinghua's avatar
wangqinghua committed
                    this.message.error(res.errMsg);
wangqinghua's avatar
wangqinghua committed
                }
wangqinghua's avatar
wangqinghua committed
                this.isOkLoading = false;
wangqinghua's avatar
wangqinghua committed
            }
wangqinghua's avatar
wangqinghua committed
        );
wangqinghua's avatar
wangqinghua committed
    }

    handleCancel() {
wangqinghua's avatar
wangqinghua committed
        this.initForm();
wangqinghua's avatar
wangqinghua committed
        this.isVisible = false;
    }
wangqinghua's avatar
wangqinghua committed

wangqinghua's avatar
wangqinghua committed
    tabsChange(index) {
wangqinghua's avatar
wangqinghua committed
        this.tabNum = index;
    }

wangqinghua's avatar
wangqinghua committed
    // 合成阈值
    getCondition() {
        this.validateForm.steps.forEach(e => {   //步骤列表
            if(e.conditionList){
                e.condition = '';
                e.conditionList.forEach(e1 => {    //危险阈值列表
                    if (e1.time == '0') {   //响应时间
                        e.condition += e1.and + '{0.0.0.0:web.test.time[' + this.validateForm.name + ',' + e.name + ',resp].last()}' + e1.equal + e1.value;
                    }
                    if (e1.time == '1') {   //响应代码
                        e.condition += e1.and + '{0.0.0.0:web.test.rspcode[' + this.validateForm.name + ',' + e.name + '].last()}' + e1.equal + e1.value;
                    }
                });
            }
            if(e.faultConditionList){
                e.faultCondition = '';
                e.faultConditionList.forEach(e2 => {    //故障阈值列表
                    if (e2.time == '0') {   //响应时间
                        e.faultCondition += e2.and + '{0.0.0.0:web.test.time[' + this.validateForm.name + ',' + e.name + ',resp].last()}' + e2.equal + e2.value;
                    }
                    if (e2.time == '1') {   //响应代码
                        e.faultCondition += e2.and + '{0.0.0.0:web.test.rspcode[' + this.validateForm.name + ',' + e.name + '].last()}' + e2.equal + e2.value;
                    }
                });
            }
        });
    }

wangqinghua's avatar
wangqinghua committed
    //添加步骤
wangqinghua's avatar
wangqinghua committed
    addStep() {
wangqinghua's avatar
wangqinghua committed
        this.indexNo += 1;
        const data =
wangqinghua's avatar
wangqinghua committed
            {
                name: '',
                url: '',
                status_codes: 200,
                posts: '',
                no: this.indexNo,
                timeout: '15',
                follow_redirects: '1',
                condition: '',
                conditionList: [],
                faultCondition: '',
                faultConditionList: [],
                show: false,
            };
wangqinghua's avatar
wangqinghua committed
        this.steps.push(data);
    }

wangqinghua's avatar
wangqinghua committed
    showCon(i) {
        this.steps[i].show = true;
    }

    closeCon(i, bool) {
        if (!bool) {
            this.steps[i].conditionList = [];
            this.steps[i].faultConditionList = [];
        }
        this.steps[i].show = false;
    }

    //删除步骤
    deleteStep(index) {
        this.steps.splice(index, 1);
    }

    /**
     * 故障阈值添加
     * @param i  步骤下标
     */
    addFault(i) {
        const demo = {
            time: '0',
            and: ' and ',
            equal: '=',
            value: '',
        };
        this.steps[i].faultConditionList.push(demo);
    }

    /**
     * 危险阈值增加
     * @param i 步骤下标
     */
    addcondition(i) {
        const demo = {
            time: '0',
            and: ' and ',
            equal: '=',
            value: '',
        };
        this.steps[i].conditionList.push(demo);
    }

    /**
     * 删除故障阈值
     * @param i  步骤下标
     * @param index  故障下标
     */
    deleteFault(i, index) {
        this.steps[i].faultConditionList.splice(index, 1);
    }

    /**
     * 删除危险阈值
     * @param i  步骤下标
     * @param index  故障下标
     */
    deleteCondition(i, index) {
        this.steps[i].conditionList.splice(index, 1);
wangqinghua's avatar
wangqinghua committed
    }
wangqinghua's avatar
wangqinghua committed
}