ServerOverview.vue 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177
  1. <template>
  2. <div>
  3. <el-row>
  4. <el-col :md="12">
  5. <div class="source">
  6. <el-form
  7. label-position="left"
  8. label-width="160px"
  9. class="server_info"
  10. >
  11. <el-form-item label="Version">
  12. <span>{{ data.version }}</span>
  13. </el-form-item>
  14. <el-form-item label="BindPort">
  15. <span>{{ data.bind_port }}</span>
  16. </el-form-item>
  17. <el-form-item label="BindUdpPort">
  18. <span>{{ data.bind_udp_port }}</span>
  19. </el-form-item>
  20. <el-form-item label="Http Port">
  21. <span>{{ data.vhost_http_port }}</span>
  22. </el-form-item>
  23. <el-form-item label="Https Port">
  24. <span>{{ data.vhost_https_port }}</span>
  25. </el-form-item>
  26. <el-form-item label="Subdomain Host">
  27. <span>{{ data.subdomain_host }}</span>
  28. </el-form-item>
  29. <el-form-item label="Max PoolCount">
  30. <span>{{ data.max_pool_count }}</span>
  31. </el-form-item>
  32. <el-form-item label="Max Ports Per Client">
  33. <span>{{ data.max_ports_per_client }}</span>
  34. </el-form-item>
  35. <el-form-item label="HeartBeat Timeout">
  36. <span>{{ data.heart_beat_timeout }}</span>
  37. </el-form-item>
  38. <el-form-item label="Client Counts">
  39. <span>{{ data.client_counts }}</span>
  40. </el-form-item>
  41. <el-form-item label="Current Connections">
  42. <span>{{ data.cur_conns }}</span>
  43. </el-form-item>
  44. <el-form-item label="Proxy Counts">
  45. <span>{{ data.proxy_counts }}</span>
  46. </el-form-item>
  47. </el-form>
  48. </div>
  49. </el-col>
  50. <el-col :md="12">
  51. <div
  52. id="traffic"
  53. style="width: 400px; height: 250px; margin-bottom: 30px"
  54. ></div>
  55. <div id="proxies" style="width: 400px; height: 250px"></div>
  56. </el-col>
  57. </el-row>
  58. </div>
  59. </template>
  60. <script setup lang="ts">
  61. import { ref } from 'vue'
  62. import { ElMessage } from 'element-plus'
  63. import { DrawTrafficChart, DrawProxyChart } from '../utils/chart'
  64. let data = ref({
  65. version: '',
  66. bind_port: '',
  67. bind_udp_port: '',
  68. vhost_http_port: '',
  69. vhost_https_port: '',
  70. subdomain_host: '',
  71. max_pool_count: '',
  72. max_ports_per_client: '',
  73. heart_beat_timeout: '',
  74. client_counts: '',
  75. cur_conns: '',
  76. proxy_counts: 0,
  77. })
  78. const fetchData = () => {
  79. fetch('../api/serverinfo', { credentials: 'include' })
  80. .then((res) => res.json())
  81. .then((json) => {
  82. data.value.version = json.version
  83. data.value.bind_port = json.bind_port
  84. data.value.bind_udp_port = json.bind_udp_port
  85. if (data.value.bind_udp_port == '0') {
  86. data.value.bind_udp_port = 'disable'
  87. }
  88. data.value.vhost_http_port = json.vhost_http_port
  89. if (data.value.vhost_http_port == '0') {
  90. data.value.vhost_http_port = 'disable'
  91. }
  92. data.value.vhost_https_port = json.vhost_https_port
  93. if (data.value.vhost_https_port == '0') {
  94. data.value.vhost_https_port = 'disable'
  95. }
  96. data.value.subdomain_host = json.subdomain_host
  97. data.value.max_pool_count = json.max_pool_count
  98. data.value.max_ports_per_client = json.max_ports_per_client
  99. if (data.value.max_ports_per_client == '0') {
  100. data.value.max_ports_per_client = 'no limit'
  101. }
  102. data.value.heart_beat_timeout = json.heart_beat_timeout
  103. data.value.client_counts = json.client_counts
  104. data.value.cur_conns = json.cur_conns
  105. data.value.proxy_counts = 0
  106. if (json.proxy_type_count != null) {
  107. if (json.proxy_type_count.tcp != null) {
  108. data.value.proxy_counts += json.proxy_type_count.tcp
  109. }
  110. if (json.proxy_type_count.udp != null) {
  111. data.value.proxy_counts += json.proxy_type_count.udp
  112. }
  113. if (json.proxy_type_count.http != null) {
  114. data.value.proxy_counts += json.proxy_type_count.http
  115. }
  116. if (json.proxy_type_count.https != null) {
  117. data.value.proxy_counts += json.proxy_type_count.https
  118. }
  119. if (json.proxy_type_count.stcp != null) {
  120. data.value.proxy_counts += json.proxy_type_count.stcp
  121. }
  122. if (json.proxy_type_count.sudp != null) {
  123. data.value.proxy_counts += json.proxy_type_count.sudp
  124. }
  125. if (json.proxy_type_count.xtcp != null) {
  126. data.value.proxy_counts += json.proxy_type_count.xtcp
  127. }
  128. }
  129. // draw chart
  130. DrawTrafficChart('traffic', json.total_traffic_in, json.total_traffic_out)
  131. DrawProxyChart('proxies', json)
  132. })
  133. .catch(() => {
  134. ElMessage({
  135. showClose: true,
  136. message: 'Get server info from frps failed!',
  137. type: 'warning',
  138. })
  139. })
  140. }
  141. fetchData()
  142. </script>
  143. <style>
  144. .source {
  145. border: 1px solid #eaeefb;
  146. border-radius: 4px;
  147. transition: 0.2s;
  148. padding: 24px;
  149. }
  150. .server_info {
  151. margin-left: 40px;
  152. font-size: 0px;
  153. }
  154. .server_info .el-form-item__label {
  155. color: #99a9bf;
  156. height: 40px;
  157. line-height: 40px;
  158. }
  159. .server_info .el-form-item__content {
  160. height: 40px;
  161. line-height: 40px;
  162. }
  163. .server_info .el-form-item {
  164. margin-right: 0;
  165. margin-bottom: 0;
  166. width: 100%;
  167. }
  168. </style>