Module: Gitlab::Asciidoc

Defined in:
lib/gitlab/asciidoc.rb,
lib/gitlab/asciidoc/html5_converter.rb,
lib/gitlab/asciidoc/include_processor.rb,
lib/gitlab/asciidoc/mermaid_block_processor.rb,
lib/gitlab/asciidoc/syntax_highlighter/html_pipeline_adapter.rb

Overview

Parser/renderer for the AsciiDoc format that uses Asciidoctor and filters the resulting HTML through HTML pipeline filters.

Defined Under Namespace

Modules: SyntaxHighlighter Classes: Html5Converter, IncludeProcessor, MermaidBlockProcessor

Constant Summary collapse

MAX_INCLUDE_DEPTH =
5
MAX_INCLUDES =
32
DEFAULT_ADOC_ATTRS =
{
    'showtitle' => true,
    'sectanchors' => true,
    'idprefix' => 'user-content-',
    'idseparator' => '-',
    'env' => 'gitlab',
    'env-gitlab' => '',
    'source-highlighter' => 'gitlab-html-pipeline',
    'icons' => 'font',
    'outfilesuffix' => '.adoc',
    'max-include-depth' => MAX_INCLUDE_DEPTH,
    # This feature is disabled because it relies on File#read to read the file.
    # If we want to enable this feature we will need to provide a "GitLab compatible" implementation.
    # This attribute is typically used to share common config (skinparam...) across all PlantUML diagrams.
    # The value can be a path or a URL.
    'kroki-plantuml-include!' => '',
    # This feature is disabled because it relies on the local file system to save diagrams retrieved from the Kroki server.
    'kroki-fetch-diagram!' => ''
}.freeze

Class Method Summary collapse

Class Method Details

.path_attrs(path) ⇒ Object



38
39
40
41
42
43
44
45
46
47
48
49
# File 'lib/gitlab/asciidoc.rb', line 38

def self.path_attrs(path)
  return {} unless path

  {
    # Set an empty docname if the path is a directory
    'docname' => if path[-1] == ::File::SEPARATOR
                   ''
                 else
                   ::File.basename(path, '.*')
                 end
  }
end

.render(input, context) ⇒ Object

Public: Converts the provided Asciidoc markup into HTML.

input - the source text in Asciidoc format context - :commit, :project, :ref, :requested_path



56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
# File 'lib/gitlab/asciidoc.rb', line 56

def self.render(input, context)
  extensions = proc do
    include_processor ::Gitlab::Asciidoc::IncludeProcessor.new(context)
    block ::Gitlab::Asciidoc::MermaidBlockProcessor
    ::Gitlab::Kroki.formats(Gitlab::CurrentSettings).each do |name|
      block ::AsciidoctorExtensions::KrokiBlockProcessor, name
    end
  end

  extra_attrs = path_attrs(context[:requested_path])
  asciidoc_opts = { safe: :secure,
                    backend: :gitlab_html5,
                    attributes: DEFAULT_ADOC_ATTRS
                                    .merge(extra_attrs)
                                    .merge({
                                               # Define the Kroki server URL from the settings.
                                               # This attribute cannot be overridden from the AsciiDoc document.
                                               'kroki-server-url' => Gitlab::CurrentSettings.kroki_url,
                                               'allow-uri-read' => Gitlab::CurrentSettings.wiki_asciidoc_allow_uri_includes
                                           }),
                    extensions: extensions }

  context[:pipeline] = :ascii_doc
  context[:max_includes] = [MAX_INCLUDES, context[:max_includes]].compact.min

  Gitlab::Plantuml.configure

  html = ::Asciidoctor.convert(input, asciidoc_opts)
  html = Banzai.render(html, context)
  html.html_safe
end