mirror of
https://github.com/TeaOSLab/EdgeAdmin.git
synced 2025-11-03 20:40:26 +08:00
54 lines
2.5 KiB
JavaScript
54 lines
2.5 KiB
JavaScript
Vue.component("http-access-log-box", {
|
|
props: ["v-access-log", "v-keyword"],
|
|
data: function () {
|
|
let accessLog = this.vAccessLog
|
|
if (accessLog.header != null && accessLog.header.Upgrade != null && accessLog.header.Upgrade.values != null && accessLog.header.Upgrade.values.$contains("websocket")) {
|
|
if (accessLog.scheme == "http") {
|
|
accessLog.scheme = "ws"
|
|
} else if (accessLog.scheme == "https") {
|
|
accessLog.scheme = "wss"
|
|
}
|
|
}
|
|
return {
|
|
accessLog: accessLog
|
|
}
|
|
},
|
|
methods: {
|
|
formatCost: function (seconds) {
|
|
var s = (seconds * 1000).toString();
|
|
var pieces = s.split(".");
|
|
if (pieces.length < 2) {
|
|
return s;
|
|
}
|
|
|
|
return pieces[0] + "." + pieces[1].substr(0, 3);
|
|
},
|
|
showLog: function () {
|
|
let that = this
|
|
let requestId = this.accessLog.requestId
|
|
this.$parent.$children.forEach(function (v) {
|
|
if (v.deselect != null) {
|
|
v.deselect()
|
|
}
|
|
})
|
|
this.select()
|
|
teaweb.popup("/servers/server/log/viewPopup?requestId=" + requestId, {
|
|
width: "50em",
|
|
height: "28em",
|
|
onClose: function () {
|
|
that.deselect()
|
|
}
|
|
})
|
|
},
|
|
select: function () {
|
|
this.$refs.box.parentNode.style.cssText = "background: rgba(0, 0, 0, 0.1)"
|
|
},
|
|
deselect: function () {
|
|
this.$refs.box.parentNode.style.cssText = ""
|
|
}
|
|
},
|
|
template: `<div :style="{'color': (accessLog.status >= 400) ? '#dc143c' : ''}" ref="box">
|
|
<span v-if="accessLog.region != null && accessLog.region.length > 0" class="grey">[{{accessLog.region}}]</span> <keyword :v-word="vKeyword">{{accessLog.remoteAddr}}</keyword> [{{accessLog.timeLocal}}] <em>"<keyword :v-word="vKeyword">{{accessLog.requestMethod}}</keyword> {{accessLog.scheme}}://<keyword :v-word="vKeyword">{{accessLog.host}}</keyword><keyword :v-word="vKeyword">{{accessLog.requestURI}}</keyword> <a :href="accessLog.scheme + '://' + accessLog.host + accessLog.requestURI" target="_blank" title="新窗口打开" class="disabled"><i class="external icon tiny"></i> </a> {{accessLog.proto}}" </em> <keyword :v-word="vKeyword">{{accessLog.status}}</keyword> <code-label v-if="accessLog.attrs != null && accessLog.attrs['cache.status'] == 'HIT'">cache hit</code-label> <code-label v-if="accessLog.attrs != null && accessLog.attrs['waf.action'] != null && accessLog.attrs['waf.action'].length > 0">waf {{accessLog.attrs['waf.action']}}</code-label> - 耗时:{{formatCost(accessLog.requestTime)}} ms
|
|
<a href="" @click.prevent="showLog" title="查看详情"><i class="icon expand"></i></a>
|
|
</div>`
|
|
}) |