@backstage/plugin-scaffolder-backend-module-gitlab 0.11.3-next.2 → 0.11.4-next.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.
package/CHANGELOG.md CHANGED
@@ -1,5 +1,31 @@
1
1
  # @backstage/plugin-scaffolder-backend-module-gitlab
2
2
 
3
+ ## 0.11.4-next.0
4
+
5
+ ### Patch Changes
6
+
7
+ - 5730c8e: Added `maskedAndHidden` option to `gitlab:projectVariable:create` and `publish:gitlab` action to support creating GitLab project variables that are both masked and hidden. Updated gitbeaker to version 43.8.0 for proper type support.
8
+ - Updated dependencies
9
+ - @backstage/integration@1.21.0-next.0
10
+ - @backstage/backend-plugin-api@1.7.1-next.0
11
+ - @backstage/config@1.3.6
12
+ - @backstage/errors@1.2.7
13
+ - @backstage/plugin-scaffolder-node@0.12.6-next.0
14
+
15
+ ## 0.11.3
16
+
17
+ ### Patch Changes
18
+
19
+ - 6b5e7d9: Allow setting optional description on group creation
20
+ - 7455dae: Use node prefix on native imports
21
+ - f0f9403: Changed `gitlab:group:ensureExists` action to use `Groups.show` API instead of `Groups.search` for checking if a group path exists. This is more efficient as it directly retrieves the group by path rather than searching and filtering results.
22
+ - 32c51c0: Added new `gitlab:user:info` scaffolder action that retrieves information about a GitLab user. The action can fetch either the current authenticated user or a specific user by ID.
23
+ - 69d880e: Bump to latest zod to ensure it has the latest features
24
+ - Updated dependencies
25
+ - @backstage/integration@1.20.0
26
+ - @backstage/backend-plugin-api@1.7.0
27
+ - @backstage/plugin-scaffolder-node@0.12.5
28
+
3
29
  ## 0.11.3-next.2
4
30
 
5
31
  ### Patch Changes
package/README.md CHANGED
@@ -117,6 +117,7 @@ spec:
117
117
  value: "${{ steps['gitlab-access-token'].output.access_token }}"
118
118
  variableType: 'env_var'
119
119
  masked: true
120
+ maskedAndHidden: false
120
121
  variableProtected: false
121
122
  raw: false
122
123
  environmentScope: '*'
@@ -100,6 +100,7 @@ function createPublishGitlabAction(options) {
100
100
  variable_type: z.enum(["env_var", "file"]).optional(),
101
101
  protected: z.boolean().optional(),
102
102
  masked: z.boolean().optional(),
103
+ masked_and_hidden: z.boolean().optional(),
103
104
  raw: z.boolean().optional(),
104
105
  environment_scope: z.string().optional()
105
106
  })
@@ -197,7 +198,7 @@ function createPublishGitlabAction(options) {
197
198
  host: integrationConfig.config.baseUrl,
198
199
  token: integrationConfig.config.token
199
200
  });
200
- await adminClient.ProjectMembers.add(projectId, userId, 50);
201
+ await adminClient.ProjectMembers.add(projectId, 50, { userId });
201
202
  }
202
203
  const remoteUrl = http_url_to_repo.replace(/\.git$/, "");
203
204
  const repoContentsUrl = `${remoteUrl}/-/blob/${defaultBranch}`;
@@ -273,6 +274,7 @@ function createPublishGitlabAction(options) {
273
274
  variable_type: variable.variable_type ?? "env_var",
274
275
  protected: variable.protected ?? false,
275
276
  masked: variable.masked ?? false,
277
+ masked_and_hidden: variable.masked_and_hidden ?? false,
276
278
  raw: variable.raw ?? false,
277
279
  environment_scope: variable.environment_scope ?? "*"
278
280
  });
@@ -285,6 +287,7 @@ function createPublishGitlabAction(options) {
285
287
  variableType: variableWithDefaults.variable_type,
286
288
  protected: variableWithDefaults.protected,
287
289
  masked: variableWithDefaults.masked,
290
+ masked_and_hidden: variableWithDefaults.masked_and_hidden,
288
291
  environmentScope: variableWithDefaults.environment_scope,
289
292
  description: variableWithDefaults.description,
290
293
  raw: variableWithDefaults.raw
@@ -1 +1 @@
1
- {"version":3,"file":"gitlab.cjs.js","sources":["../../src/actions/gitlab.ts"],"sourcesContent":["/*\n * Copyright 2021 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { InputError } from '@backstage/errors';\nimport { ScmIntegrationRegistry } from '@backstage/integration';\nimport {\n createTemplateAction,\n getRepoSourceDirectory,\n initRepoAndPush,\n parseRepoUrl,\n} from '@backstage/plugin-scaffolder-node';\nimport { Gitlab, VariableType } from '@gitbeaker/rest';\nimport { Config } from '@backstage/config';\nimport { examples } from './gitlab.examples';\n\n/**\n * Creates a new action that initializes a git repository of the content in the workspace\n * and publishes it to GitLab.\n *\n * @public\n */\nexport function createPublishGitlabAction(options: {\n integrations: ScmIntegrationRegistry;\n config: Config;\n}) {\n const { integrations, config } = options;\n\n return createTemplateAction({\n id: 'publish:gitlab',\n description:\n 'Initializes a git repository of the content in the workspace, and publishes it to GitLab.',\n examples,\n schema: {\n input: {\n repoUrl: z =>\n z.string({\n description: `Accepts the format 'gitlab.com?repo=project_name&owner=group_name' where 'project_name' is the repository name and 'group_name' is a group or username`,\n }),\n repoVisibility: z =>\n z\n .enum(['private', 'public', 'internal'], {\n description: `Sets the visibility of the repository. The default value is 'private'. (deprecated, use settings.visibility instead)`,\n })\n .optional(),\n defaultBranch: z =>\n z\n .string({\n description: `Sets the default branch on the repository. The default value is 'master'`,\n })\n .optional(),\n gitCommitMessage: z =>\n z\n .string({\n description: `Sets the commit message on the repository. The default value is 'initial commit'`,\n })\n .optional(),\n gitAuthorName: z =>\n z\n .string({\n description: `Sets the default author name for the commit. The default value is 'Scaffolder'`,\n })\n .optional(),\n gitAuthorEmail: z =>\n z\n .string({\n description: `Sets the default author email for the commit.`,\n })\n .optional(),\n signCommit: z =>\n z\n .boolean({\n description: 'Sign commit with configured PGP private key',\n })\n .optional(),\n sourcePath: z =>\n z\n .union([z.string(), z.boolean()], {\n description:\n 'Path within the workspace that will be used as the repository root. If omitted or set to true, the entire workspace will be published as the repository. If set to false, the created repository will be empty.',\n })\n .optional(),\n skipExisting: z =>\n z\n .boolean({\n description:\n 'Do not publish the repository if it already exists. The default value is false.',\n })\n .optional(),\n token: z =>\n z\n .string({\n description: 'The token to use for authorization to GitLab',\n })\n .optional(),\n setUserAsOwner: z =>\n z\n .boolean({\n description:\n 'Set the token user as owner of the newly created repository. Requires a token authorized to do the edit in the integration configuration for the matching host',\n })\n .optional(),\n topics: z =>\n z\n .array(z.string(), {\n description:\n 'Topic labels to apply on the repository. (deprecated, use settings.topics instead)',\n })\n .optional(),\n settings: z =>\n z\n .object({\n path: z\n .string({\n description:\n 'Repository name for new project. Generated based on name if not provided (generated as lowercase with dashes).',\n })\n .optional(),\n auto_devops_enabled: z\n .boolean({\n description: 'Enable Auto DevOps for this project',\n })\n .optional(),\n ci_config_path: z\n .string({\n description: 'Custom CI config path for this project',\n })\n .optional(),\n description: z\n .string({\n description: 'Short project description',\n })\n .optional(),\n merge_method: z\n .enum(['merge', 'rebase_merge', 'ff'], {\n description: 'Merge Methods (merge, rebase_merge, ff)',\n })\n .optional(),\n squash_option: z\n .enum(['default_off', 'default_on', 'never', 'always'], {\n description:\n 'Set squash option for the project (never, always, default_on, default_off)',\n })\n .optional(),\n topics: z\n .array(z.string(), {\n description: 'Topic labels to apply on the repository',\n })\n .optional(),\n visibility: z\n .enum(['private', 'public', 'internal'], {\n description:\n 'The visibility of the project. Can be private, internal, or public. The default value is private.',\n })\n .optional(),\n only_allow_merge_if_all_discussions_are_resolved: z\n .boolean({\n description:\n 'Set whether merge requests can only be merged when all the discussions are resolved.',\n })\n .optional(),\n only_allow_merge_if_pipeline_succeeds: z\n .boolean({\n description:\n 'Set whether merge requests can only be merged with successful pipelines. This setting is named Pipelines must succeed in the project settings.',\n })\n .optional(),\n allow_merge_on_skipped_pipeline: z\n .boolean({\n description:\n 'Set whether or not merge requests can be merged with skipped jobs.',\n })\n .optional(),\n })\n .optional(),\n branches: z =>\n z\n .array(\n z.object({\n name: z.string(),\n protect: z.boolean().optional(),\n create: z.boolean().optional(),\n ref: z.string().optional(),\n }),\n )\n .optional(),\n projectVariables: z =>\n z\n .array(\n z.object({\n key: z.string(),\n value: z.string(),\n description: z.string().optional(),\n variable_type: z.enum(['env_var', 'file']).optional(),\n protected: z.boolean().optional(),\n masked: z.boolean().optional(),\n raw: z.boolean().optional(),\n environment_scope: z.string().optional(),\n }),\n )\n .optional(),\n },\n output: {\n remoteUrl: z =>\n z.string({\n description: 'A URL to the repository with the provider',\n }),\n repoContentsUrl: z =>\n z.string({\n description: 'A URL to the root of the repository',\n }),\n projectId: z =>\n z.number({\n description: 'The ID of the project',\n }),\n commitHash: z =>\n z.string({\n description: 'The git commit hash of the initial commit',\n }),\n created: z =>\n z.boolean({\n description: 'Whether the repository was created or not',\n }),\n },\n },\n async handler(ctx) {\n const {\n repoUrl,\n repoVisibility = 'private',\n defaultBranch = 'master',\n gitCommitMessage = 'initial commit',\n gitAuthorName,\n gitAuthorEmail,\n setUserAsOwner = false,\n topics = [],\n settings = {},\n branches = [],\n projectVariables = [],\n skipExisting = false,\n signCommit,\n } = ctx.input;\n const { owner, repo, host } = parseRepoUrl(repoUrl, integrations);\n\n if (!owner) {\n throw new InputError(\n `No owner provided for host: ${host}, and repo ${repo}`,\n );\n }\n\n const integrationConfig = integrations.gitlab.byHost(host);\n\n if (!integrationConfig) {\n throw new InputError(\n `No matching integration configuration for host ${host}, please check your integrations config`,\n );\n }\n\n if (!integrationConfig.config.token && !ctx.input.token) {\n throw new InputError(`No token available for host ${host}`);\n }\n\n const token = ctx.input.token || integrationConfig.config.token!;\n const tokenType = ctx.input.token ? 'oauthToken' : 'token';\n\n const client = new Gitlab({\n host: integrationConfig.config.baseUrl,\n [tokenType]: token,\n });\n\n let targetNamespaceId;\n let targetNamespaceKind;\n try {\n const namespaceResponse = (await client.Namespaces.show(owner)) as {\n id: number;\n kind: string;\n };\n\n targetNamespaceId = namespaceResponse.id;\n targetNamespaceKind = namespaceResponse.kind;\n } catch (e) {\n if (e.cause?.response?.status === 404) {\n throw new InputError(\n `The namespace ${owner} is not found or the user doesn't have permissions to access it`,\n );\n }\n throw e;\n }\n\n const { id: userId } = (await client.Users.showCurrentUser()) as {\n id: number;\n };\n\n if (!targetNamespaceId) {\n targetNamespaceId = userId;\n targetNamespaceKind = 'user';\n }\n\n const existingProjects =\n targetNamespaceKind === 'user'\n ? await client.Users.allProjects(owner, { search: repo })\n : await client.Groups.allProjects(owner, { search: repo });\n\n const existingProject = existingProjects.find(\n project => project.path === repo,\n );\n\n if (!skipExisting || (skipExisting && !existingProject)) {\n ctx.logger.info(`Creating repo ${repo} in namespace ${owner}.`);\n const { id: projectId, http_url_to_repo } =\n await client.Projects.create({\n namespaceId: targetNamespaceId,\n name: repo,\n visibility: repoVisibility,\n ...(topics.length ? { topics } : {}),\n ...(Object.keys(settings).length ? { ...settings } : {}),\n });\n\n // When setUserAsOwner is true the input token is expected to come from an unprivileged user GitLab\n // OAuth flow. In this case GitLab works in a way that allows the unprivileged user to\n // create the repository, but not to push the default protected branch (e.g. master).\n // In order to set the user as owner of the newly created repository we need to check that the\n // GitLab integration configuration for the matching host contains a token and use\n // such token to bootstrap a new privileged client.\n if (setUserAsOwner && integrationConfig.config.token) {\n const adminClient = new Gitlab({\n host: integrationConfig.config.baseUrl,\n token: integrationConfig.config.token,\n });\n\n await adminClient.ProjectMembers.add(projectId, userId, 50);\n }\n\n const remoteUrl = (http_url_to_repo as string).replace(/\\.git$/, '');\n const repoContentsUrl = `${remoteUrl}/-/blob/${defaultBranch}`;\n\n const gitAuthorInfo = {\n name: gitAuthorName\n ? gitAuthorName\n : config.getOptionalString('scaffolder.defaultAuthor.name'),\n email: gitAuthorEmail\n ? gitAuthorEmail\n : config.getOptionalString('scaffolder.defaultAuthor.email'),\n };\n const signingKey =\n integrationConfig.config.commitSigningKey ??\n config.getOptionalString('scaffolder.defaultCommitSigningKey');\n if (signCommit && !signingKey) {\n throw new Error(\n 'Signing commits is enabled but no signing key is provided in the configuration',\n );\n }\n\n const shouldSkipPublish =\n typeof ctx.input.sourcePath === 'boolean' && !ctx.input.sourcePath;\n if (!shouldSkipPublish) {\n const commitResult = await initRepoAndPush({\n dir:\n typeof ctx.input.sourcePath === 'boolean'\n ? ctx.workspacePath\n : getRepoSourceDirectory(\n ctx.workspacePath,\n ctx.input.sourcePath,\n ),\n remoteUrl: http_url_to_repo as string,\n defaultBranch,\n auth: {\n username: 'oauth2',\n password: token,\n },\n logger: ctx.logger,\n commitMessage: gitCommitMessage\n ? gitCommitMessage\n : config.getOptionalString('scaffolder.defaultCommitMessage'),\n gitAuthorInfo,\n signingKey: signCommit ? signingKey : undefined,\n });\n\n if (branches) {\n for (const branch of branches) {\n const {\n name,\n protect = false,\n create = false,\n ref = 'master',\n } = branch;\n\n if (create) {\n try {\n await client.Branches.create(projectId, name, ref);\n } catch (e) {\n throw new InputError(\n `Branch creation failed for ${name}. ${printGitlabError(\n e,\n )}`,\n );\n }\n ctx.logger.info(\n `Branch ${name} created for ${projectId} with ref ${ref}`,\n );\n }\n\n if (protect) {\n try {\n await client.ProtectedBranches.protect(projectId, name);\n } catch (e) {\n throw new InputError(\n `Branch protection failed for ${name}. ${printGitlabError(\n e,\n )}`,\n );\n }\n ctx.logger.info(`Branch ${name} protected for ${projectId}`);\n }\n }\n }\n ctx.output('commitHash', commitResult?.commitHash);\n }\n\n if (projectVariables) {\n for (const variable of projectVariables) {\n const variableWithDefaults = Object.assign(variable, {\n variable_type: (variable.variable_type ??\n 'env_var') as VariableType,\n protected: variable.protected ?? false,\n masked: variable.masked ?? false,\n raw: variable.raw ?? false,\n environment_scope: variable.environment_scope ?? '*',\n });\n\n try {\n await client.ProjectVariables.create(\n projectId,\n variableWithDefaults.key,\n variableWithDefaults.value,\n {\n variableType: variableWithDefaults.variable_type,\n protected: variableWithDefaults.protected,\n masked: variableWithDefaults.masked,\n environmentScope: variableWithDefaults.environment_scope,\n description: variableWithDefaults.description,\n raw: variableWithDefaults.raw,\n },\n );\n } catch (e) {\n throw new InputError(\n `Environment variable creation failed for ${\n variableWithDefaults.key\n }. ${printGitlabError(e)}`,\n );\n }\n }\n }\n ctx.output('remoteUrl', remoteUrl);\n ctx.output('repoContentsUrl', repoContentsUrl);\n ctx.output('projectId', projectId);\n ctx.output('created', true);\n } else if (existingProject) {\n ctx.logger.info(`Repo ${repo} already exists in namespace ${owner}.`);\n const {\n id: projectId,\n http_url_to_repo,\n default_branch,\n } = existingProject;\n const remoteUrl = (http_url_to_repo as string).replace(/\\.git$/, '');\n ctx.output('remoteUrl', remoteUrl);\n ctx.output('repoContentsUrl', `${remoteUrl}/-/blob/${default_branch}`);\n ctx.output('projectId', projectId);\n ctx.output('created', false);\n }\n },\n });\n}\n\nfunction printGitlabError(error: any): string {\n return JSON.stringify({ code: error.code, message: error.description });\n}\n"],"names":["createTemplateAction","examples","parseRepoUrl","InputError","Gitlab","initRepoAndPush","getRepoSourceDirectory"],"mappings":"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"}
1
+ {"version":3,"file":"gitlab.cjs.js","sources":["../../src/actions/gitlab.ts"],"sourcesContent":["/*\n * Copyright 2021 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { InputError } from '@backstage/errors';\nimport { ScmIntegrationRegistry } from '@backstage/integration';\nimport {\n createTemplateAction,\n getRepoSourceDirectory,\n initRepoAndPush,\n parseRepoUrl,\n} from '@backstage/plugin-scaffolder-node';\nimport { Gitlab, VariableType } from '@gitbeaker/rest';\nimport { Config } from '@backstage/config';\nimport { examples } from './gitlab.examples';\n\n/**\n * Creates a new action that initializes a git repository of the content in the workspace\n * and publishes it to GitLab.\n *\n * @public\n */\nexport function createPublishGitlabAction(options: {\n integrations: ScmIntegrationRegistry;\n config: Config;\n}) {\n const { integrations, config } = options;\n\n return createTemplateAction({\n id: 'publish:gitlab',\n description:\n 'Initializes a git repository of the content in the workspace, and publishes it to GitLab.',\n examples,\n schema: {\n input: {\n repoUrl: z =>\n z.string({\n description: `Accepts the format 'gitlab.com?repo=project_name&owner=group_name' where 'project_name' is the repository name and 'group_name' is a group or username`,\n }),\n repoVisibility: z =>\n z\n .enum(['private', 'public', 'internal'], {\n description: `Sets the visibility of the repository. The default value is 'private'. (deprecated, use settings.visibility instead)`,\n })\n .optional(),\n defaultBranch: z =>\n z\n .string({\n description: `Sets the default branch on the repository. The default value is 'master'`,\n })\n .optional(),\n gitCommitMessage: z =>\n z\n .string({\n description: `Sets the commit message on the repository. The default value is 'initial commit'`,\n })\n .optional(),\n gitAuthorName: z =>\n z\n .string({\n description: `Sets the default author name for the commit. The default value is 'Scaffolder'`,\n })\n .optional(),\n gitAuthorEmail: z =>\n z\n .string({\n description: `Sets the default author email for the commit.`,\n })\n .optional(),\n signCommit: z =>\n z\n .boolean({\n description: 'Sign commit with configured PGP private key',\n })\n .optional(),\n sourcePath: z =>\n z\n .union([z.string(), z.boolean()], {\n description:\n 'Path within the workspace that will be used as the repository root. If omitted or set to true, the entire workspace will be published as the repository. If set to false, the created repository will be empty.',\n })\n .optional(),\n skipExisting: z =>\n z\n .boolean({\n description:\n 'Do not publish the repository if it already exists. The default value is false.',\n })\n .optional(),\n token: z =>\n z\n .string({\n description: 'The token to use for authorization to GitLab',\n })\n .optional(),\n setUserAsOwner: z =>\n z\n .boolean({\n description:\n 'Set the token user as owner of the newly created repository. Requires a token authorized to do the edit in the integration configuration for the matching host',\n })\n .optional(),\n topics: z =>\n z\n .array(z.string(), {\n description:\n 'Topic labels to apply on the repository. (deprecated, use settings.topics instead)',\n })\n .optional(),\n settings: z =>\n z\n .object({\n path: z\n .string({\n description:\n 'Repository name for new project. Generated based on name if not provided (generated as lowercase with dashes).',\n })\n .optional(),\n auto_devops_enabled: z\n .boolean({\n description: 'Enable Auto DevOps for this project',\n })\n .optional(),\n ci_config_path: z\n .string({\n description: 'Custom CI config path for this project',\n })\n .optional(),\n description: z\n .string({\n description: 'Short project description',\n })\n .optional(),\n merge_method: z\n .enum(['merge', 'rebase_merge', 'ff'], {\n description: 'Merge Methods (merge, rebase_merge, ff)',\n })\n .optional(),\n squash_option: z\n .enum(['default_off', 'default_on', 'never', 'always'], {\n description:\n 'Set squash option for the project (never, always, default_on, default_off)',\n })\n .optional(),\n topics: z\n .array(z.string(), {\n description: 'Topic labels to apply on the repository',\n })\n .optional(),\n visibility: z\n .enum(['private', 'public', 'internal'], {\n description:\n 'The visibility of the project. Can be private, internal, or public. The default value is private.',\n })\n .optional(),\n only_allow_merge_if_all_discussions_are_resolved: z\n .boolean({\n description:\n 'Set whether merge requests can only be merged when all the discussions are resolved.',\n })\n .optional(),\n only_allow_merge_if_pipeline_succeeds: z\n .boolean({\n description:\n 'Set whether merge requests can only be merged with successful pipelines. This setting is named Pipelines must succeed in the project settings.',\n })\n .optional(),\n allow_merge_on_skipped_pipeline: z\n .boolean({\n description:\n 'Set whether or not merge requests can be merged with skipped jobs.',\n })\n .optional(),\n })\n .optional(),\n branches: z =>\n z\n .array(\n z.object({\n name: z.string(),\n protect: z.boolean().optional(),\n create: z.boolean().optional(),\n ref: z.string().optional(),\n }),\n )\n .optional(),\n projectVariables: z =>\n z\n .array(\n z.object({\n key: z.string(),\n value: z.string(),\n description: z.string().optional(),\n variable_type: z.enum(['env_var', 'file']).optional(),\n protected: z.boolean().optional(),\n masked: z.boolean().optional(),\n masked_and_hidden: z.boolean().optional(),\n raw: z.boolean().optional(),\n environment_scope: z.string().optional(),\n }),\n )\n .optional(),\n },\n output: {\n remoteUrl: z =>\n z.string({\n description: 'A URL to the repository with the provider',\n }),\n repoContentsUrl: z =>\n z.string({\n description: 'A URL to the root of the repository',\n }),\n projectId: z =>\n z.number({\n description: 'The ID of the project',\n }),\n commitHash: z =>\n z.string({\n description: 'The git commit hash of the initial commit',\n }),\n created: z =>\n z.boolean({\n description: 'Whether the repository was created or not',\n }),\n },\n },\n async handler(ctx) {\n const {\n repoUrl,\n repoVisibility = 'private',\n defaultBranch = 'master',\n gitCommitMessage = 'initial commit',\n gitAuthorName,\n gitAuthorEmail,\n setUserAsOwner = false,\n topics = [],\n settings = {},\n branches = [],\n projectVariables = [],\n skipExisting = false,\n signCommit,\n } = ctx.input;\n const { owner, repo, host } = parseRepoUrl(repoUrl, integrations);\n\n if (!owner) {\n throw new InputError(\n `No owner provided for host: ${host}, and repo ${repo}`,\n );\n }\n\n const integrationConfig = integrations.gitlab.byHost(host);\n\n if (!integrationConfig) {\n throw new InputError(\n `No matching integration configuration for host ${host}, please check your integrations config`,\n );\n }\n\n if (!integrationConfig.config.token && !ctx.input.token) {\n throw new InputError(`No token available for host ${host}`);\n }\n\n const token = ctx.input.token || integrationConfig.config.token!;\n const tokenType = ctx.input.token ? 'oauthToken' : 'token';\n\n const client = new Gitlab({\n host: integrationConfig.config.baseUrl,\n [tokenType]: token,\n });\n\n let targetNamespaceId;\n let targetNamespaceKind;\n try {\n const namespaceResponse = (await client.Namespaces.show(owner)) as {\n id: number;\n kind: string;\n };\n\n targetNamespaceId = namespaceResponse.id;\n targetNamespaceKind = namespaceResponse.kind;\n } catch (e) {\n if (e.cause?.response?.status === 404) {\n throw new InputError(\n `The namespace ${owner} is not found or the user doesn't have permissions to access it`,\n );\n }\n throw e;\n }\n\n const { id: userId } = (await client.Users.showCurrentUser()) as {\n id: number;\n };\n\n if (!targetNamespaceId) {\n targetNamespaceId = userId;\n targetNamespaceKind = 'user';\n }\n\n const existingProjects =\n targetNamespaceKind === 'user'\n ? await client.Users.allProjects(owner, { search: repo })\n : await client.Groups.allProjects(owner, { search: repo });\n\n const existingProject = existingProjects.find(\n project => project.path === repo,\n );\n\n if (!skipExisting || (skipExisting && !existingProject)) {\n ctx.logger.info(`Creating repo ${repo} in namespace ${owner}.`);\n const { id: projectId, http_url_to_repo } =\n await client.Projects.create({\n namespaceId: targetNamespaceId,\n name: repo,\n visibility: repoVisibility,\n ...(topics.length ? { topics } : {}),\n ...(Object.keys(settings).length ? { ...settings } : {}),\n });\n\n // When setUserAsOwner is true the input token is expected to come from an unprivileged user GitLab\n // OAuth flow. In this case GitLab works in a way that allows the unprivileged user to\n // create the repository, but not to push the default protected branch (e.g. master).\n // In order to set the user as owner of the newly created repository we need to check that the\n // GitLab integration configuration for the matching host contains a token and use\n // such token to bootstrap a new privileged client.\n if (setUserAsOwner && integrationConfig.config.token) {\n const adminClient = new Gitlab({\n host: integrationConfig.config.baseUrl,\n token: integrationConfig.config.token,\n });\n\n await adminClient.ProjectMembers.add(projectId, 50, { userId });\n }\n\n const remoteUrl = (http_url_to_repo as string).replace(/\\.git$/, '');\n const repoContentsUrl = `${remoteUrl}/-/blob/${defaultBranch}`;\n\n const gitAuthorInfo = {\n name: gitAuthorName\n ? gitAuthorName\n : config.getOptionalString('scaffolder.defaultAuthor.name'),\n email: gitAuthorEmail\n ? gitAuthorEmail\n : config.getOptionalString('scaffolder.defaultAuthor.email'),\n };\n const signingKey =\n integrationConfig.config.commitSigningKey ??\n config.getOptionalString('scaffolder.defaultCommitSigningKey');\n if (signCommit && !signingKey) {\n throw new Error(\n 'Signing commits is enabled but no signing key is provided in the configuration',\n );\n }\n\n const shouldSkipPublish =\n typeof ctx.input.sourcePath === 'boolean' && !ctx.input.sourcePath;\n if (!shouldSkipPublish) {\n const commitResult = await initRepoAndPush({\n dir:\n typeof ctx.input.sourcePath === 'boolean'\n ? ctx.workspacePath\n : getRepoSourceDirectory(\n ctx.workspacePath,\n ctx.input.sourcePath,\n ),\n remoteUrl: http_url_to_repo as string,\n defaultBranch,\n auth: {\n username: 'oauth2',\n password: token,\n },\n logger: ctx.logger,\n commitMessage: gitCommitMessage\n ? gitCommitMessage\n : config.getOptionalString('scaffolder.defaultCommitMessage'),\n gitAuthorInfo,\n signingKey: signCommit ? signingKey : undefined,\n });\n\n if (branches) {\n for (const branch of branches) {\n const {\n name,\n protect = false,\n create = false,\n ref = 'master',\n } = branch;\n\n if (create) {\n try {\n await client.Branches.create(projectId, name, ref);\n } catch (e) {\n throw new InputError(\n `Branch creation failed for ${name}. ${printGitlabError(\n e,\n )}`,\n );\n }\n ctx.logger.info(\n `Branch ${name} created for ${projectId} with ref ${ref}`,\n );\n }\n\n if (protect) {\n try {\n await client.ProtectedBranches.protect(projectId, name);\n } catch (e) {\n throw new InputError(\n `Branch protection failed for ${name}. ${printGitlabError(\n e,\n )}`,\n );\n }\n ctx.logger.info(`Branch ${name} protected for ${projectId}`);\n }\n }\n }\n ctx.output('commitHash', commitResult?.commitHash);\n }\n\n if (projectVariables) {\n for (const variable of projectVariables) {\n const variableWithDefaults = Object.assign(variable, {\n variable_type: (variable.variable_type ??\n 'env_var') as VariableType,\n protected: variable.protected ?? false,\n masked: variable.masked ?? false,\n masked_and_hidden: variable.masked_and_hidden ?? false,\n raw: variable.raw ?? false,\n environment_scope: variable.environment_scope ?? '*',\n });\n\n try {\n await client.ProjectVariables.create(\n projectId,\n variableWithDefaults.key,\n variableWithDefaults.value,\n {\n variableType: variableWithDefaults.variable_type,\n protected: variableWithDefaults.protected,\n masked: variableWithDefaults.masked,\n masked_and_hidden: variableWithDefaults.masked_and_hidden,\n environmentScope: variableWithDefaults.environment_scope,\n description: variableWithDefaults.description,\n raw: variableWithDefaults.raw,\n },\n );\n } catch (e) {\n throw new InputError(\n `Environment variable creation failed for ${\n variableWithDefaults.key\n }. ${printGitlabError(e)}`,\n );\n }\n }\n }\n ctx.output('remoteUrl', remoteUrl);\n ctx.output('repoContentsUrl', repoContentsUrl);\n ctx.output('projectId', projectId);\n ctx.output('created', true);\n } else if (existingProject) {\n ctx.logger.info(`Repo ${repo} already exists in namespace ${owner}.`);\n const {\n id: projectId,\n http_url_to_repo,\n default_branch,\n } = existingProject;\n const remoteUrl = (http_url_to_repo as string).replace(/\\.git$/, '');\n ctx.output('remoteUrl', remoteUrl);\n ctx.output('repoContentsUrl', `${remoteUrl}/-/blob/${default_branch}`);\n ctx.output('projectId', projectId);\n ctx.output('created', false);\n }\n },\n });\n}\n\nfunction printGitlabError(error: any): string {\n return JSON.stringify({ code: error.code, message: error.description });\n}\n"],"names":["createTemplateAction","examples","parseRepoUrl","InputError","Gitlab","initRepoAndPush","getRepoSourceDirectory"],"mappings":"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"}
@@ -35,6 +35,9 @@ const createGitlabProjectVariableAction = (options) => {
35
35
  masked: (z) => z.boolean({
36
36
  description: "Whether the variable is masked"
37
37
  }).default(false).optional(),
38
+ maskedAndHidden: (z) => z.boolean({
39
+ description: "Whether the variable is masked and hidden"
40
+ }).default(false).optional(),
38
41
  raw: (z) => z.boolean({
39
42
  description: "Whether the variable is expandable"
40
43
  }).default(false).optional(),
@@ -52,6 +55,7 @@ const createGitlabProjectVariableAction = (options) => {
52
55
  variableType,
53
56
  variableProtected = false,
54
57
  masked = false,
58
+ maskedAndHidden = false,
55
59
  raw = false,
56
60
  environmentScope = "*",
57
61
  token
@@ -65,6 +69,7 @@ const createGitlabProjectVariableAction = (options) => {
65
69
  variableType,
66
70
  protected: variableProtected,
67
71
  masked,
72
+ masked_and_hidden: maskedAndHidden,
68
73
  raw,
69
74
  environmentScope
70
75
  });
@@ -1 +1 @@
1
- {"version":3,"file":"gitlabProjectVariableCreate.cjs.js","sources":["../../src/actions/gitlabProjectVariableCreate.ts"],"sourcesContent":["/*\n * Copyright 2021 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { ScmIntegrationRegistry } from '@backstage/integration';\nimport { createTemplateAction } from '@backstage/plugin-scaffolder-node';\nimport { VariableType } from '@gitbeaker/rest';\nimport { getClient, parseRepoUrl } from '../util';\nimport { examples } from './gitlabProjectVariableCreate.examples';\n\n/**\n * Creates a `gitlab:projectVariable:create` Scaffolder action.\n *\n * @param options - Templating configuration.\n * @public\n */\nexport const createGitlabProjectVariableAction = (options: {\n integrations: ScmIntegrationRegistry;\n}) => {\n const { integrations } = options;\n return createTemplateAction({\n id: 'gitlab:projectVariable:create',\n examples,\n schema: {\n input: {\n repoUrl: z =>\n z.string({\n description: `Accepts the format 'gitlab.com?repo=project_name&owner=group_name' where 'project_name' is the repository name and 'group_name' is a group or username`,\n }),\n token: z =>\n z\n .string({\n description: 'The token to use for authorization to GitLab',\n })\n .optional(),\n projectId: z =>\n z.union([z.number(), z.string()], {\n description: 'Project ID',\n }),\n key: z =>\n z\n .string({\n description:\n 'The key of a variable; must have no more than 255 characters; only A-Z, a-z, 0-9, and _ are allowed',\n })\n .regex(/^[A-Za-z0-9_]{1,255}$/),\n value: z =>\n z.string({\n description: 'The value of a variable',\n }),\n variableType: z =>\n z.string({\n description: 'Variable Type (env_var or file)',\n }),\n variableProtected: z =>\n z\n .boolean({\n description: 'Whether the variable is protected',\n })\n .default(false)\n .optional(),\n masked: z =>\n z\n .boolean({\n description: 'Whether the variable is masked',\n })\n .default(false)\n .optional(),\n raw: z =>\n z\n .boolean({\n description: 'Whether the variable is expandable',\n })\n .default(false)\n .optional(),\n environmentScope: z =>\n z\n .string({\n description: 'The environment_scope of the variable',\n })\n .default('*')\n .optional(),\n },\n },\n async handler(ctx) {\n const {\n repoUrl,\n projectId,\n key,\n value,\n variableType,\n variableProtected = false,\n masked = false,\n raw = false,\n environmentScope = '*',\n token,\n } = ctx.input;\n\n const { host } = parseRepoUrl(repoUrl, integrations);\n\n const api = getClient({ host, integrations, token });\n\n await ctx.checkpoint({\n key: `create.project.variables.${projectId}.${key}.${value}`,\n fn: async () => {\n await api.ProjectVariables.create(projectId, key, value, {\n variableType: variableType as VariableType,\n protected: variableProtected,\n masked,\n raw,\n environmentScope,\n });\n },\n });\n },\n });\n};\n"],"names":["createTemplateAction","examples","parseRepoUrl","getClient"],"mappings":"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"}
1
+ {"version":3,"file":"gitlabProjectVariableCreate.cjs.js","sources":["../../src/actions/gitlabProjectVariableCreate.ts"],"sourcesContent":["/*\n * Copyright 2021 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { ScmIntegrationRegistry } from '@backstage/integration';\nimport { createTemplateAction } from '@backstage/plugin-scaffolder-node';\nimport { VariableType } from '@gitbeaker/rest';\nimport { getClient, parseRepoUrl } from '../util';\nimport { examples } from './gitlabProjectVariableCreate.examples';\n\n/**\n * Creates a `gitlab:projectVariable:create` Scaffolder action.\n *\n * @param options - Templating configuration.\n * @public\n */\nexport const createGitlabProjectVariableAction = (options: {\n integrations: ScmIntegrationRegistry;\n}) => {\n const { integrations } = options;\n return createTemplateAction({\n id: 'gitlab:projectVariable:create',\n examples,\n schema: {\n input: {\n repoUrl: z =>\n z.string({\n description: `Accepts the format 'gitlab.com?repo=project_name&owner=group_name' where 'project_name' is the repository name and 'group_name' is a group or username`,\n }),\n token: z =>\n z\n .string({\n description: 'The token to use for authorization to GitLab',\n })\n .optional(),\n projectId: z =>\n z.union([z.number(), z.string()], {\n description: 'Project ID',\n }),\n key: z =>\n z\n .string({\n description:\n 'The key of a variable; must have no more than 255 characters; only A-Z, a-z, 0-9, and _ are allowed',\n })\n .regex(/^[A-Za-z0-9_]{1,255}$/),\n value: z =>\n z.string({\n description: 'The value of a variable',\n }),\n variableType: z =>\n z.string({\n description: 'Variable Type (env_var or file)',\n }),\n variableProtected: z =>\n z\n .boolean({\n description: 'Whether the variable is protected',\n })\n .default(false)\n .optional(),\n masked: z =>\n z\n .boolean({\n description: 'Whether the variable is masked',\n })\n .default(false)\n .optional(),\n maskedAndHidden: z =>\n z\n .boolean({\n description: 'Whether the variable is masked and hidden',\n })\n .default(false)\n .optional(),\n raw: z =>\n z\n .boolean({\n description: 'Whether the variable is expandable',\n })\n .default(false)\n .optional(),\n environmentScope: z =>\n z\n .string({\n description: 'The environment_scope of the variable',\n })\n .default('*')\n .optional(),\n },\n },\n async handler(ctx) {\n const {\n repoUrl,\n projectId,\n key,\n value,\n variableType,\n variableProtected = false,\n masked = false,\n maskedAndHidden = false,\n raw = false,\n environmentScope = '*',\n token,\n } = ctx.input;\n\n const { host } = parseRepoUrl(repoUrl, integrations);\n\n const api = getClient({ host, integrations, token });\n\n await ctx.checkpoint({\n key: `create.project.variables.${projectId}.${key}.${value}`,\n fn: async () => {\n await api.ProjectVariables.create(projectId, key, value, {\n variableType: variableType as VariableType,\n protected: variableProtected,\n masked,\n masked_and_hidden: maskedAndHidden,\n raw,\n environmentScope,\n });\n },\n });\n },\n });\n};\n"],"names":["createTemplateAction","examples","parseRepoUrl","getClient"],"mappings":"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"}
@@ -144,6 +144,26 @@ const examples = [
144
144
  }
145
145
  ]
146
146
  })
147
+ },
148
+ {
149
+ description: "Create a GitLab project variable that is masked and hidden.",
150
+ example: yaml__default.default.stringify({
151
+ steps: [
152
+ {
153
+ id: "createVariable",
154
+ action: "gitlab:projectVariable:create",
155
+ name: "Create GitLab Project Variable",
156
+ input: {
157
+ repoUrl: "gitlab.com?repo=repo&owner=owner",
158
+ projectId: "999",
159
+ key: "SECRET_TOKEN",
160
+ value: "super-secret-token",
161
+ variableType: "env_var",
162
+ maskedAndHidden: true
163
+ }
164
+ }
165
+ ]
166
+ })
147
167
  }
148
168
  ];
149
169
 
@@ -1 +1 @@
1
- {"version":3,"file":"gitlabProjectVariableCreate.examples.cjs.js","sources":["../../src/actions/gitlabProjectVariableCreate.examples.ts"],"sourcesContent":["/*\n * Copyright 2023 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport { TemplateExample } from '@backstage/plugin-scaffolder-node';\nimport yaml from 'yaml';\n\nexport const examples: TemplateExample[] = [\n {\n description: 'Creating a GitLab project variable of type env_var',\n example: yaml.stringify({\n steps: [\n {\n id: 'createVariable',\n action: 'gitlab:createGitlabProjectVariableAction',\n name: 'Create GitLab Project Variable',\n input: {\n repoUrl: 'gitlab.com?repo=repo&owner=owner',\n projectId: '123',\n key: 'MY_VARIABLE',\n value: 'my_value',\n variableType: 'env_var',\n },\n },\n ],\n }),\n },\n {\n description: 'Creating a GitLab project variable of type file',\n example: yaml.stringify({\n steps: [\n {\n id: 'createVariable',\n action: 'gitlab:createGitlabProjectVariableAction',\n name: 'Create GitLab Project Variable',\n input: {\n repoUrl: 'gitlab.com?repo=repo&owner=owner',\n projectId: '123',\n key: 'MY_VARIABLE',\n value: 'my-file-content',\n variableType: 'file',\n },\n },\n ],\n }),\n },\n {\n description: 'Create a GitLab project variable that is protected.',\n example: yaml.stringify({\n steps: [\n {\n id: 'createVariable',\n action: 'gitlab:createGitlabProjectVariableAction',\n name: 'Create GitLab Project Variable',\n input: {\n repoUrl: 'gitlab.com?repo=repo&owner=owner',\n projectId: '456',\n key: 'MY_VARIABLE',\n value: 'my_value',\n variableType: 'env_var',\n variableProtected: true,\n },\n },\n ],\n }),\n },\n {\n description: 'Create a GitLab project variable with masked flag as true',\n example: yaml.stringify({\n steps: [\n {\n id: 'createVariable',\n action: 'gitlab:createGitlabProjectVariableAction',\n name: 'Create GitLab Project Variable',\n input: {\n repoUrl: 'gitlab.com?repo=repo&owner=owner',\n projectId: '789',\n key: 'DB_PASSWORD',\n value: 'password123',\n variableType: 'env_var',\n masked: true,\n },\n },\n ],\n }),\n },\n {\n description: 'Create a GitLab project variable that is expandable.',\n example: yaml.stringify({\n steps: [\n {\n id: 'createVariable',\n action: 'gitlab:projectVariable:create',\n name: 'Create GitLab Project Variable',\n input: {\n repoUrl: 'gitlab.com?repo=repo&owner=owner',\n projectId: '123',\n key: 'MY_VARIABLE',\n value: 'my_value',\n variableType: 'env_var',\n raw: true,\n },\n },\n ],\n }),\n },\n {\n description:\n 'Create a GitLab project variable with a specific environment scope.',\n example: yaml.stringify({\n steps: [\n {\n id: 'createVariable',\n action: 'gitlab:projectVariable:create',\n name: 'Create GitLab Project Variable',\n input: {\n repoUrl: 'gitlab.com?repo=repo&owner=owner',\n projectId: '123',\n key: 'MY_VARIABLE',\n value: 'my_value',\n variableType: 'env_var',\n environmentScope: 'production',\n },\n },\n ],\n }),\n },\n {\n description:\n 'Create a GitLab project variable with a wildcard environment scope.',\n example: yaml.stringify({\n steps: [\n {\n id: 'createVariable',\n action: 'gitlab:projectVariable:create',\n name: 'Create GitLab Project Variable',\n input: {\n repoUrl: 'gitlab.com?repo=repo&owner=owner',\n projectId: '123',\n key: 'MY_VARIABLE',\n value: 'my_value',\n variableType: 'env_var',\n environmentScope: '*',\n },\n },\n ],\n }),\n },\n];\n"],"names":["yaml"],"mappings":"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"}
1
+ {"version":3,"file":"gitlabProjectVariableCreate.examples.cjs.js","sources":["../../src/actions/gitlabProjectVariableCreate.examples.ts"],"sourcesContent":["/*\n * Copyright 2023 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport { TemplateExample } from '@backstage/plugin-scaffolder-node';\nimport yaml from 'yaml';\n\nexport const examples: TemplateExample[] = [\n {\n description: 'Creating a GitLab project variable of type env_var',\n example: yaml.stringify({\n steps: [\n {\n id: 'createVariable',\n action: 'gitlab:createGitlabProjectVariableAction',\n name: 'Create GitLab Project Variable',\n input: {\n repoUrl: 'gitlab.com?repo=repo&owner=owner',\n projectId: '123',\n key: 'MY_VARIABLE',\n value: 'my_value',\n variableType: 'env_var',\n },\n },\n ],\n }),\n },\n {\n description: 'Creating a GitLab project variable of type file',\n example: yaml.stringify({\n steps: [\n {\n id: 'createVariable',\n action: 'gitlab:createGitlabProjectVariableAction',\n name: 'Create GitLab Project Variable',\n input: {\n repoUrl: 'gitlab.com?repo=repo&owner=owner',\n projectId: '123',\n key: 'MY_VARIABLE',\n value: 'my-file-content',\n variableType: 'file',\n },\n },\n ],\n }),\n },\n {\n description: 'Create a GitLab project variable that is protected.',\n example: yaml.stringify({\n steps: [\n {\n id: 'createVariable',\n action: 'gitlab:createGitlabProjectVariableAction',\n name: 'Create GitLab Project Variable',\n input: {\n repoUrl: 'gitlab.com?repo=repo&owner=owner',\n projectId: '456',\n key: 'MY_VARIABLE',\n value: 'my_value',\n variableType: 'env_var',\n variableProtected: true,\n },\n },\n ],\n }),\n },\n {\n description: 'Create a GitLab project variable with masked flag as true',\n example: yaml.stringify({\n steps: [\n {\n id: 'createVariable',\n action: 'gitlab:createGitlabProjectVariableAction',\n name: 'Create GitLab Project Variable',\n input: {\n repoUrl: 'gitlab.com?repo=repo&owner=owner',\n projectId: '789',\n key: 'DB_PASSWORD',\n value: 'password123',\n variableType: 'env_var',\n masked: true,\n },\n },\n ],\n }),\n },\n {\n description: 'Create a GitLab project variable that is expandable.',\n example: yaml.stringify({\n steps: [\n {\n id: 'createVariable',\n action: 'gitlab:projectVariable:create',\n name: 'Create GitLab Project Variable',\n input: {\n repoUrl: 'gitlab.com?repo=repo&owner=owner',\n projectId: '123',\n key: 'MY_VARIABLE',\n value: 'my_value',\n variableType: 'env_var',\n raw: true,\n },\n },\n ],\n }),\n },\n {\n description:\n 'Create a GitLab project variable with a specific environment scope.',\n example: yaml.stringify({\n steps: [\n {\n id: 'createVariable',\n action: 'gitlab:projectVariable:create',\n name: 'Create GitLab Project Variable',\n input: {\n repoUrl: 'gitlab.com?repo=repo&owner=owner',\n projectId: '123',\n key: 'MY_VARIABLE',\n value: 'my_value',\n variableType: 'env_var',\n environmentScope: 'production',\n },\n },\n ],\n }),\n },\n {\n description:\n 'Create a GitLab project variable with a wildcard environment scope.',\n example: yaml.stringify({\n steps: [\n {\n id: 'createVariable',\n action: 'gitlab:projectVariable:create',\n name: 'Create GitLab Project Variable',\n input: {\n repoUrl: 'gitlab.com?repo=repo&owner=owner',\n projectId: '123',\n key: 'MY_VARIABLE',\n value: 'my_value',\n variableType: 'env_var',\n environmentScope: '*',\n },\n },\n ],\n }),\n },\n {\n description: 'Create a GitLab project variable that is masked and hidden.',\n example: yaml.stringify({\n steps: [\n {\n id: 'createVariable',\n action: 'gitlab:projectVariable:create',\n name: 'Create GitLab Project Variable',\n input: {\n repoUrl: 'gitlab.com?repo=repo&owner=owner',\n projectId: '999',\n key: 'SECRET_TOKEN',\n value: 'super-secret-token',\n variableType: 'env_var',\n maskedAndHidden: true,\n },\n },\n ],\n }),\n },\n];\n"],"names":["yaml"],"mappings":"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"}
package/dist/index.d.ts CHANGED
@@ -53,6 +53,7 @@ declare function createPublishGitlabAction(options: {
53
53
  variable_type?: "file" | "env_var" | undefined;
54
54
  masked?: boolean | undefined;
55
55
  environment_scope?: string | undefined;
56
+ masked_and_hidden?: boolean | undefined;
56
57
  }[] | undefined;
57
58
  }, {
58
59
  remoteUrl: string;
@@ -256,6 +257,7 @@ declare const createGitlabProjectVariableAction: (options: {
256
257
  token?: string | undefined;
257
258
  variableProtected?: boolean | undefined;
258
259
  masked?: boolean | undefined;
260
+ maskedAndHidden?: boolean | undefined;
259
261
  raw?: boolean | undefined;
260
262
  environmentScope?: string | undefined;
261
263
  }, {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@backstage/plugin-scaffolder-backend-module-gitlab",
3
- "version": "0.11.3-next.2",
3
+ "version": "0.11.4-next.0",
4
4
  "backstage": {
5
5
  "role": "backend-plugin-module",
6
6
  "pluginId": "scaffolder",
@@ -53,20 +53,20 @@
53
53
  "test": "backstage-cli package test"
54
54
  },
55
55
  "dependencies": {
56
- "@backstage/backend-plugin-api": "1.7.0-next.1",
56
+ "@backstage/backend-plugin-api": "1.7.1-next.0",
57
57
  "@backstage/config": "1.3.6",
58
58
  "@backstage/errors": "1.2.7",
59
- "@backstage/integration": "1.20.0-next.2",
60
- "@backstage/plugin-scaffolder-node": "0.12.5-next.1",
61
- "@gitbeaker/requester-utils": "^41.2.0",
62
- "@gitbeaker/rest": "^41.2.0",
59
+ "@backstage/integration": "1.21.0-next.0",
60
+ "@backstage/plugin-scaffolder-node": "0.12.6-next.0",
61
+ "@gitbeaker/requester-utils": "^43.8.0",
62
+ "@gitbeaker/rest": "^43.8.0",
63
63
  "luxon": "^3.0.0",
64
64
  "yaml": "^2.0.0",
65
65
  "zod": "^3.25.76"
66
66
  },
67
67
  "devDependencies": {
68
- "@backstage/backend-test-utils": "1.11.0-next.1",
69
- "@backstage/cli": "0.35.4-next.2",
70
- "@backstage/plugin-scaffolder-node-test-utils": "0.3.8-next.1"
68
+ "@backstage/backend-test-utils": "1.11.1-next.0",
69
+ "@backstage/cli": "0.35.5-next.0",
70
+ "@backstage/plugin-scaffolder-node-test-utils": "0.3.9-next.0"
71
71
  }
72
72
  }