From 873c91c4f7ae92acbff61a600e8c8bf7e58c495d Mon Sep 17 00:00:00 2001 From: Andrew Eisenberg Date: Wed, 7 Aug 2024 14:20:43 -0700 Subject: [PATCH 1/4] Update README with detailed information Update `README.md` to include detailed information about inputs, workflow permissions, build modes, and actions. * **Inputs**: Add a section on inputs, including the `config` option, `languages`, `queries`, `packs`, `db-location`, `ram`, `threads`, and `source-root`. * **Workflow Permissions**: Add a section on workflow permissions required for the actions. * **Build Modes**: Add a section explaining the different build modes available for the actions (`none`, `autobuild`, `manual`). * **Actions**: Add a section describing the different actions (`init`, `autobuild`, `analyze`, `upload-sarif`, `resolve-environment`, `start-proxy`) and how to use them, with links to the relevant documentation on GitHub. --- For more details, open the [Copilot Workspace session](https://copilot-workspace.githubnext.com/github/codeql-action?shareId=XXXX-XXXX-XXXX-XXXX). --- README.md | 34 +++++++++++++++++++++++++++++++++- 1 file changed, 33 insertions(+), 1 deletion(-) diff --git a/README.md b/README.md index 9c66db211f..a72772d7ef 100644 --- a/README.md +++ b/README.md @@ -16,10 +16,42 @@ We recommend using default setup to configure CodeQL analysis for your repositor You can also configure advanced setup for a repository to find security vulnerabilities in your code using a highly customizable code scanning configuration. For more information, see "[Configuring advanced setup for code scanning](https://docs.github.com/en/code-security/code-scanning/creating-an-advanced-setup-for-code-scanning/configuring-advanced-setup-for-code-scanning)" and "[Customizing your advanced setup for code scanning](https://docs.github.com/en/code-security/code-scanning/creating-an-advanced-setup-for-code-scanning/customizing-your-advanced-setup-for-code-scanning)." -### Permissions +### Inputs + +The CodeQL Action supports various inputs to customize the analysis. Here are some important inputs: + +- `config`: Path of the config file to use. This input allows you to specify a custom configuration file for the analysis. +- `languages`: A comma-separated list of CodeQL languages to analyze. +- `queries`: Comma-separated list of additional queries to run. By default, this overrides the same setting in a configuration file; prefix with "+" to use both sets of queries. +- `packs`: Comma-separated list of packs to run. Reference a pack in the format `scope/name[@version]`. If `version` is not specified, then the latest version of the pack is used. By default, this overrides the same setting in a configuration file; prefix with "+" to use both sets of packs. +- `db-location`: Path where CodeQL databases should be created. If not specified, a temporary directory will be used. +- `ram`: The amount of memory in MB that can be used by CodeQL extractors. +- `threads`: The number of threads that can be used by CodeQL extractors. +- `source-root`: Path of the root source code directory, relative to $GITHUB_WORKSPACE. + +### Workflow Permissions All advanced setup code scanning workflows must have the `security-events: write` permission. Workflows in private repositories must additionally have the `contents: read` permission. For more information, see "[Assigning permissions to jobs](https://docs.github.com/en/actions/using-jobs/assigning-permissions-to-jobs)." +### Build Modes + +The CodeQL Action supports different build modes for analyzing the source code. The available build modes are: + +- `none`: The database will be created without building the source code. Available for all interpreted languages and some compiled languages. +- `autobuild`: The database will be created by attempting to automatically build the source code. Available for all compiled languages. +- `manual`: The database will be created by building the source code using a manually specified build command. To use this build mode, specify manual build steps in your workflow between the `init` and `analyze` steps. Available for all compiled languages. + +### Actions + +The CodeQL Action includes several actions that can be used in your workflows. Here are the available actions and how to use them: + +- `init`: Sets up CodeQL for analysis. For more information, see the [init action documentation](/~https://github.com/github/codeql-action/blob/main/init/action.yml). +- `autobuild`: Attempts to automatically build the code. For more information, see the [autobuild action documentation](/~https://github.com/github/codeql-action/blob/main/autobuild/action.yml). +- `analyze`: Finalizes the CodeQL database and runs the analysis. For more information, see the [analyze action documentation](/~https://github.com/github/codeql-action/blob/main/analyze/action.yml). +- `upload-sarif`: Uploads a SARIF file to Code Scanning. For more information, see the [upload-sarif action documentation](/~https://github.com/github/codeql-action/blob/main/upload-sarif/action.yml). +- `resolve-environment`: Attempts to infer a build environment suitable for automatic builds. For more information, see the [resolve-environment action documentation](/~https://github.com/github/codeql-action/blob/main/resolve-environment/action.yml). +- `start-proxy`: Starts an HTTP proxy server. For more information, see the [start-proxy action documentation](/~https://github.com/github/codeql-action/blob/main/start-proxy/action.yml). + ## Supported versions of the CodeQL Action The following versions of the CodeQL Action are currently supported: From c768f67a10a112cf8cfa64e2cb2f9e150e489316 Mon Sep 17 00:00:00 2001 From: Andrew Eisenberg Date: Fri, 9 Aug 2024 13:29:40 -0700 Subject: [PATCH 2/4] Clean up README Restructured the change to the README. Instead of directly including the descriptions of the language inputs, added links to the inputs for each action. --- README.md | 44 +++++++++++++++++++++++++------------------- autobuild/action.yml | 2 +- 2 files changed, 26 insertions(+), 20 deletions(-) diff --git a/README.md b/README.md index a72772d7ef..e895343514 100644 --- a/README.md +++ b/README.md @@ -16,18 +16,24 @@ We recommend using default setup to configure CodeQL analysis for your repositor You can also configure advanced setup for a repository to find security vulnerabilities in your code using a highly customizable code scanning configuration. For more information, see "[Configuring advanced setup for code scanning](https://docs.github.com/en/code-security/code-scanning/creating-an-advanced-setup-for-code-scanning/configuring-advanced-setup-for-code-scanning)" and "[Customizing your advanced setup for code scanning](https://docs.github.com/en/code-security/code-scanning/creating-an-advanced-setup-for-code-scanning/customizing-your-advanced-setup-for-code-scanning)." -### Inputs +### Actions + +This repository contains several actions that enable you to analyze code in your repository using CodeQL and upload the analysis to GitHub Code Scanning. Actions in this repository also allow you to upload to GitHub analyses generated by any SARIF-producing SAST tool. + +Actions for CodeQL analyses: + +- `init`: Sets up CodeQL for analysis. For information about input parameters, see the [init action definition](/~https://github.com/github/codeql-action/blob/main/init/action.yml). +- `analyze`: Finalizes the CodeQL database, runs the analysis, and uploads the results to Code Scanning. For information about input parameters, see the [analyze action definition](/~https://github.com/github/codeql-action/blob/main/analyze/action.yml). + +Actions for uploading analyses generated by third-party tools: -The CodeQL Action supports various inputs to customize the analysis. Here are some important inputs: +- `upload-sarif`: Uploads a SARIF file to Code Scanning. If you are using the `analyze` action, there is no reason to use this action as well. For information about input parameters, see the [upload-sarif action definition](/~https://github.com/github/codeql-action/blob/main/upload-sarif/action.yml). -- `config`: Path of the config file to use. This input allows you to specify a custom configuration file for the analysis. -- `languages`: A comma-separated list of CodeQL languages to analyze. -- `queries`: Comma-separated list of additional queries to run. By default, this overrides the same setting in a configuration file; prefix with "+" to use both sets of queries. -- `packs`: Comma-separated list of packs to run. Reference a pack in the format `scope/name[@version]`. If `version` is not specified, then the latest version of the pack is used. By default, this overrides the same setting in a configuration file; prefix with "+" to use both sets of packs. -- `db-location`: Path where CodeQL databases should be created. If not specified, a temporary directory will be used. -- `ram`: The amount of memory in MB that can be used by CodeQL extractors. -- `threads`: The number of threads that can be used by CodeQL extractors. -- `source-root`: Path of the root source code directory, relative to $GITHUB_WORKSPACE. +Actions with special purposes and unlikely to be used directly: + +- `autobuild`: (Deprecated) Attempts to automatically build the code. Only used for analyzing languages that require a build. Use the `build-mode: autobuild` input in the `init` action instead. For information about input parameters, see the [autobuild action definition](/~https://github.com/github/codeql-action/blob/main/autobuild/action.yml). +- `resolve-environment`: Attempts to infer a build environment suitable for automatic builds. For information about input parameters, see the [resolve-environment action definition](/~https://github.com/github/codeql-action/blob/main/resolve-environment/action.yml). +- `start-proxy`: Starts an HTTP proxy server for downloading dependencies in private registries. For information about input parameters, see the [start-proxy action definition](/~https://github.com/github/codeql-action/blob/main/start-proxy/action.yml). ### Workflow Permissions @@ -41,16 +47,16 @@ The CodeQL Action supports different build modes for analyzing the source code. - `autobuild`: The database will be created by attempting to automatically build the source code. Available for all compiled languages. - `manual`: The database will be created by building the source code using a manually specified build command. To use this build mode, specify manual build steps in your workflow between the `init` and `analyze` steps. Available for all compiled languages. -### Actions +#### Which build mode should I use? + +Interpreted languages must use `none` for the build mode. + +For compiled languages: -The CodeQL Action includes several actions that can be used in your workflows. Here are the available actions and how to use them: +- `manual` build mode will typically produce the most precise results, but it is more difficult to set up and will cause the analysis to take slightly more time to run. +- `autobuild` build mode is simpler to set up, but will only work for projects with generic build steps that can be guessed by the heuristics of the autobuild scripts. If `autobuild` fails, then you must switch to `manual` or `none`. If `autobuild` succeeds, then the results and run time will be the same as `manual` mode. +- `none` build mode is also simpler to set up and is slightly faster to run, but there is a possibility that some alerts will be missed. This may happen if your repository does any code generation during compilation or if there are any dependencies downloaded from registries that the workflow does not have access to. `none` is not yet supported by C/C++, Swift, Go, or Kotlin. -- `init`: Sets up CodeQL for analysis. For more information, see the [init action documentation](/~https://github.com/github/codeql-action/blob/main/init/action.yml). -- `autobuild`: Attempts to automatically build the code. For more information, see the [autobuild action documentation](/~https://github.com/github/codeql-action/blob/main/autobuild/action.yml). -- `analyze`: Finalizes the CodeQL database and runs the analysis. For more information, see the [analyze action documentation](/~https://github.com/github/codeql-action/blob/main/analyze/action.yml). -- `upload-sarif`: Uploads a SARIF file to Code Scanning. For more information, see the [upload-sarif action documentation](/~https://github.com/github/codeql-action/blob/main/upload-sarif/action.yml). -- `resolve-environment`: Attempts to infer a build environment suitable for automatic builds. For more information, see the [resolve-environment action documentation](/~https://github.com/github/codeql-action/blob/main/resolve-environment/action.yml). -- `start-proxy`: Starts an HTTP proxy server. For more information, see the [start-proxy action documentation](/~https://github.com/github/codeql-action/blob/main/start-proxy/action.yml). ## Supported versions of the CodeQL Action @@ -77,7 +83,7 @@ We typically release new minor versions of the CodeQL Action and Bundle when a n | `v2.22.1` | `2.14.6` | Enterprise Server 3.11 | Supports CodeQL Action v3, but did not ship with CodeQL Action v3. For more information, see "[Code scanning: deprecation of CodeQL Action v2](https://github.blog/changelog/2024-01-12-code-scanning-deprecation-of-codeql-action-v2/#users-of-github-enterprise-server-311)." | | `v2.20.3` | `2.13.5` | Enterprise Server 3.10 | Does not support CodeQL Action v3. | -CodeQL Action v2 will stop receiving updates when GHES 3.11 is deprecated. +CodeQL Action v2 will stop receiving updates when GHES 3.11 is deprecated. See the full list of GHES release and deprecation dates at [GitHub Enterprise Server releases](https://docs.github.com/en/enterprise-server/admin/all-releases#releases-of-github-enterprise-server). diff --git a/autobuild/action.yml b/autobuild/action.yml index f688b56119..c2a2ca5bdc 100644 --- a/autobuild/action.yml +++ b/autobuild/action.yml @@ -1,5 +1,5 @@ name: 'CodeQL: Autobuild' -description: 'Attempt to automatically build code' +description: '(Deprecated) Attempt to automatically build the code. Only used for analyzing languages that require a build. Use the `build-mode: autobuild` input in the `init` action instead.' author: 'GitHub' inputs: token: From 3b143d4ee53147b9b8dbfd7cb59596df2701a785 Mon Sep 17 00:00:00 2001 From: Andrew Eisenberg Date: Thu, 3 Oct 2024 15:06:40 -0700 Subject: [PATCH 3/4] Update readme --- README.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/README.md b/README.md index e895343514..0c657ae8e2 100644 --- a/README.md +++ b/README.md @@ -31,9 +31,9 @@ Actions for uploading analyses generated by third-party tools: Actions with special purposes and unlikely to be used directly: -- `autobuild`: (Deprecated) Attempts to automatically build the code. Only used for analyzing languages that require a build. Use the `build-mode: autobuild` input in the `init` action instead. For information about input parameters, see the [autobuild action definition](/~https://github.com/github/codeql-action/blob/main/autobuild/action.yml). -- `resolve-environment`: Attempts to infer a build environment suitable for automatic builds. For information about input parameters, see the [resolve-environment action definition](/~https://github.com/github/codeql-action/blob/main/resolve-environment/action.yml). -- `start-proxy`: Starts an HTTP proxy server for downloading dependencies in private registries. For information about input parameters, see the [start-proxy action definition](/~https://github.com/github/codeql-action/blob/main/start-proxy/action.yml). +- `autobuild`: Attempts to automatically build the code. Only used for analyzing languages that require a build. Use the `build-mode: autobuild` input in the `init` action instead. For information about input parameters, see the [autobuild action definition](/~https://github.com/github/codeql-action/blob/main/autobuild/action.yml). +- `resolve-environment`: [Experimental] Attempts to infer a build environment suitable for automatic builds. For information about input parameters, see the [resolve-environment action definition](/~https://github.com/github/codeql-action/blob/main/resolve-environment/action.yml). +- `start-proxy`: [Experimental] Start the HTTP proxy server. Internal use only and will change without notice. For information about input parameters, see the [start-proxy action definition](/~https://github.com/github/codeql-action/blob/main/start-proxy/action.yml). ### Workflow Permissions From bed2a47f201e917459bc40343380c570a730ff06 Mon Sep 17 00:00:00 2001 From: Andrew Eisenberg Date: Thu, 3 Oct 2024 18:32:01 -0700 Subject: [PATCH 4/4] Update autobuild/action.yml --- autobuild/action.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/autobuild/action.yml b/autobuild/action.yml index c2a2ca5bdc..80d8c1c31e 100644 --- a/autobuild/action.yml +++ b/autobuild/action.yml @@ -1,5 +1,5 @@ name: 'CodeQL: Autobuild' -description: '(Deprecated) Attempt to automatically build the code. Only used for analyzing languages that require a build. Use the `build-mode: autobuild` input in the `init` action instead.' +description: 'Attempt to automatically build the code. Only used for analyzing languages that require a build. Use the `build-mode: autobuild` input in the `init` action instead.' author: 'GitHub' inputs: token: