@actions/languageserver 0.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (107) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +134 -0
  3. package/dist/client.d.ts +3 -0
  4. package/dist/client.d.ts.map +1 -0
  5. package/dist/client.js +8 -0
  6. package/dist/client.js.map +1 -0
  7. package/dist/commands.d.ts +4 -0
  8. package/dist/commands.d.ts.map +1 -0
  9. package/dist/commands.js +5 -0
  10. package/dist/commands.js.map +1 -0
  11. package/dist/connection.d.ts +3 -0
  12. package/dist/connection.d.ts.map +1 -0
  13. package/dist/connection.js +127 -0
  14. package/dist/connection.js.map +1 -0
  15. package/dist/context-providers/action-outputs.d.ts +5 -0
  16. package/dist/context-providers/action-outputs.d.ts.map +1 -0
  17. package/dist/context-providers/action-outputs.js +5 -0
  18. package/dist/context-providers/action-outputs.js.map +1 -0
  19. package/dist/context-providers/secrets.d.ts +8 -0
  20. package/dist/context-providers/secrets.d.ts.map +1 -0
  21. package/dist/context-providers/secrets.js +122 -0
  22. package/dist/context-providers/secrets.js.map +1 -0
  23. package/dist/context-providers/steps.d.ts +6 -0
  24. package/dist/context-providers/steps.d.ts.map +1 -0
  25. package/dist/context-providers/steps.js +60 -0
  26. package/dist/context-providers/steps.js.map +1 -0
  27. package/dist/context-providers/variables.d.ts +13 -0
  28. package/dist/context-providers/variables.d.ts.map +1 -0
  29. package/dist/context-providers/variables.js +120 -0
  30. package/dist/context-providers/variables.js.map +1 -0
  31. package/dist/context-providers.d.ts +6 -0
  32. package/dist/context-providers.d.ts.map +1 -0
  33. package/dist/context-providers.js +20 -0
  34. package/dist/context-providers.js.map +1 -0
  35. package/dist/description-provider.d.ts +5 -0
  36. package/dist/description-provider.d.ts.map +1 -0
  37. package/dist/description-provider.js +20 -0
  38. package/dist/description-provider.js.map +1 -0
  39. package/dist/description-providers/action-description.d.ts +5 -0
  40. package/dist/description-providers/action-description.d.ts.map +1 -0
  41. package/dist/description-providers/action-description.js +18 -0
  42. package/dist/description-providers/action-description.js.map +1 -0
  43. package/dist/description-providers/action-input.d.ts +6 -0
  44. package/dist/description-providers/action-input.d.ts.map +1 -0
  45. package/dist/description-providers/action-input.js +36 -0
  46. package/dist/description-providers/action-input.js.map +1 -0
  47. package/dist/file-provider.d.ts +5 -0
  48. package/dist/file-provider.d.ts.map +1 -0
  49. package/dist/file-provider.js +49 -0
  50. package/dist/file-provider.js.map +1 -0
  51. package/dist/index.d.ts +2 -0
  52. package/dist/index.d.ts.map +1 -0
  53. package/dist/index.js +19 -0
  54. package/dist/index.js.map +1 -0
  55. package/dist/initializationOptions.d.ts +45 -0
  56. package/dist/initializationOptions.d.ts.map +1 -0
  57. package/dist/initializationOptions.js +2 -0
  58. package/dist/initializationOptions.js.map +1 -0
  59. package/dist/on-completion.d.ts +7 -0
  60. package/dist/on-completion.d.ts.map +1 -0
  61. package/dist/on-completion.js +15 -0
  62. package/dist/on-completion.js.map +1 -0
  63. package/dist/request.d.ts +7 -0
  64. package/dist/request.d.ts.map +1 -0
  65. package/dist/request.js +4 -0
  66. package/dist/request.js.map +1 -0
  67. package/dist/utils/action-metadata.d.ts +5 -0
  68. package/dist/utils/action-metadata.d.ts.map +1 -0
  69. package/dist/utils/action-metadata.js +56 -0
  70. package/dist/utils/action-metadata.js.map +1 -0
  71. package/dist/utils/cache.d.ts +14 -0
  72. package/dist/utils/cache.d.ts.map +1 -0
  73. package/dist/utils/cache.js +35 -0
  74. package/dist/utils/cache.js.map +1 -0
  75. package/dist/utils/error.d.ts +3 -0
  76. package/dist/utils/error.d.ts.map +1 -0
  77. package/dist/utils/error.js +22 -0
  78. package/dist/utils/error.js.map +1 -0
  79. package/dist/utils/repo-permission.d.ts +6 -0
  80. package/dist/utils/repo-permission.d.ts.map +1 -0
  81. package/dist/utils/repo-permission.js +36 -0
  82. package/dist/utils/repo-permission.js.map +1 -0
  83. package/dist/utils/timer.d.ts +2 -0
  84. package/dist/utils/timer.d.ts.map +1 -0
  85. package/dist/utils/timer.js +12 -0
  86. package/dist/utils/timer.js.map +1 -0
  87. package/dist/utils/username.d.ts +4 -0
  88. package/dist/utils/username.d.ts.map +1 -0
  89. package/dist/utils/username.js +14 -0
  90. package/dist/utils/username.js.map +1 -0
  91. package/dist/value-providers/action-inputs.d.ts +8 -0
  92. package/dist/value-providers/action-inputs.d.ts.map +1 -0
  93. package/dist/value-providers/action-inputs.js +28 -0
  94. package/dist/value-providers/action-inputs.js.map +1 -0
  95. package/dist/value-providers/job-environment.d.ts +5 -0
  96. package/dist/value-providers/job-environment.d.ts.map +1 -0
  97. package/dist/value-providers/job-environment.js +21 -0
  98. package/dist/value-providers/job-environment.js.map +1 -0
  99. package/dist/value-providers/runs-on.d.ts +5 -0
  100. package/dist/value-providers/runs-on.d.ts.map +1 -0
  101. package/dist/value-providers/runs-on.js +34 -0
  102. package/dist/value-providers/runs-on.js.map +1 -0
  103. package/dist/value-providers.d.ts +6 -0
  104. package/dist/value-providers.d.ts.map +1 -0
  105. package/dist/value-providers.js +30 -0
  106. package/dist/value-providers.js.map +1 -0
  107. package/package.json +75 -0
@@ -0,0 +1,35 @@
1
+ export class TTLCache {
2
+ constructor(defaultTTLinMS = 10 * 60 * 1000) {
3
+ this.defaultTTLinMS = defaultTTLinMS;
4
+ this.cache = new Map();
5
+ }
6
+ /**
7
+ *
8
+ * @param key Key to cache value under
9
+ * @param ttlInMS How long is the content valid. If optional, default value will be used
10
+ * @param getter Function to retrieve content if not in cache
11
+ */
12
+ async get(key, ttlInMS, getter) {
13
+ const hasEntry = this.cache.has(key);
14
+ const e = hasEntry && this.cache.get(key);
15
+ if (hasEntry && e && e.cachedAt > Date.now() - (ttlInMS || this.defaultTTLinMS)) {
16
+ return e.content;
17
+ }
18
+ try {
19
+ const content = await getter();
20
+ this.cache.set(key, {
21
+ cachedAt: Date.now(),
22
+ content
23
+ });
24
+ return content;
25
+ }
26
+ catch (e) {
27
+ this.cache.delete(key);
28
+ throw e;
29
+ }
30
+ }
31
+ clear() {
32
+ this.cache.clear();
33
+ }
34
+ }
35
+ //# sourceMappingURL=cache.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cache.js","sourceRoot":"","sources":["../../src/utils/cache.ts"],"names":[],"mappings":"AAMA,MAAM,OAAO,QAAQ;IAGnB,YAAoB,iBAAyB,EAAE,GAAG,EAAE,GAAG,IAAI;QAAvC,mBAAc,GAAd,cAAc,CAAyB;QAFnD,UAAK,GAAG,IAAI,GAAG,EAA+B,CAAC;IAEO,CAAC;IAE/D;;;;;OAKG;IACH,KAAK,CAAC,GAAG,CAAI,GAAW,EAAE,OAA2B,EAAE,MAAwB;QAC7E,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QACrC,MAAM,CAAC,GAAG,QAAQ,IAAI,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QAC1C,IAAI,QAAQ,IAAI,CAAC,IAAI,CAAC,CAAC,QAAQ,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,CAAC,OAAO,IAAI,IAAI,CAAC,cAAc,CAAC,EAAE;YAC/E,OAAO,CAAC,CAAC,OAAY,CAAC;SACvB;QAED,IAAI;YACF,MAAM,OAAO,GAAG,MAAM,MAAM,EAAE,CAAC;YAE/B,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE;gBAClB,QAAQ,EAAE,IAAI,CAAC,GAAG,EAAE;gBACpB,OAAO;aACR,CAAC,CAAC;YAEH,OAAO,OAAO,CAAC;SAChB;QAAC,OAAO,CAAC,EAAE;YACV,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;YACvB,MAAM,CAAC,CAAC;SACT;IACH,CAAC;IAED,KAAK;QACH,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC;IACrB,CAAC;CACF"}
@@ -0,0 +1,3 @@
1
+ export declare function errorMessage(error: unknown): string;
2
+ export declare function errorStatus(error: unknown): number | undefined;
3
+ //# sourceMappingURL=error.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"error.d.ts","sourceRoot":"","sources":["../../src/utils/error.ts"],"names":[],"mappings":"AAEA,wBAAgB,YAAY,CAAC,KAAK,EAAE,OAAO,GAAG,MAAM,CAkBnD;AAED,wBAAgB,WAAW,CAAC,KAAK,EAAE,OAAO,GAAG,MAAM,GAAG,SAAS,CAI9D"}
@@ -0,0 +1,22 @@
1
+ export function errorMessage(error) {
2
+ if (error instanceof Error) {
3
+ return error.message;
4
+ }
5
+ if (typeof error === "string") {
6
+ return error;
7
+ }
8
+ if ("name" in error) {
9
+ return error.name;
10
+ }
11
+ const status = errorStatus(error);
12
+ if (status) {
13
+ return `HTTP ${status}`;
14
+ }
15
+ return "Unknown error";
16
+ }
17
+ export function errorStatus(error) {
18
+ if ("status" in error) {
19
+ return error.status;
20
+ }
21
+ }
22
+ //# sourceMappingURL=error.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"error.js","sourceRoot":"","sources":["../../src/utils/error.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU,YAAY,CAAC,KAAc;IACzC,IAAI,KAAK,YAAY,KAAK,EAAE;QAC1B,OAAO,KAAK,CAAC,OAAO,CAAC;KACtB;IACD,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;QAC7B,OAAO,KAAK,CAAC;KACd;IAED,IAAI,MAAM,IAAK,KAAsB,EAAE;QACrC,OAAQ,KAAsB,CAAC,IAAI,CAAC;KACrC;IAED,MAAM,MAAM,GAAG,WAAW,CAAC,KAAK,CAAC,CAAC;IAClC,IAAI,MAAM,EAAE;QACV,OAAO,QAAQ,MAAM,EAAE,CAAC;KACzB;IAED,OAAO,eAAe,CAAC;AACzB,CAAC;AAED,MAAM,UAAU,WAAW,CAAC,KAAc;IACxC,IAAI,QAAQ,IAAK,KAAsB,EAAE;QACvC,OAAQ,KAAsB,CAAC,MAAM,CAAC;KACvC;AACH,CAAC"}
@@ -0,0 +1,6 @@
1
+ import { Octokit } from "@octokit/rest";
2
+ import { RepositoryContext } from "../initializationOptions";
3
+ import { TTLCache } from "./cache";
4
+ export type RepoPermission = "admin" | "write" | "read" | "none";
5
+ export declare function getRepoPermission(octokit: Octokit, cache: TTLCache, repo: RepositoryContext): Promise<RepoPermission>;
6
+ //# sourceMappingURL=repo-permission.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"repo-permission.d.ts","sourceRoot":"","sources":["../../src/utils/repo-permission.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,OAAO,EAAC,MAAM,eAAe,CAAC;AACtC,OAAO,EAAC,iBAAiB,EAAC,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAC,QAAQ,EAAC,MAAM,SAAS,CAAC;AAIjC,MAAM,MAAM,cAAc,GAAG,OAAO,GAAG,OAAO,GAAG,MAAM,GAAG,MAAM,CAAC;AAEjE,wBAAsB,iBAAiB,CACrC,OAAO,EAAE,OAAO,EAChB,KAAK,EAAE,QAAQ,EACf,IAAI,EAAE,iBAAiB,GACtB,OAAO,CAAC,cAAc,CAAC,CAgBzB"}
@@ -0,0 +1,36 @@
1
+ import { error } from "@actions/languageservice/log";
2
+ import { errorStatus } from "./error";
3
+ import { getUsername } from "./username";
4
+ export async function getRepoPermission(octokit, cache, repo) {
5
+ const username = await getUsername(octokit, cache);
6
+ const permission = await cache.get(`${repo.owner}/${repo.name}/${username}/permission`, undefined, () => fetchRepoPermission(octokit, repo, username));
7
+ switch (permission) {
8
+ case "admin":
9
+ case "write":
10
+ case "read":
11
+ case "none":
12
+ return permission;
13
+ default:
14
+ error(`Unknown permission: ${permission}`);
15
+ return "none";
16
+ }
17
+ }
18
+ async function fetchRepoPermission(octokit, repo, username) {
19
+ try {
20
+ const res = await octokit.request("GET /repos/{owner}/{repo}/collaborators/{username}/permission", {
21
+ owner: repo.owner,
22
+ repo: repo.name,
23
+ username: username
24
+ });
25
+ const permission = res.data?.permission;
26
+ return permission;
27
+ }
28
+ catch (e) {
29
+ const status = errorStatus(e);
30
+ if (status === 404 || status === 403) {
31
+ return "none";
32
+ }
33
+ throw e;
34
+ }
35
+ }
36
+ //# sourceMappingURL=repo-permission.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"repo-permission.js","sourceRoot":"","sources":["../../src/utils/repo-permission.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,KAAK,EAAC,MAAM,8BAA8B,CAAC;AAInD,OAAO,EAAC,WAAW,EAAC,MAAM,SAAS,CAAC;AACpC,OAAO,EAAC,WAAW,EAAC,MAAM,YAAY,CAAC;AAIvC,MAAM,CAAC,KAAK,UAAU,iBAAiB,CACrC,OAAgB,EAChB,KAAe,EACf,IAAuB;IAEvB,MAAM,QAAQ,GAAG,MAAM,WAAW,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;IACnD,MAAM,UAAU,GAAG,MAAM,KAAK,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,IAAI,IAAI,QAAQ,aAAa,EAAE,SAAS,EAAE,GAAG,EAAE,CACtG,mBAAmB,CAAC,OAAO,EAAE,IAAI,EAAE,QAAQ,CAAC,CAC7C,CAAC;IAEF,QAAQ,UAAU,EAAE;QAClB,KAAK,OAAO,CAAC;QACb,KAAK,OAAO,CAAC;QACb,KAAK,MAAM,CAAC;QACZ,KAAK,MAAM;YACT,OAAO,UAAU,CAAC;QACpB;YACE,KAAK,CAAC,uBAAuB,UAAU,EAAE,CAAC,CAAC;YAC3C,OAAO,MAAM,CAAC;KACjB;AACH,CAAC;AAED,KAAK,UAAU,mBAAmB,CAAC,OAAgB,EAAE,IAAuB,EAAE,QAAgB;IAC5F,IAAI;QACF,MAAM,GAAG,GAAG,MAAM,OAAO,CAAC,OAAO,CAAC,+DAA+D,EAAE;YACjG,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,QAAQ,EAAE,QAAQ;SACnB,CAAC,CAAC;QACH,MAAM,UAAU,GAAG,GAAG,CAAC,IAAI,EAAE,UAAU,CAAC;QACxC,OAAO,UAAU,CAAC;KACnB;IAAC,OAAO,CAAC,EAAE;QACV,MAAM,MAAM,GAAG,WAAW,CAAC,CAAC,CAAC,CAAC;QAC9B,IAAI,MAAM,KAAK,GAAG,IAAI,MAAM,KAAK,GAAG,EAAE;YACpC,OAAO,MAAM,CAAC;SACf;QACD,MAAM,CAAC,CAAC;KACT;AACH,CAAC"}
@@ -0,0 +1,2 @@
1
+ export declare function timeOperation<T>(name: string, f: () => T): Promise<T>;
2
+ //# sourceMappingURL=timer.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"timer.d.ts","sourceRoot":"","sources":["../../src/utils/timer.ts"],"names":[],"mappings":"AAEA,wBAAsB,aAAa,CAAC,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAW3E"}
@@ -0,0 +1,12 @@
1
+ import { log } from "@actions/languageservice/log";
2
+ export async function timeOperation(name, f) {
3
+ const start = Date.now();
4
+ const result = f();
5
+ if (result instanceof Promise) {
6
+ await result;
7
+ }
8
+ const end = Date.now();
9
+ log(`${name} took ${end - start}ms`);
10
+ return result;
11
+ }
12
+ //# sourceMappingURL=timer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"timer.js","sourceRoot":"","sources":["../../src/utils/timer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,GAAG,EAAC,MAAM,8BAA8B,CAAC;AAEjD,MAAM,CAAC,KAAK,UAAU,aAAa,CAAI,IAAY,EAAE,CAAU;IAC7D,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;IACzB,MAAM,MAAM,GAAG,CAAC,EAAE,CAAC;IACnB,IAAI,MAAM,YAAY,OAAO,EAAE;QAC7B,MAAM,MAAM,CAAC;KACd;IAED,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;IAEvB,GAAG,CAAC,GAAG,IAAI,SAAS,GAAG,GAAG,KAAK,IAAI,CAAC,CAAC;IACrC,OAAO,MAAM,CAAC;AAChB,CAAC"}
@@ -0,0 +1,4 @@
1
+ import { Octokit } from "@octokit/rest";
2
+ import { TTLCache } from "./cache";
3
+ export declare function getUsername(octokit: Octokit, cache: TTLCache): Promise<string>;
4
+ //# sourceMappingURL=username.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"username.d.ts","sourceRoot":"","sources":["../../src/utils/username.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,OAAO,EAAC,MAAM,eAAe,CAAC;AACtC,OAAO,EAAC,QAAQ,EAAC,MAAM,SAAS,CAAC;AAEjC,wBAAsB,WAAW,CAAC,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,GAAG,OAAO,CAAC,MAAM,CAAC,CAEpF"}
@@ -0,0 +1,14 @@
1
+ export async function getUsername(octokit, cache) {
2
+ return await cache.get(`/username`, undefined, () => fetchUsername(octokit));
3
+ }
4
+ async function fetchUsername(octokit) {
5
+ try {
6
+ const username = await octokit.request("GET /user").then(res => res.data.login);
7
+ return username;
8
+ }
9
+ catch (e) {
10
+ console.log("Failure to retrieve username: ", e);
11
+ throw e;
12
+ }
13
+ }
14
+ //# sourceMappingURL=username.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"username.js","sourceRoot":"","sources":["../../src/utils/username.ts"],"names":[],"mappings":"AAGA,MAAM,CAAC,KAAK,UAAU,WAAW,CAAC,OAAgB,EAAE,KAAe;IACjE,OAAO,MAAM,KAAK,CAAC,GAAG,CAAC,WAAW,EAAE,SAAS,EAAE,GAAG,EAAE,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,CAAC;AAC/E,CAAC;AAED,KAAK,UAAU,aAAa,CAAC,OAAgB;IAC3C,IAAI;QACF,MAAM,QAAQ,GAAG,MAAM,OAAO,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAChF,OAAO,QAAQ,CAAC;KACjB;IAAC,OAAO,CAAC,EAAE;QACV,OAAO,CAAC,GAAG,CAAC,gCAAgC,EAAE,CAAC,CAAC,CAAC;QACjD,MAAM,CAAC,CAAC;KACT;AACH,CAAC"}
@@ -0,0 +1,8 @@
1
+ import { ActionInputs, ActionReference } from "@actions/languageservice/action";
2
+ import { WorkflowContext } from "@actions/languageservice/context/workflow-context";
3
+ import { Value } from "@actions/languageservice/value-providers/config";
4
+ import { Octokit } from "@octokit/rest";
5
+ import { TTLCache } from "../utils/cache";
6
+ export declare function getActionInputs(client: Octokit, cache: TTLCache, action: ActionReference): Promise<ActionInputs | undefined>;
7
+ export declare function getActionInputValues(client: Octokit, cache: TTLCache, context: WorkflowContext): Promise<Value[]>;
8
+ //# sourceMappingURL=action-inputs.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"action-inputs.d.ts","sourceRoot":"","sources":["../../src/value-providers/action-inputs.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,YAAY,EAAE,eAAe,EAAuB,MAAM,iCAAiC,CAAC;AACpG,OAAO,EAAC,eAAe,EAAC,MAAM,mDAAmD,CAAC;AAClF,OAAO,EAAC,KAAK,EAAC,MAAM,iDAAiD,CAAC;AAEtE,OAAO,EAAC,OAAO,EAAC,MAAM,eAAe,CAAC;AAEtC,OAAO,EAAC,QAAQ,EAAC,MAAM,gBAAgB,CAAC;AAExC,wBAAsB,eAAe,CACnC,MAAM,EAAE,OAAO,EACf,KAAK,EAAE,QAAQ,EACf,MAAM,EAAE,eAAe,GACtB,OAAO,CAAC,YAAY,GAAG,SAAS,CAAC,CAEnC;AAED,wBAAsB,oBAAoB,CACxC,MAAM,EAAE,OAAO,EACf,KAAK,EAAE,QAAQ,EACf,OAAO,EAAE,eAAe,GACvB,OAAO,CAAC,KAAK,EAAE,CAAC,CAsBlB"}
@@ -0,0 +1,28 @@
1
+ import { parseActionReference } from "@actions/languageservice/action";
2
+ import { isActionStep } from "@actions/workflow-parser/model/type-guards";
3
+ import { fetchActionMetadata } from "../utils/action-metadata";
4
+ export async function getActionInputs(client, cache, action) {
5
+ return (await fetchActionMetadata(client, cache, action))?.inputs;
6
+ }
7
+ export async function getActionInputValues(client, cache, context) {
8
+ if (!context.step || !isActionStep(context.step)) {
9
+ return [];
10
+ }
11
+ const action = parseActionReference(context.step.uses.value);
12
+ if (!action) {
13
+ return [];
14
+ }
15
+ const inputs = await getActionInputs(client, cache, action);
16
+ if (!inputs) {
17
+ return [];
18
+ }
19
+ return Object.entries(inputs).map(([inputName, input]) => {
20
+ return {
21
+ label: inputName,
22
+ description: input.description,
23
+ insertText: `${inputName}: `,
24
+ deprecated: input.deprecationMessage !== undefined
25
+ };
26
+ });
27
+ }
28
+ //# sourceMappingURL=action-inputs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"action-inputs.js","sourceRoot":"","sources":["../../src/value-providers/action-inputs.ts"],"names":[],"mappings":"AAAA,OAAO,EAAgC,oBAAoB,EAAC,MAAM,iCAAiC,CAAC;AAGpG,OAAO,EAAC,YAAY,EAAC,MAAM,4CAA4C,CAAC;AAExE,OAAO,EAAC,mBAAmB,EAAC,MAAM,0BAA0B,CAAC;AAG7D,MAAM,CAAC,KAAK,UAAU,eAAe,CACnC,MAAe,EACf,KAAe,EACf,MAAuB;IAEvB,OAAO,CAAC,MAAM,mBAAmB,CAAC,MAAM,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC,EAAE,MAAM,CAAC;AACpE,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,oBAAoB,CACxC,MAAe,EACf,KAAe,EACf,OAAwB;IAExB,IAAI,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;QAChD,OAAO,EAAE,CAAC;KACX;IAED,MAAM,MAAM,GAAG,oBAAoB,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC7D,IAAI,CAAC,MAAM,EAAE;QACX,OAAO,EAAE,CAAC;KACX;IACD,MAAM,MAAM,GAAG,MAAM,eAAe,CAAC,MAAM,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC;IAC5D,IAAI,CAAC,MAAM,EAAE;QACX,OAAO,EAAE,CAAC;KACX;IAED,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,KAAK,CAAC,EAAE,EAAE;QACvD,OAAO;YACL,KAAK,EAAE,SAAS;YAChB,WAAW,EAAE,KAAK,CAAC,WAAW;YAC9B,UAAU,EAAE,GAAG,SAAS,IAAI;YAC5B,UAAU,EAAE,KAAK,CAAC,kBAAkB,KAAK,SAAS;SACnD,CAAC;IACJ,CAAC,CAAC,CAAC;AACL,CAAC"}
@@ -0,0 +1,5 @@
1
+ import { Value } from "@actions/languageservice/value-providers/config";
2
+ import { Octokit } from "@octokit/rest";
3
+ import { TTLCache } from "../utils/cache";
4
+ export declare function getEnvironments(client: Octokit, cache: TTLCache, owner: string, name: string): Promise<Value[]>;
5
+ //# sourceMappingURL=job-environment.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"job-environment.d.ts","sourceRoot":"","sources":["../../src/value-providers/job-environment.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,KAAK,EAAC,MAAM,iDAAiD,CAAC;AACtE,OAAO,EAAC,OAAO,EAAC,MAAM,eAAe,CAAC;AACtC,OAAO,EAAC,QAAQ,EAAC,MAAM,gBAAgB,CAAC;AAExC,wBAAsB,eAAe,CAAC,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC,CAKrH"}
@@ -0,0 +1,21 @@
1
+ export async function getEnvironments(client, cache, owner, name) {
2
+ const environments = await cache.get(`${owner}/${name}/environments`, undefined, () => fetchEnvironments(client, owner, name));
3
+ return Array.from(environments).map(env => ({ label: env }));
4
+ }
5
+ async function fetchEnvironments(client, owner, name) {
6
+ let environments = [];
7
+ try {
8
+ const response = await client.repos.getAllEnvironments({
9
+ owner,
10
+ repo: name
11
+ });
12
+ if (response.data.environments) {
13
+ environments = response.data.environments.map(env => env.name);
14
+ }
15
+ }
16
+ catch (e) {
17
+ console.log("Failure to retrieve environments: ", e);
18
+ }
19
+ return environments;
20
+ }
21
+ //# sourceMappingURL=job-environment.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"job-environment.js","sourceRoot":"","sources":["../../src/value-providers/job-environment.ts"],"names":[],"mappings":"AAIA,MAAM,CAAC,KAAK,UAAU,eAAe,CAAC,MAAe,EAAE,KAAe,EAAE,KAAa,EAAE,IAAY;IACjG,MAAM,YAAY,GAAG,MAAM,KAAK,CAAC,GAAG,CAAC,GAAG,KAAK,IAAI,IAAI,eAAe,EAAE,SAAS,EAAE,GAAG,EAAE,CACpF,iBAAiB,CAAC,MAAM,EAAE,KAAK,EAAE,IAAI,CAAC,CACvC,CAAC;IACF,OAAO,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,EAAC,KAAK,EAAE,GAAG,EAAC,CAAC,CAAC,CAAC;AAC7D,CAAC;AAED,KAAK,UAAU,iBAAiB,CAAC,MAAe,EAAE,KAAa,EAAE,IAAY;IAC3E,IAAI,YAAY,GAAa,EAAE,CAAC;IAChC,IAAI;QACF,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,KAAK,CAAC,kBAAkB,CAAC;YACrD,KAAK;YACL,IAAI,EAAE,IAAI;SACX,CAAC,CAAC;QAEH,IAAI,QAAQ,CAAC,IAAI,CAAC,YAAY,EAAE;YAC9B,YAAY,GAAG,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;SAChE;KACF;IAAC,OAAO,CAAC,EAAE;QACV,OAAO,CAAC,GAAG,CAAC,oCAAoC,EAAE,CAAC,CAAC,CAAC;KACtD;IAED,OAAO,YAAY,CAAC;AACtB,CAAC"}
@@ -0,0 +1,5 @@
1
+ import { Value } from "@actions/languageservice/value-providers/config";
2
+ import { Octokit } from "@octokit/rest";
3
+ import { TTLCache } from "../utils/cache";
4
+ export declare function getRunnerLabels(client: Octokit, cache: TTLCache, owner: string, name: string): Promise<Value[]>;
5
+ //# sourceMappingURL=runs-on.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"runs-on.d.ts","sourceRoot":"","sources":["../../src/value-providers/runs-on.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,KAAK,EAAC,MAAM,iDAAiD,CAAC;AAEtE,OAAO,EAAC,OAAO,EAAC,MAAM,eAAe,CAAC;AACtC,OAAO,EAAC,QAAQ,EAAC,MAAM,gBAAgB,CAAC;AAKxC,wBAAsB,eAAe,CAAC,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC,CAUrH"}
@@ -0,0 +1,34 @@
1
+ import { log } from "@actions/languageservice/log";
2
+ import { DEFAULT_RUNNER_LABELS } from "@actions/languageservice/value-providers/default";
3
+ import { errorMessage } from "../utils/error";
4
+ // Limitation: getRunnerLabels returns default hosted labels and labels for repository self-hosted runners.
5
+ // It doesn't return labels for organization runners visible to the repository.
6
+ export async function getRunnerLabels(client, cache, owner, name) {
7
+ const repoLabels = await cache.get(`${owner}/${name}/runner-labels`, undefined, () => fetchRunnerLabels(client, owner, name));
8
+ for (const label of DEFAULT_RUNNER_LABELS) {
9
+ repoLabels.add(label);
10
+ }
11
+ return Array.from(repoLabels).map(label => ({ label }));
12
+ }
13
+ async function fetchRunnerLabels(client, owner, name) {
14
+ const labels = new Set();
15
+ try {
16
+ const itor = client.paginate.iterator(client.actions.listSelfHostedRunnersForRepo, {
17
+ owner,
18
+ repo: name,
19
+ per_page: 100
20
+ });
21
+ for await (const response of itor) {
22
+ for (const runner of response.data) {
23
+ for (const label of runner.labels) {
24
+ labels.add(label.name);
25
+ }
26
+ }
27
+ }
28
+ }
29
+ catch (e) {
30
+ log(`Failure to retrieve runner labels: ${errorMessage(e)}`);
31
+ }
32
+ return labels;
33
+ }
34
+ //# sourceMappingURL=runs-on.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"runs-on.js","sourceRoot":"","sources":["../../src/value-providers/runs-on.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,GAAG,EAAC,MAAM,8BAA8B,CAAC;AAEjD,OAAO,EAAC,qBAAqB,EAAC,MAAM,kDAAkD,CAAC;AAGvF,OAAO,EAAC,YAAY,EAAC,MAAM,gBAAgB,CAAC;AAE5C,2GAA2G;AAC3G,+EAA+E;AAC/E,MAAM,CAAC,KAAK,UAAU,eAAe,CAAC,MAAe,EAAE,KAAe,EAAE,KAAa,EAAE,IAAY;IACjG,MAAM,UAAU,GAAG,MAAM,KAAK,CAAC,GAAG,CAAC,GAAG,KAAK,IAAI,IAAI,gBAAgB,EAAE,SAAS,EAAE,GAAG,EAAE,CACnF,iBAAiB,CAAC,MAAM,EAAE,KAAK,EAAE,IAAI,CAAC,CACvC,CAAC;IAEF,KAAK,MAAM,KAAK,IAAI,qBAAqB,EAAE;QACzC,UAAU,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;KACvB;IAED,OAAO,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,EAAC,KAAK,EAAC,CAAC,CAAC,CAAC;AACxD,CAAC;AAED,KAAK,UAAU,iBAAiB,CAAC,MAAe,EAAE,KAAa,EAAE,IAAY;IAC3E,MAAM,MAAM,GAAG,IAAI,GAAG,EAAU,CAAC;IACjC,IAAI;QACF,MAAM,IAAI,GAAG,MAAM,CAAC,QAAQ,CAAC,QAAQ,CAAC,MAAM,CAAC,OAAO,CAAC,4BAA4B,EAAE;YACjF,KAAK;YACL,IAAI,EAAE,IAAI;YACV,QAAQ,EAAE,GAAG;SACd,CAAC,CAAC;QAEH,IAAI,KAAK,EAAE,MAAM,QAAQ,IAAI,IAAI,EAAE;YACjC,KAAK,MAAM,MAAM,IAAI,QAAQ,CAAC,IAAI,EAAE;gBAClC,KAAK,MAAM,KAAK,IAAI,MAAM,CAAC,MAAM,EAAE;oBACjC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;iBACxB;aACF;SACF;KACF;IAAC,OAAO,CAAC,EAAE;QACV,GAAG,CAAC,sCAAsC,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;KAC9D;IAED,OAAO,MAAM,CAAC;AAChB,CAAC"}
@@ -0,0 +1,6 @@
1
+ import { ValueProviderConfig } from "@actions/languageservice";
2
+ import { Octokit } from "@octokit/rest";
3
+ import { RepositoryContext } from "./initializationOptions";
4
+ import { TTLCache } from "./utils/cache";
5
+ export declare function valueProviders(client: Octokit | undefined, repo: RepositoryContext | undefined, cache: TTLCache): ValueProviderConfig;
6
+ //# sourceMappingURL=value-providers.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"value-providers.d.ts","sourceRoot":"","sources":["../src/value-providers.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,mBAAmB,EAAC,MAAM,0BAA0B,CAAC;AAG7D,OAAO,EAAC,OAAO,EAAC,MAAM,eAAe,CAAC;AACtC,OAAO,EAAC,iBAAiB,EAAC,MAAM,yBAAyB,CAAC;AAC1D,OAAO,EAAC,QAAQ,EAAC,MAAM,eAAe,CAAC;AAKvC,wBAAgB,cAAc,CAC5B,MAAM,EAAE,OAAO,GAAG,SAAS,EAC3B,IAAI,EAAE,iBAAiB,GAAG,SAAS,EACnC,KAAK,EAAE,QAAQ,GACd,mBAAmB,CAyBrB"}
@@ -0,0 +1,30 @@
1
+ import { ValueProviderKind } from "@actions/languageservice/value-providers/config";
2
+ import { getActionInputValues } from "./value-providers/action-inputs";
3
+ import { getEnvironments } from "./value-providers/job-environment";
4
+ import { getRunnerLabels } from "./value-providers/runs-on";
5
+ export function valueProviders(client, repo, cache) {
6
+ if (!repo || !client) {
7
+ return {};
8
+ }
9
+ return {
10
+ "job-environment": {
11
+ kind: ValueProviderKind.AllowedValues,
12
+ caseInsensitive: true,
13
+ get: () => getEnvironments(client, cache, repo.owner, repo.name)
14
+ },
15
+ "job-environment-name": {
16
+ kind: ValueProviderKind.AllowedValues,
17
+ caseInsensitive: true,
18
+ get: () => getEnvironments(client, cache, repo.owner, repo.name)
19
+ },
20
+ "runs-on": {
21
+ kind: ValueProviderKind.SuggestedValues,
22
+ get: () => getRunnerLabels(client, cache, repo.owner, repo.name)
23
+ },
24
+ "step-with": {
25
+ kind: ValueProviderKind.AllowedValues,
26
+ get: (context) => getActionInputValues(client, cache, context)
27
+ }
28
+ };
29
+ }
30
+ //# sourceMappingURL=value-providers.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"value-providers.js","sourceRoot":"","sources":["../src/value-providers.ts"],"names":[],"mappings":"AAEA,OAAO,EAAC,iBAAiB,EAAC,MAAM,iDAAiD,CAAC;AAIlF,OAAO,EAAC,oBAAoB,EAAC,MAAM,iCAAiC,CAAC;AACrE,OAAO,EAAC,eAAe,EAAC,MAAM,mCAAmC,CAAC;AAClE,OAAO,EAAC,eAAe,EAAC,MAAM,2BAA2B,CAAC;AAE1D,MAAM,UAAU,cAAc,CAC5B,MAA2B,EAC3B,IAAmC,EACnC,KAAe;IAEf,IAAI,CAAC,IAAI,IAAI,CAAC,MAAM,EAAE;QACpB,OAAO,EAAE,CAAC;KACX;IAED,OAAO;QACL,iBAAiB,EAAE;YACjB,IAAI,EAAE,iBAAiB,CAAC,aAAa;YACrC,eAAe,EAAE,IAAI;YACrB,GAAG,EAAE,GAAG,EAAE,CAAC,eAAe,CAAC,MAAM,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC;SACjE;QACD,sBAAsB,EAAE;YACtB,IAAI,EAAE,iBAAiB,CAAC,aAAa;YACrC,eAAe,EAAE,IAAI;YACrB,GAAG,EAAE,GAAG,EAAE,CAAC,eAAe,CAAC,MAAM,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC;SACjE;QACD,SAAS,EAAE;YACT,IAAI,EAAE,iBAAiB,CAAC,eAAe;YACvC,GAAG,EAAE,GAAG,EAAE,CAAC,eAAe,CAAC,MAAM,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC;SACjE;QACD,WAAW,EAAE;YACX,IAAI,EAAE,iBAAiB,CAAC,aAAa;YACrC,GAAG,EAAE,CAAC,OAAwB,EAAE,EAAE,CAAC,oBAAoB,CAAC,MAAM,EAAE,KAAK,EAAE,OAAO,CAAC;SAChF;KACF,CAAC;AACJ,CAAC"}
package/package.json ADDED
@@ -0,0 +1,75 @@
1
+ {
2
+ "name": "@actions/languageserver",
3
+ "version": "0.2.0",
4
+ "description": "Language server for GitHub Actions",
5
+ "license": "MIT",
6
+ "type": "module",
7
+ "source": "./src/index.ts",
8
+ "publishConfig": {
9
+ "access": "public"
10
+ },
11
+ "exports": {
12
+ ".": {
13
+ "import": "./dist/index.js"
14
+ },
15
+ "./*": {
16
+ "import": "./dist/*.js"
17
+ }
18
+ },
19
+ "typesVersions": {
20
+ "*": {
21
+ ".": [
22
+ "./dist/index.d.ts"
23
+ ],
24
+ "*": [
25
+ "./dist/*.d.ts"
26
+ ]
27
+ }
28
+ },
29
+ "repository": {
30
+ "type": "git",
31
+ "url": "https://github.com/actions/languageservices"
32
+ },
33
+ "scripts": {
34
+ "build": "tsc --build tsconfig.build.json",
35
+ "clean": "rimraf dist",
36
+ "format": "prettier --write '**/*.ts'",
37
+ "format-check": "prettier --check '**/*.ts'",
38
+ "lint": "eslint 'src/**/*.ts'",
39
+ "lint-fix": "eslint --fix 'src/**/*.ts'",
40
+ "prepublishOnly": "npm run build && npm run test",
41
+ "test": "NODE_OPTIONS=\"--experimental-vm-modules\" jest",
42
+ "test-watch": "NODE_OPTIONS=\"--experimental-vm-modules\" jest --watch",
43
+ "watch": "tsc --build tsconfig.build.json --watch"
44
+ },
45
+ "dependencies": {
46
+ "@actions/languageservice": "^0.2.0",
47
+ "@actions/workflow-parser": "^0.2.0",
48
+ "@octokit/rest": "^19.0.7",
49
+ "@octokit/types": "^9.0.0",
50
+ "vscode-languageserver": "^8.0.2",
51
+ "vscode-languageserver-textdocument": "^1.0.7",
52
+ "yaml": "^2.1.3"
53
+ },
54
+ "engines": {
55
+ "node": ">= 16.15"
56
+ },
57
+ "files": [
58
+ "dist/**/*"
59
+ ],
60
+ "devDependencies": {
61
+ "@types/jest": "^29.0.3",
62
+ "@typescript-eslint/eslint-plugin": "^5.56.0",
63
+ "@typescript-eslint/parser": "^5.56.0",
64
+ "eslint": "^8.36.0",
65
+ "eslint-config-prettier": "^8.8.0",
66
+ "eslint-plugin-prettier": "^4.2.1",
67
+ "fetch-mock": "^9.11.0",
68
+ "jest": "^29.0.3",
69
+ "prettier": "^2.8.3",
70
+ "rimraf": "^3.0.2",
71
+ "ts-jest": "^29.0.3",
72
+ "typescript": "^4.8.4"
73
+ },
74
+ "gitHead": "b79d0e8e4706e94ce93ca367f47bc4207c8dedfa"
75
+ }