This package contains the logic for the GitHub Actions workflows language server.
The package contains TypeScript types and compiled ECMAScript modules.
npm install @actions/languageserviceThe language service features use three sources of information:
- a built-in static schema for the workflow YAML file
- value providers which can dynamically add values to the schema, for example, the list of available labels for a repository when validating
runs-on. - context providers which can dynamically provide available contexts used in expressions. For example, the contents of the
github.eventcontext for a given workflow file.
Validate a workflow file, returns an array of Diagnostic objects.
const config: ValidationConfig = {
valueProviderConfig: valueProviders(sessionToken, repoContext, cache),
contextProviderConfig: contextProviders(sessionToken, repoContext, cache),
};
const result = await validate(textDocument, config); // result is an array of `Diagnostic`Get information when hovering over a token in the workflow file.
import {hover} from "@actions/languageservice";
const document = {
uri: "file:///path/to/file",
getText: () => "on: push\n jobs:\n build:\n runs-on: ubuntu-latest\n steps:\n - run: echo hello"
};
const hover = await hover(document, {line: 0, character: 1}); // { contents: { kind: "markdown", value: "The event that triggers the workflow" } }import {complete} from "@actions/languageservice";
const document = {
uri: "file:///path/to/file",
getText: () => `on:
jobs:
build:
runs-on: ubuntu-latest
steps:
- run: echo hello`
};
// Trigger completion for `on: |`
const suggestions = await complete(document, {line: 0, character: 4});will return
See CONTRIBUTING.md at the root of the repository for general guidelines and recommendations.
If you do want to contribute, please run prettier to format your code and add unit tests as appropriate before submitting your PR.
npm run buildor to watch for changes
npm run watchnpm testor to watch for changes and run tests:
npm run test-watchnpm run format-checkThis project is licensed under the terms of the MIT open source license. Please refer to MIT for the full terms.
[{ "documentation": { "kind": "markdown", "value": "Runs your workflow when branch protection rules in the workflow repository are changed.", }, "label": "branch_protection_rule", "textEdit": { "newText": "branch_protection_rule", "range": { "end": {"character": 4, "line": 0,}, "start": {"character": 4, "line": 0}, }, }, }, //... other events ]