mihari 1.5.0 → 2.2.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (96) hide show
  1. checksums.yaml +4 -4
  2. data/.github/ISSUE_TEMPLATE/bug_report.md +43 -0
  3. data/.github/ISSUE_TEMPLATE/feature_request.md +15 -0
  4. data/.github/workflows/test.yml +41 -17
  5. data/.rubocop.yml +6 -0
  6. data/.standard.yml +4 -0
  7. data/README.md +21 -266
  8. data/bin/console +1 -0
  9. data/build_frontend.sh +14 -0
  10. data/docker/Dockerfile +5 -3
  11. data/examples/ipinfo_hosted_domains.rb +1 -1
  12. data/{screenshots → images}/alert.png +0 -0
  13. data/images/logo.png +0 -0
  14. data/{screenshots → images}/misp.png +0 -0
  15. data/{screenshots/eyecatch.png → images/overview.png} +0 -0
  16. data/{screenshots → images}/slack.png +0 -0
  17. data/images/web_alerts.png +0 -0
  18. data/images/web_config.png +0 -0
  19. data/lib/mihari.rb +2 -2
  20. data/lib/mihari/analyzers/base.rb +11 -2
  21. data/lib/mihari/analyzers/circl.rb +3 -3
  22. data/lib/mihari/analyzers/onyphe.rb +2 -2
  23. data/lib/mihari/analyzers/securitytrails.rb +2 -2
  24. data/lib/mihari/analyzers/shodan.rb +4 -0
  25. data/lib/mihari/cli.rb +73 -301
  26. data/lib/mihari/commands/binaryedge.rb +21 -0
  27. data/lib/mihari/commands/censys.rb +22 -0
  28. data/lib/mihari/commands/circl.rb +21 -0
  29. data/lib/mihari/commands/config.rb +27 -0
  30. data/lib/mihari/commands/crtsh.rb +22 -0
  31. data/lib/mihari/commands/dnpedia.rb +21 -0
  32. data/lib/mihari/commands/dnstwister.rb +21 -0
  33. data/lib/mihari/commands/free_text.rb +21 -0
  34. data/lib/mihari/commands/http_hash.rb +25 -0
  35. data/lib/mihari/commands/json.rb +42 -0
  36. data/lib/mihari/commands/onyphe.rb +21 -0
  37. data/lib/mihari/commands/otx.rb +21 -0
  38. data/lib/mihari/commands/passive_dns.rb +21 -0
  39. data/lib/mihari/commands/passive_ssl.rb +21 -0
  40. data/lib/mihari/commands/passivetotal.rb +21 -0
  41. data/lib/mihari/commands/pulsedive.rb +21 -0
  42. data/lib/mihari/commands/reverse_whois.rb +21 -0
  43. data/lib/mihari/commands/securitytrails.rb +22 -0
  44. data/lib/mihari/commands/securitytrails_domain_feed.rb +23 -0
  45. data/lib/mihari/commands/shodan.rb +21 -0
  46. data/lib/mihari/commands/spyse.rb +22 -0
  47. data/lib/mihari/commands/ssh_fingerprint.rb +21 -0
  48. data/lib/mihari/commands/urlscan.rb +25 -0
  49. data/lib/mihari/commands/virustotal.rb +21 -0
  50. data/lib/mihari/commands/web.rb +22 -0
  51. data/lib/mihari/commands/zoomeye.rb +22 -0
  52. data/lib/mihari/config.rb +12 -0
  53. data/lib/mihari/configurable.rb +4 -5
  54. data/lib/mihari/database.rb +8 -2
  55. data/lib/mihari/emitters/slack.rb +1 -1
  56. data/lib/mihari/emitters/the_hive.rb +1 -1
  57. data/lib/mihari/models/alert.rb +51 -0
  58. data/lib/mihari/models/artifact.rb +13 -2
  59. data/lib/mihari/notifiers/exception_notifier.rb +4 -4
  60. data/lib/mihari/serializers/alert.rb +1 -1
  61. data/lib/mihari/serializers/artifact.rb +1 -1
  62. data/lib/mihari/serializers/tag.rb +1 -1
  63. data/lib/mihari/status.rb +6 -14
  64. data/lib/mihari/version.rb +1 -1
  65. data/lib/mihari/web/app.rb +51 -0
  66. data/lib/mihari/web/controllers/alerts_controller.rb +75 -0
  67. data/lib/mihari/web/controllers/artifacts_controller.rb +24 -0
  68. data/lib/mihari/web/controllers/base_controller.rb +22 -0
  69. data/lib/mihari/web/controllers/command_controller.rb +26 -0
  70. data/lib/mihari/web/controllers/config_controller.rb +13 -0
  71. data/lib/mihari/web/controllers/sources_controller.rb +12 -0
  72. data/lib/mihari/web/controllers/tags_controller.rb +28 -0
  73. data/lib/mihari/web/helpers/json.rb +53 -0
  74. data/lib/mihari/web/public/index.html +1 -0
  75. data/lib/mihari/web/public/redoc-static.html +519 -0
  76. data/lib/mihari/web/public/static/favicon.ico +0 -0
  77. data/lib/mihari/web/public/static/fonts/fa-brands-400.099a9556.woff +0 -0
  78. data/lib/mihari/web/public/static/fonts/fa-brands-400.30cc681d.eot +0 -0
  79. data/lib/mihari/web/public/static/fonts/fa-brands-400.3b89dd10.ttf +0 -0
  80. data/lib/mihari/web/public/static/fonts/fa-brands-400.f7307680.woff2 +0 -0
  81. data/lib/mihari/web/public/static/fonts/fa-regular-400.1f77739c.ttf +0 -0
  82. data/lib/mihari/web/public/static/fonts/fa-regular-400.7124eb50.woff +0 -0
  83. data/lib/mihari/web/public/static/fonts/fa-regular-400.7630483d.eot +0 -0
  84. data/lib/mihari/web/public/static/fonts/fa-regular-400.f0f82301.woff2 +0 -0
  85. data/lib/mihari/web/public/static/fonts/fa-solid-900.1042e8ca.eot +0 -0
  86. data/lib/mihari/web/public/static/fonts/fa-solid-900.605ed792.ttf +0 -0
  87. data/lib/mihari/web/public/static/fonts/fa-solid-900.9fe5a17c.woff +0 -0
  88. data/lib/mihari/web/public/static/fonts/fa-solid-900.e8a427e1.woff2 +0 -0
  89. data/lib/mihari/web/public/static/img/fa-brands-400.ba7ed552.svg +3717 -0
  90. data/lib/mihari/web/public/static/img/fa-regular-400.0bb42845.svg +801 -0
  91. data/lib/mihari/web/public/static/img/fa-solid-900.376c1f97.svg +5034 -0
  92. data/lib/mihari/web/public/static/js/app.cccddb2b.js +12 -0
  93. data/lib/mihari/web/public/static/js/app.cccddb2b.js.map +1 -0
  94. data/mihari.gemspec +16 -4
  95. metadata +264 -21
  96. data/lib/mihari/alert_viewer.rb +0 -23
@@ -1,23 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- module Mihari
4
- class AlertViewer
5
- def list(title: nil, source: nil, tag: nil, limit: 5)
6
- limit = limit.to_i
7
- raise ArgumentError, "limit should be bigger than zero" unless limit.positive?
8
-
9
- relation = Alert.includes(:tags, :artifacts)
10
- relation = relation.where(title: title) if title
11
- relation = relation.where(source: source) if source
12
- relation = relation.where(tags: {name: tag}) if tag
13
-
14
- alerts = relation.limit(limit).order(id: :desc)
15
- alerts.map do |alert|
16
- json = AlertSerializer.new(alert).as_json
17
- json[:artifacts] = (json[:artifacts] || []).map { |artifact_| artifact_[:data] }
18
- json[:tags] = (json[:tags] || []).map { |tag_| tag_[:name] }
19
- json
20
- end
21
- end
22
- end
23
- end