Home

Awesome

<!-- markdownlint-disable MD013 MD033 MD041 --> <!-- header-intro-start --> <!-- header-intro-end --> <!-- header-logo-start --> <div align="center"> <a href="https://megalinter.io" target="blank" title="Visit MegaLinter Web Site"> <img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/images/megalinter-banner.png" alt="MegaLinter" min-height="200px"> </a> </div> <!-- header-logo-end --> <!-- mega-linter-title-start -->

MegaLinter, by OX Security

<!-- mega-linter-title-end --> <!-- mega-linter-badges-start -->

GitHub release Docker Pulls Downloads/week GitHub stars MegaLinter codecov

<!-- gh-dependents-info-used-by-start -->

Generated by github-dependents-info<!-- gh-dependents-info-used-by-end --> Secured with Trivy GitHub contributors GitHub Sponsors PRs Welcome Tweet

<!-- mega-linter-badges-end --> <!-- welcome-phrase-start -->

MegaLinter is an Open-Source tool for CI/CD workflows that analyzes the consistency of your code, IAC, configuration, and scripts in your repository sources, to ensure all your projects sources are clean and formatted whatever IDE/toolbox is used by their developers, powered by OX Security.

Supporting 62 languages, 23 formats, 20 tooling formats and ready to use out of the box, as a GitHub action or any CI system, highly configurable and free for all uses.

MegaLinter has native integrations with many of the major CI/CD tools of the market.

GitHub Gitlab Azure Bitbucket Jenkins Drone Concourse Docker SARIF Grafana

<!-- welcome-phrase-end -->

MegaLinter Presentation GIF

Upgrade to MegaLinter v8 :)

Upgrade to v8 Video

<!-- online-doc-start -->

Before going below, see Online Documentation Web Site which has a much easier user navigation than this README

<!-- online-doc-end --> <!-- table-of-contents-start -->

Table of Contents

<!-- table-of-contents-end -->

Why MegaLinter

Projects need to contain clean code, in order to avoid technical debt, that makes evolutive maintenance harder and time consuming.

By using code formatters and code linters, you ensure that your code base is easier to read and respects best practices, from the kick-off to each step of the project lifecycle

Not all developers have the good habit to use linters in their IDEs, making code reviews harder and longer to process

By using MegaLinter, you'll enjoy the following benefits for you and your team:

<!-- quick-start-section-start --> <!-- markdown-headers --- title: Quick Start with MegaLinter description: Setup MegaLinter in 5 minutes thanks to its assisted installation tool --- -->

Quick Start

Runner Install

Notes:

<!-- quick-start-section-end --> <!-- supported-linters-section-start --> <!-- markdown-headers --- title: List of the 100+ supported linters embedded in MegaLinter description: Full list of all linters for all languages and formats that are available in MegaLinter --- -->

Supported Linters

All linters are integrated in the MegaLinter docker image, which is frequently upgraded with their latest versions

<!-- languages-section-start--> <!-- linters-table-start -->

Languages

<!-- -->LanguageLinterAdditional
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/bash.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->BASHbash-exec<br/>BASH_EXEC
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/bash.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->BASHshellcheck<br/>BASH_SHELLCHECKGitHub stars sarif
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/bash.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->BASHshfmt<br/>BASH_SHFMTGitHub stars formatter
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/c.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->Ccpplint<br/>C_CPPLINTGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/c.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->Cclang-format<br/>C_CLANG_FORMATGitHub stars autofix
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/clojure.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->CLOJUREclj-kondo<br/>CLOJURE_CLJ_KONDOGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/clojure.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->CLOJUREcljstyle<br/>CLOJURE_CLJSTYLEGitHub stars autofix
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/coffee.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->COFFEEcoffeelint<br/>COFFEE_COFFEELINTGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/cpp.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->C++ (CPP)cpplint<br/>CPP_CPPLINTGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/cpp.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->C++ (CPP)clang-format<br/>CPP_CLANG_FORMATGitHub stars autofix
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/csharp.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->C# (CSHARP)dotnet-format<br/>CSHARP_DOTNET_FORMATGitHub stars formatter
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/csharp.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->C# (CSHARP)csharpier<br/>CSHARP_CSHARPIERGitHub stars formatter
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/csharp.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->C# (CSHARP)roslynator<br/>CSHARP_ROSLYNATORGitHub stars formatter
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/dart.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->DARTdartanalyzer<br/>DART_DARTANALYZERdowngraded version GitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/go.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->GOgolangci-lint<br/>GO_GOLANGCI_LINTGitHub stars autofix
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/go.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->GOrevive<br/>GO_REVIVEGitHub stars sarif
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/groovy.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->GROOVYnpm-groovy-lint<br/>GROOVY_NPM_GROOVY_LINTGitHub stars autofix sarif
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/java.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->JAVAcheckstyle<br/>JAVA_CHECKSTYLEGitHub stars sarif
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/java.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->JAVApmd<br/>JAVA_PMDGitHub stars sarif
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/javascript.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->JAVASCRIPTeslint<br/>JAVASCRIPT_ESGitHub stars autofix sarif
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/javascript.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->JAVASCRIPTstandard<br/>JAVASCRIPT_STANDARDGitHub stars autofix
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/javascript.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->JAVASCRIPTprettier<br/>JAVASCRIPT_PRETTIERGitHub stars formatter
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/jsx.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->JSXeslint<br/>JSX_ESLINTGitHub stars autofix sarif
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/kotlin.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->KOTLINktlint<br/>KOTLIN_KTLINTGitHub stars autofix sarif
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/kotlin.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->KOTLINdetekt<br/>KOTLIN_DETEKTGitHub stars sarif
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/lua.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->LUAluacheck<br/>LUA_LUACHECKGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/lua.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->LUAselene<br/>LUA_SELENEGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/lua.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->LUAstylua<br/>LUA_STYLUAGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/default.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->MAKEFILEcheckmake<br/>MAKEFILE_CHECKMAKEGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/perl.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->PERLperlcritic<br/>PERL_PERLCRITICGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/php.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->PHPphpcs<br/>PHP_PHPCSGitHub stars sarif
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/php.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->PHPphpstan<br/>PHP_PHPSTANdowngraded version GitHub stars sarif
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/php.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->PHPpsalm<br/>PHP_PSALMGitHub stars sarif
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/php.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->PHPphplint<br/>PHP_PHPLINTGitHub stars sarif
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/php.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->PHPphp-cs-fixer<br/>PHP_PHPCSFIXERGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/powershell.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->POWERSHELLpowershell<br/>POWERSHELL_POWERSHELLGitHub stars autofix
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/powershell.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->POWERSHELLpowershell_formatter<br/>POWERSHELL_POWERSHELL_FORMATTERGitHub stars formatter
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/python.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->PYTHONpylint<br/>PYTHON_PYLINTGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/python.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->PYTHONblack<br/>PYTHON_BLACKGitHub stars formatter
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/python.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->PYTHONflake8<br/>PYTHON_FLAKE8GitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/python.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->PYTHONisort<br/>PYTHON_ISORTGitHub stars formatter
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/python.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->PYTHONbandit<br/>PYTHON_BANDITGitHub stars sarif
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/python.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->PYTHONmypy<br/>PYTHON_MYPYGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/python.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->PYTHONpyright<br/>PYTHON_PYRIGHTGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/python.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->PYTHONruff<br/>PYTHON_RUFFGitHub stars autofix sarif
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/r.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->Rlintr<br/>R_LINTRGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/raku.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->RAKUraku<br/>RAKU_RAKUGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/ruby.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->RUBYrubocop<br/>RUBY_RUBOCOPGitHub stars autofix
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/rust.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->RUSTclippy<br/>RUST_CLIPPYGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/salesforce.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->SALESFORCEsfdx-scanner-apex<br/>SALESFORCE_SFDX_SCANNER_APEXGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/salesforce.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->SALESFORCEsfdx-scanner-aura<br/>SALESFORCE_SFDX_SCANNER_AURAGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/salesforce.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->SALESFORCEsfdx-scanner-lwc<br/>SALESFORCE_SFDX_SCANNER_LWCGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/salesforce.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->SALESFORCElightning-flow-scanner<br/>SALESFORCE_LIGHTNING_FLOW_SCANNERGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/scala.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->SCALAscalafix<br/>SCALA_SCALAFIXGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/sql.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->SQLsqlfluff<br/>SQL_SQLFLUFFGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/sql.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->SQLtsqllint<br/>SQL_TSQLLINTGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/swift.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->SWIFTswiftlint<br/>SWIFT_SWIFTLINTGitHub stars autofix
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/tsx.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->TSXeslint<br/>TSX_ESLINTGitHub stars autofix sarif
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/typescript.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->TYPESCRIPTeslint<br/>TYPESCRIPT_ESGitHub stars autofix sarif
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/typescript.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->TYPESCRIPTts-standard<br/>TYPESCRIPT_STANDARDGitHub stars autofix
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/typescript.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->TYPESCRIPTprettier<br/>TYPESCRIPT_PRETTIERGitHub stars formatter
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/vbdotnet.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->Visual Basic .NET (VBDOTNET)dotnet-format<br/>VBDOTNET_DOTNET_FORMATGitHub stars formatter

Formats

<!-- -->FormatLinterAdditional
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/css.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->CSSstylelint<br/>CSS_STYLELINTGitHub stars autofix
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/env.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->ENVdotenv-linter<br/>ENV_DOTENV_LINTERGitHub stars autofix
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/graphql.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->GRAPHQLgraphql-schema-linter<br/>GRAPHQL_GRAPHQL_SCHEMA_LINTERGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/html.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->HTMLdjlint<br/>HTML_DJLINTGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/html.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->HTMLhtmlhint<br/>HTML_HTMLHINTGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/json.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->JSONjsonlint<br/>JSON_JSONLINTGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/json.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->JSONeslint-plugin-jsonc<br/>JSON_ESLINT_PLUGIN_JSONCGitHub stars autofix sarif
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/json.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->JSONv8r<br/>JSON_V8RGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/json.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->JSONprettier<br/>JSON_PRETTIERGitHub stars formatter
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/json.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->JSONnpm-package-json-lint<br/>JSON_NPM_PACKAGE_JSON_LINTGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/latex.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->LATEXchktex<br/>LATEX_CHKTEX
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/markdown.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->MARKDOWNmarkdownlint<br/>MARKDOWN_MARKDOWNLINTGitHub stars formatter
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/markdown.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->MARKDOWNremark-lint<br/>MARKDOWN_REMARK_LINTGitHub stars formatter
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/markdown.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->MARKDOWNmarkdown-link-check<br/>MARKDOWN_MARKDOWN_LINK_CHECKdowngraded version GitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/markdown.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->MARKDOWNmarkdown-table-formatter<br/>MARKDOWN_MARKDOWN_TABLE_FORMATTERGitHub stars formatter
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/protobuf.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->PROTOBUFprotolint<br/>PROTOBUF_PROTOLINTGitHub stars autofix
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/rst.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->RSTrst-lint<br/>RST_RST_LINTGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/rst.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->RSTrstcheck<br/>RST_RSTCHECKGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/rst.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->RSTrstfmt<br/>RST_RSTFMTformatter
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/xml.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->XMLxmllint<br/>XML_XMLLINTautofix
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/yaml.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->YAMLprettier<br/>YAML_PRETTIERGitHub stars formatter
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/yaml.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->YAMLyamllint<br/>YAML_YAMLLINTGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/yaml.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->YAMLv8r<br/>YAML_V8RGitHub stars

Tooling formats

<!-- -->Tooling formatLinterAdditional
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/default.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->ACTIONactionlint<br/>ACTION_ACTIONLINTGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/ansible.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->ANSIBLEansible-lint<br/>ANSIBLE_ANSIBLE_LINTGitHub stars sarif
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/default.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->APIspectral<br/>API_SPECTRALGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/arm.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->ARMarm-ttk<br/>ARM_ARM_TTKGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/default.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->BICEPbicep_linter<br/>BICEP_BICEP_LINTERGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/cloudformation.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->CLOUDFORMATIONcfn-lint<br/>CLOUDFORMATION_CFN_LINTGitHub stars sarif
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/dockerfile.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->DOCKERFILEhadolint<br/>DOCKERFILE_HADOLINTGitHub stars sarif
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/editorconfig.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->EDITORCONFIGeditorconfig-checker<br/>EDITORCONFIG_EDITORCONFIG_CHECKERGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/gherkin.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->GHERKINgherkin-lint<br/>GHERKIN_GHERKIN_LINTGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/kubernetes.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->KUBERNETESkubeconform<br/>KUBERNETES_KUBECONFORMGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/kubernetes.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->KUBERNETEShelm<br/>KUBERNETES_HELMGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/kubernetes.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->KUBERNETESkubescape<br/>KUBERNETES_KUBESCAPEdowngraded version GitHub stars sarif
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/puppet.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->PUPPETpuppet-lint<br/>PUPPET_PUPPET_LINTGitHub stars autofix
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/snakemake.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->SNAKEMAKEsnakemake<br/>SNAKEMAKE_LINTGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/snakemake.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->SNAKEMAKEsnakefmt<br/>SNAKEMAKE_SNAKEFMTGitHub stars formatter
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/tekton.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->TEKTONtekton-lint<br/>TEKTON_TEKTON_LINTGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/terraform.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->TERRAFORMtflint<br/>TERRAFORM_TFLINTGitHub stars sarif
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/terraform.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->TERRAFORMterrascan<br/>TERRAFORM_TERRASCANdowngraded version GitHub stars sarif
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/terraform.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->TERRAFORMterragrunt<br/>TERRAFORM_TERRAGRUNTGitHub stars autofix
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/terraform.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->TERRAFORMterraform-fmt<br/>TERRAFORM_TERRAFORM_FMTGitHub stars formatter

Other

<!-- -->Code quality checkerLinterAdditional
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/copypaste.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->COPYPASTEjscpd<br/>COPYPASTE_JSCPDGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/default.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->REPOSITORYcheckov<br/>REPOSITORY_CHECKOVGitHub stars sarif
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/default.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->REPOSITORYdevskim<br/>REPOSITORY_DEVSKIMGitHub stars sarif
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/default.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->REPOSITORYdustilock<br/>REPOSITORY_DUSTILOCKGitHub stars sarif
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/default.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->REPOSITORYgit_diff<br/>REPOSITORY_GIT_DIFFGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/default.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->REPOSITORYgitleaks<br/>REPOSITORY_GITLEAKSGitHub stars sarif
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/default.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->REPOSITORYgrype<br/>REPOSITORY_GRYPEdowngraded version GitHub stars sarif
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/default.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->REPOSITORYkics<br/>REPOSITORY_KICSGitHub stars sarif
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/default.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->REPOSITORYls-lint<br/>REPOSITORY_LS_LINTGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/default.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->REPOSITORYsecretlint<br/>REPOSITORY_SECRETLINTGitHub stars sarif
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/default.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->REPOSITORYsemgrep<br/>REPOSITORY_SEMGREPGitHub stars sarif
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/default.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->REPOSITORYsyft<br/>REPOSITORY_SYFTGitHub stars sarif
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/default.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->REPOSITORYtrivy<br/>REPOSITORY_TRIVYGitHub stars sarif
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/default.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->REPOSITORYtrivy-sbom<br/>REPOSITORY_TRIVY_SBOMGitHub stars sarif
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/default.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->REPOSITORYtrufflehog<br/>REPOSITORY_TRUFFLEHOGGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/spell.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->SPELLcspell<br/>SPELL_CSPELLGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/spell.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->SPELLproselint<br/>SPELL_PROSELINTGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/spell.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->SPELLvale<br/>SPELL_VALEGitHub stars
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/spell.ico" alt="" height="32px" class="megalinter-icon"></a> <!-- linter-icon -->SPELLlychee<br/>SPELL_LYCHEEGitHub stars
<!-- linters-table-end --> <!-- supported-linters-section-end --> <!-- installation-section-start --> <!-- markdown-headers --- title: MegaLinter Installation Guide description: How to install MegaLinter on Github Actions, Gitlab CI, Azure Pipelines, Jenkins, Concourse, Drone CI or to run locally --- -->

Installation

<!-- install-assisted-section-start --> <!-- markdown-headers --- title: Install mega-linter with automated setup description: Setup MegaLinter in 5 minutes thanks to its assisted installation tool --- -->

Assisted installation

Just run npx mega-linter-runner --install at the root of your repository and answer questions, it will generate ready to use configuration files for MegaLinter :)

Runner Install

<!-- install-assisted-section-end --> <!-- install-version-section-start --> <!-- markdown-headers --- title: Selecting a MegaLinter version to use description: You can use latest release or beta version of MegaLinter, know the differences ! --- -->

Which version to use ?

The following instructions examples are using latest MegaLinter stable version (v8 , always corresponding to the latest release)

You can also use beta version (corresponding to the content of main branch)

<!-- install-version-section-end --> <!-- install-github-section-start --> <!-- markdown-headers --- title: Install MegaLinter on GitHub Actions description: Manual instructions to setup MegaLinter in a GitHub Action Workflow --- -->

GitHub Action

  1. Create a new file in your repository called .github/workflows/mega-linter.yml
  2. Copy the example workflow from below into that new file, no extra configuration required
  3. Commit that file to a new branch
  4. Open up a pull request and observe the action working
  5. Enjoy your more stable, and cleaner code base

NOTES:

In your repository you should have a .github/workflows folder with GitHub Action similar to below:

<details> <summary>This file should have this code</summary>
---
# MegaLinter GitHub Action configuration file
# More info at https://megalinter.io
name: MegaLinter

on:
  # Trigger mega-linter at every push. Action will also be visible from Pull Requests to main
  push: # Comment this line to trigger action only on pull-requests (not recommended if you don't pay for GH Actions)
  pull_request:
    branches: [master, main]

env: # Comment env block if you don't want to apply fixes
  # Apply linter fixes configuration
  APPLY_FIXES: all # When active, APPLY_FIXES must also be defined as environment variable (in github/workflows/mega-linter.yml or other CI tool)
  APPLY_FIXES_EVENT: pull_request # Decide which event triggers application of fixes in a commit or a PR (pull_request, push, all)
  APPLY_FIXES_MODE: commit # If APPLY_FIXES is used, defines if the fixes are directly committed (commit) or posted in a PR (pull_request)

concurrency:
  group: ${{ github.ref }}-${{ github.workflow }}
  cancel-in-progress: true

jobs:
  megalinter:
    name: MegaLinter
    runs-on: ubuntu-latest
    permissions:
      # Give the default GITHUB_TOKEN write permission to commit and push, comment issues & post new PR
      # Remove the ones you do not need
      contents: write
      issues: write
      pull-requests: write
    steps:
      # Git Checkout
      - name: Checkout Code
        uses: actions/checkout@v4
        with:
          token: ${{ secrets.PAT || secrets.GITHUB_TOKEN }}
          fetch-depth: 0 # If you use VALIDATE_ALL_CODEBASE = true, you can remove this line to improve performances

      # MegaLinter
      - name: MegaLinter
        id: ml
        # You can override MegaLinter flavor used to have faster performances
        # More info at https://megalinter.io/flavors/
        uses: oxsecurity/megalinter@v8
        env:
          # All available variables are described in documentation
          # https://megalinter.io/configuration/
          VALIDATE_ALL_CODEBASE: ${{ github.event_name == 'push' && github.ref == 'refs/heads/main' }} # Validates all source when push on main, else just the git diff with main. Override with true if you always want to lint all sources
          GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
          # ADD YOUR CUSTOM ENV VARIABLES HERE OR DEFINE THEM IN A FILE .mega-linter.yml AT THE ROOT OF YOUR REPOSITORY
          # DISABLE: COPYPASTE,SPELL # Uncomment to disable copy-paste and spell checks

      # Upload MegaLinter artifacts
      - name: Archive production artifacts
        if: success() || failure()
        uses: actions/upload-artifact@v4
        with:
          name: MegaLinter reports
          path: |
            megalinter-reports
            mega-linter.log

      # Create pull request if applicable (for now works only on PR from same repository, not from forks)
      - name: Create Pull Request with applied fixes
        id: cpr
        if: steps.ml.outputs.has_updated_sources == 1 && (env.APPLY_FIXES_EVENT == 'all' || env.APPLY_FIXES_EVENT == github.event_name) && env.APPLY_FIXES_MODE == 'pull_request' && (github.event_name == 'push' || github.event.pull_request.head.repo.full_name == github.repository) && !contains(github.event.head_commit.message, 'skip fix')
        uses: peter-evans/create-pull-request@v6
        with:
          token: ${{ secrets.PAT || secrets.GITHUB_TOKEN }}
          commit-message: "[MegaLinter] Apply linters automatic fixes"
          title: "[MegaLinter] Apply linters automatic fixes"
          labels: bot
      - name: Create PR output
        if: steps.ml.outputs.has_updated_sources == 1 && (env.APPLY_FIXES_EVENT == 'all' || env.APPLY_FIXES_EVENT == github.event_name) && env.APPLY_FIXES_MODE == 'pull_request' && (github.event_name == 'push' || github.event.pull_request.head.repo.full_name == github.repository) && !contains(github.event.head_commit.message, 'skip fix')
        run: |
          echo "Pull Request Number - ${{ steps.cpr.outputs.pull-request-number }}"
          echo "Pull Request URL - ${{ steps.cpr.outputs.pull-request-url }}"

      # Push new commit if applicable (for now works only on PR from same repository, not from forks)
      - name: Prepare commit
        if: steps.ml.outputs.has_updated_sources == 1 && (env.APPLY_FIXES_EVENT == 'all' || env.APPLY_FIXES_EVENT == github.event_name) && env.APPLY_FIXES_MODE == 'commit' && github.ref != 'refs/heads/main' && (github.event_name == 'push' || github.event.pull_request.head.repo.full_name == github.repository) && !contains(github.event.head_commit.message, 'skip fix')
        run: sudo chown -Rc $UID .git/
      - name: Commit and push applied linter fixes
        if: steps.ml.outputs.has_updated_sources == 1 && (env.APPLY_FIXES_EVENT == 'all' || env.APPLY_FIXES_EVENT == github.event_name) && env.APPLY_FIXES_MODE == 'commit' && github.ref != 'refs/heads/main' && (github.event_name == 'push' || github.event.pull_request.head.repo.full_name == github.repository) && !contains(github.event.head_commit.message, 'skip fix')
        uses: stefanzweifel/git-auto-commit-action@v4
        with:
          branch: ${{ github.event.pull_request.head.ref || github.head_ref || github.ref }}
          commit_message: "[MegaLinter] Apply linters fixes"
          commit_user_name: megalinter-bot
          commit_user_email: nicolas.vuillamy@ox.security
</details> <!-- install-github-section-end --> <!-- install-gitlab-section-start --> <!-- markdown-headers --- title: Install MegaLinter on Gitlab CI description: Manual instructions to setup MegaLinter as a Gitlab Pipeline job --- -->

GitLab CI

Manual setup

Create or update .gitlab-ci.yml file at the root of your repository

# MegaLinter GitLab CI job configuration file
# More info at https://megalinter.io/

mega-linter:
  stage: test
  # You can override MegaLinter flavor used to have faster performances
  # More info at https://megalinter.io/flavors/
  image: oxsecurity/megalinter:v8
  script: [ "true" ] # if script: ["true"] doesn't work, you may try ->  script: [ "/bin/bash /entrypoint.sh" ]
  variables:
    # All available variables are described in documentation
    # https://megalinter.io/configuration/
    DEFAULT_WORKSPACE: $CI_PROJECT_DIR
    # ADD YOUR CUSTOM ENV VARIABLES HERE TO OVERRIDE VALUES OF .mega-linter.yml AT THE ROOT OF YOUR REPOSITORY
  artifacts:
    when: always
    paths:
      - megalinter-reports
    expire_in: 1 week

Create a Gitlab access token and define it in a variable GITLAB_ACCESS_TOKEN_MEGALINTER in the project CI/CD masked variables. Make sure your token (e.g. if a project token) as the appropriate role for commenting a merge request (at least developer).

config-gitlab-access-token

Screenshot

Using R2Devops

R2Devops Logo

Our friends at R2Devops have packaged a Gitlab-CI MegaLinter workflow on their open-source templates marketplace, and it can post MegaLinter results in Gitlab Code Quality Reports !

Screenshot

<!-- install-gitlab-section-end --> <!-- install-azure-section-start --> <!-- markdown-headers --- title: Install MegaLinter on Azure Pipelines description: Manual instructions to setup MegaLinter as an Azure Pipelines job --- -->

Azure Pipelines

Use the following Azure Pipelines YAML template

You can configure a build validation branch policy against a single repository or across all repositories. If you configure across all repositories then your pipeline is stored in a central repository.

Single Repository

Add the following to an azure-pipelines.yaml file within your code repository:

  # Run MegaLinter to detect linting and security issues
  - job: MegaLinter
    pool:
      vmImage: ubuntu-latest
    steps:
      # Checkout repo
      - checkout: self

      # Pull MegaLinter docker image
      - script: docker pull oxsecurity/megalinter:v8
        displayName: Pull MegaLinter

      # Run MegaLinter
      - script: |
          docker run -v $(System.DefaultWorkingDirectory):/tmp/lint \
            --env-file <(env | grep -e SYSTEM_ -e BUILD_ -e TF_ -e AGENT_) \
            -e SYSTEM_ACCESSTOKEN=$(System.AccessToken) \
            -e GIT_AUTHORIZATION_BEARER=$(System.AccessToken) \
            oxsecurity/megalinter:v8
        displayName: Run MegaLinter

      # Upload MegaLinter reports
      - task: PublishPipelineArtifact@1
        condition: succeededOrFailed()
        displayName: Upload MegaLinter reports
        inputs:
          targetPath: "$(System.DefaultWorkingDirectory)/megalinter-reports/"
          artifactName: MegaLinterReport

Central Repository

Add the following to an azure-pipelines.yaml file within a separate repository e.g. 'MegaLinter' repository:

# Run MegaLinter to detect linting and security issues

trigger: none

pool:
  vmImage: ubuntu-latest

variables:
  repoName: $[ replace(split(variables['System.PullRequest.SourceRepositoryURI'], '/')[6], '%20', ' ') ]

steps:
  # Checkout triggering repo
  - checkout: git://$(System.TeamProject)/$(repoName)@$(System.PullRequest.SourceBranch)
    displayName: Checkout Triggering Repository

  # Pull MegaLinter docker image
  - script: docker pull oxsecurity/megalinter:v8
    displayName: Pull MegaLinter

  # Run MegaLinter
  - script: |
      docker run -v $(System.DefaultWorkingDirectory):/tmp/lint \
        --env-file <(env | grep -e SYSTEM_ -e BUILD_ -e TF_ -e AGENT_) \
        -e SYSTEM_ACCESSTOKEN=$(System.AccessToken) \
        -e GIT_AUTHORIZATION_BEARER=$(System.AccessToken) \
        oxsecurity/megalinter:v8
    displayName: Run MegaLinter

  # Upload MegaLinter reports
  - task: PublishPipelineArtifact@1
    condition: succeededOrFailed()
    displayName: MegaLinter Report
    inputs:
      targetPath: $(System.DefaultWorkingDirectory)/megalinter-reports/
      artifactName: MegaLinterReport

Pull Request Comments

To benefit from Pull Request comments, please follow configuration instructions

Detailed Tutorial

You can also follow this detailed tutorial by DonKoning

<!-- install-azure-section-end --> <!-- install-bitbucket-section-start --> <!-- markdown-headers --- title: Install MegaLinter on Bitbucket Pipelines description: Manual instructions to setup MegaLinter as a Bitbucket Pipelines job --- -->

Bitbucket Pipelines

  1. Create a bitbucket-pipelines.yml file on the root directory of your repository

  2. Copy and paste the following template or add the step to your existing pipeline.

image: atlassian/default-image:3
pipelines:
  default:
    - parallel:
      - step:
          name: Run MegaLinter
          image: oxsecurity/megalinter:v8
          script:
            - export DEFAULT_WORKSPACE=$BITBUCKET_CLONE_DIR && bash /entrypoint.sh
          artifacts:
            -  megalinter-reports/**
<!-- install-bitbucket-section-end --> <!-- install-jenkins-section-start --> <!-- markdown-headers --- title: Install MegaLinter on Jenkins description: Manual instructions to setup MegaLinter as a Jenkins job --- -->

Jenkins

Add the following stage in your Jenkinsfile

You may activate File.io reporter or E-mail reporter to access detailed logs and fixed source

// Lint with MegaLinter: https://megalinter.io/
stage('MegaLinter') {
    agent {
        docker {
            image 'oxsecurity/megalinter:v8'
            args "-u root -e VALIDATE_ALL_CODEBASE=true -v ${WORKSPACE}:/tmp/lint --entrypoint=''"
            reuseNode true
        }
    }
    steps {
        sh '/entrypoint.sh'
    }
    post {
        always {
            archiveArtifacts allowEmptyArchive: true, artifacts: 'mega-linter.log,megalinter-reports/**/*', defaultExcludes: false, followSymlinks: false
        }
    }
}

CloudBees themselves made a nice tutorial about how to use MegaLinter with Jenkins !

<div style="text-align:center"><iframe width="560" height="315" src="https://www.youtube.com/embed/KhkNf2tQ3hM" title="YouTube video player" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture" allowfullscreen></iframe></div> <!-- install-jenkins-section-end --> <!-- install-concourse-section-start --> <!-- markdown-headers --- title: Install MegaLinter on Concourse description: Manual instructions to setup MegaLinter as a Concourse job --- -->

Concourse

Pipeline step

Use the following job.step in your pipeline template

Note: make sure you have job.plan.get step which gets repo containing your repository as shown in example

---

  - name: linting
    plan:
      - get: repo
      - task: linting
        config:
          platform: linux
          image_resource:
            type: docker-image
            source:
              repository: oxsecurity/megalinter
              tag: v8
          inputs:
            - name: repo
          run:
            path: bash
            args:
            - -cxe
            - |
              cd repo
              export DEFAULT_WORKSPACE=$(pwd)
              bash -ex /entrypoint.sh
              ## doing this because concourse doesn't work as other CI systems
          # params:
            # PARALLEL: true
            # DISABLE: SPELL
            # APPLY_FIXES: all
            # DISABLE_ERRORS: true
            # VALIDATE_ALL_CODEBASE: true

OR

Use it as reusable task

Create reusable concourse task which can be used with multiple pipelines

  1. Create task file task-linting.yaml
---
platform: linux
image_resource:
  type: docker-image
  source:
    repository: oxsecurity/megalinter
    tag: v8

inputs:
- name: repo

## uncomment this if you want reports as task output
# output:
# - name: reports
#   path: repo/megalinter-reports

run:
  path: bash
  args:
  - -cxe
  - |
    cd repo
    export DEFAULT_WORKSPACE=$(pwd)
    bash -ex /entrypoint.sh
  1. Use that task-linting.yaml task in pipeline

Note:

  1. make sure task-linting.yaml is available in that repo input at root

  2. task output is not shown here

resources:

  - name: linting
    plan:
      - get: repo
      - task: linting
        file: repo/task-linting.yaml
        # params:
        #   PARALLEL: true
        #   DISABLE: SPELL
        #   APPLY_FIXES: all
        #   DISABLE_ERRORS: true
        #   VALIDATE_ALL_CODEBASE: true
<!-- install-concourse-section-end --> <!-- install-drone-section-start --> <!-- markdown-headers --- title: Install MegaLinter on Drone CI description: Manual instructions to setup MegaLinter as a Drone CI job --- -->

Drone CI

Warning: Drone CI support is experimental and is undergoing heavy modifications (see issue #2047).

  1. Create a .drone.yml file on the root directory of your repository

  2. Copy and paste the following template:

kind: pipeline
type: docker
name: MegaLinter

workspace:
  path: /tmp/lint

steps:

- name: megalinter
  image: oxsecurity/megalinter:v8
  environment:
    DEFAULT_WORKSPACE: /tmp/lint

This uses the Drone CI docker runner, so it's needed to install and configure it beforehand on your Drone CI server.

(Optional) Adjusting trigger rules

The Drone CI workflow should trigger automatically for every scenario (push, pull request, sync…) however, you can optionally change this behavior by changing the trigger. For example:

kind: pipeline
type: docker
name: MegaLinter

workspace:
  path: /tmp/lint

steps:

- name: megalinter
  image: oxsecurity/megalinter:v8
  environment:
    DEFAULT_WORKSPACE: /tmp/lint

trigger:
  event:
  - push

The workflow above should only trigger on push, not on any other situation. For more information about how to configure Drone CI trigger rules, click here.

<!-- install-drone-section-end --> <!-- install-docker-section-start --> <!-- markdown-headers --- title: Run MegaLinter as a Docker image description: Manual instructions to run MegaLinter as a docker image --- -->

Docker container

You can also run megalinter with its Docker container, just execute this command:

docker run --rm -v /var/run/docker.sock:/var/run/docker.sock:rw -v $(pwd):/tmp/lint:rw oxsecurity/megalinter:v8

No extra arguments are needed, however, megalinter will lint all of the files inside the /tmp/lint folder, so it may be needed to configure your tool of choice to use the /tmp/lint folder as workspace. This can also be changed:

Example:

docker run --rm -v /var/run/docker.sock:/var/run/docker.sock:rw -v $(pwd):/example/folder:rw oxsecurity/megalinter:v8

<!-- install-docker-section-end --> <!-- install-locally-section-start --> <!-- markdown-headers --- title: Run MegaLinter locally on your computer description: Manual instructions to run MegaLinter locally on your computer --- -->

Run MegaLinter locally

Version Downloads/week Downloads/total

You can use mega-linter-runner to locally run MegaLinter with the same configuration defined in .mega-linter.yml file

See mega-linter-runner installation instructions

Example

npx mega-linter-runner --flavor salesforce -e "'ENABLE=DOCKERFILE,MARKDOWN,YAML'" -e 'SHOW_ELAPSED_TIME=true'

Note: You can also use such command line in your custom CI/CD pipelines

<!-- install-locally-section-end --> <!-- installation-section-end --> <!-- configuration-section-start --> <!-- markdown-headers --- title: MegaLinter configuration Guide description: List of all configuration variables that can be used to customize the use of MegaLinter (activation, filtering, auto-update, pre-post commands…) --- -->

Configuration

<!-- config-file-section-start --> <!-- markdown-headers --- title: MegaLinter configuration file description: Use config file with auto-completion to customize MegaLinter behaviour --- -->

.mega-linter.yml file

MegaLinter configuration variables are defined in a .mega-linter.yml file at the root of the repository or with environment variables. You can see an example config file in this repo: .mega-linter.yml

Configuration is assisted with autocompletion and validation in most commonly used IDEs, thanks to JSON schema stored on schemastore.org

You can also define variables as environment variables.

Assisted configuration

<!-- config-file-section-end --> <!-- config-variables-section-start --> <!-- markdown-headers --- title: All Megalinter configuration common variables description: List of common variables that you can use to customize MegaLinter behaviour --- -->

Common variables

ENV VARDefault ValueNotes
ADDITIONAL_EXCLUDED_DIRECTORIES[]List of additional excluded directory basenames. they're excluded at any nested level.
APPLY_FIXESnoneActivates formatting and autofix (more info)
CLEAR_REPORT_FOLDERfalseFlag to clear files from report folder (usually megalinter-reports) before starting the linting process
CONFIG_PROPERTIES_TO_APPEND[]List of configuration properties to append their values (instead of replacing them) in case of using EXTENDS.
DEFAULT_BRANCHHEADDeprecated: The name of the repository's default branch.
DEFAULT_WORKSPACE/tmp/lintThe location containing files to lint if you are running locally.
DISABLE_ERRORSfalseFlag to have the linter complete with exit code 0 even if errors were detected.
DISABLE<!-- -->List of disabled descriptors keys (more info)
DISABLE_LINTERS<!-- -->List of disabled linters keys (more info)
DISABLE_ERRORS_LINTERS<!-- -->List of enabled but not blocking linters keys (more info)
ENABLE<!-- -->List of enabled descriptors keys (more info)
ENABLE_LINTERS<!-- -->List of enabled linters keys (more info)
EXCLUDED_DIRECTORIES[…many values…]List of excluded directory basenames. they're excluded at any nested level.
EXTENDS<!-- -->Base mega-linter.yml config file(s) to extend local configuration from. Can be a single URL or a list of .mega-linter.yml config files URLs. Later files take precedence.
FAIL_IF_MISSING_LINTER_IN_FLAVORfalseIf set to true, MegaLinter fails if a linter is missing in the selected flavor
FAIL_IF_UPDATED_SOURCESfalseIf set to true, MegaLinter fails if a linter or formatter has autofixed sources, even if there are no errors
FILTER_REGEX_EXCLUDEnoneRegular expression defining which files will be excluded from linting (more info) .ex: .*src/test.*)
FILTER_REGEX_INCLUDEallRegular expression defining which files will be processed by linters (more info) .ex: .*src/.*)
FLAVOR_SUGGESTIONStrueProvides suggestions about different MegaLinter flavors to use to improve runtime performances
FORMATTERS_DISABLE_ERRORStrueFormatter errors will be reported as errors (and not warnings) if this variable is set to false
GIT_AUTHORIZATION_BEARER<!-- -->If set, calls git with Authorization: Bearer+value
GITHUB_WORKSPACE<!-- -->Base directory for REPORT_OUTPUT_FOLDER, for user-defined linter rules location, for location of linted files if DEFAULT_WORKSPACE isn't set
IGNORE_GENERATED_FILESfalseIf set to true, MegaLinter will skip files containing @generated marker but without @not-generated marker (more info at https://generated.at)
IGNORE_GITIGNORED_FILEStrueIf set to true, MegaLinter will skip files ignored by git using .gitignore file
JAVASCRIPT_DEFAULT_STYLEstandardJavascript default style to check/apply. standard,prettier
LINTER_RULES_PATH.github/lintersDirectory for all linter configuration rules.<br/> Can be a local folder or a remote URL (ex: https://raw.githubusercontent.com/some_org/some_repo/mega-linter-rules )
LOG_FILEmega-linter.logThe file name for outputting logs. All output is sent to the log file regardless of LOG_LEVEL. Use none to not generate this file.
LOG_LEVELINFOHow much output the script will generate to the console. One of INFO, DEBUG, WARNING or ERROR.
MARKDOWN_DEFAULT_STYLEmarkdownlintMarkdown default style to check/apply. markdownlint,remark-lint
MEGALINTER_CONFIG.mega-linter.ymlName of MegaLinter configuration file. Can be defined remotely, in that case set this environment variable with the remote URL of .mega-linter.yml config file
MEGALINTER_FILES_TO_LINT[]Comma-separated list of files to analyze. Using this variable will bypass other file listing methods
PARALLELtrueProcess linters in parallel to improve overall MegaLinter performance. If true, linters of same language or formats are grouped in the same parallel process to avoid lock issues if fixing the same files
PARALLEL_PROCESS_NUMBER<!-- -->All available cores are used by default. If there are too many, you need to decrease the number of used cores in order to enhance performances (example: 4)
PLUGINS[]List of plugin urls to install and run during MegaLinter run
POST_COMMANDS[]Custom bash commands to run after linters
PRE_COMMANDS[]Custom bash commands to run before linters
PRINT_ALPACAtrueEnable printing alpaca image to console
PRINT_ALL_FILESfalseDisplay all files analyzed by the linter instead of only the number
REPORT_OUTPUT_FOLDER${GITHUB_WORKSPACE}/megalinter-reportsDirectory for generating report files. Set to none to not generate reports
SECURED_ENV_VARIABLES[]Additional list of secured environment variables to hide when calling linters.
SECURED_ENV_VARIABLES_DEFAULTMegaLinter & CI platforms sensitive variablesList of secured environment variables to hide when calling linters. Default list. This is not recommended to override this variable, use SECURED_ENV_VARIABLES
SHOW_ELAPSED_TIMEfalseDisplays elapsed time in reports
SHOW_SKIPPED_LINTERStrueDisplays all disabled linters mega-linter could have run
SKIP_CLI_LINT_MODES[]Comma-separated list of cli_lint_modes. To use if you want to skip linters with some CLI lint modes (ex: file,project). Available values: file,cli_lint_mode,project.
TYPESCRIPT_DEFAULT_STYLEstandardTypescript default style to check/apply. standard,prettier
VALIDATE_ALL_CODEBASEtrueWill parse the entire repository and find all files to validate across all types. NOTE: When set to false, only new or edited files will be parsed for validation.
<!-- config-variables-section-end --> <!-- config-activation-section-start --> <!-- markdown-headers --- title: Configure activation and deactivation of linters within MegaLinter description: You can enable, disable, make not blocking, allow a minimum number of errors... --- -->

Activation and deactivation

MegaLinter have all linters enabled by default, but allows to enable only some, or disable only some

Examples:

ENABLE: JAVASCRIPT,GROOVY
DISABLE_LINTERS: JAVASCRIPT_STANDARD
DISABLE_ERRORS_LINTERS: REPOSITORY_DEVSKIM
DISABLE: PHP
DISABLE_LINTERS:
  - PHP_PHPSTAN
  - PHP_PSALM
<!-- config-activation-section-end --> <!-- config-filtering-section-start --> <!-- markdown-headers --- title: Configure filtering of files analyzed by MegaLinter description: Exclude files from linting --- -->

Filter linted files

If you need to lint only a folder or exclude some files from linting, you can use optional environment parameters FILTER_REGEX_INCLUDE and FILTER_REGEX_EXCLUDE You can apply filters to a single linter by defining variable <LINTER_KEY>_FILTER_REGEX_INCLUDE and <LINTER_KEY>_FILTER_REGEX_EXCLUDE

Examples:

Warning: not applicable with linters using CLI lint mode project (see details)

<!-- config-filtering-section-end --> <!-- config-apply-fixes-section-start --> <!-- markdown-headers --- title: Configure auto-fixing of issues by MegaLinter description: Use MegaLinter to auto apply corrections on your repository files --- -->

Apply fixes

Mega-linter is able to apply fixes provided by linters. To use this capability, you need 3 env variables defined at top level

Only for GitHub Action Workflow file if you use it:

Apply fixes issues

You may see github permission errors, or workflows not run on the new commit.

To solve these issues, you can apply one of the following solutions.

Notes

megalinter-reports/
<!-- config-apply-fixes-section-end --> <!-- config-linters-section-start --> <!-- markdown-headers --- title: Linter scoped variables description: Every linters has its own variables that can be customized --- -->

Linter specific variables

See variables related to a single linter behavior in linters documentations

<!-- config-linters-section-end --> <!-- config-precommands-section-start --> <!-- markdown-headers --- title: Configure custom commands to run before linters description: Customize your MegaLinter run by installing linters extensions with npm, pip, or even raw bash before linters are run --- -->

Pre-commands

MegaLinter can run custom commands before running linters (for example, installing an plugin required by one of the linters you use)

Example in .mega-linter.yml config file

PRE_COMMANDS:
  - command: npm install eslint-plugin-whatever
    cwd: root        # Will be run at the root of MegaLinter docker image
    secured_env: true  # True by default, but if defined to false, no global variable will be hidden (for example if you need GITHUB_TOKEN)
  - command: echo "pre-test command has been called"
    cwd: workspace   # Will be run at the root of the workspace (usually your repository root)
    continue_if_failed: False  # Will stop the process if command is failed (return code > 0)
  - command: pip install flake8-cognitive-complexity
    venv: flake8 # Will be run within flake8 python virtualenv. There is one virtualenv per python-based linter, with the same name
  - command: export MY_OUTPUT_VAR="my output var" && export MY_OUTPUT_VAR2="my output var2"
    output_variables: ["MY_OUTPUT_VAR","MY_OUTPUT_VAR2"] # Will collect the values of output variables and update MegaLinter own ENV context
  - command: echo "Some command called before loading MegaLinter plugins"
    cwd: workspace   # Will be run at the root of the workspace (usually your repository root)
    continue_if_failed: False  # Will stop the process if command is failed (return code > 0)
    tag: before_plugins # Tag indicating that the command will be run before loading plugins
PropertyDescriptionDefault value
commandCommand line to runMandatory
cwdDirectory where to run the command (workspace or root)workspace
secured_envApply filtering of secured env variables before calling the command (default true)<br/>Be careful if you disable it !true
continue_if_failedIf set to false, stop MegaLinter process in case of command failuretrue
venvIf set, runs the command into the related python venv<!-- -->
output_variablesENV variables to get from output after running the commands, and store in MegaLinter ENV context, so they can be reused in next commands[]
tagTag defining at which commands entry point the command will be run (available tags: before_plugins)<!-- -->
<!-- config-precommands-section-end --> <!-- config-postcommands-section-start --> <!-- markdown-headers --- title: Configure custom commands to run after linters description: Customize your MegaLinter run by running commands after linters are run --- -->

Post-commands

MegaLinter can run custom commands after running linters (for example, running additional tests)

Example in .mega-linter.yml config file

POST_COMMANDS:
  - command: npm run test
    cwd: "workspace"   # Will be run at the root of the workspace (usually your repository root)
    continue_if_failed: False  # Will stop the process if command is failed (return code > 0)
<!-- config-postcommands-section-end --> <!-- config-variables-security-section-start --> <!-- markdown-headers --- title: Configure environment variables security with MegaLinter description: Hide from linter executables the environment variables that can contain secrets --- -->

Environment variables security

Secured env variables

MegaLinter runs on a docker image and calls the linters via command line to gather their results.

If you run it from your CI/CD pipelines, the docker image may have access to your environment variables, that can contain secrets defined in CI/CD variables.

As it can be complicated to trust the authors of all the open-source linters, MegaLinter removes variables from the environment used to call linters.

Thanks to this feature, you only need to trust MegaLinter and its internal python dependencies, but there is no need to trust all the linters that are used !

You can add secured variables to the default list using configuration property SECURED_ENV_VARIABLES in .mega-linter.yml or in an environment variable (priority is given to ENV variables above .mega-linter.yml property).

Values can be:

Environment variables are secured for each command line called (linters, plugins, sarif formatter...) except for PRE_COMMANDS , ONLY if you define secured_env: false in the command.

Secured configuration examples

SECURED_ENV_VARIABLES:
  - MY_SECRET_TOKEN
  - ANOTHER_VAR_CONTAINING_SENSITIVE_DATA
  - OX_API_KEY
  - (MY.*VAR)  # Regex format
SECURED_ENV_VARIABLES=MY_SECRET_TOKEN,ANOTHER_VAR_CONTAINING_SENSITIVE_DATA,OX_API_KEY

Default secured variables

If you override SECURED_ENV_VARIABLES_DEFAULT, it replaces the default list, so it's better to only define SECURED_ENV_VARIABLES to add them to the default list !

SECURED_ENV_VARIABLES_DEFAULT contains:

Unhide variables for linters

You can configure exceptions for a specific linter by defining (linter-key)_UNSECURED_ENV_VARIABLES.

Variable names in this list won't be hidden to the linter commands.

TERRAFORM_TFLINT_UNSECURED_ENV_VARIABLES:
  - GITHUB_TOKEN # Can contain string only, not regex
<!-- config-variables-security-section-end --> <!-- config-cli-lint-mode-section-start --> <!-- markdown-headers --- title: Override the way linters are called by MegaLinter description: Cli lint mode can be list_of_files, project or files --- -->

CLI lint mode

Each linter is pre-configured to use a default lint mode, which are visible in the MegaLinter documentation (example). The possible values are:

You can override the CLI_LINT_MODE by using a configuration variable for each linter (see linters documentation).

Allowing file or list_of_files to be overridden to project is mostly for workarounds. For example, some linters have a problem finding their config file when the current folder isn't the repository's root folder.

Special considerations:

<!-- config-cli-lint-mode-section-end --> <!-- configuration-section-end --> <!-- reporters-section-start --> <!-- markdown-headers --- title: MegaLinter Reporters Guide description: "List of all available reporters: Text, SARIF, TAP, GitHub, Gitlab, Azure, IDE, File.io, Email, JSON…" --- -->

Reporters

MegaLinter can generate various reports that you can activate / deactivate and customize

ReporterDescriptionDefault
Text filesGenerates One log file by linter + suggestions for fixes that can not be automatedActive
SARIF (beta)Generates an aggregated SARIF output fileInactive
GitHub Pull Request commentsMegaLinter posts a comment on the PR with a summary of lint results, and links to detailed logsActive if GitHub Action
Gitlab Merge Request commentsMega-Linter posts a comment on the MR with a summary of lint results, and links to detailed logsActive if in Gitlab CI
Azure Pipelines Pull Request commentsMega-Linter posts a comment on the PR with a summary of lint results, and links to detailed logsActive if in Azure Pipelines
Bitbucket Pull Request commentsMega-Linter posts a comment on the PR with a summary of lint results, and links to detailed logsActive if in Bitbucket CI
API (Grafana)Sends logs and metrics to Grafana endpoint (Loki / Prometheus)Inactive
Updated sourcesZip containing all formatted and autofixed sources so you can extract them in your repositoryActive
IDE ConfigurationApply MegaLinter configuration in your local IDE with linter config files and IDE extensionsActive
GitHub StatusOne GitHub status by linter on the PR, with links to detailed logsActive if GitHub Action
File.ioSend reports on file.io so you can access them with a simple hyperlink provided at the end of console logInactive
JSONGenerates a JSON output report fileInactive
EmailReceive all reports on your e-mail, if you can not use artifactsActive
TAP filesOne file by linter following Test Anything Protocol formatActive
ConsoleExecution logs visible in console with summary table and links to other reports at the endActive
Markdown SummaryGenerates a Markdown summary report fileInactive
<!-- reporters-section-end --> <!-- flavors-section-start --> <!-- markdown-headers --- title: MegaLinter Flavors for better performances description: Use one of the numerous MegaLinter flavors to run MegaLinter even faster with only the linters you need --- -->

Flavors

To improve run performances, we generate Flavored MegaLinter images containing only the list of linters related to a project type

The following table doesn't display docker pulls from MegaLinter v4 & v5 images.

<!-- flavors-table-start -->
<!-- -->FlavorDescriptionEmbedded lintersInfo
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/images/mega-linter-square.png" alt="" height="32px" class="megalinter-icon"></a>allDefault MegaLinter Flavor124Docker Image Size (tag) Docker Pulls
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/c_cpp.ico" alt="" height="32px" class="megalinter-icon"></a>c_cppOptimized for pure C/C++ projects54Docker Image Size (tag) Docker Pulls
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/ci_light.ico" alt="" height="32px" class="megalinter-icon"></a>ci_lightOptimized for CI items (Dockerfile, Jenkinsfile, JSON/YAML schemas,XML21Docker Image Size (tag) Docker Pulls
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/cupcake.ico" alt="" height="32px" class="megalinter-icon"></a>cupcakeMegaLinter for the most commonly used languages83Docker Image Size (tag) Docker Pulls
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/documentation.ico" alt="" height="32px" class="megalinter-icon"></a>documentationMegaLinter for documentation projects49Docker Image Size (tag) Docker Pulls
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/dotnet.ico" alt="" height="32px" class="megalinter-icon"></a>dotnetOptimized for C, C++, C# or VB based projects62Docker Image Size (tag) Docker Pulls
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/dotnetweb.ico" alt="" height="32px" class="megalinter-icon"></a>dotnetwebOptimized for C, C++, C# or VB based projects with JS/TS71Docker Image Size (tag) Docker Pulls
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/formatters.ico" alt="" height="32px" class="megalinter-icon"></a>formattersContains only formatters17Docker Image Size (tag) Docker Pulls
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/go.ico" alt="" height="32px" class="megalinter-icon"></a>goOptimized for GO based projects51Docker Image Size (tag) Docker Pulls
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/java.ico" alt="" height="32px" class="megalinter-icon"></a>javaOptimized for JAVA based projects52Docker Image Size (tag) Docker Pulls
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/javascript.ico" alt="" height="32px" class="megalinter-icon"></a>javascriptOptimized for JAVASCRIPT or TYPESCRIPT based projects59Docker Image Size (tag) Docker Pulls
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/php.ico" alt="" height="32px" class="megalinter-icon"></a>phpOptimized for PHP based projects54Docker Image Size (tag) Docker Pulls
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/python.ico" alt="" height="32px" class="megalinter-icon"></a>pythonOptimized for PYTHON based projects62Docker Image Size (tag) Docker Pulls
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/ruby.ico" alt="" height="32px" class="megalinter-icon"></a>rubyOptimized for RUBY based projects50Docker Image Size (tag) Docker Pulls
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/rust.ico" alt="" height="32px" class="megalinter-icon"></a>rustOptimized for RUST based projects50Docker Image Size (tag) Docker Pulls
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/salesforce.ico" alt="" height="32px" class="megalinter-icon"></a>salesforceOptimized for Salesforce based projects54Docker Image Size (tag) Docker Pulls
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/security.ico" alt="" height="32px" class="megalinter-icon"></a>securityOptimized for security24Docker Image Size (tag) Docker Pulls
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/swift.ico" alt="" height="32px" class="megalinter-icon"></a>swiftOptimized for SWIFT based projects50Docker Image Size (tag) Docker Pulls
<img src="https://github.com/oxsecurity/megalinter/raw/main/docs/assets/icons/terraform.ico" alt="" height="32px" class="megalinter-icon"></a>terraformOptimized for TERRAFORM based projects54Docker Image Size (tag) Docker Pulls
<!-- flavors-table-end -->

If you need a new flavor, post an issue :wink:

<!-- flavors-section-end --> <!-- badge-section-start --> <!-- markdown-headers --- title: MegaLinter Badges description: Show that your repositories are cleaned and secured with MegaLinter with a badge --- -->

Badge

You can show MegaLinter status with a badge in your repository README

MegaLinter

If your main branch is master , replace main by master in URLs

Markdown

[![MegaLinter](https://github.com/<OWNER>/<REPOSITORY>/workflows/MegaLinter/badge.svg?branch=main)](https://github.com/<OWNER>/<REPOSITORY>/actions?query=workflow%3AMegaLinter+branch%3Amain)
[![MegaLinter](https://github.com/nvuillam/npm-groovy-lint/workflows/MegaLinter/badge.svg?branch=main)](https://github.com/nvuillam/npm-groovy-lint/actions?query=workflow%3AMegaLinter+branch%3Amain)

reStructuredText

.. |MegaLinter yes| image:: https://github.com/<OWNER>/<REPOSITORY>/workflows/MegaLinter/badge.svg?branch=main
   :target: https://github.com/<OWNER>/<REPOSITORY>/actions?query=workflow%3AMegaLinter+branch%3Amain
.. |MegaLinter yes| image:: https://github.com/nvuillam/npm-groovy-lint/workflows/MegaLinter/badge.svg?branch=main
   :target: https://github.com/nvuillam/npm-groovy-lint/actions?query=workflow%3AMegaLinter+branch%3Amain

Note: IF you did not use MegaLinter as GitHub Action name, please read GitHub Actions Badges documentation{target=_blank}

<!-- badge-section-end --> <!-- plugins-section-start --> <!-- markdown-headers --- title: MegaLinter plugins description: Build and use your own plugins for MegaLinter, like jupyfmt, nitpick, mustache and linkcheck --- -->

Plugins

For performances and security reasons, we can not embed all linters of the world within MegaLinter.

But our core architecture allows to build and publish MegaLinter Plugins !

External Plugins Catalog

<!-- plugins-table-start -->
NameDescriptionAuthorRaw URL
jupyfmtThe uncompromising Jupyter notebook formatterKim Philipp JablonskiDescriptor
linkcheckPlugin to check and validate markdown links exist and workingShiran RubinDescriptor
nitpickCommand-line tool and flake8 plugin to enforce the same settings across multiple language-independent projectsW. Augusto AndreoliDescriptor
mustachePlugin to validate Logstash pipeline definition files using mustacheYann JouaniqueDescriptor
salt-lintChecks Salt State files (SLS) for best practices and behavior that could potentially be improved.Joachim GrimmDescriptor
<!-- plugins-table-end -->

Note: Using an external plugin means you trust its author

Submit a Pull Request if you want your plugin to appear here :)

Use external plugins

Add plugin URLs in PLUGINS property of .mega-linter.yml. URLs must either begin with "https://" or take the form of "file://<path>", where <path> points to a valid plugin descriptor file.

Note: Both <path> and the default mount directory (/tmp/lint/<path>) will be checked for a valid descriptor.

Example

PLUGINS:
  - https://raw.githubusercontent.com/kpj/jupyfmt/master/mega-linter-plugin-jupyfmt/jupyfmt.megalinter-descriptor.yml
  - file://.automation/test/mega-linter-plugin-test/test.megalinter-descriptor.yml

Create your own plugin

You can implement your own descriptors and load them as plugins during MegaLinter runtime

Limitations

<!-- plugins-section-end --> <!-- articles-section-start --> <!-- markdown-headers --- title: MegaLinter Articles Reference description: List of all known articles, blog posts and videos that talk about MegaLinter usage --- -->

They talk about MegaLinter

<!-- /* cspell:disable */ -->

English articles

ArticleAuthor
MegaLinter Performance Tuning for Maximum Efficiency{target=_blank}Wes Dean{target=_blank}
10 MegaLinter Tips and Tricks Unlock its Full Potential{target=_blank}Wes Dean{target=_blank}
30 Seconds to Setup MegaLinter: Your Go-To Tool for Automated Code Quality{target=_blank}Peng Cao
Introducing MegaLinter: Streamlining Code Quality Checks Across Multiple Languages{target=_blank}Cloud Tuned{target=_blank}
Infrastructure as Code GitHub Codespace Template{target=_blank}Luke Murray{target=_blank}
5 ways MegaLinter upped our DevSecOps game{target=_blank}Wes Dean{target=_blank}
Achieve Code Consistency: MegaLinter Integration in Azure DevOps{target=_blank}Don Koning{target=_blank} on Microsoft Tech Community{target=_blank}
MegaLinter in Azure DevOps{target=_blank}James Cook{target=_blank}
Maximize your code consistency with Megalinter{target=_blank}Tor Ivar Asbølmo{target=_blank} on codewithme.cloud{target=_blank}
8 Tools to Scan Node.js Applications for Security Vulnerability{target=_blank}Chandan Kumar{target=_blank} on GeekFlare.com{target=_blank}
Use the Workflows JSON schema in your IDE{target=_blank}Google Cloud{target=_blank}
Level up your Unity Packages with CI/CD{target=_blank}RunningMattress{target=_blank}
Writing documentation as a champ in engineering teams{target=_blank}Gijs Reijn{target=_blank}
GitHub Actions: sharing your secrets with third-party actions{target=_blank}Constantin Bosse{target=_blank} and Stephen Hosom{target=_blank}
GitOps security topics you must address{target=_blank}Wiebe de Roos{target=_blank}
Talk about the Kotlin plugins Kover, Ktlint and Detekt. Made for the AmsterdamJUG meetup.{target=_blank}Simone de Gijt{target=_blank}
Linting - What is all the fluff about?{target=_blank}Neil Shepard{target=_blank}, University Of Sheffield
How to apply security at the source using GitOps{target=_blank}Edu Minguez{target=_blank}
How to linter basic things like trailing whitespaces and newlines{target=_blank}Nicolai Antiferov{target=_blank}
Open-source linters landscape in 2021{target=_blank}Cédric Teyton{target=_blank}
Node.js Coding Standard Tools with MegaLinter on Gitlab CI{target=_blank}Albion Bame{target=_blank}
Linting a Jekyll blog with MegaLinter{target=_blank}Alec Johnson{target=_blank}
MegaLinter sells his soul and joins OX Security{target=_blank}Nicolas Vuillamy{target=_blank}
Limit your technical debt and secure your code base using MegaLinter{target=_blank}Nicolas Vuillamy{target=_blank}

French articles

ArticleAuthor
MegaLinter{target=_blank}Stéphane Robert, 3DS OutScale{target=_blank}
MegaLinter: un linter pour les gouverner tous{target=_blank}Guillaume Arnaud, WeScale{target=_blank}
MegaLinter, votre meilleur ami pour un code de qualité{target=_blank}Thomas Sanson{target=_blank}

Japanese articles

ArticleAuthor
Try using MegaLinter{target=_blank}Takashi Minayaga{target=_blank}

Videos

<div style="text-align:center"><iframe width="560" height="315" src="https://www.youtube.com/embed/iBMWAk5QIfM" title="YouTube video player" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture" allowfullscreen></iframe></div> <div style="text-align:center"><iframe width="560" height="315" src="https://www.youtube.com/embed/KhkNf2tQ3hM" title="YouTube video player" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture" allowfullscreen></iframe></div> <div style="text-align:center"><iframe width="560" height="315" src="https://www.youtube.com/embed/SlKurrIsUls" title="YouTube video player" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture" allowfullscreen></iframe></div> <div style="text-align:center"><iframe width="560" height="315" src="https://www.youtube.com/embed/NauVD4z-cMA" title="YouTube video player" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture" allowfullscreen></iframe></div> <div style="text-align:center"><iframe width="560" height="315" src="https://www.youtube.com/embed/hk950RUwIUA" title="YouTube video player" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture" allowfullscreen></iframe></div> <div style="text-align:center"><iframe width="560" height="315" src="https://www.youtube.com/embed/oegOSmVegiQ?start=1510" title="YouTube video player" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share" allowfullscreen></iframe></div> <div style="text-align:center"><iframe width="560" height="315" src="https://www.youtube.com/embed/raCDpsP9O78" title="YouTube video player" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture" allowfullscreen></iframe></div>

Web Sites

<!-- - [iac-analyzers.dev/](https://iac-analyzers.dev/){target=_blank} -->

Linters

<!-- referring-linters-start --> <!-- referring-linters-end --> <!-- /* cspell:enable */ --> <!-- articles-section-end --> <!-- frequently-asked-questions-section-start --> <!-- markdown-headers --- title: Frequently Asked Questions about MegaLinter description: List of recurrent questions about MegaLinter --- -->

Frequently Asked Questions

My repo CI already have linters and they're perfectly working, so why do I need MegaLinter ?

You can perfectly continue using your installed linters and deactivate them in .mega-linter.yml. For example, in a javascript project using eslint, you can configure MegaLinter with DISABLE: JAVASCRIPT. That way, you will benefit from both your installed linters but also from other MegaLinter linters checking JSON, YAML, Markdown, Dockerfile, Bash, spelling mistakes, dead URLs…

Ok but… how does it work ?

MegaLinter is based on Docker images containing either all linters, or just a selection of linters if you are using a MegaLinter flavor for a project using a specific language / format

The core architecture does the following:

<!-- frequently-asked-questions-section-end --> <!-- how-to-contribute-section-start --> <!-- markdown-headers --- title: MegaLinter Contributing Guide description: Help MegaLinter by starring the repo, post issues and Pull Requests, or even sponsor the author --- -->

How to contribute

Contributions to MegaLinter are very welcome, the more we're, the stronger MegaLinter is ! Please follow Contributing Guide

To help, you can also:

<!-- how-to-contribute-section-end --> <!-- special-thanks-section-start --> <!-- markdown-headers --- title: Special Thanks from MegaLinter description: List of all contributors, websites and linters that help MegaLinter to grow and be better everyday --- -->

Special thanks

Maintainers

MegaLinter wouldn't be what it is without its great team of maintainers !

Contributors

<a href="https://github.com/oxsecurity/megalinter/graphs/contributors"> <img src="https://contrib.rocks/image?repo=oxsecurity/megalinter" /> </a>

Open-source teams

MegaLinter obviously would not exist without its linters and libraries, so many thanks to all the dedicated Open-Source teams maintaining all these awesome linters !

Super-Linter team

MegaLinter has been built on the ashes of a rejected Pull Request{target=_blank} on GitHub Super-Linter{target=_blank}.

Even if I disagree with their decision to remain in bash, the core team has always been nice and supporting during the time I was a Super-Linter contributor{target=_blank} :)

<!-- special-thanks-section-end --> <!-- license-section-start -->

License

<!-- license-section-end --> <!-- mega-linter-vs-super-linter-section-start --> <!-- markdown-headers --- title: Compare MegaLinter and SuperLinter description: Detailed differences between MegaLinter and SuperLinter (performances, reporters, architecture…) --- -->

MegaLinter vs Super-Linter

The hard-fork of Super-Linter to be rewritten in Python isn't just a language switch: use of python flexibility and libraries allowed to define lots of additional functions described below

Security

MegaLinter hides many environment variables when calling the linters.

That way you need to trust only MegaLinter core code with your secrets, not the 100+ embedded linters !

Performances

More languages and formats linted

Automatically apply formatting and fixes

MegaLinter can automatically apply fixes performed by linters, and push them to the same branch, or create a Pull Request that you can validate

This is pretty handy, especially for linter errors related to formatting (in that case, you don't have any manual update to perform)

Run locally

MegaLinter can be run locally thanks to mega-linter-runner

Reports

Capabilities

Additional Reporters

Screenshot

Screenshot

Screenshot

Screenshot

Screenshot

Screenshot

Enhanced Configuration

Runner Install

Assisted configuration

Enhanced Documentation

HTML doc home

HTML doc linter

HTML doc IDE

Plugins management

For linters less commonly used, MegaLinters offers a plugins architecture so anyone can publish plugins

Simplify architecture and evolutive maintenance

Improve robustness & stability

<!-- mega-linter-vs-super-linter-section-end -->