Commit dd445481 authored by Brett Walker's avatar Brett Walker

Add support for Rel-License microformat

We now support license attribution.
Add a `rel="license"` to a hand-coded HTML link.
An example of such a link can be found on
https://creativecommons.org/choose/

Changelog: added
parent f8c832e2
......@@ -998,6 +998,8 @@ Here's a sample audio clip:
### Inline HTML
> Allowing `rel="license"` [introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/20857) in GitLab 14.6.
To see the second example of Markdown rendered in HTML,
[view it in GitLab](https://gitlab.com/gitlab-org/gitlab/-/blob/master/doc/user/markdown.md#inline-html).
......@@ -1006,6 +1008,7 @@ You can also use raw HTML in your Markdown, and it usually works pretty well.
See the documentation for HTML::Pipeline's [SanitizationFilter](https://github.com/jch/html-pipeline/blob/v2.12.3/lib/html/pipeline/sanitization_filter.rb#L42)
class for the list of allowed HTML tags and attributes. In addition to the default
`SanitizationFilter` allowlist, GitLab allows `span`, `abbr`, `details` and `summary` elements.
`rel="license"` is allowed on links to support the [Rel-License microformat](https://microformats.org/wiki/rel-license) and license attribution.
```html
<dl>
......
......@@ -59,6 +59,9 @@ module Banzai
def remove_rel
lambda do |env|
if env[:node_name] == 'a'
# we allow rel="license" to support the Rel-license microformat
# http://microformats.org/wiki/rel-license
unless env[:node].attribute('rel')&.value == 'license'
env[:node].remove_attribute('rel')
end
end
......@@ -66,4 +69,5 @@ module Banzai
end
end
end
end
end
......@@ -112,7 +112,9 @@ module Banzai
def add_nofollow!(uri, node)
if SCHEMES.include?(uri&.scheme)
license = true if node.attribute('rel')&.value == 'license'
node.set_attribute('rel', 'nofollow noreferrer noopener')
node.kwattr_append('rel', 'license') if license
node.set_attribute('target', '_blank')
end
end
......
......@@ -191,4 +191,15 @@ RSpec.describe Banzai::Filter::ExternalLinkFilter do
end
end
end
context 'for links that have `rel=license`' do
let(:doc) { filter %q(<a rel="license" href="http://example.com">rel-license</a>) }
it_behaves_like 'an external link with rel attribute'
it 'maintains rel license' do
expect(doc.at_css('a')).to have_attribute('rel')
expect(doc.at_css('a')['rel']).to include 'license'
end
end
end
......@@ -115,6 +115,11 @@ RSpec.describe Banzai::Filter::SanitizationFilter do
expect(filter(act).to_html).to eq exp
end
it 'allows `rel=license` in links' do
exp = act = '<a rel="license" href="http://example.com">rel-license</a>'
expect(filter(act).to_html).to eq exp
end
it 'allows `data-math-style` attribute on `code` and `pre` elements' do
html = <<-HTML
<pre class="code" data-math-style="inline">something</pre>
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment