karafka-web 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (178) hide show
  1. checksums.yaml +7 -0
  2. checksums.yaml.gz.sig +3 -0
  3. data/.coditsu/ci.yml +3 -0
  4. data/.diffend.yml +3 -0
  5. data/.github/FUNDING.yml +1 -0
  6. data/.github/ISSUE_TEMPLATE/bug_report.md +50 -0
  7. data/.github/ISSUE_TEMPLATE/feature_request.md +20 -0
  8. data/.github/workflows/ci.yml +49 -0
  9. data/.gitignore +69 -0
  10. data/.ruby-gemset +1 -0
  11. data/.ruby-version +1 -0
  12. data/CHANGELOG.md +9 -0
  13. data/CODE_OF_CONDUCT.md +46 -0
  14. data/Gemfile +7 -0
  15. data/Gemfile.lock +52 -0
  16. data/LICENSE +17 -0
  17. data/README.md +29 -0
  18. data/bin/karafka-web +33 -0
  19. data/certs/cert_chain.pem +26 -0
  20. data/config/locales/errors.yml +9 -0
  21. data/karafka-web.gemspec +44 -0
  22. data/lib/karafka/web/app.rb +17 -0
  23. data/lib/karafka/web/config.rb +80 -0
  24. data/lib/karafka/web/deserializer.rb +20 -0
  25. data/lib/karafka/web/errors.rb +25 -0
  26. data/lib/karafka/web/installer.rb +124 -0
  27. data/lib/karafka/web/processing/consumer.rb +66 -0
  28. data/lib/karafka/web/processing/consumers/aggregator.rb +130 -0
  29. data/lib/karafka/web/processing/consumers/state.rb +32 -0
  30. data/lib/karafka/web/tracking/base_contract.rb +31 -0
  31. data/lib/karafka/web/tracking/consumers/contracts/consumer_group.rb +33 -0
  32. data/lib/karafka/web/tracking/consumers/contracts/job.rb +26 -0
  33. data/lib/karafka/web/tracking/consumers/contracts/partition.rb +22 -0
  34. data/lib/karafka/web/tracking/consumers/contracts/report.rb +95 -0
  35. data/lib/karafka/web/tracking/consumers/contracts/topic.rb +29 -0
  36. data/lib/karafka/web/tracking/consumers/listeners/base.rb +33 -0
  37. data/lib/karafka/web/tracking/consumers/listeners/errors.rb +107 -0
  38. data/lib/karafka/web/tracking/consumers/listeners/pausing.rb +45 -0
  39. data/lib/karafka/web/tracking/consumers/listeners/processing.rb +157 -0
  40. data/lib/karafka/web/tracking/consumers/listeners/statistics.rb +123 -0
  41. data/lib/karafka/web/tracking/consumers/listeners/status.rb +58 -0
  42. data/lib/karafka/web/tracking/consumers/sampler.rb +216 -0
  43. data/lib/karafka/web/tracking/memoized_shell.rb +48 -0
  44. data/lib/karafka/web/tracking/reporter.rb +144 -0
  45. data/lib/karafka/web/tracking/ttl_array.rb +59 -0
  46. data/lib/karafka/web/tracking/ttl_hash.rb +16 -0
  47. data/lib/karafka/web/ui/app.rb +78 -0
  48. data/lib/karafka/web/ui/base.rb +77 -0
  49. data/lib/karafka/web/ui/controllers/base.rb +40 -0
  50. data/lib/karafka/web/ui/controllers/become_pro.rb +17 -0
  51. data/lib/karafka/web/ui/controllers/cluster.rb +24 -0
  52. data/lib/karafka/web/ui/controllers/consumers.rb +27 -0
  53. data/lib/karafka/web/ui/controllers/errors.rb +43 -0
  54. data/lib/karafka/web/ui/controllers/jobs.rb +33 -0
  55. data/lib/karafka/web/ui/controllers/requests/params.rb +30 -0
  56. data/lib/karafka/web/ui/controllers/responses/data.rb +26 -0
  57. data/lib/karafka/web/ui/controllers/routing.rb +30 -0
  58. data/lib/karafka/web/ui/helpers/application_helper.rb +144 -0
  59. data/lib/karafka/web/ui/lib/hash_proxy.rb +66 -0
  60. data/lib/karafka/web/ui/lib/paginate_array.rb +38 -0
  61. data/lib/karafka/web/ui/models/consumer_group.rb +20 -0
  62. data/lib/karafka/web/ui/models/health.rb +44 -0
  63. data/lib/karafka/web/ui/models/job.rb +13 -0
  64. data/lib/karafka/web/ui/models/message.rb +99 -0
  65. data/lib/karafka/web/ui/models/partition.rb +13 -0
  66. data/lib/karafka/web/ui/models/process.rb +56 -0
  67. data/lib/karafka/web/ui/models/processes.rb +86 -0
  68. data/lib/karafka/web/ui/models/state.rb +67 -0
  69. data/lib/karafka/web/ui/models/topic.rb +19 -0
  70. data/lib/karafka/web/ui/pro/app.rb +120 -0
  71. data/lib/karafka/web/ui/pro/controllers/cluster.rb +16 -0
  72. data/lib/karafka/web/ui/pro/controllers/consumers.rb +54 -0
  73. data/lib/karafka/web/ui/pro/controllers/dlq.rb +44 -0
  74. data/lib/karafka/web/ui/pro/controllers/errors.rb +57 -0
  75. data/lib/karafka/web/ui/pro/controllers/explorer.rb +79 -0
  76. data/lib/karafka/web/ui/pro/controllers/health.rb +33 -0
  77. data/lib/karafka/web/ui/pro/controllers/jobs.rb +26 -0
  78. data/lib/karafka/web/ui/pro/controllers/routing.rb +26 -0
  79. data/lib/karafka/web/ui/pro/views/consumers/_breadcrumbs.erb +27 -0
  80. data/lib/karafka/web/ui/pro/views/consumers/_consumer.erb +60 -0
  81. data/lib/karafka/web/ui/pro/views/consumers/_counters.erb +50 -0
  82. data/lib/karafka/web/ui/pro/views/consumers/_summary.erb +81 -0
  83. data/lib/karafka/web/ui/pro/views/consumers/consumer/_consumer_group.erb +109 -0
  84. data/lib/karafka/web/ui/pro/views/consumers/consumer/_job.erb +26 -0
  85. data/lib/karafka/web/ui/pro/views/consumers/consumer/_metrics.erb +126 -0
  86. data/lib/karafka/web/ui/pro/views/consumers/consumer/_no_jobs.erb +9 -0
  87. data/lib/karafka/web/ui/pro/views/consumers/consumer/_no_subscriptions.erb +9 -0
  88. data/lib/karafka/web/ui/pro/views/consumers/consumer/_partition.erb +32 -0
  89. data/lib/karafka/web/ui/pro/views/consumers/consumer/_stopped.erb +10 -0
  90. data/lib/karafka/web/ui/pro/views/consumers/consumer/_tabs.erb +20 -0
  91. data/lib/karafka/web/ui/pro/views/consumers/index.erb +30 -0
  92. data/lib/karafka/web/ui/pro/views/consumers/jobs.erb +42 -0
  93. data/lib/karafka/web/ui/pro/views/consumers/subscriptions.erb +23 -0
  94. data/lib/karafka/web/ui/pro/views/dlq/_breadcrumbs.erb +5 -0
  95. data/lib/karafka/web/ui/pro/views/dlq/_no_topics.erb +9 -0
  96. data/lib/karafka/web/ui/pro/views/dlq/_topic.erb +12 -0
  97. data/lib/karafka/web/ui/pro/views/dlq/index.erb +16 -0
  98. data/lib/karafka/web/ui/pro/views/errors/_breadcrumbs.erb +25 -0
  99. data/lib/karafka/web/ui/pro/views/errors/_detail.erb +29 -0
  100. data/lib/karafka/web/ui/pro/views/errors/_error.erb +26 -0
  101. data/lib/karafka/web/ui/pro/views/errors/_partition_option.erb +7 -0
  102. data/lib/karafka/web/ui/pro/views/errors/index.erb +58 -0
  103. data/lib/karafka/web/ui/pro/views/errors/show.erb +56 -0
  104. data/lib/karafka/web/ui/pro/views/explorer/_breadcrumbs.erb +29 -0
  105. data/lib/karafka/web/ui/pro/views/explorer/_detail.erb +21 -0
  106. data/lib/karafka/web/ui/pro/views/explorer/_encryption_enabled.erb +18 -0
  107. data/lib/karafka/web/ui/pro/views/explorer/_failed_deserialization.erb +4 -0
  108. data/lib/karafka/web/ui/pro/views/explorer/_message.erb +16 -0
  109. data/lib/karafka/web/ui/pro/views/explorer/_partition_option.erb +7 -0
  110. data/lib/karafka/web/ui/pro/views/explorer/_topic.erb +12 -0
  111. data/lib/karafka/web/ui/pro/views/explorer/index.erb +17 -0
  112. data/lib/karafka/web/ui/pro/views/explorer/partition.erb +56 -0
  113. data/lib/karafka/web/ui/pro/views/explorer/show.erb +65 -0
  114. data/lib/karafka/web/ui/pro/views/health/_breadcrumbs.erb +5 -0
  115. data/lib/karafka/web/ui/pro/views/health/_partition.erb +35 -0
  116. data/lib/karafka/web/ui/pro/views/health/index.erb +60 -0
  117. data/lib/karafka/web/ui/pro/views/jobs/_breadcrumbs.erb +5 -0
  118. data/lib/karafka/web/ui/pro/views/jobs/_job.erb +31 -0
  119. data/lib/karafka/web/ui/pro/views/jobs/_no_jobs.erb +9 -0
  120. data/lib/karafka/web/ui/pro/views/jobs/index.erb +34 -0
  121. data/lib/karafka/web/ui/pro/views/shared/_navigation.erb +57 -0
  122. data/lib/karafka/web/ui/public/images/favicon.ico +0 -0
  123. data/lib/karafka/web/ui/public/images/logo.svg +28 -0
  124. data/lib/karafka/web/ui/public/javascripts/application.js +41 -0
  125. data/lib/karafka/web/ui/public/javascripts/bootstrap.min.js +7 -0
  126. data/lib/karafka/web/ui/public/javascripts/highlight.min.js +337 -0
  127. data/lib/karafka/web/ui/public/javascripts/live_poll.js +124 -0
  128. data/lib/karafka/web/ui/public/javascripts/timeago.min.js +1 -0
  129. data/lib/karafka/web/ui/public/stylesheets/application.css +106 -0
  130. data/lib/karafka/web/ui/public/stylesheets/bootstrap.min.css +7 -0
  131. data/lib/karafka/web/ui/public/stylesheets/bootstrap.min.css.map +1 -0
  132. data/lib/karafka/web/ui/public/stylesheets/highlight.min.css +10 -0
  133. data/lib/karafka/web/ui/views/cluster/_breadcrumbs.erb +5 -0
  134. data/lib/karafka/web/ui/views/cluster/_broker.erb +5 -0
  135. data/lib/karafka/web/ui/views/cluster/_partition.erb +22 -0
  136. data/lib/karafka/web/ui/views/cluster/index.erb +72 -0
  137. data/lib/karafka/web/ui/views/consumers/_breadcrumbs.erb +27 -0
  138. data/lib/karafka/web/ui/views/consumers/_consumer.erb +43 -0
  139. data/lib/karafka/web/ui/views/consumers/_counters.erb +44 -0
  140. data/lib/karafka/web/ui/views/consumers/_summary.erb +81 -0
  141. data/lib/karafka/web/ui/views/consumers/consumer/_consumer_group.erb +109 -0
  142. data/lib/karafka/web/ui/views/consumers/consumer/_job.erb +26 -0
  143. data/lib/karafka/web/ui/views/consumers/consumer/_metrics.erb +126 -0
  144. data/lib/karafka/web/ui/views/consumers/consumer/_no_jobs.erb +9 -0
  145. data/lib/karafka/web/ui/views/consumers/consumer/_no_subscriptions.erb +9 -0
  146. data/lib/karafka/web/ui/views/consumers/consumer/_partition.erb +32 -0
  147. data/lib/karafka/web/ui/views/consumers/consumer/_stopped.erb +10 -0
  148. data/lib/karafka/web/ui/views/consumers/consumer/_tabs.erb +20 -0
  149. data/lib/karafka/web/ui/views/consumers/index.erb +29 -0
  150. data/lib/karafka/web/ui/views/errors/_breadcrumbs.erb +19 -0
  151. data/lib/karafka/web/ui/views/errors/_detail.erb +29 -0
  152. data/lib/karafka/web/ui/views/errors/_error.erb +26 -0
  153. data/lib/karafka/web/ui/views/errors/index.erb +38 -0
  154. data/lib/karafka/web/ui/views/errors/show.erb +30 -0
  155. data/lib/karafka/web/ui/views/jobs/_breadcrumbs.erb +5 -0
  156. data/lib/karafka/web/ui/views/jobs/_job.erb +22 -0
  157. data/lib/karafka/web/ui/views/jobs/_no_jobs.erb +9 -0
  158. data/lib/karafka/web/ui/views/jobs/index.erb +31 -0
  159. data/lib/karafka/web/ui/views/layout.erb +23 -0
  160. data/lib/karafka/web/ui/views/routing/_breadcrumbs.erb +15 -0
  161. data/lib/karafka/web/ui/views/routing/_consumer_group.erb +34 -0
  162. data/lib/karafka/web/ui/views/routing/_detail.erb +25 -0
  163. data/lib/karafka/web/ui/views/routing/_topic.erb +18 -0
  164. data/lib/karafka/web/ui/views/routing/index.erb +10 -0
  165. data/lib/karafka/web/ui/views/routing/show.erb +26 -0
  166. data/lib/karafka/web/ui/views/shared/_become_pro.erb +13 -0
  167. data/lib/karafka/web/ui/views/shared/_brand.erb +3 -0
  168. data/lib/karafka/web/ui/views/shared/_content.erb +31 -0
  169. data/lib/karafka/web/ui/views/shared/_header.erb +20 -0
  170. data/lib/karafka/web/ui/views/shared/_navigation.erb +57 -0
  171. data/lib/karafka/web/ui/views/shared/_pagination.erb +21 -0
  172. data/lib/karafka/web/ui/views/shared/exceptions/not_found.erb +39 -0
  173. data/lib/karafka/web/ui/views/shared/exceptions/pro_only.erb +52 -0
  174. data/lib/karafka/web/version.rb +8 -0
  175. data/lib/karafka/web.rb +60 -0
  176. data.tar.gz.sig +0 -0
  177. metadata +328 -0
  178. metadata.gz.sig +0 -0
@@ -0,0 +1,337 @@
1
+ /*!
2
+ Highlight.js v11.7.0 (git: 82688fad18)
3
+ (c) 2006-2022 undefined and other contributors
4
+ License: BSD-3-Clause
5
+ */
6
+ var hljs=function(){"use strict";var e={exports:{}};function t(e){
7
+ return e instanceof Map?e.clear=e.delete=e.set=()=>{
8
+ throw Error("map is read-only")}:e instanceof Set&&(e.add=e.clear=e.delete=()=>{
9
+ throw Error("set is read-only")
10
+ }),Object.freeze(e),Object.getOwnPropertyNames(e).forEach((n=>{var i=e[n]
11
+ ;"object"!=typeof i||Object.isFrozen(i)||t(i)})),e}
12
+ e.exports=t,e.exports.default=t;class n{constructor(e){
13
+ void 0===e.data&&(e.data={}),this.data=e.data,this.isMatchIgnored=!1}
14
+ ignoreMatch(){this.isMatchIgnored=!0}}function i(e){
15
+ return e.replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/"/g,"&quot;").replace(/'/g,"&#x27;")
16
+ }function r(e,...t){const n=Object.create(null);for(const t in e)n[t]=e[t]
17
+ ;return t.forEach((e=>{for(const t in e)n[t]=e[t]})),n}
18
+ const s=e=>!!e.scope||e.sublanguage&&e.language;class o{constructor(e,t){
19
+ this.buffer="",this.classPrefix=t.classPrefix,e.walk(this)}addText(e){
20
+ this.buffer+=i(e)}openNode(e){if(!s(e))return;let t=""
21
+ ;t=e.sublanguage?"language-"+e.language:((e,{prefix:t})=>{if(e.includes(".")){
22
+ const n=e.split(".")
23
+ ;return[`${t}${n.shift()}`,...n.map(((e,t)=>`${e}${"_".repeat(t+1)}`))].join(" ")
24
+ }return`${t}${e}`})(e.scope,{prefix:this.classPrefix}),this.span(t)}
25
+ closeNode(e){s(e)&&(this.buffer+="</span>")}value(){return this.buffer}span(e){
26
+ this.buffer+=`<span class="${e}">`}}const a=(e={})=>{const t={children:[]}
27
+ ;return Object.assign(t,e),t};class c{constructor(){
28
+ this.rootNode=a(),this.stack=[this.rootNode]}get top(){
29
+ return this.stack[this.stack.length-1]}get root(){return this.rootNode}add(e){
30
+ this.top.children.push(e)}openNode(e){const t=a({scope:e})
31
+ ;this.add(t),this.stack.push(t)}closeNode(){
32
+ if(this.stack.length>1)return this.stack.pop()}closeAllNodes(){
33
+ for(;this.closeNode(););}toJSON(){return JSON.stringify(this.rootNode,null,4)}
34
+ walk(e){return this.constructor._walk(e,this.rootNode)}static _walk(e,t){
35
+ return"string"==typeof t?e.addText(t):t.children&&(e.openNode(t),
36
+ t.children.forEach((t=>this._walk(e,t))),e.closeNode(t)),e}static _collapse(e){
37
+ "string"!=typeof e&&e.children&&(e.children.every((e=>"string"==typeof e))?e.children=[e.children.join("")]:e.children.forEach((e=>{
38
+ c._collapse(e)})))}}class l extends c{constructor(e){super(),this.options=e}
39
+ addKeyword(e,t){""!==e&&(this.openNode(t),this.addText(e),this.closeNode())}
40
+ addText(e){""!==e&&this.add(e)}addSublanguage(e,t){const n=e.root
41
+ ;n.sublanguage=!0,n.language=t,this.add(n)}toHTML(){
42
+ return new o(this,this.options).value()}finalize(){return!0}}function g(e){
43
+ return e?"string"==typeof e?e:e.source:null}function d(e){return p("(?=",e,")")}
44
+ function u(e){return p("(?:",e,")*")}function h(e){return p("(?:",e,")?")}
45
+ function p(...e){return e.map((e=>g(e))).join("")}function f(...e){const t=(e=>{
46
+ const t=e[e.length-1]
47
+ ;return"object"==typeof t&&t.constructor===Object?(e.splice(e.length-1,1),t):{}
48
+ })(e);return"("+(t.capture?"":"?:")+e.map((e=>g(e))).join("|")+")"}
49
+ function b(e){return RegExp(e.toString()+"|").exec("").length-1}
50
+ const m=/\[(?:[^\\\]]|\\.)*\]|\(\??|\\([1-9][0-9]*)|\\./
51
+ ;function E(e,{joinWith:t}){let n=0;return e.map((e=>{n+=1;const t=n
52
+ ;let i=g(e),r="";for(;i.length>0;){const e=m.exec(i);if(!e){r+=i;break}
53
+ r+=i.substring(0,e.index),
54
+ i=i.substring(e.index+e[0].length),"\\"===e[0][0]&&e[1]?r+="\\"+(Number(e[1])+t):(r+=e[0],
55
+ "("===e[0]&&n++)}return r})).map((e=>`(${e})`)).join(t)}
56
+ const x="[a-zA-Z]\\w*",w="[a-zA-Z_]\\w*",y="\\b\\d+(\\.\\d+)?",_="(-?)(\\b0[xX][a-fA-F0-9]+|(\\b\\d+(\\.\\d*)?|\\.\\d+)([eE][-+]?\\d+)?)",O="\\b(0b[01]+)",v={
57
+ begin:"\\\\[\\s\\S]",relevance:0},N={scope:"string",begin:"'",end:"'",
58
+ illegal:"\\n",contains:[v]},k={scope:"string",begin:'"',end:'"',illegal:"\\n",
59
+ contains:[v]},M=(e,t,n={})=>{const i=r({scope:"comment",begin:e,end:t,
60
+ contains:[]},n);i.contains.push({scope:"doctag",
61
+ begin:"[ ]*(?=(TODO|FIXME|NOTE|BUG|OPTIMIZE|HACK|XXX):)",
62
+ end:/(TODO|FIXME|NOTE|BUG|OPTIMIZE|HACK|XXX):/,excludeBegin:!0,relevance:0})
63
+ ;const s=f("I","a","is","so","us","to","at","if","in","it","on",/[A-Za-z]+['](d|ve|re|ll|t|s|n)/,/[A-Za-z]+[-][a-z]+/,/[A-Za-z][a-z]{2,}/)
64
+ ;return i.contains.push({begin:p(/[ ]+/,"(",s,/[.]?[:]?([.][ ]|[ ])/,"){3}")}),i
65
+ },S=M("//","$"),R=M("/\\*","\\*/"),j=M("#","$");var A=Object.freeze({
66
+ __proto__:null,MATCH_NOTHING_RE:/\b\B/,IDENT_RE:x,UNDERSCORE_IDENT_RE:w,
67
+ NUMBER_RE:y,C_NUMBER_RE:_,BINARY_NUMBER_RE:O,
68
+ RE_STARTERS_RE:"!|!=|!==|%|%=|&|&&|&=|\\*|\\*=|\\+|\\+=|,|-|-=|/=|/|:|;|<<|<<=|<=|<|===|==|=|>>>=|>>=|>=|>>>|>>|>|\\?|\\[|\\{|\\(|\\^|\\^=|\\||\\|=|\\|\\||~",
69
+ SHEBANG:(e={})=>{const t=/^#![ ]*\//
70
+ ;return e.binary&&(e.begin=p(t,/.*\b/,e.binary,/\b.*/)),r({scope:"meta",begin:t,
71
+ end:/$/,relevance:0,"on:begin":(e,t)=>{0!==e.index&&t.ignoreMatch()}},e)},
72
+ BACKSLASH_ESCAPE:v,APOS_STRING_MODE:N,QUOTE_STRING_MODE:k,PHRASAL_WORDS_MODE:{
73
+ begin:/\b(a|an|the|are|I'm|isn't|don't|doesn't|won't|but|just|should|pretty|simply|enough|gonna|going|wtf|so|such|will|you|your|they|like|more)\b/
74
+ },COMMENT:M,C_LINE_COMMENT_MODE:S,C_BLOCK_COMMENT_MODE:R,HASH_COMMENT_MODE:j,
75
+ NUMBER_MODE:{scope:"number",begin:y,relevance:0},C_NUMBER_MODE:{scope:"number",
76
+ begin:_,relevance:0},BINARY_NUMBER_MODE:{scope:"number",begin:O,relevance:0},
77
+ REGEXP_MODE:{begin:/(?=\/[^/\n]*\/)/,contains:[{scope:"regexp",begin:/\//,
78
+ end:/\/[gimuy]*/,illegal:/\n/,contains:[v,{begin:/\[/,end:/\]/,relevance:0,
79
+ contains:[v]}]}]},TITLE_MODE:{scope:"title",begin:x,relevance:0},
80
+ UNDERSCORE_TITLE_MODE:{scope:"title",begin:w,relevance:0},METHOD_GUARD:{
81
+ begin:"\\.\\s*[a-zA-Z_]\\w*",relevance:0},END_SAME_AS_BEGIN:e=>Object.assign(e,{
82
+ "on:begin":(e,t)=>{t.data._beginMatch=e[1]},"on:end":(e,t)=>{
83
+ t.data._beginMatch!==e[1]&&t.ignoreMatch()}})});function I(e,t){
84
+ "."===e.input[e.index-1]&&t.ignoreMatch()}function T(e,t){
85
+ void 0!==e.className&&(e.scope=e.className,delete e.className)}function L(e,t){
86
+ t&&e.beginKeywords&&(e.begin="\\b("+e.beginKeywords.split(" ").join("|")+")(?!\\.)(?=\\b|\\s)",
87
+ e.__beforeBegin=I,e.keywords=e.keywords||e.beginKeywords,delete e.beginKeywords,
88
+ void 0===e.relevance&&(e.relevance=0))}function B(e,t){
89
+ Array.isArray(e.illegal)&&(e.illegal=f(...e.illegal))}function D(e,t){
90
+ if(e.match){
91
+ if(e.begin||e.end)throw Error("begin & end are not supported with match")
92
+ ;e.begin=e.match,delete e.match}}function H(e,t){
93
+ void 0===e.relevance&&(e.relevance=1)}const P=(e,t)=>{if(!e.beforeMatch)return
94
+ ;if(e.starts)throw Error("beforeMatch cannot be used with starts")
95
+ ;const n=Object.assign({},e);Object.keys(e).forEach((t=>{delete e[t]
96
+ })),e.keywords=n.keywords,e.begin=p(n.beforeMatch,d(n.begin)),e.starts={
97
+ relevance:0,contains:[Object.assign(n,{endsParent:!0})]
98
+ },e.relevance=0,delete n.beforeMatch
99
+ },C=["of","and","for","in","not","or","if","then","parent","list","value"]
100
+ ;function $(e,t,n="keyword"){const i=Object.create(null)
101
+ ;return"string"==typeof e?r(n,e.split(" ")):Array.isArray(e)?r(n,e):Object.keys(e).forEach((n=>{
102
+ Object.assign(i,$(e[n],t,n))})),i;function r(e,n){
103
+ t&&(n=n.map((e=>e.toLowerCase()))),n.forEach((t=>{const n=t.split("|")
104
+ ;i[n[0]]=[e,U(n[0],n[1])]}))}}function U(e,t){
105
+ return t?Number(t):(e=>C.includes(e.toLowerCase()))(e)?0:1}const z={},K=e=>{
106
+ console.error(e)},W=(e,...t)=>{console.log("WARN: "+e,...t)},X=(e,t)=>{
107
+ z[`${e}/${t}`]||(console.log(`Deprecated as of ${e}. ${t}`),z[`${e}/${t}`]=!0)
108
+ },G=Error();function Z(e,t,{key:n}){let i=0;const r=e[n],s={},o={}
109
+ ;for(let e=1;e<=t.length;e++)o[e+i]=r[e],s[e+i]=!0,i+=b(t[e-1])
110
+ ;e[n]=o,e[n]._emit=s,e[n]._multi=!0}function F(e){(e=>{
111
+ e.scope&&"object"==typeof e.scope&&null!==e.scope&&(e.beginScope=e.scope,
112
+ delete e.scope)})(e),"string"==typeof e.beginScope&&(e.beginScope={
113
+ _wrap:e.beginScope}),"string"==typeof e.endScope&&(e.endScope={_wrap:e.endScope
114
+ }),(e=>{if(Array.isArray(e.begin)){
115
+ if(e.skip||e.excludeBegin||e.returnBegin)throw K("skip, excludeBegin, returnBegin not compatible with beginScope: {}"),
116
+ G
117
+ ;if("object"!=typeof e.beginScope||null===e.beginScope)throw K("beginScope must be object"),
118
+ G;Z(e,e.begin,{key:"beginScope"}),e.begin=E(e.begin,{joinWith:""})}})(e),(e=>{
119
+ if(Array.isArray(e.end)){
120
+ if(e.skip||e.excludeEnd||e.returnEnd)throw K("skip, excludeEnd, returnEnd not compatible with endScope: {}"),
121
+ G
122
+ ;if("object"!=typeof e.endScope||null===e.endScope)throw K("endScope must be object"),
123
+ G;Z(e,e.end,{key:"endScope"}),e.end=E(e.end,{joinWith:""})}})(e)}function V(e){
124
+ function t(t,n){
125
+ return RegExp(g(t),"m"+(e.case_insensitive?"i":"")+(e.unicodeRegex?"u":"")+(n?"g":""))
126
+ }class n{constructor(){
127
+ this.matchIndexes={},this.regexes=[],this.matchAt=1,this.position=0}
128
+ addRule(e,t){
129
+ t.position=this.position++,this.matchIndexes[this.matchAt]=t,this.regexes.push([t,e]),
130
+ this.matchAt+=b(e)+1}compile(){0===this.regexes.length&&(this.exec=()=>null)
131
+ ;const e=this.regexes.map((e=>e[1]));this.matcherRe=t(E(e,{joinWith:"|"
132
+ }),!0),this.lastIndex=0}exec(e){this.matcherRe.lastIndex=this.lastIndex
133
+ ;const t=this.matcherRe.exec(e);if(!t)return null
134
+ ;const n=t.findIndex(((e,t)=>t>0&&void 0!==e)),i=this.matchIndexes[n]
135
+ ;return t.splice(0,n),Object.assign(t,i)}}class i{constructor(){
136
+ this.rules=[],this.multiRegexes=[],
137
+ this.count=0,this.lastIndex=0,this.regexIndex=0}getMatcher(e){
138
+ if(this.multiRegexes[e])return this.multiRegexes[e];const t=new n
139
+ ;return this.rules.slice(e).forEach((([e,n])=>t.addRule(e,n))),
140
+ t.compile(),this.multiRegexes[e]=t,t}resumingScanAtSamePosition(){
141
+ return 0!==this.regexIndex}considerAll(){this.regexIndex=0}addRule(e,t){
142
+ this.rules.push([e,t]),"begin"===t.type&&this.count++}exec(e){
143
+ const t=this.getMatcher(this.regexIndex);t.lastIndex=this.lastIndex
144
+ ;let n=t.exec(e)
145
+ ;if(this.resumingScanAtSamePosition())if(n&&n.index===this.lastIndex);else{
146
+ const t=this.getMatcher(0);t.lastIndex=this.lastIndex+1,n=t.exec(e)}
147
+ return n&&(this.regexIndex+=n.position+1,
148
+ this.regexIndex===this.count&&this.considerAll()),n}}
149
+ if(e.compilerExtensions||(e.compilerExtensions=[]),
150
+ e.contains&&e.contains.includes("self"))throw Error("ERR: contains `self` is not supported at the top-level of a language. See documentation.")
151
+ ;return e.classNameAliases=r(e.classNameAliases||{}),function n(s,o){const a=s
152
+ ;if(s.isCompiled)return a
153
+ ;[T,D,F,P].forEach((e=>e(s,o))),e.compilerExtensions.forEach((e=>e(s,o))),
154
+ s.__beforeBegin=null,[L,B,H].forEach((e=>e(s,o))),s.isCompiled=!0;let c=null
155
+ ;return"object"==typeof s.keywords&&s.keywords.$pattern&&(s.keywords=Object.assign({},s.keywords),
156
+ c=s.keywords.$pattern,
157
+ delete s.keywords.$pattern),c=c||/\w+/,s.keywords&&(s.keywords=$(s.keywords,e.case_insensitive)),
158
+ a.keywordPatternRe=t(c,!0),
159
+ o&&(s.begin||(s.begin=/\B|\b/),a.beginRe=t(a.begin),s.end||s.endsWithParent||(s.end=/\B|\b/),
160
+ s.end&&(a.endRe=t(a.end)),
161
+ a.terminatorEnd=g(a.end)||"",s.endsWithParent&&o.terminatorEnd&&(a.terminatorEnd+=(s.end?"|":"")+o.terminatorEnd)),
162
+ s.illegal&&(a.illegalRe=t(s.illegal)),
163
+ s.contains||(s.contains=[]),s.contains=[].concat(...s.contains.map((e=>(e=>(e.variants&&!e.cachedVariants&&(e.cachedVariants=e.variants.map((t=>r(e,{
164
+ variants:null},t)))),e.cachedVariants?e.cachedVariants:q(e)?r(e,{
165
+ starts:e.starts?r(e.starts):null
166
+ }):Object.isFrozen(e)?r(e):e))("self"===e?s:e)))),s.contains.forEach((e=>{n(e,a)
167
+ })),s.starts&&n(s.starts,o),a.matcher=(e=>{const t=new i
168
+ ;return e.contains.forEach((e=>t.addRule(e.begin,{rule:e,type:"begin"
169
+ }))),e.terminatorEnd&&t.addRule(e.terminatorEnd,{type:"end"
170
+ }),e.illegal&&t.addRule(e.illegal,{type:"illegal"}),t})(a),a}(e)}function q(e){
171
+ return!!e&&(e.endsWithParent||q(e.starts))}class J extends Error{
172
+ constructor(e,t){super(e),this.name="HTMLInjectionError",this.html=t}}
173
+ const Y=i,Q=r,ee=Symbol("nomatch");var te=(t=>{
174
+ const i=Object.create(null),r=Object.create(null),s=[];let o=!0
175
+ ;const a="Could not find the language '{}', did you forget to load/include a language module?",c={
176
+ disableAutodetect:!0,name:"Plain text",contains:[]};let g={
177
+ ignoreUnescapedHTML:!1,throwUnescapedHTML:!1,noHighlightRe:/^(no-?highlight)$/i,
178
+ languageDetectRe:/\blang(?:uage)?-([\w-]+)\b/i,classPrefix:"hljs-",
179
+ cssSelector:"pre code",languages:null,__emitter:l};function b(e){
180
+ return g.noHighlightRe.test(e)}function m(e,t,n){let i="",r=""
181
+ ;"object"==typeof t?(i=e,
182
+ n=t.ignoreIllegals,r=t.language):(X("10.7.0","highlight(lang, code, ...args) has been deprecated."),
183
+ X("10.7.0","Please use highlight(code, options) instead.\nhttps://github.com/highlightjs/highlight.js/issues/2277"),
184
+ r=e,i=t),void 0===n&&(n=!0);const s={code:i,language:r};k("before:highlight",s)
185
+ ;const o=s.result?s.result:E(s.language,s.code,n)
186
+ ;return o.code=s.code,k("after:highlight",o),o}function E(e,t,r,s){
187
+ const c=Object.create(null);function l(){if(!N.keywords)return void M.addText(S)
188
+ ;let e=0;N.keywordPatternRe.lastIndex=0;let t=N.keywordPatternRe.exec(S),n=""
189
+ ;for(;t;){n+=S.substring(e,t.index)
190
+ ;const r=y.case_insensitive?t[0].toLowerCase():t[0],s=(i=r,N.keywords[i]);if(s){
191
+ const[e,i]=s
192
+ ;if(M.addText(n),n="",c[r]=(c[r]||0)+1,c[r]<=7&&(R+=i),e.startsWith("_"))n+=t[0];else{
193
+ const n=y.classNameAliases[e]||e;M.addKeyword(t[0],n)}}else n+=t[0]
194
+ ;e=N.keywordPatternRe.lastIndex,t=N.keywordPatternRe.exec(S)}var i
195
+ ;n+=S.substring(e),M.addText(n)}function d(){null!=N.subLanguage?(()=>{
196
+ if(""===S)return;let e=null;if("string"==typeof N.subLanguage){
197
+ if(!i[N.subLanguage])return void M.addText(S)
198
+ ;e=E(N.subLanguage,S,!0,k[N.subLanguage]),k[N.subLanguage]=e._top
199
+ }else e=x(S,N.subLanguage.length?N.subLanguage:null)
200
+ ;N.relevance>0&&(R+=e.relevance),M.addSublanguage(e._emitter,e.language)
201
+ })():l(),S=""}function u(e,t){let n=1;const i=t.length-1;for(;n<=i;){
202
+ if(!e._emit[n]){n++;continue}const i=y.classNameAliases[e[n]]||e[n],r=t[n]
203
+ ;i?M.addKeyword(r,i):(S=r,l(),S=""),n++}}function h(e,t){
204
+ return e.scope&&"string"==typeof e.scope&&M.openNode(y.classNameAliases[e.scope]||e.scope),
205
+ e.beginScope&&(e.beginScope._wrap?(M.addKeyword(S,y.classNameAliases[e.beginScope._wrap]||e.beginScope._wrap),
206
+ S=""):e.beginScope._multi&&(u(e.beginScope,t),S="")),N=Object.create(e,{parent:{
207
+ value:N}}),N}function p(e,t,i){let r=((e,t)=>{const n=e&&e.exec(t)
208
+ ;return n&&0===n.index})(e.endRe,i);if(r){if(e["on:end"]){const i=new n(e)
209
+ ;e["on:end"](t,i),i.isMatchIgnored&&(r=!1)}if(r){
210
+ for(;e.endsParent&&e.parent;)e=e.parent;return e}}
211
+ if(e.endsWithParent)return p(e.parent,t,i)}function f(e){
212
+ return 0===N.matcher.regexIndex?(S+=e[0],1):(I=!0,0)}function b(e){
213
+ const n=e[0],i=t.substring(e.index),r=p(N,e,i);if(!r)return ee;const s=N
214
+ ;N.endScope&&N.endScope._wrap?(d(),
215
+ M.addKeyword(n,N.endScope._wrap)):N.endScope&&N.endScope._multi?(d(),
216
+ u(N.endScope,e)):s.skip?S+=n:(s.returnEnd||s.excludeEnd||(S+=n),
217
+ d(),s.excludeEnd&&(S=n));do{
218
+ N.scope&&M.closeNode(),N.skip||N.subLanguage||(R+=N.relevance),N=N.parent
219
+ }while(N!==r.parent);return r.starts&&h(r.starts,e),s.returnEnd?0:n.length}
220
+ let m={};function w(i,s){const a=s&&s[0];if(S+=i,null==a)return d(),0
221
+ ;if("begin"===m.type&&"end"===s.type&&m.index===s.index&&""===a){
222
+ if(S+=t.slice(s.index,s.index+1),!o){const t=Error(`0 width match regex (${e})`)
223
+ ;throw t.languageName=e,t.badRule=m.rule,t}return 1}
224
+ if(m=s,"begin"===s.type)return(e=>{
225
+ const t=e[0],i=e.rule,r=new n(i),s=[i.__beforeBegin,i["on:begin"]]
226
+ ;for(const n of s)if(n&&(n(e,r),r.isMatchIgnored))return f(t)
227
+ ;return i.skip?S+=t:(i.excludeBegin&&(S+=t),
228
+ d(),i.returnBegin||i.excludeBegin||(S=t)),h(i,e),i.returnBegin?0:t.length})(s)
229
+ ;if("illegal"===s.type&&!r){
230
+ const e=Error('Illegal lexeme "'+a+'" for mode "'+(N.scope||"<unnamed>")+'"')
231
+ ;throw e.mode=N,e}if("end"===s.type){const e=b(s);if(e!==ee)return e}
232
+ if("illegal"===s.type&&""===a)return 1
233
+ ;if(A>1e5&&A>3*s.index)throw Error("potential infinite loop, way more iterations than matches")
234
+ ;return S+=a,a.length}const y=O(e)
235
+ ;if(!y)throw K(a.replace("{}",e)),Error('Unknown language: "'+e+'"')
236
+ ;const _=V(y);let v="",N=s||_;const k={},M=new g.__emitter(g);(()=>{const e=[]
237
+ ;for(let t=N;t!==y;t=t.parent)t.scope&&e.unshift(t.scope)
238
+ ;e.forEach((e=>M.openNode(e)))})();let S="",R=0,j=0,A=0,I=!1;try{
239
+ for(N.matcher.considerAll();;){
240
+ A++,I?I=!1:N.matcher.considerAll(),N.matcher.lastIndex=j
241
+ ;const e=N.matcher.exec(t);if(!e)break;const n=w(t.substring(j,e.index),e)
242
+ ;j=e.index+n}
243
+ return w(t.substring(j)),M.closeAllNodes(),M.finalize(),v=M.toHTML(),{
244
+ language:e,value:v,relevance:R,illegal:!1,_emitter:M,_top:N}}catch(n){
245
+ if(n.message&&n.message.includes("Illegal"))return{language:e,value:Y(t),
246
+ illegal:!0,relevance:0,_illegalBy:{message:n.message,index:j,
247
+ context:t.slice(j-100,j+100),mode:n.mode,resultSoFar:v},_emitter:M};if(o)return{
248
+ language:e,value:Y(t),illegal:!1,relevance:0,errorRaised:n,_emitter:M,_top:N}
249
+ ;throw n}}function x(e,t){t=t||g.languages||Object.keys(i);const n=(e=>{
250
+ const t={value:Y(e),illegal:!1,relevance:0,_top:c,_emitter:new g.__emitter(g)}
251
+ ;return t._emitter.addText(e),t})(e),r=t.filter(O).filter(N).map((t=>E(t,e,!1)))
252
+ ;r.unshift(n);const s=r.sort(((e,t)=>{
253
+ if(e.relevance!==t.relevance)return t.relevance-e.relevance
254
+ ;if(e.language&&t.language){if(O(e.language).supersetOf===t.language)return 1
255
+ ;if(O(t.language).supersetOf===e.language)return-1}return 0})),[o,a]=s,l=o
256
+ ;return l.secondBest=a,l}function w(e){let t=null;const n=(e=>{
257
+ let t=e.className+" ";t+=e.parentNode?e.parentNode.className:""
258
+ ;const n=g.languageDetectRe.exec(t);if(n){const t=O(n[1])
259
+ ;return t||(W(a.replace("{}",n[1])),
260
+ W("Falling back to no-highlight mode for this block.",e)),t?n[1]:"no-highlight"}
261
+ return t.split(/\s+/).find((e=>b(e)||O(e)))})(e);if(b(n))return
262
+ ;if(k("before:highlightElement",{el:e,language:n
263
+ }),e.children.length>0&&(g.ignoreUnescapedHTML||(console.warn("One of your code blocks includes unescaped HTML. This is a potentially serious security risk."),
264
+ console.warn("https://github.com/highlightjs/highlight.js/wiki/security"),
265
+ console.warn("The element with unescaped HTML:"),
266
+ console.warn(e)),g.throwUnescapedHTML))throw new J("One of your code blocks includes unescaped HTML.",e.innerHTML)
267
+ ;t=e;const i=t.textContent,s=n?m(i,{language:n,ignoreIllegals:!0}):x(i)
268
+ ;e.innerHTML=s.value,((e,t,n)=>{const i=t&&r[t]||n
269
+ ;e.classList.add("hljs"),e.classList.add("language-"+i)
270
+ })(e,n,s.language),e.result={language:s.language,re:s.relevance,
271
+ relevance:s.relevance},s.secondBest&&(e.secondBest={
272
+ language:s.secondBest.language,relevance:s.secondBest.relevance
273
+ }),k("after:highlightElement",{el:e,result:s,text:i})}let y=!1;function _(){
274
+ "loading"!==document.readyState?document.querySelectorAll(g.cssSelector).forEach(w):y=!0
275
+ }function O(e){return e=(e||"").toLowerCase(),i[e]||i[r[e]]}
276
+ function v(e,{languageName:t}){"string"==typeof e&&(e=[e]),e.forEach((e=>{
277
+ r[e.toLowerCase()]=t}))}function N(e){const t=O(e)
278
+ ;return t&&!t.disableAutodetect}function k(e,t){const n=e;s.forEach((e=>{
279
+ e[n]&&e[n](t)}))}
280
+ "undefined"!=typeof window&&window.addEventListener&&window.addEventListener("DOMContentLoaded",(()=>{
281
+ y&&_()}),!1),Object.assign(t,{highlight:m,highlightAuto:x,highlightAll:_,
282
+ highlightElement:w,
283
+ highlightBlock:e=>(X("10.7.0","highlightBlock will be removed entirely in v12.0"),
284
+ X("10.7.0","Please use highlightElement now."),w(e)),configure:e=>{g=Q(g,e)},
285
+ initHighlighting:()=>{
286
+ _(),X("10.6.0","initHighlighting() deprecated. Use highlightAll() now.")},
287
+ initHighlightingOnLoad:()=>{
288
+ _(),X("10.6.0","initHighlightingOnLoad() deprecated. Use highlightAll() now.")
289
+ },registerLanguage:(e,n)=>{let r=null;try{r=n(t)}catch(t){
290
+ if(K("Language definition for '{}' could not be registered.".replace("{}",e)),
291
+ !o)throw t;K(t),r=c}
292
+ r.name||(r.name=e),i[e]=r,r.rawDefinition=n.bind(null,t),r.aliases&&v(r.aliases,{
293
+ languageName:e})},unregisterLanguage:e=>{delete i[e]
294
+ ;for(const t of Object.keys(r))r[t]===e&&delete r[t]},
295
+ listLanguages:()=>Object.keys(i),getLanguage:O,registerAliases:v,
296
+ autoDetection:N,inherit:Q,addPlugin:e=>{(e=>{
297
+ e["before:highlightBlock"]&&!e["before:highlightElement"]&&(e["before:highlightElement"]=t=>{
298
+ e["before:highlightBlock"](Object.assign({block:t.el},t))
299
+ }),e["after:highlightBlock"]&&!e["after:highlightElement"]&&(e["after:highlightElement"]=t=>{
300
+ e["after:highlightBlock"](Object.assign({block:t.el},t))})})(e),s.push(e)}
301
+ }),t.debugMode=()=>{o=!1},t.safeMode=()=>{o=!0
302
+ },t.versionString="11.7.0",t.regex={concat:p,lookahead:d,either:f,optional:h,
303
+ anyNumberOfTimes:u};for(const t in A)"object"==typeof A[t]&&e.exports(A[t])
304
+ ;return Object.assign(t,A),t})({});return te}()
305
+ ;"object"==typeof exports&&"undefined"!=typeof module&&(module.exports=hljs);/*! `bash` grammar compiled for Highlight.js 11.7.0 */
306
+ (()=>{var e=(()=>{"use strict";return e=>{const s=e.regex,t={},n={begin:/\$\{/,
307
+ end:/\}/,contains:["self",{begin:/:-/,contains:[t]}]};Object.assign(t,{
308
+ className:"variable",variants:[{
309
+ begin:s.concat(/\$[\w\d#@][\w\d_]*/,"(?![\\w\\d])(?![$])")},n]});const a={
310
+ className:"subst",begin:/\$\(/,end:/\)/,contains:[e.BACKSLASH_ESCAPE]},i={
311
+ begin:/<<-?\s*(?=\w+)/,starts:{contains:[e.END_SAME_AS_BEGIN({begin:/(\w+)/,
312
+ end:/(\w+)/,className:"string"})]}},c={className:"string",begin:/"/,end:/"/,
313
+ contains:[e.BACKSLASH_ESCAPE,t,a]};a.contains.push(c);const o={begin:/\$?\(\(/,
314
+ end:/\)\)/,contains:[{begin:/\d+#[0-9a-f]+/,className:"number"},e.NUMBER_MODE,t]
315
+ },r=e.SHEBANG({binary:"(fish|bash|zsh|sh|csh|ksh|tcsh|dash|scsh)",relevance:10
316
+ }),l={className:"function",begin:/\w[\w\d_]*\s*\(\s*\)\s*\{/,returnBegin:!0,
317
+ contains:[e.inherit(e.TITLE_MODE,{begin:/\w[\w\d_]*/})],relevance:0};return{
318
+ name:"Bash",aliases:["sh"],keywords:{$pattern:/\b[a-z][a-z0-9._-]+\b/,
319
+ keyword:["if","then","else","elif","fi","for","while","in","do","done","case","esac","function"],
320
+ literal:["true","false"],
321
+ built_in:["break","cd","continue","eval","exec","exit","export","getopts","hash","pwd","readonly","return","shift","test","times","trap","umask","unset","alias","bind","builtin","caller","command","declare","echo","enable","help","let","local","logout","mapfile","printf","read","readarray","source","type","typeset","ulimit","unalias","set","shopt","autoload","bg","bindkey","bye","cap","chdir","clone","comparguments","compcall","compctl","compdescribe","compfiles","compgroups","compquote","comptags","comptry","compvalues","dirs","disable","disown","echotc","echoti","emulate","fc","fg","float","functions","getcap","getln","history","integer","jobs","kill","limit","log","noglob","popd","print","pushd","pushln","rehash","sched","setcap","setopt","stat","suspend","ttyctl","unfunction","unhash","unlimit","unsetopt","vared","wait","whence","where","which","zcompile","zformat","zftp","zle","zmodload","zparseopts","zprof","zpty","zregexparse","zsocket","zstyle","ztcp","chcon","chgrp","chown","chmod","cp","dd","df","dir","dircolors","ln","ls","mkdir","mkfifo","mknod","mktemp","mv","realpath","rm","rmdir","shred","sync","touch","truncate","vdir","b2sum","base32","base64","cat","cksum","comm","csplit","cut","expand","fmt","fold","head","join","md5sum","nl","numfmt","od","paste","ptx","pr","sha1sum","sha224sum","sha256sum","sha384sum","sha512sum","shuf","sort","split","sum","tac","tail","tr","tsort","unexpand","uniq","wc","arch","basename","chroot","date","dirname","du","echo","env","expr","factor","groups","hostid","id","link","logname","nice","nohup","nproc","pathchk","pinky","printenv","printf","pwd","readlink","runcon","seq","sleep","stat","stdbuf","stty","tee","test","timeout","tty","uname","unlink","uptime","users","who","whoami","yes"]
322
+ },contains:[r,e.SHEBANG(),l,o,e.HASH_COMMENT_MODE,i,{match:/(\/[a-z._-]+)+/},c,{
323
+ className:"",begin:/\\"/},{className:"string",begin:/'/,end:/'/},t]}}})()
324
+ ;hljs.registerLanguage("bash",e)})();/*! `shell` grammar compiled for Highlight.js 11.7.0 */
325
+ (()=>{var s=(()=>{"use strict";return s=>({name:"Shell Session",
326
+ aliases:["console","shellsession"],contains:[{className:"meta.prompt",
327
+ begin:/^\s{0,3}[/~\w\d[\]()@-]*[>%$#][ ]?/,starts:{end:/[^\\](?=\s*$)/,
328
+ subLanguage:"bash"}}]})})();hljs.registerLanguage("shell",s)})();/*! `plaintext` grammar compiled for Highlight.js 11.7.0 */
329
+ (()=>{var t=(()=>{"use strict";return t=>({name:"Plain text",
330
+ aliases:["text","txt"],disableAutodetect:!0})})()
331
+ ;hljs.registerLanguage("plaintext",t)})();/*! `json` grammar compiled for Highlight.js 11.7.0 */
332
+ (()=>{var e=(()=>{"use strict";return e=>{const a=["true","false","null"],n={
333
+ scope:"literal",beginKeywords:a.join(" ")};return{name:"JSON",keywords:{
334
+ literal:a},contains:[{className:"attr",begin:/"(\\.|[^\\"\r\n])*"(?=\s*:)/,
335
+ relevance:1.01},{match:/[{}[\],:]/,className:"punctuation",relevance:0
336
+ },e.QUOTE_STRING_MODE,n,e.C_NUMBER_MODE,e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE],
337
+ illegal:"\\S"}}})();hljs.registerLanguage("json",e)})();
@@ -0,0 +1,124 @@
1
+ // inspired by https://github.com/mperham/sidekiq JS code
2
+ //
3
+ // Live polls changes but won't refresh DOM if the payload is the same and will stop polling if
4
+ // user is selecting anything.
5
+
6
+ var livePollTimer = null;
7
+ var oldDOM = null;
8
+
9
+ // Check is there is any text selected in the Web-UI
10
+ // It drives me crazy when I'm selecting things in Sidekiq Web-UI and the page is refreshed
11
+ // This mitigates this problem for Karafka Web
12
+ function isAnyTextSelected() {
13
+ var text = "";
14
+
15
+ if (typeof window.getSelection != "undefined") {
16
+ text = window.getSelection().toString();
17
+ } else if (typeof document.selection != "undefined" && document.selection.type == "Text") {
18
+ text = document.selection.createRange().text;
19
+ }
20
+
21
+ return(text != "");
22
+ }
23
+
24
+ function bindPollingButtonClick() {
25
+ var selector = document.getElementById("live-poll");
26
+
27
+ if (selector == null) { return }
28
+
29
+ selector.addEventListener('click', handleLivePollingButtonClick);
30
+ }
31
+
32
+ function handleLivePollingButtonClick() {
33
+ toggleLivePollState();
34
+ setLivePollButton();
35
+ setPollingListener();
36
+ }
37
+
38
+ function toggleLivePollState() {
39
+ if (localStorage.karafkaLivePoll == "enabled") {
40
+ localStorage.karafkaLivePoll = "disabled";
41
+ } else {
42
+ localStorage.karafkaLivePoll = "enabled"
43
+ }
44
+ }
45
+
46
+ function setLivePollButton() {
47
+ selector = document.getElementById("live-poll");
48
+
49
+ if (selector == null) { return }
50
+
51
+ if (localStorage.karafkaLivePoll == "enabled") {
52
+ selector.textContent = selector.dataset.on;
53
+ selector.classList.add("btn-success");
54
+ selector.classList.remove("btn-secondary");
55
+ } else {
56
+ selector.textContent = selector.dataset.off;
57
+ selector.classList.add("btn-secondary");
58
+ selector.classList.remove("btn-success");
59
+ }
60
+ }
61
+
62
+ function checkResponse(resp) {
63
+ if (!resp.ok) {
64
+ throw response.error();
65
+ }
66
+ return resp
67
+ }
68
+
69
+ function replacePage(text) {
70
+ var new_parser = new DOMParser();
71
+ var new_doc = new_parser.parseFromString(text, "text/html");
72
+ var new_content = new_doc.getElementById('content');
73
+
74
+ // Do not modify if exactly the same content
75
+ if (oldDOM == new_content.innerHTML) { return }
76
+
77
+ document.getElementById("content").replaceWith(new_content)
78
+
79
+ oldDOM = new_content.innerHTML;
80
+
81
+ addListeners();
82
+ }
83
+
84
+ function showError(error) {
85
+ console.error(error)
86
+ }
87
+
88
+ function scheduleLivePoll() {
89
+ if (oldDOM == null) {
90
+ oldDOM = document.getElementById("content").innerHTML;
91
+ }
92
+
93
+ let ti = parseInt(localStorage.karafkaTimeInterval) || 5000;
94
+ livePollTimer = setTimeout(livePollCallback, ti);
95
+ }
96
+
97
+ function livePollCallback() {
98
+ clearTimeout(livePollTimer);
99
+ livePollTimer = null;
100
+
101
+ if (isAnyTextSelected()) {
102
+ setPollingListener();
103
+ return;
104
+ }
105
+
106
+ fetch(window.location.href)
107
+ .then(checkResponse)
108
+ .then(resp => resp.text())
109
+ .then(replacePage)
110
+ .catch(showError)
111
+ .finally(setPollingListener)
112
+ }
113
+
114
+ function setPollingListener() {
115
+ selector = document.getElementById("live-poll");
116
+
117
+ if (localStorage.karafkaLivePoll == "disabled" || selector == null) {
118
+ clearTimeout(livePollTimer);
119
+ livePollTimer = null;
120
+ } else {
121
+ clearTimeout(livePollTimer);
122
+ scheduleLivePoll();
123
+ }
124
+ }
@@ -0,0 +1 @@
1
+ !function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports):"function"==typeof define&&define.amd?define(["exports"],t):t((e=e||self).timeago={})}(this,function(e){"use strict";var r=["second","minute","hour","day","week","month","year"];var a=["秒","分钟","小时","天","周","个月","年"];function t(e,t){n[e]=t}function i(e){return n[e]||n.en_US}var n={},f=[60,60,24,7,365/7/12,12];function o(e){return e instanceof Date?e:!isNaN(e)||/^\d+$/.test(e)?new Date(parseInt(e)):(e=(e||"").trim().replace(/\.\d+/,"").replace(/-/,"/").replace(/-/,"/").replace(/(\d)T(\d)/,"$1 $2").replace(/Z/," UTC").replace(/([+-]\d\d):?(\d\d)/," $1$2"),new Date(e))}function d(e,t){for(var n=e<0?1:0,r=e=Math.abs(e),a=0;e>=f[a]&&a<f.length;a++)e/=f[a];return(0===(a*=2)?9:1)<(e=Math.floor(e))&&(a+=1),t(e,a,r)[n].replace("%s",e.toString())}function l(e,t){return((t?o(t):new Date)-o(e))/1e3}var s="timeago-id";function h(e){return parseInt(e.getAttribute(s))}var p={},v=function(e){clearTimeout(e),delete p[e]};function m(e,t,n,r){v(h(e));var a=r.relativeDate,i=r.minInterval,o=l(t,a);e.innerText=d(o,n);var u,c=setTimeout(function(){m(e,t,n,r)},Math.min(1e3*Math.max(function(e){for(var t=1,n=0,r=Math.abs(e);e>=f[n]&&n<f.length;n++)e/=f[n],t*=f[n];return r=(r%=t)?t-r:t,Math.ceil(r)}(o),i||1),2147483647));p[c]=0,u=c,e.setAttribute(s,u)}t("en_US",function(e,t){if(0===t)return["just now","right now"];var n=r[Math.floor(t/2)];return 1<e&&(n+="s"),[e+" "+n+" ago","in "+e+" "+n]}),t("zh_CN",function(e,t){if(0===t)return["刚刚","片刻后"];var n=a[~~(t/2)];return[e+" "+n+"前",e+" "+n+"后"]}),e.cancel=function(e){e?v(h(e)):Object.keys(p).forEach(v)},e.format=function(e,t,n){return d(l(e,n&&n.relativeDate),i(t))},e.register=t,e.render=function(e,t,n){var r=e.length?e:[e];return r.forEach(function(e){m(e,e.getAttribute("datetime"),i(t),n||{})}),r},Object.defineProperty(e,"__esModule",{value:!0})});
@@ -0,0 +1,106 @@
1
+ body {
2
+ background-color: #f5f6fe;
3
+ font-size: 95%;
4
+ color: #393939;
5
+ }
6
+
7
+ #content {
8
+ display: none;
9
+ }
10
+
11
+ .container {
12
+ max-width: 1170px;
13
+ }
14
+
15
+ .navbar {
16
+ background-color: #4051b5;
17
+ }
18
+
19
+ .count {
20
+ font-weight: bold;
21
+ color: #4550e6;
22
+ }
23
+
24
+ .badge {
25
+ font-weight: normal;
26
+ }
27
+
28
+ .bg-light {
29
+ color: #393939;
30
+ }
31
+
32
+ .stat {
33
+ font-size: 125%;
34
+ }
35
+
36
+ .status-row-quiet {
37
+ border-left: rgb(255, 193, 7);
38
+ }
39
+
40
+ .status-row-quieting {
41
+ border-left: rgb(255, 193, 7);
42
+ }
43
+
44
+ .status-row-stopping {
45
+ border-left: rgb(255, 193, 7);
46
+ }
47
+
48
+ .status-row-stopped {
49
+ border-left: rgb(220, 53, 69);
50
+ opacity: 50%;
51
+ }
52
+
53
+ .pagination > li > a {
54
+ background-color: white;
55
+ color: #4051b5;
56
+ }
57
+
58
+ .pagination > li > a:focus,
59
+ .pagination > li > a:hover,
60
+ .pagination > li > span:focus,
61
+ .pagination > li > span:hover {
62
+ color: #5a5a5a;
63
+ background-color: #eee;
64
+ border-color: #ddd;
65
+ }
66
+
67
+ .pagination > .active > a {
68
+ color: white !important;
69
+ background-color: #4051b5 !Important;
70
+ border: solid 1px #4051b5 !Important;
71
+ }
72
+
73
+ .pagination > .active > a:hover {
74
+ background-color: #4051b5 !Important;
75
+ border: solid 1px #4051b5;
76
+ }
77
+
78
+ #summary .card-group .card ul {
79
+ padding-left: 0;
80
+ }
81
+
82
+ .breadcrumb {
83
+ background-color: #eaecf4;
84
+ padding: .75rem 1rem;
85
+ }
86
+
87
+ a {
88
+ text-decoration: none;
89
+ }
90
+
91
+ a:hover {
92
+ text-decoration: underline;
93
+ }
94
+
95
+ code.wrapped {
96
+ display: block;
97
+ white-space: pre-wrap;
98
+ }
99
+
100
+ #counters a {
101
+ color: inherit;
102
+ }
103
+
104
+ #content .error-message {
105
+ max-width: 700px;
106
+ }