mihari 5.6.2 → 5.7.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (267) hide show
  1. checksums.yaml +4 -4
  2. data/.rubocop.yml +5 -1
  3. data/README.md +1 -0
  4. data/config.ru +1 -1
  5. data/lib/mihari/actor.rb +18 -2
  6. data/lib/mihari/analyzers/base.rb +13 -12
  7. data/lib/mihari/analyzers/binaryedge.rb +4 -1
  8. data/lib/mihari/analyzers/censys.rb +4 -2
  9. data/lib/mihari/analyzers/circl.rb +4 -1
  10. data/lib/mihari/analyzers/crtsh.rb +4 -1
  11. data/lib/mihari/analyzers/dnstwister.rb +4 -1
  12. data/lib/mihari/analyzers/feed.rb +3 -0
  13. data/lib/mihari/analyzers/fofa.rb +65 -0
  14. data/lib/mihari/analyzers/greynoise.rb +4 -1
  15. data/lib/mihari/analyzers/hunterhow.rb +6 -1
  16. data/lib/mihari/analyzers/onyphe.rb +4 -1
  17. data/lib/mihari/analyzers/otx.rb +4 -1
  18. data/lib/mihari/analyzers/passivetotal.rb +4 -1
  19. data/lib/mihari/analyzers/pulsedive.rb +3 -0
  20. data/lib/mihari/analyzers/securitytrails.rb +4 -1
  21. data/lib/mihari/analyzers/shodan.rb +4 -1
  22. data/lib/mihari/analyzers/urlscan.rb +4 -1
  23. data/lib/mihari/analyzers/virustotal.rb +4 -1
  24. data/lib/mihari/analyzers/virustotal_intelligence.rb +4 -1
  25. data/lib/mihari/analyzers/zoomeye.rb +5 -2
  26. data/lib/mihari/cli/alert.rb +3 -0
  27. data/lib/mihari/cli/base.rb +3 -0
  28. data/lib/mihari/cli/database.rb +3 -0
  29. data/lib/mihari/cli/main.rb +3 -0
  30. data/lib/mihari/cli/rule.rb +3 -0
  31. data/lib/mihari/clients/base.rb +3 -0
  32. data/lib/mihari/clients/binaryedge.rb +5 -2
  33. data/lib/mihari/clients/censys.rb +7 -4
  34. data/lib/mihari/clients/circl.rb +3 -0
  35. data/lib/mihari/clients/crtsh.rb +3 -0
  36. data/lib/mihari/clients/dnstwister.rb +3 -0
  37. data/lib/mihari/clients/fofa.rb +83 -0
  38. data/lib/mihari/clients/greynoise.rb +5 -2
  39. data/lib/mihari/clients/hunterhow.rb +5 -2
  40. data/lib/mihari/clients/misp.rb +3 -0
  41. data/lib/mihari/clients/onyphe.rb +5 -2
  42. data/lib/mihari/clients/otx.rb +3 -0
  43. data/lib/mihari/clients/passivetotal.rb +3 -0
  44. data/lib/mihari/clients/publsedive.rb +4 -1
  45. data/lib/mihari/clients/securitytrails.rb +3 -0
  46. data/lib/mihari/clients/shodan.rb +5 -2
  47. data/lib/mihari/clients/the_hive.rb +3 -0
  48. data/lib/mihari/clients/urlscan.rb +7 -4
  49. data/lib/mihari/clients/virustotal.rb +5 -2
  50. data/lib/mihari/clients/zoomeye.rb +3 -0
  51. data/lib/mihari/commands/alert.rb +9 -16
  52. data/lib/mihari/commands/database.rb +3 -0
  53. data/lib/mihari/commands/rule.rb +10 -1
  54. data/lib/mihari/commands/search.rb +13 -29
  55. data/lib/mihari/commands/version.rb +3 -0
  56. data/lib/mihari/commands/web.rb +4 -1
  57. data/lib/mihari/config.rb +139 -150
  58. data/lib/mihari/constants.rb +1 -1
  59. data/lib/mihari/database.rb +6 -0
  60. data/lib/mihari/emitters/base.rb +13 -11
  61. data/lib/mihari/emitters/database.rb +4 -1
  62. data/lib/mihari/emitters/misp.rb +7 -4
  63. data/lib/mihari/emitters/slack.rb +3 -3
  64. data/lib/mihari/emitters/the_hive.rb +3 -3
  65. data/lib/mihari/emitters/webhook.rb +4 -3
  66. data/lib/mihari/enrichers/base.rb +15 -9
  67. data/lib/mihari/enrichers/google_public_dns.rb +6 -5
  68. data/lib/mihari/enrichers/ipinfo.rb +11 -9
  69. data/lib/mihari/enrichers/shodan.rb +4 -6
  70. data/lib/mihari/enrichers/whois.rb +12 -9
  71. data/lib/mihari/entities/tag.rb +1 -0
  72. data/lib/mihari/errors.rb +6 -0
  73. data/lib/mihari/feed/parser.rb +3 -0
  74. data/lib/mihari/feed/reader.rb +3 -0
  75. data/lib/mihari/http.rb +6 -0
  76. data/lib/mihari/mixins/autonomous_system.rb +3 -0
  77. data/lib/mihari/mixins/configurable.rb +3 -0
  78. data/lib/mihari/mixins/error_notification.rb +3 -0
  79. data/lib/mihari/mixins/falsepositive.rb +3 -0
  80. data/lib/mihari/mixins/refang.rb +3 -0
  81. data/lib/mihari/mixins/retriable.rb +6 -2
  82. data/lib/mihari/models/alert.rb +7 -4
  83. data/lib/mihari/models/artifact.rb +6 -0
  84. data/lib/mihari/models/autonomous_system.rb +4 -1
  85. data/lib/mihari/models/cpe.rb +4 -1
  86. data/lib/mihari/models/dns.rb +4 -1
  87. data/lib/mihari/models/geolocation.rb +4 -1
  88. data/lib/mihari/models/port.rb +4 -1
  89. data/lib/mihari/models/reverse_dns.rb +4 -1
  90. data/lib/mihari/models/rule.rb +6 -3
  91. data/lib/mihari/models/tag.rb +3 -0
  92. data/lib/mihari/models/tagging.rb +3 -0
  93. data/lib/mihari/models/whois.rb +4 -3
  94. data/lib/mihari/rule.rb +31 -12
  95. data/lib/mihari/schemas/alert.rb +3 -0
  96. data/lib/mihari/schemas/analyzer.rb +11 -0
  97. data/lib/mihari/schemas/emitter.rb +3 -0
  98. data/lib/mihari/schemas/enricher.rb +3 -0
  99. data/lib/mihari/schemas/macros.rb +4 -0
  100. data/lib/mihari/schemas/mixins.rb +5 -0
  101. data/lib/mihari/schemas/rule.rb +3 -0
  102. data/lib/mihari/service.rb +26 -0
  103. data/lib/mihari/services/alert_builder.rb +85 -9
  104. data/lib/mihari/services/alert_runner.rb +8 -19
  105. data/lib/mihari/services/rule_builder.rb +13 -12
  106. data/lib/mihari/services/rule_runner.rb +7 -32
  107. data/lib/mihari/structs/binaryedge.rb +22 -28
  108. data/lib/mihari/structs/censys.rb +48 -141
  109. data/lib/mihari/structs/config.rb +19 -30
  110. data/lib/mihari/structs/filters.rb +38 -0
  111. data/lib/mihari/structs/fofa.rb +47 -0
  112. data/lib/mihari/structs/google_public_dns.rb +10 -32
  113. data/lib/mihari/structs/greynoise.rb +33 -90
  114. data/lib/mihari/structs/hunterhow.rb +24 -28
  115. data/lib/mihari/structs/ipinfo.rb +14 -37
  116. data/lib/mihari/structs/onyphe.rb +31 -80
  117. data/lib/mihari/structs/shodan.rb +47 -114
  118. data/lib/mihari/structs/urlscan.rb +24 -69
  119. data/lib/mihari/structs/virustotal_intelligence.rb +20 -64
  120. data/lib/mihari/type_checker.rb +4 -0
  121. data/lib/mihari/types.rb +3 -0
  122. data/lib/mihari/version.rb +1 -1
  123. data/lib/mihari/web/api.rb +15 -10
  124. data/lib/mihari/web/app.rb +64 -56
  125. data/lib/mihari/web/endpoints/alerts.rb +127 -85
  126. data/lib/mihari/web/endpoints/artifacts.rb +91 -79
  127. data/lib/mihari/web/endpoints/configs.rb +18 -13
  128. data/lib/mihari/web/endpoints/ip_addresses.rb +35 -15
  129. data/lib/mihari/web/endpoints/rules.rb +236 -187
  130. data/lib/mihari/web/endpoints/tags.rb +42 -35
  131. data/lib/mihari/web/middleware/connection_adapter.rb +16 -9
  132. data/lib/mihari/web/middleware/error_notification_adapter.rb +17 -10
  133. data/lib/mihari/web/public/assets/{index-28d4c79d.js → index-07fafab5.js} +31 -30
  134. data/lib/mihari/web/public/assets/mode-yaml-24faa242.js +8 -0
  135. data/lib/mihari/web/public/index.html +1 -1
  136. data/lib/mihari.rb +24 -6
  137. data/mihari.gemspec +9 -2
  138. data/mkdocs.yml +4 -2
  139. metadata +38 -133
  140. data/docs/alternatives.md +0 -5
  141. data/docs/analyzers/binaryedge.md +0 -26
  142. data/docs/analyzers/censys.md +0 -31
  143. data/docs/analyzers/circl.md +0 -37
  144. data/docs/analyzers/crtsh.md +0 -26
  145. data/docs/analyzers/dnstwister.md +0 -25
  146. data/docs/analyzers/feed.md +0 -73
  147. data/docs/analyzers/greynoise.md +0 -26
  148. data/docs/analyzers/hunterhow.md +0 -33
  149. data/docs/analyzers/index.md +0 -103
  150. data/docs/analyzers/onyphe.md +0 -26
  151. data/docs/analyzers/otx.md +0 -28
  152. data/docs/analyzers/passivetotal.md +0 -52
  153. data/docs/analyzers/pulsedive.md +0 -28
  154. data/docs/analyzers/securitytrails.md +0 -41
  155. data/docs/analyzers/shodan.md +0 -26
  156. data/docs/analyzers/urlscan.md +0 -28
  157. data/docs/analyzers/virustotal.md +0 -43
  158. data/docs/analyzers/virustotal_intelligence.md +0 -33
  159. data/docs/analyzers/zoomeye.md +0 -38
  160. data/docs/configuration.md +0 -35
  161. data/docs/emitters/database.md +0 -22
  162. data/docs/emitters/hive.md +0 -26
  163. data/docs/emitters/index.md +0 -36
  164. data/docs/emitters/misp.md +0 -21
  165. data/docs/emitters/slack.md +0 -21
  166. data/docs/emitters/webhook.md +0 -63
  167. data/docs/enrichers/google_public_dns.md +0 -19
  168. data/docs/enrichers/index.md +0 -35
  169. data/docs/enrichers/ipinfo.md +0 -26
  170. data/docs/enrichers/shodan.md +0 -22
  171. data/docs/enrichers/whois.md +0 -17
  172. data/docs/github_actions.md +0 -43
  173. data/docs/index.md +0 -11
  174. data/docs/installation.md +0 -31
  175. data/docs/requirements.md +0 -13
  176. data/docs/rule.md +0 -168
  177. data/docs/tags.md +0 -3
  178. data/docs/usage.md +0 -103
  179. data/frontend/.eslintrc.cjs +0 -22
  180. data/frontend/.gitignore +0 -31
  181. data/frontend/.prettierrc.json +0 -8
  182. data/frontend/README.md +0 -3
  183. data/frontend/env.d.ts +0 -5
  184. data/frontend/index.html +0 -21
  185. data/frontend/package-lock.json +0 -7219
  186. data/frontend/package.json +0 -67
  187. data/frontend/public/favicon.ico +0 -0
  188. data/frontend/scripts/swagger_doc_to_yaml.rb +0 -23
  189. data/frontend/src/App.vue +0 -27
  190. data/frontend/src/ace-config.ts +0 -6
  191. data/frontend/src/api-helper.ts +0 -111
  192. data/frontend/src/api.ts +0 -105
  193. data/frontend/src/components/ErrorMessage.vue +0 -31
  194. data/frontend/src/components/Loading.vue +0 -15
  195. data/frontend/src/components/Navbar.vue +0 -42
  196. data/frontend/src/components/Pagination.vue +0 -119
  197. data/frontend/src/components/alert/Alert.vue +0 -87
  198. data/frontend/src/components/alert/Alerts.vue +0 -63
  199. data/frontend/src/components/alert/AlertsWithPagination.vue +0 -90
  200. data/frontend/src/components/alert/AlertsWrapper.vue +0 -128
  201. data/frontend/src/components/alert/Form.vue +0 -182
  202. data/frontend/src/components/artifact/AS.vue +0 -29
  203. data/frontend/src/components/artifact/Artifact.vue +0 -287
  204. data/frontend/src/components/artifact/ArtifactTag.vue +0 -64
  205. data/frontend/src/components/artifact/ArtifactTags.vue +0 -29
  206. data/frontend/src/components/artifact/ArtifactWrapper.vue +0 -57
  207. data/frontend/src/components/artifact/CPEs.vue +0 -23
  208. data/frontend/src/components/artifact/DnsRecords.vue +0 -38
  209. data/frontend/src/components/artifact/Ports.vue +0 -23
  210. data/frontend/src/components/artifact/ReverseDnsNames.vue +0 -31
  211. data/frontend/src/components/artifact/Tags.vue +0 -29
  212. data/frontend/src/components/artifact/WhoisRecord.vue +0 -44
  213. data/frontend/src/components/config/Configs.vue +0 -65
  214. data/frontend/src/components/config/ConfigsWrapper.vue +0 -32
  215. data/frontend/src/components/link/Link.vue +0 -32
  216. data/frontend/src/components/link/Links.vue +0 -42
  217. data/frontend/src/components/rule/EditRule.vue +0 -72
  218. data/frontend/src/components/rule/EditRuleWrapper.vue +0 -48
  219. data/frontend/src/components/rule/Form.vue +0 -158
  220. data/frontend/src/components/rule/InputForm.vue +0 -45
  221. data/frontend/src/components/rule/NewRule.vue +0 -57
  222. data/frontend/src/components/rule/Rule.vue +0 -100
  223. data/frontend/src/components/rule/RuleWrapper.vue +0 -53
  224. data/frontend/src/components/rule/Rules.vue +0 -84
  225. data/frontend/src/components/rule/RulesWrapper.vue +0 -121
  226. data/frontend/src/components/rule/YAML.vue +0 -37
  227. data/frontend/src/components/tag/Tag.vue +0 -65
  228. data/frontend/src/components/tag/Tags.vue +0 -37
  229. data/frontend/src/countries.ts +0 -350
  230. data/frontend/src/index.ts +0 -20
  231. data/frontend/src/links/anyrun.ts +0 -19
  232. data/frontend/src/links/base.ts +0 -14
  233. data/frontend/src/links/censys.ts +0 -20
  234. data/frontend/src/links/crtsh.ts +0 -20
  235. data/frontend/src/links/dnslytics.ts +0 -38
  236. data/frontend/src/links/greynoise.ts +0 -20
  237. data/frontend/src/links/index.ts +0 -40
  238. data/frontend/src/links/intezer.ts +0 -20
  239. data/frontend/src/links/otx.ts +0 -33
  240. data/frontend/src/links/securitytrails.ts +0 -38
  241. data/frontend/src/links/shodan.ts +0 -20
  242. data/frontend/src/links/urlscan.ts +0 -50
  243. data/frontend/src/links/virustotal.ts +0 -72
  244. data/frontend/src/main.ts +0 -41
  245. data/frontend/src/router/index.ts +0 -57
  246. data/frontend/src/rule.ts +0 -14
  247. data/frontend/src/shims-vue.d.ts +0 -6
  248. data/frontend/src/swagger.yaml +0 -771
  249. data/frontend/src/types.ts +0 -188
  250. data/frontend/src/utils.ts +0 -54
  251. data/frontend/src/views/Alerts.vue +0 -20
  252. data/frontend/src/views/Artifact.vue +0 -39
  253. data/frontend/src/views/Configs.vue +0 -20
  254. data/frontend/src/views/EditRule.vue +0 -39
  255. data/frontend/src/views/NewRule.vue +0 -26
  256. data/frontend/src/views/Rule.vue +0 -39
  257. data/frontend/src/views/Rules.vue +0 -20
  258. data/frontend/tests/utils.spec.ts +0 -9
  259. data/frontend/tsconfig.app.json +0 -21
  260. data/frontend/tsconfig.json +0 -14
  261. data/frontend/tsconfig.node.json +0 -13
  262. data/frontend/tsconfig.vitest.json +0 -12
  263. data/frontend/vite.config.ts +0 -24
  264. data/frontend/vitest.config.ts +0 -21
  265. data/lib/mihari/services/alert_proxy.rb +0 -92
  266. data/lib/mihari/templates/rule.yml.erb +0 -5
  267. data/lib/mihari/web/public/assets/mode-yaml-a21faa53.js +0 -8
@@ -1,65 +0,0 @@
1
- <template>
2
- <div class="box">
3
- <div class="table-container">
4
- <table class="table is-fullwidth">
5
- <thead>
6
- <tr>
7
- <th>Name</th>
8
- <th>Type</th>
9
- <th>Configured</th>
10
- <th>Key-value(s)</th>
11
- </tr>
12
- </thead>
13
- <tbody>
14
- <tr v-for="config in configs" :key="config.name">
15
- <td>
16
- {{ config.name }}
17
- </td>
18
- <td>
19
- {{ config.type }}
20
- </td>
21
- <td>
22
- <button class="button is-success is-small ml-1" v-if="config.isConfigured">
23
- <span class="icon is-small">
24
- <font-awesome-icon icon="check"></font-awesome-icon>
25
- </span>
26
- <span>Yes</span>
27
- </button>
28
- <button class="button is-warning is-small ml-1" v-else>
29
- <span class="icon is-small">
30
- <font-awesome-icon icon="exclamation"></font-awesome-icon>
31
- </span>
32
- <span>No</span>
33
- </button>
34
- </td>
35
- <td>
36
- <ul>
37
- <li v-for="(kv, index) in config.values" :key="index">
38
- <strong> {{ kv.key }} </strong>:
39
- <code v-if="kv.value">{{ kv.value }}</code>
40
- <span v-else>N/A</span>
41
- </li>
42
- </ul>
43
- </td>
44
- </tr>
45
- </tbody>
46
- </table>
47
- </div>
48
- </div>
49
- </template>
50
-
51
- <script lang="ts">
52
- import { defineComponent, type PropType } from "vue"
53
-
54
- import type { Config } from "@/types"
55
-
56
- export default defineComponent({
57
- name: "ConfigsItem",
58
- props: {
59
- configs: {
60
- type: Array as PropType<Config[]>,
61
- required: true
62
- }
63
- }
64
- })
65
- </script>
@@ -1,32 +0,0 @@
1
- <template>
2
- <Loading v-if="getConfigsTask.isRunning"></Loading>
3
- <ErrorMessage v-if="getConfigsTask.isError" :error="getConfigsTask.last?.error"></ErrorMessage>
4
- <Configs :configs="getConfigsTask.last.value" v-if="getConfigsTask.last?.value"></Configs>
5
- </template>
6
-
7
- <script lang="ts">
8
- import { defineComponent, onMounted } from "vue"
9
-
10
- import { generateGetConfigsTask } from "@/api-helper"
11
- import Configs from "@/components/config/Configs.vue"
12
- import ErrorMessage from "@/components/ErrorMessage.vue"
13
- import Loading from "@/components/Loading.vue"
14
-
15
- export default defineComponent({
16
- name: "ConfigsWrapper",
17
- components: {
18
- Configs,
19
- Loading,
20
- ErrorMessage
21
- },
22
- setup() {
23
- const getConfigsTask = generateGetConfigsTask()
24
-
25
- onMounted(async () => {
26
- await getConfigsTask.perform()
27
- })
28
-
29
- return { getConfigsTask }
30
- }
31
- })
32
- </script>
@@ -1,32 +0,0 @@
1
- <template>
2
- <a :href="link.href(data)" class="tag is-white" target="_blank">
3
- <img :src="link.favicon()" alt="favicon" />
4
- <span>{{ link.name }}</span>
5
- </a>
6
- </template>
7
-
8
- <script lang="ts">
9
- import { defineComponent, type PropType } from "vue"
10
-
11
- import type { Link } from "@/types"
12
-
13
- export default defineComponent({
14
- name: "LinkItem",
15
- props: {
16
- data: {
17
- type: String,
18
- required: true
19
- },
20
- link: {
21
- type: Object as PropType<Link>,
22
- required: true
23
- }
24
- }
25
- })
26
- </script>
27
-
28
- <style scoped>
29
- .tag img {
30
- margin-right: 5px;
31
- }
32
- </style>
@@ -1,42 +0,0 @@
1
- <template>
2
- <div class="tags are-medium">
3
- <LinkComponent :data="data" :link="link" v-for="link in selectedLinks" :key="link.name" />
4
- </div>
5
- </template>
6
-
7
- <script lang="ts">
8
- import { computed, defineComponent } from "vue"
9
-
10
- import LinkComponent from "@/components/link/Link.vue"
11
- import { Links } from "@/links"
12
- import type { Link } from "@/types"
13
-
14
- export default defineComponent({
15
- name: "LinksItem",
16
- components: {
17
- LinkComponent
18
- },
19
- props: {
20
- data: {
21
- type: String,
22
- required: true
23
- },
24
- type: {
25
- type: String,
26
- required: true
27
- }
28
- },
29
- setup(props) {
30
- const links = Links
31
- const selectedLinks = computed((): Link[] => {
32
- if (props.type === undefined) {
33
- return links
34
- }
35
-
36
- return links.filter((link) => link.type === props.type)
37
- })
38
-
39
- return { selectedLinks }
40
- }
41
- })
42
- </script>
@@ -1,72 +0,0 @@
1
- <template>
2
- <div class="column">
3
- <h2 class="is-size-2 mb-4">Edit rule: {{ rule.id }}</h2>
4
- <InputForm v-model:yaml="yaml" @update-yaml="updateYAML"></InputForm>
5
- <div class="field is-grouped is-grouped-centered">
6
- <p class="control">
7
- <a class="button is-primary" @click="edit">
8
- <span class="icon is-small">
9
- <font-awesome-icon icon="edit"></font-awesome-icon>
10
- </span>
11
- <span>Edit</span>
12
- </a>
13
- </p>
14
- </div>
15
- <div v-if="updateRuleTask.last?.error">
16
- <hr />
17
- <ErrorMessage :error="updateRuleTask.last?.error"></ErrorMessage>
18
- </div>
19
- </div>
20
- </template>
21
-
22
- <script lang="ts">
23
- import { defineComponent, type PropType, toRef } from "vue"
24
- import { useRouter } from "vue-router"
25
-
26
- import { generateUpdateRuleTask } from "@/api-helper"
27
- import ErrorMessage from "@/components/ErrorMessage.vue"
28
- import InputForm from "@/components/rule/InputForm.vue"
29
- import type { Rule } from "@/types"
30
-
31
- export default defineComponent({
32
- name: "EditRule",
33
- components: {
34
- InputForm,
35
- ErrorMessage
36
- },
37
- props: {
38
- rule: {
39
- type: Object as PropType<Rule>,
40
- required: true
41
- }
42
- },
43
- setup(props) {
44
- const router = useRouter()
45
-
46
- const rule = toRef(props, "rule")
47
- const yaml = toRef(rule.value, "yaml")
48
-
49
- const updateRuleTask = generateUpdateRuleTask()
50
-
51
- const updateYAML = (value: string) => {
52
- yaml.value = value
53
- }
54
-
55
- const edit = async () => {
56
- const rule = await updateRuleTask.perform({
57
- id: props.rule.id,
58
- yaml: yaml.value
59
- })
60
-
61
- router.push({ name: "Rule", params: { id: rule.id } })
62
- }
63
-
64
- return {
65
- edit,
66
- yaml,
67
- updateYAML,
68
- updateRuleTask
69
- }
70
- }
71
- })
72
- </script>
@@ -1,48 +0,0 @@
1
- <template>
2
- <Loading v-if="getRuleTask.isRunning"></Loading>
3
- <ErrorMessage v-if="getRuleTask.isError" :error="getRuleTask.last?.error"></ErrorMessage>
4
- <EditRule :rule="getRuleTask.last.value" v-if="getRuleTask.last?.value"></EditRule>
5
- </template>
6
-
7
- <script lang="ts">
8
- import { defineComponent, onMounted, watch } from "vue"
9
-
10
- import { generateGetRuleTask } from "@/api-helper"
11
- import ErrorMessage from "@/components/ErrorMessage.vue"
12
- import Loading from "@/components/Loading.vue"
13
- import EditRule from "@/components/rule/EditRule.vue"
14
-
15
- export default defineComponent({
16
- name: "EditRuleWrapper",
17
- components: {
18
- EditRule,
19
- Loading,
20
- ErrorMessage
21
- },
22
- props: {
23
- id: {
24
- type: String,
25
- required: true
26
- }
27
- },
28
- setup(props) {
29
- const getRuleTask = generateGetRuleTask()
30
-
31
- const getRule = async () => {
32
- await getRuleTask.perform(props.id)
33
- }
34
-
35
- onMounted(async () => {
36
- await getRule()
37
- })
38
-
39
- watch(props, async () => {
40
- await getRule()
41
- })
42
-
43
- return {
44
- getRuleTask
45
- }
46
- }
47
- })
48
- </script>
@@ -1,158 +0,0 @@
1
- <template>
2
- <div class="columns">
3
- <div class="column">
4
- <div class="field is-horizontal">
5
- <div class="field-label is-normal">
6
- <label class="label">Title</label>
7
- </div>
8
- <div class="field-body">
9
- <div class="field">
10
- <p class="control">
11
- <input class="input" type="text" v-model="title" />
12
- </p>
13
- </div>
14
- </div>
15
- </div>
16
- </div>
17
- <div class="column">
18
- <div class="field is-horizontal">
19
- <div class="field-label is-normal">
20
- <label class="label">Description</label>
21
- </div>
22
- <div class="field-body">
23
- <div class="field">
24
- <p class="control">
25
- <input class="input" type="text" v-model="description" />
26
- </p>
27
- </div>
28
- </div>
29
- </div>
30
- </div>
31
- </div>
32
- <div class="columns">
33
- <div class="column">
34
- <div class="field is-horizontal">
35
- <div class="field-label is-normal">
36
- <label class="label">Tag</label>
37
- </div>
38
- <div class="field-body">
39
- <div class="field">
40
- <div class="control">
41
- <div class="select">
42
- <select v-model="tagInput">
43
- <option></option>
44
- <option v-for="tag_ in tags" :key="tag_">
45
- {{ tag_ }}
46
- </option>
47
- </select>
48
- </div>
49
- </div>
50
- </div>
51
- </div>
52
- </div>
53
- </div>
54
- <div class="column"></div>
55
- </div>
56
- <div class="columns">
57
- <div class="column">
58
- <div class="field is-horizontal">
59
- <div class="field-label is-normal">
60
- <label class="label">From</label>
61
- </div>
62
- <div class="field-body">
63
- <div class="field">
64
- <p class="control">
65
- <input class="input" type="date" v-model="fromAt" />
66
- </p>
67
- </div>
68
- </div>
69
- </div>
70
- </div>
71
- <div class="column">
72
- <div class="field is-horizontal">
73
- <div class="field-label is-normal">
74
- <label class="label">To</label>
75
- </div>
76
- <div class="field-body">
77
- <div class="field">
78
- <p class="control">
79
- <input class="input" type="date" v-model="toAt" />
80
- </p>
81
- </div>
82
- </div>
83
- </div>
84
- </div>
85
- </div>
86
- </template>
87
-
88
- <script lang="ts">
89
- import { defineComponent, type PropType, ref, toRef, watch } from "vue"
90
- import { useRoute } from "vue-router"
91
-
92
- import type { RuleSearchParams } from "@/types"
93
- import { normalizeQueryParam } from "@/utils"
94
-
95
- export default defineComponent({
96
- name: "RulesForm",
97
- props: {
98
- tags: {
99
- type: Array as PropType<string[]>,
100
- required: true
101
- },
102
- page: {
103
- type: Number,
104
- required: true
105
- },
106
- tag: {
107
- type: String,
108
- required: false
109
- }
110
- },
111
- setup(props) {
112
- const route = useRoute()
113
-
114
- const description = ref<string | undefined>(undefined)
115
- const fromAt = ref<string | undefined>(undefined)
116
- const tagInput = toRef(props, "tag")
117
- const title = ref<string | undefined>(undefined)
118
- const toAt = ref<string | undefined>(undefined)
119
-
120
- const updateByQueryParams = () => {
121
- const tag_ = route.query["tag"]
122
- if (tagInput.value === undefined) {
123
- tagInput.value = normalizeQueryParam(tag_)
124
- }
125
- }
126
-
127
- const getSearchParams = (): RuleSearchParams => {
128
- updateByQueryParams()
129
-
130
- const params: RuleSearchParams = {
131
- description: description.value === "" ? undefined : description.value,
132
- page: props.page,
133
- tag: tagInput.value === "" ? undefined : tagInput.value,
134
- title: title.value === "" ? undefined : title.value,
135
- toAt: toAt.value === "" ? undefined : toAt.value,
136
- fromAt: fromAt.value === "" ? undefined : fromAt.value
137
- }
138
- return params
139
- }
140
-
141
- watch(
142
- () => props.tag,
143
- () => {
144
- tagInput.value = props.tag
145
- }
146
- )
147
-
148
- return {
149
- description,
150
- fromAt,
151
- getSearchParams,
152
- title,
153
- toAt,
154
- tagInput
155
- }
156
- }
157
- })
158
- </script>
@@ -1,45 +0,0 @@
1
- <template>
2
- <div class="block">
3
- <VAceEditor
4
- class="vue-ace-editor"
5
- v-model:value="yamlInput"
6
- lang="yaml"
7
- theme="monokai"
8
- :options="{
9
- fontSize: 16,
10
- minLines: 6,
11
- maxLines: 10000
12
- }"
13
- ></VAceEditor>
14
- </div>
15
- </template>
16
-
17
- <script lang="ts">
18
- import "@/ace-config"
19
-
20
- import { defineComponent, toRef, watchEffect } from "vue"
21
- import { VAceEditor } from "vue3-ace-editor"
22
-
23
- export default defineComponent({
24
- name: "RuleInputForm",
25
- components: {
26
- VAceEditor
27
- },
28
- props: {
29
- yaml: {
30
- type: String,
31
- required: true
32
- }
33
- },
34
- emits: ["update-yaml"],
35
- setup(props, context) {
36
- const yamlInput = toRef(props, "yaml")
37
-
38
- watchEffect(() => {
39
- context.emit("update-yaml", yamlInput.value)
40
- })
41
-
42
- return { yamlInput }
43
- }
44
- })
45
- </script>
@@ -1,57 +0,0 @@
1
- <template>
2
- <div class="column">
3
- <h2 class="is-size-2 mb-4">New rule</h2>
4
- <InputForm v-model:yaml="yaml" @update-yaml="updateYAML"></InputForm>
5
- <div class="field is-grouped is-grouped-centered">
6
- <p class="control">
7
- <a class="button is-primary" @click="create">
8
- <span class="icon is-small">
9
- <font-awesome-icon icon="plus"></font-awesome-icon>
10
- </span>
11
- <span>Create</span>
12
- </a>
13
- </p>
14
- </div>
15
- <div v-if="createRuleTask.last?.error">
16
- <hr />
17
- <ErrorMessage :error="createRuleTask.last?.error"></ErrorMessage>
18
- </div>
19
- </div>
20
- </template>
21
-
22
- <script lang="ts">
23
- import { defineComponent, ref } from "vue"
24
- import { useRouter } from "vue-router"
25
-
26
- import { generateCreateRuleTask } from "@/api-helper"
27
- import ErrorMessage from "@/components/ErrorMessage.vue"
28
- import InputForm from "@/components/rule/InputForm.vue"
29
- import { getRuleTemplate } from "@/rule"
30
-
31
- export default defineComponent({
32
- name: "NewRule",
33
- components: {
34
- InputForm,
35
- ErrorMessage
36
- },
37
- setup() {
38
- const router = useRouter()
39
-
40
- const yaml = ref(getRuleTemplate())
41
-
42
- const createRuleTask = generateCreateRuleTask()
43
-
44
- const updateYAML = (value: string) => {
45
- yaml.value = value
46
- }
47
-
48
- const create = async () => {
49
- const rule = await createRuleTask.perform({ yaml: yaml.value })
50
-
51
- router.push({ name: "Rule", params: { id: rule.id } })
52
- }
53
-
54
- return { yaml, create, updateYAML, createRuleTask }
55
- }
56
- })
57
- </script>
@@ -1,100 +0,0 @@
1
- <template>
2
- <div class="column">
3
- <div v-if="runRuleTask.isRunning">
4
- <Loading></Loading>
5
- <hr />
6
- </div>
7
- <div v-if="runRuleTask.last?.error">
8
- <ErrorMessage :error="runRuleTask.last.error"></ErrorMessage>
9
- <hr />
10
- </div>
11
- <h2 class="is-size-2 mb-4">Rule</h2>
12
- <p class="block is-clearfix">
13
- <span class="buttons is-pulled-right">
14
- <button class="button is-primary is-light is-small" @click="runRule">
15
- <span>Run</span>
16
- <span class="icon is-small">
17
- <font-awesome-icon icon="arrow-right"></font-awesome-icon>
18
- </span>
19
- </button>
20
- <router-link
21
- class="button is-info is-light is-small"
22
- :to="{ name: 'EditRule', params: { id: rule.id } }"
23
- >
24
- <span>Edit</span>
25
- <span class="icon is-small">
26
- <font-awesome-icon icon="edit"></font-awesome-icon>
27
- </span>
28
- </router-link>
29
- <button class="button is-light is-small" @click="deleteRule">
30
- <span>Delete</span>
31
- <span class="icon is-small">
32
- <font-awesome-icon icon="times"></font-awesome-icon>
33
- </span>
34
- </button>
35
- </span>
36
- </p>
37
- <YAML :yaml="rule.yaml"></YAML>
38
- </div>
39
- <hr />
40
- <div class="column">
41
- <h2 class="is-size-2 mb-4">Related alerts</h2>
42
-
43
- <Alerts :ruleId="rule.id"></Alerts>
44
- </div>
45
- </template>
46
-
47
- <script lang="ts">
48
- import { defineComponent, type PropType } from "vue"
49
- import { useRouter } from "vue-router"
50
-
51
- import { generateDeleteRuleTask, generateRunRuleTask } from "@/api-helper"
52
- import Alerts from "@/components/alert/AlertsWithPagination.vue"
53
- import ErrorMessage from "@/components/ErrorMessage.vue"
54
- import Loading from "@/components/Loading.vue"
55
- import YAML from "@/components/rule/YAML.vue"
56
- import type { Rule } from "@/types"
57
-
58
- export default defineComponent({
59
- name: "RuleItem",
60
- props: {
61
- rule: {
62
- type: Object as PropType<Rule>,
63
- required: true
64
- }
65
- },
66
- components: {
67
- YAML,
68
- Alerts,
69
- Loading,
70
- ErrorMessage
71
- },
72
- emits: ["refresh"],
73
- setup(props, context) {
74
- const router = useRouter()
75
-
76
- const deleteRuleTask = generateDeleteRuleTask()
77
- const runRuleTask = generateRunRuleTask()
78
-
79
- const deleteRule = async () => {
80
- const result = window.confirm(`Are you sure you want to delete ${props.rule.id}?`)
81
-
82
- if (result) {
83
- await deleteRuleTask.perform(props.rule.id)
84
- router.push("/")
85
- }
86
- }
87
-
88
- const runRule = async () => {
89
- await runRuleTask.perform(props.rule.id)
90
- context.emit("refresh")
91
- }
92
-
93
- return {
94
- deleteRule,
95
- runRule,
96
- runRuleTask
97
- }
98
- }
99
- })
100
- </script>