From a21286cf706a5e623f19ec787c99135d8de6cb04 Mon Sep 17 00:00:00 2001 From: kwall Date: Thu, 1 Feb 2024 12:57:52 +0000 Subject: [PATCH] Fix #31: Enable anchor links for kroxylicious.io Signed-off-by: kwall --- Gemfile | 1 + Gemfile.lock | 10 ++++++++++ _config.yml | 1 + _layouts/index.html | 2 +- _layouts/overview.html | 6 +++--- _layouts/use-cases.html | 4 ++-- _use_cases/encryption-at-rest.markdown | 12 +++++++----- css/code.css | 20 ++++++++++++++++++++ overview.markdown | 1 + use-cases.markdown | 1 + 10 files changed, 47 insertions(+), 11 deletions(-) diff --git a/Gemfile b/Gemfile index 79f3ac0..0519bf6 100644 --- a/Gemfile +++ b/Gemfile @@ -13,6 +13,7 @@ group :jekyll_plugins do gem "jekyll-feed", "~> 0.12" gem "jekyll-sass-converter" gem "jekyll-seo-tag" + gem "jekyll-toc" end # Windows and JRuby does not include zoneinfo files, so bundle the tzinfo-data gem diff --git a/Gemfile.lock b/Gemfile.lock index f6153fe..62042dd 100644 --- a/Gemfile.lock +++ b/Gemfile.lock @@ -39,6 +39,9 @@ GEM sass-embedded (~> 1.54) jekyll-seo-tag (2.8.0) jekyll (>= 3.8, < 5.0) + jekyll-toc (0.18.0) + jekyll (>= 3.9) + nokogiri (~> 1.12) jekyll-watch (2.2.1) listen (~> 3.0) kramdown (2.4.0) @@ -50,9 +53,15 @@ GEM rb-fsevent (~> 0.10, >= 0.10.3) rb-inotify (~> 0.9, >= 0.9.10) mercenary (0.4.0) + mini_portile2 (2.8.5) + nokogiri (1.16.0) + mini_portile2 (~> 2.8.2) + racc (~> 1.4) pathutil (0.16.2) forwardable-extended (~> 2.6) public_suffix (5.0.3) + racc (1.7.3) + racc (1.7.3-java) rake (13.1.0) rb-fsevent (0.11.2) rb-inotify (0.10.1) @@ -94,6 +103,7 @@ DEPENDENCIES jekyll-feed (~> 0.12) jekyll-sass-converter jekyll-seo-tag + jekyll-toc tzinfo (>= 1, < 3) tzinfo-data wdm (~> 0.1.1) diff --git a/_config.yml b/_config.yml index da208ba..a491bd8 100644 --- a/_config.yml +++ b/_config.yml @@ -31,6 +31,7 @@ plugins: - jekyll-feed - jekyll-sass-converter - jekyll-seo-tag + - jekyll-toc # Exclude from processing. # The following items will not be processed, by default. diff --git a/_layouts/index.html b/_layouts/index.html index f9994eb..c61f9dc 100644 --- a/_layouts/index.html +++ b/_layouts/index.html @@ -36,4 +36,4 @@

Kroxylicious transparently inje - \ No newline at end of file + diff --git a/_layouts/overview.html b/_layouts/overview.html index b9ea23e..500e869 100644 --- a/_layouts/overview.html +++ b/_layouts/overview.html @@ -1,5 +1,5 @@ ---- layout: default +toc: true ---
@@ -7,10 +7,10 @@
- {{ content | markdownify }} + {{ content | markdownify | inject_anchors }}
- \ No newline at end of file + diff --git a/_layouts/use-cases.html b/_layouts/use-cases.html index ae55fc6..56877ef 100644 --- a/_layouts/use-cases.html +++ b/_layouts/use-cases.html @@ -1,5 +1,6 @@ --- layout: default +toc: true ---
@@ -9,8 +10,7 @@
{% for use_case in site.use_cases %} -

{{ use_case.name }}

-

{{ use_case.content | markdownify }}

+

{{ use_case.content | markdownify | inject_anchors}}

{% endfor %}
diff --git a/_use_cases/encryption-at-rest.markdown b/_use_cases/encryption-at-rest.markdown index f35a966..aefacae 100644 --- a/_use_cases/encryption-at-rest.markdown +++ b/_use_cases/encryption-at-rest.markdown @@ -2,7 +2,9 @@ name: Encryption At Rest --- -## Why +### Encryption At Rest + +#### Why Apache Kafka® does not directly support any form of encryption for data stored within a broker. This means that the contents of records sent to Apache Kafka are stored in the clear on the broker's disks. Anyone with sufficient access, such as a Kafka Administrator @@ -20,7 +22,7 @@ data is now residing in the clear on the file systems of the service provider. |:-----------------------------------------------------------------:| | *Problem: Plain text records readable by the Kafka Admins* | -### Isn't TLS sufficient? +##### Isn't TLS sufficient? TLS encrypts the content _in transit_. It means that someone using a network sniffer cannot intercept what is being sent over the wire between the application and the Kafka Broker. However, once the network packets arrive at the broker, @@ -29,7 +31,7 @@ of the broker and in the clear when the data is written to the file system. TLS does not change the problem. -### Isn't storage volume encryption an answer? +##### Isn't storage volume encryption an answer? With storage volume encryption, the contents of the volume are encrypted with a single key. This approach provides some mitigations. If the storage device is stolen or the storage device hijacked and attached to an attacker's computer, the attacker won't have @@ -41,7 +43,7 @@ to be able to read the data, including the Kafka confidential records. Storage volume encryption doesn't really solve the problem. -### Can't the applications encrypt/decrypt the data? +##### Can't the applications encrypt/decrypt the data? It is possible for producing applications to encrypt data before sending it to Kafka, and for consuming applications to decrypt it again. With this approach the brokers never possess the records in the clear and as they don't have encryption keys, they cannot @@ -64,7 +66,7 @@ of a design flaw or bug are significant (confidentiality breach). Having the applications encrypt/decrypt data themselves, whilst technically feasible, is not really a tenable solution at the scale required for most enterprises. -# Kroxylicious Topic Encryption +#### Kroxylicious Topic Encryption The Kroxylicious Topic Encryption feature offers a solution to the problem. The proxy takes the responsibility to encrypt and decrypt the messages. In this way, the Kafka Brokers never see the plain text content of diff --git a/css/code.css b/css/code.css index 05f6b0b..c12dbc5 100644 --- a/css/code.css +++ b/css/code.css @@ -148,3 +148,23 @@ .highlight .w { color: #bbbbbb; } + +h2>a.anchor, h3>a.anchor, h4>a.anchor, h5>a.anchor, h6>a.anchor { + display: block; + margin-left: -1.5ex; + position: absolute; + text-decoration: none !important; + visibility: hidden; + z-index: 2; + transition: visibility 1s; +} + +h2>a.anchor::before, h3>a.anchor::before, h4>a.anchor::before, h5>a.anchor::before, h6>a.anchor::before { + content: "\00A7"; + display: block; +} + +h2:hover>a.anchor, h2>a.anchor:hover, h3:hover>a.anchor, h3>a.anchor:hover, h4:hover>a.anchor, h4>a.anchor:hover, h5:hover>a.anchor, h5>a.anchor:hover, h6:hover>a.anchor, h6>a.anchor:hover { + visibility: visible; +} + diff --git a/overview.markdown b/overview.markdown index 920a943..4bd37fb 100644 --- a/overview.markdown +++ b/overview.markdown @@ -2,6 +2,7 @@ layout: overview title: Overview permalink: /overview/ +toc: true --- This page provides an overview of how Kroxylicious works. For more details, please refer to the [documentation](./kroxylicious). diff --git a/use-cases.markdown b/use-cases.markdown index ef20a7f..91b3cae 100644 --- a/use-cases.markdown +++ b/use-cases.markdown @@ -2,5 +2,6 @@ layout: use-cases title: Use Cases permalink: /use-cases/ +toc: true ---