Support Git as only VCS (#4346)

Co-authored-by: Patrick Schratz <patrick.schratz@gmail.com>
This commit is contained in:
qwerty287 2024-12-27 23:49:19 +02:00 committed by GitHub
parent 1ed009424d
commit fdfabe6368
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
29 changed files with 100 additions and 98 deletions

View file

@ -157,12 +157,6 @@ var flags = []cli.Flag{
Name: "repo-url", Name: "repo-url",
Usage: "Set the metadata environment variable \"CI_REPO_URL\".", Usage: "Set the metadata environment variable \"CI_REPO_URL\".",
}, },
&cli.StringFlag{
Sources: cli.EnvVars("CI_REPO_SCM"),
Name: "repo-scm",
Usage: "Set the metadata environment variable \"CI_REPO_SCM\".",
Value: "git",
},
&cli.StringFlag{ &cli.StringFlag{
Sources: cli.EnvVars("CI_REPO_DEFAULT_BRANCH"), Sources: cli.EnvVars("CI_REPO_DEFAULT_BRANCH"),
Name: "repo-default-branch", Name: "repo-default-branch",

View file

@ -78,7 +78,6 @@ func metadataFromContext(_ context.Context, c *cli.Command, axis matrix.Axis, w
// Repo // Repo
metadataFileAndOverrideOrDefault(c, "repo-remote-id", func(s string) { m.Repo.RemoteID = s }, c.String) metadataFileAndOverrideOrDefault(c, "repo-remote-id", func(s string) { m.Repo.RemoteID = s }, c.String)
metadataFileAndOverrideOrDefault(c, "repo-url", func(s string) { m.Repo.ForgeURL = s }, c.String) metadataFileAndOverrideOrDefault(c, "repo-url", func(s string) { m.Repo.ForgeURL = s }, c.String)
metadataFileAndOverrideOrDefault(c, "repo-scm", func(s string) { m.Repo.SCM = s }, c.String)
metadataFileAndOverrideOrDefault(c, "repo-default-branch", func(s string) { m.Repo.Branch = s }, c.String) metadataFileAndOverrideOrDefault(c, "repo-default-branch", func(s string) { m.Repo.Branch = s }, c.String)
metadataFileAndOverrideOrDefault(c, "repo-clone-url", func(s string) { m.Repo.CloneURL = s }, c.String) metadataFileAndOverrideOrDefault(c, "repo-clone-url", func(s string) { m.Repo.CloneURL = s }, c.String)
metadataFileAndOverrideOrDefault(c, "repo-clone-ssh-url", func(s string) { m.Repo.CloneSSHURL = s }, c.String) metadataFileAndOverrideOrDefault(c, "repo-clone-ssh-url", func(s string) { m.Repo.CloneSSHURL = s }, c.String)

View file

@ -5115,9 +5115,6 @@ const docTemplate = `{
"require_approval": { "require_approval": {
"$ref": "#/definitions/model.ApprovalMode" "$ref": "#/definitions/model.ApprovalMode"
}, },
"scm": {
"$ref": "#/definitions/SCMKind"
},
"timeout": { "timeout": {
"type": "integer" "type": "integer"
}, },
@ -5184,21 +5181,6 @@ const docTemplate = `{
"VisibilityInternal" "VisibilityInternal"
] ]
}, },
"SCMKind": {
"type": "string",
"enum": [
"git",
"hg",
"fossil",
"perforce"
],
"x-enum-varnames": [
"RepoGit",
"RepoHg",
"RepoFossil",
"RepoPerforce"
]
},
"Secret": { "Secret": {
"type": "object", "type": "object",
"properties": { "properties": {
@ -5581,9 +5563,6 @@ const docTemplate = `{
"remote_id": { "remote_id": {
"type": "string" "type": "string"
}, },
"scm": {
"type": "string"
},
"trusted": { "trusted": {
"$ref": "#/definitions/metadata.TrustedConfiguration" "$ref": "#/definitions/metadata.TrustedConfiguration"
} }

View file

@ -686,16 +686,6 @@ Example configuration to use a custom clone plugin:
+ image: octocat/custom-git-plugin + image: octocat/custom-git-plugin
``` ```
Example configuration to clone Mercurial repository:
```diff
clone:
- name: hg
+ image: plugins/hg
+ settings:
+ path: bitbucket.org/foo/bar
```
### Git Submodules ### Git Submodules
To use the credentials that cloned the repository to clone it's submodules, update `.gitmodules` to use `https` instead of `git`: To use the credentials that cloned the repository to clone it's submodules, update `.gitmodules` to use `https` instead of `git`:

View file

@ -56,7 +56,6 @@ This is the reference list of all environment variables available to your pipeli
| `CI_REPO_OWNER` | repository owner | `john-doe` | | `CI_REPO_OWNER` | repository owner | `john-doe` |
| `CI_REPO_NAME` | repository name | `my-repo` | | `CI_REPO_NAME` | repository name | `my-repo` |
| `CI_REPO_REMOTE_ID` | repository remote ID, is the UID it has in the forge | `82` | | `CI_REPO_REMOTE_ID` | repository remote ID, is the UID it has in the forge | `82` |
| `CI_REPO_SCM` | repository SCM | `git` |
| `CI_REPO_URL` | repository web URL | `https://git.example.com/john-doe/my-repo` | | `CI_REPO_URL` | repository web URL | `https://git.example.com/john-doe/my-repo` |
| `CI_REPO_CLONE_URL` | repository clone URL | `https://git.example.com/john-doe/my-repo.git` | | `CI_REPO_CLONE_URL` | repository clone URL | `https://git.example.com/john-doe/my-repo.git` |
| `CI_REPO_CLONE_SSH_URL` | repository SSH clone URL | `git@git.example.com:john-doe/my-repo.git` | | `CI_REPO_CLONE_SSH_URL` | repository SSH clone URL | `git@git.example.com:john-doe/my-repo.git` |

View file

@ -140,6 +140,10 @@ The following restructuring was done to achieve a more consistent grouping:
- The `latest` tag has been dropped to avoid accidental major version upgrades. - The `latest` tag has been dropped to avoid accidental major version upgrades.
A dedicated semver tag specification must be used, i.e., either a fixed version (like `v3.0.0`) or a rolling tag (e.g. `v3.0` or `v3`). A dedicated semver tag specification must be used, i.e., either a fixed version (like `v3.0.0`) or a rolling tag (e.g. `v3.0` or `v3`).
- Git is now the only officially supported SCM.
No others were supported previously, but the existence of the env var `CI_REPO_SCM` indicated that others might be.
The env var has now been removed including unused code associated with it.
- Previously, some (official) plugins were granted the `privileged` option by default to allow simplified usage. - Previously, some (official) plugins were granted the `privileged` option by default to allow simplified usage.
To streamline this process and enhance security transparency, no plugin is granted the `privileged` options by default anymore. To streamline this process and enhance security transparency, no plugin is granted the `privileged` options by default anymore.
To allow the use of these plugins in >= 3.0, they must be set explicitly through `WOODPECKER_PLUGINS_PRIVILEGED` on the admin side. To allow the use of these plugins in >= 3.0, they must be set explicitly through `WOODPECKER_PLUGINS_PRIVILEGED` on the admin side.
@ -168,6 +172,60 @@ The following restructuring was done to achieve a more consistent grouping:
- Webhook signatures now use the `rfc9421` protocol - Webhook signatures now use the `rfc9421` protocol
## User migrations
- `gated` has been replaced by `require-approval`
- Removed built-in environment variables:
- `CI_COMMIT_URL` use `CI_PIPELINE_FORGE_URL`
- `CI_STEP_FINISHED` as empty during execution
- `CI_PIPELINE_FINISHED` as empty during execution
- `CI_PIPELINE_STATUS` was always `success`
- `CI_STEP_STATUS` was always `success`
- `CI_REPO_SCM` was always `git`
- Set `/woodpecker` as default workdir for the **woodpecker-cli** container
- Secret filters for plugins now check against tag if specified
- Compatibility mode of deprecated `pipeline:`, `platform:` and `branches:` pipeline config options are now removed and pipeline will now fail if still in use.
- Removed `steps.[name].group` in favor of `steps.[name].depends_on` (see [workflow syntax](/docs/usage/workflow-syntax#depends_on) to learn how to set dependencies)
- Pipelines without a config file will now be skipped instead of failing
- Removed `includes` and `excludes` support from **event** filter
- Removed upper-casing all secret env vars, instead, the value of the `secrets` property is used. [Read more](/docs/usage/secrets#usage)
- Removed alternative names for secrets, use `environment` with `from_secret`
- Removed `environment` filter, use `when.evaluate`
- Removed `WOODPECKER_WEBHOOK_HOST` in favor of `WOODPECKER_EXPERT_WEBHOOK_HOST`
- Renamed `start_time`, `end_time`, `created_at`, `started_at`, `finished_at` and `reviewed_at` JSON fields to `started`, `finished`, `created`, `started`, `finished`, `reviewed`
- JSON field `trusted` on repo model was changed from boolean to object
- Update all webhooks by pressing the "Repair all" button in the admin settings as the webhook token claims have changed
- Crons now use standard Linux syntax without seconds
- Removed old API routes: `registry/` -> `registries`, `/authorize/token`
- Replaced `registry` command with `repo registry` in cli
- Deprecated `secrets`, use `environment` with `from_secret`
- Empty string environment variables are not set
- CLI commands got restructured to provide a simplified structure:
- `woodpecker-cli secret [add|rm|...] --global` is now `woodpecker-cli admin secret [add|rm|...]`
- `woodpecker-cli user` is now `woodpecker-cli admin user`
- `woodpecker-cli log-level` is now `woodpecker-cli admin log-level`
- `woodpecker-cli secret [add|rm|...] --organization` is now `woodpecker-cli org secret [add|rm|...]`
- `woodpecker-cli deploy` is now `woodpecker-cli pipeline deploy`
- `woodpecker-cli log` is now `woodpecker-cli pipeline log`
- `woodpecker-cli cron` is now `woodpecker-cli repo cron`
- `woodpecker-cli secret [add|rm|...] --repository` is now `woodpecker-cli repo secret [add|rm|...]`
- `woodpecker-cli pipeline logs` is now `woodpecker-cli pipeline log show`
- `woodpecker-cli [registry|secret|...] info` is now `woodpecker-cli [registry|secret|...] show`
## Admin migrations
- Deprecate `WOODPECKER_LOG_XORM` and `WOODPECKER_LOG_XORM_SQL` use `"WOODPECKER_DATABASE_LOG` and `"WOODPECKER_DATABASE_LOG_SQL`
- Deprecate `WOODPECKER_FILTER_LABELS` use `WOODPECKER_AGENT_LABELS`
- Move docker resource limit settings from server into agent configuration
- Rename server environment variable `WOODPECKER_ESCALATE` to `WOODPECKER_PLUGINS_PRIVILEGED`
- All default privileged plugins (like `woodpeckerci/plugin-docker-buildx`) were removed. Please carefully [re-add those plugins](/docs/next/administration/server-config#woodpecker_plugins_privileged) you trust and rely on.
- `WOODPECKER_DEFAULT_CLONE_IMAGE` got deprecated use `WOODPECKER_DEFAULT_CLONE_PLUGIN`
- Check trusted-clone- and privileged-plugins by image name and tag (if tag is set)
- Removed `WOODPECKER_DEV_OAUTH_HOST` and `WOODPECKER_DEV_GITEA_OAUTH_URL` use `WOODPECKER_EXPERT_FORGE_OAUTH_HOST`
- Removed `WOODPECKER_ROOT_PATH` and `WOODPECKER_ROOT_URL` config variables. Use `WOODPECKER_HOST` with a path instead
- Removed implicitly defined `regcred` image pull secret name. Set it explicitly via `WOODPECKER_BACKEND_K8S_PULL_SECRET_NAMES`
- Removed slice definition for env vars
- Migrated to rfc9421 for webhook signatures
- Replaced `configs` object by `netrc` in external configuration APIs - Replaced `configs` object by `netrc` in external configuration APIs
- Upgrading from 1.x versions to 3.x is disallowed, upgrading to 2.x first is required to ensure proper DB migrations - Upgrading from 1.x versions to 3.x is disallowed, upgrading to 2.x first is required to ensure proper DB migrations

View file

@ -63,10 +63,6 @@ func (e *local) setupClone(state *workflowState) error {
// execClone executes a clone-step locally. // execClone executes a clone-step locally.
func (e *local) execClone(ctx context.Context, step *types.Step, state *workflowState, env []string) error { func (e *local) execClone(ctx context.Context, step *types.Step, state *workflowState, env []string) error {
if scm := step.Environment["CI_REPO_SCM"]; scm != "git" {
return fmt.Errorf("local backend can only clone from git repos, but this repo use '%s'", scm)
}
if err := checkGitCloneCap(); err != nil { if err := checkGitCloneCap(); err != nil {
return fmt.Errorf("check for git clone capabilities failed: %w", err) return fmt.Errorf("check for git clone capabilities failed: %w", err)
} }

View file

@ -45,7 +45,6 @@ func SetDroneEnviron(env map[string]string) {
copyEnv("CI_COMMIT_AUTHOR_AVATAR", "DRONE_COMMIT_AUTHOR_AVATAR", env) copyEnv("CI_COMMIT_AUTHOR_AVATAR", "DRONE_COMMIT_AUTHOR_AVATAR", env)
// repo // repo
copyEnv("CI_REPO", "DRONE_REPO", env) copyEnv("CI_REPO", "DRONE_REPO", env)
copyEnv("CI_REPO_SCM", "DRONE_REPO_SCM", env)
copyEnv("CI_REPO_OWNER", "DRONE_REPO_OWNER", env) copyEnv("CI_REPO_OWNER", "DRONE_REPO_OWNER", env)
copyEnv("CI_REPO_NAME", "DRONE_REPO_NAME", env) copyEnv("CI_REPO_NAME", "DRONE_REPO_NAME", env)
copyEnv("CI_REPO_URL", "DRONE_REPO_LINK", env) copyEnv("CI_REPO_URL", "DRONE_REPO_LINK", env)
@ -59,6 +58,7 @@ func SetDroneEnviron(env map[string]string) {
copyEnv("CI_STEP_NUMBER", "DRONE_STEP_NUMBER", env) copyEnv("CI_STEP_NUMBER", "DRONE_STEP_NUMBER", env)
env["DRONE_BUILD_STATUS"] = "success" env["DRONE_BUILD_STATUS"] = "success"
env["DRONE_REPO_SCM"] = "git"
// some quirks // some quirks

View file

@ -59,7 +59,6 @@ CI_REPO_CLONE_URL=https://codeberg.org/Epsilon_02/todo-checker.git
CI_REPO_DEFAULT_BRANCH=main CI_REPO_DEFAULT_BRANCH=main
CI_REPO_NAME=todo-checker CI_REPO_NAME=todo-checker
CI_REPO_OWNER=Epsilon_02 CI_REPO_OWNER=Epsilon_02
CI_REPO_SCM=git
CI_STEP_NAME=wp_01h1z7v5d1tskaqjexw0ng6w7d_0_step_3 CI_STEP_NAME=wp_01h1z7v5d1tskaqjexw0ng6w7d_0_step_3
CI_STEP_STARTED=1685749339 CI_STEP_STARTED=1685749339
CI_SYSTEM_PLATFORM=linux/amd64 CI_SYSTEM_PLATFORM=linux/amd64
@ -164,7 +163,6 @@ CI_REPO_NAME=woodpecker-test
CI_REPO_OWNER=test CI_REPO_OWNER=test
CI_REPO_PRIVATE=false CI_REPO_PRIVATE=false
CI_REPO_REMOTE_ID=4 CI_REPO_REMOTE_ID=4
CI_REPO_SCM=git
CI_REPO_TRUSTED=false CI_REPO_TRUSTED=false
CI_REPO_TRUSTED_NETWORK=false CI_REPO_TRUSTED_NETWORK=false
CI_REPO_TRUSTED_VOLUMES=false CI_REPO_TRUSTED_VOLUMES=false

View file

@ -53,7 +53,6 @@ func (m *Metadata) Environ() map[string]string {
setNonEmptyEnvVar(params, "CI_REPO_NAME", repo.Name) setNonEmptyEnvVar(params, "CI_REPO_NAME", repo.Name)
setNonEmptyEnvVar(params, "CI_REPO_OWNER", repo.Owner) setNonEmptyEnvVar(params, "CI_REPO_OWNER", repo.Owner)
setNonEmptyEnvVar(params, "CI_REPO_REMOTE_ID", repo.RemoteID) setNonEmptyEnvVar(params, "CI_REPO_REMOTE_ID", repo.RemoteID)
setNonEmptyEnvVar(params, "CI_REPO_SCM", repo.SCM)
setNonEmptyEnvVar(params, "CI_REPO_URL", repo.ForgeURL) setNonEmptyEnvVar(params, "CI_REPO_URL", repo.ForgeURL)
setNonEmptyEnvVar(params, "CI_REPO_CLONE_URL", repo.CloneURL) setNonEmptyEnvVar(params, "CI_REPO_CLONE_URL", repo.CloneURL)
setNonEmptyEnvVar(params, "CI_REPO_CLONE_SSH_URL", repo.CloneSSHURL) setNonEmptyEnvVar(params, "CI_REPO_CLONE_SSH_URL", repo.CloneSSHURL)

View file

@ -34,7 +34,6 @@ type (
Owner string `json:"owner,omitempty"` Owner string `json:"owner,omitempty"`
RemoteID string `json:"remote_id,omitempty"` RemoteID string `json:"remote_id,omitempty"`
ForgeURL string `json:"forge_url,omitempty"` ForgeURL string `json:"forge_url,omitempty"`
SCM string `json:"scm,omitempty"`
CloneURL string `json:"clone_url,omitempty"` CloneURL string `json:"clone_url,omitempty"`
CloneSSHURL string `json:"clone_url_ssh,omitempty"` CloneSSHURL string `json:"clone_url_ssh,omitempty"`
Private bool `json:"private,omitempty"` Private bool `json:"private,omitempty"`

View file

@ -59,14 +59,10 @@ func convertRepo(from *internal.Repo, perm *internal.RepoPerm) *model.Repo {
ForgeURL: from.Links.HTML.Href, ForgeURL: from.Links.HTML.Href,
IsSCMPrivate: from.IsPrivate, IsSCMPrivate: from.IsPrivate,
Avatar: from.Owner.Links.Avatar.Href, Avatar: from.Owner.Links.Avatar.Href,
SCMKind: model.SCMKind(from.Scm),
Branch: from.MainBranch.Name, Branch: from.MainBranch.Name,
Perm: convertPerm(perm), Perm: convertPerm(perm),
PREnabled: true, PREnabled: true,
} }
if repo.SCMKind == model.RepoHg {
repo.Branch = "default"
}
return &repo return &repo
} }

View file

@ -48,7 +48,7 @@ func Test_helper(t *testing.T) {
from := &internal.Repo{ from := &internal.Repo{
FullName: "octocat/hello-world", FullName: "octocat/hello-world",
IsPrivate: true, IsPrivate: true,
Scm: "hg", Scm: "git",
} }
from.Owner.Links.Avatar.Href = "http://..." from.Owner.Links.Avatar.Href = "http://..."
from.Links.HTML.Href = "https://bitbucket.org/foo/bar" from.Links.HTML.Href = "https://bitbucket.org/foo/bar"
@ -61,8 +61,6 @@ func Test_helper(t *testing.T) {
g.Assert(to.FullName).Equal(from.FullName) g.Assert(to.FullName).Equal(from.FullName)
g.Assert(to.Owner).Equal("octocat") g.Assert(to.Owner).Equal("octocat")
g.Assert(to.Name).Equal("hello-world") g.Assert(to.Name).Equal("hello-world")
g.Assert(to.Branch).Equal("default")
g.Assert(string(to.SCMKind)).Equal(from.Scm)
g.Assert(to.IsSCMPrivate).Equal(from.IsPrivate) g.Assert(to.IsSCMPrivate).Equal(from.IsPrivate)
g.Assert(to.Clone).Equal(from.Links.HTML.Href) g.Assert(to.Clone).Equal(from.Links.HTML.Href)
g.Assert(to.ForgeURL).Equal(from.Links.HTML.Href) g.Assert(to.ForgeURL).Equal(from.Links.HTML.Href)

View file

@ -125,7 +125,6 @@ func Test_parser(t *testing.T) {
r, b, err := parseHook(req) r, b, err := parseHook(req)
g.Assert(err).IsNil() g.Assert(err).IsNil()
g.Assert(r.FullName).Equal("martinherren1984/publictestrepo") g.Assert(r.FullName).Equal("martinherren1984/publictestrepo")
g.Assert(r.SCMKind).Equal(model.RepoGit)
g.Assert(r.Clone).Equal("https://bitbucket.org/martinherren1984/publictestrepo") g.Assert(r.Clone).Equal("https://bitbucket.org/martinherren1984/publictestrepo")
g.Assert(b.Commit).Equal("c14c1bb05dfb1fdcdf06b31485fff61b0ea44277") g.Assert(b.Commit).Equal("c14c1bb05dfb1fdcdf06b31485fff61b0ea44277")
g.Assert(b.Message).Equal("a\n") g.Assert(b.Message).Equal("a\n")

View file

@ -56,7 +56,6 @@ func convertRepo(from *bb.Repository, perm *model.Perm, branch string) *model.Re
Name: from.Slug, Name: from.Slug,
Owner: from.Project.Key, Owner: from.Project.Key,
Branch: branch, Branch: branch,
SCMKind: model.RepoGit,
IsSCMPrivate: true, // Since we have to use Netrc it has to always be private :/ TODO: Is this really true? IsSCMPrivate: true, // Since we have to use Netrc it has to always be private :/ TODO: Is this really true?
FullName: fmt.Sprintf("%s/%s", from.Project.Key, from.Slug), FullName: fmt.Sprintf("%s/%s", from.Project.Key, from.Slug),
Perm: perm, Perm: perm,

View file

@ -83,7 +83,6 @@ func TestHelper(t *testing.T) {
g.Assert(to.Name).Equal("REPO") g.Assert(to.Name).Equal("REPO")
g.Assert(to.Owner).Equal("PRJ") g.Assert(to.Owner).Equal("PRJ")
g.Assert(to.Branch).Equal("main") g.Assert(to.Branch).Equal("main")
g.Assert(to.SCMKind).Equal(model.RepoGit)
g.Assert(to.FullName).Equal("PRJ/REPO") g.Assert(to.FullName).Equal("PRJ/REPO")
g.Assert(to.Perm).Equal(perm) g.Assert(to.Perm).Equal(perm)
g.Assert(to.Clone).Equal("https://git.domain/clone") g.Assert(to.Clone).Equal("https://git.domain/clone")

View file

@ -37,7 +37,6 @@ func toRepo(from *forgejo.Repository) *model.Repo {
) )
return &model.Repo{ return &model.Repo{
ForgeRemoteID: model.ForgeRemoteID(fmt.Sprint(from.ID)), ForgeRemoteID: model.ForgeRemoteID(fmt.Sprint(from.ID)),
SCMKind: model.RepoGit,
Name: name, Name: name,
Owner: from.Owner.UserName, Owner: from.Owner.UserName,
FullName: from.FullName, FullName: from.FullName,

View file

@ -55,7 +55,6 @@ func TestForgejoParser(t *testing.T) {
Clone: "https://codeberg.org/meisam/woodpecktester.git", Clone: "https://codeberg.org/meisam/woodpecktester.git",
CloneSSH: "git@codeberg.org:meisam/woodpecktester.git", CloneSSH: "git@codeberg.org:meisam/woodpecktester.git",
Branch: "main", Branch: "main",
SCMKind: "git",
PREnabled: true, PREnabled: true,
Perm: &model.Perm{ Perm: &model.Perm{
Pull: true, Pull: true,
@ -90,7 +89,6 @@ func TestForgejoParser(t *testing.T) {
ForgeURL: "http://forgejo.golang.org/gordon/hello-world", ForgeURL: "http://forgejo.golang.org/gordon/hello-world",
Clone: "http://forgejo.golang.org/gordon/hello-world.git", Clone: "http://forgejo.golang.org/gordon/hello-world.git",
CloneSSH: "git@forgejo.golang.org:gordon/hello-world.git", CloneSSH: "git@forgejo.golang.org:gordon/hello-world.git",
SCMKind: "git",
IsSCMPrivate: true, IsSCMPrivate: true,
Perm: &model.Perm{ Perm: &model.Perm{
Pull: true, Pull: true,
@ -126,7 +124,6 @@ func TestForgejoParser(t *testing.T) {
Clone: "http://127.0.0.1:3000/Test-CI/multi-line-secrets.git", Clone: "http://127.0.0.1:3000/Test-CI/multi-line-secrets.git",
CloneSSH: "ssh://git@127.0.0.1:2200/Test-CI/multi-line-secrets.git", CloneSSH: "ssh://git@127.0.0.1:2200/Test-CI/multi-line-secrets.git",
Branch: "main", Branch: "main",
SCMKind: "git",
Perm: &model.Perm{ Perm: &model.Perm{
Pull: true, Pull: true,
Push: true, Push: true,
@ -161,7 +158,6 @@ func TestForgejoParser(t *testing.T) {
Clone: "http://forgejo.golang.org/gordon/hello-world.git", Clone: "http://forgejo.golang.org/gordon/hello-world.git",
CloneSSH: "git@forgejo.golang.org:gordon/hello-world.git", CloneSSH: "git@forgejo.golang.org:gordon/hello-world.git",
Branch: "main", Branch: "main",
SCMKind: "git",
IsSCMPrivate: true, IsSCMPrivate: true,
Perm: &model.Perm{ Perm: &model.Perm{
Pull: true, Pull: true,
@ -195,7 +191,6 @@ func TestForgejoParser(t *testing.T) {
Clone: "https://forgejo.golang.org/gordon/hello-world.git", Clone: "https://forgejo.golang.org/gordon/hello-world.git",
CloneSSH: "", CloneSSH: "",
Branch: "main", Branch: "main",
SCMKind: "git",
IsSCMPrivate: true, IsSCMPrivate: true,
Perm: &model.Perm{ Perm: &model.Perm{
Pull: true, Pull: true,
@ -233,7 +228,6 @@ func TestForgejoParser(t *testing.T) {
Clone: "http://127.0.0.1:3000/Test-CI/multi-line-secrets.git", Clone: "http://127.0.0.1:3000/Test-CI/multi-line-secrets.git",
CloneSSH: "ssh://git@127.0.0.1:2200/Test-CI/multi-line-secrets.git", CloneSSH: "ssh://git@127.0.0.1:2200/Test-CI/multi-line-secrets.git",
Branch: "main", Branch: "main",
SCMKind: "git",
PREnabled: true, PREnabled: true,
IsSCMPrivate: false, IsSCMPrivate: false,
Perm: &model.Perm{ Perm: &model.Perm{
@ -275,7 +269,6 @@ func TestForgejoParser(t *testing.T) {
Clone: "https://forgejo.com/anbraten/test-repo.git", Clone: "https://forgejo.com/anbraten/test-repo.git",
CloneSSH: "git@forgejo.com:anbraten/test-repo.git", CloneSSH: "git@forgejo.com:anbraten/test-repo.git",
Branch: "main", Branch: "main",
SCMKind: "git",
PREnabled: true, PREnabled: true,
Perm: &model.Perm{ Perm: &model.Perm{
Pull: true, Pull: true,
@ -313,7 +306,6 @@ func TestForgejoParser(t *testing.T) {
Clone: "https://forgejo.com/anbraten/test-repo.git", Clone: "https://forgejo.com/anbraten/test-repo.git",
CloneSSH: "git@forgejo.com:anbraten/test-repo.git", CloneSSH: "git@forgejo.com:anbraten/test-repo.git",
Branch: "main", Branch: "main",
SCMKind: "git",
PREnabled: true, PREnabled: true,
Perm: &model.Perm{ Perm: &model.Perm{
Pull: true, Pull: true,
@ -351,7 +343,6 @@ func TestForgejoParser(t *testing.T) {
Clone: "https://git.xxx/anbraten/demo.git", Clone: "https://git.xxx/anbraten/demo.git",
CloneSSH: "ssh://git@git.xxx:22/anbraten/demo.git", CloneSSH: "ssh://git@git.xxx:22/anbraten/demo.git",
Branch: "main", Branch: "main",
SCMKind: "git",
PREnabled: true, PREnabled: true,
IsSCMPrivate: true, IsSCMPrivate: true,
Perm: &model.Perm{ Perm: &model.Perm{

View file

@ -38,7 +38,6 @@ func toRepo(from *gitea.Repository) *model.Repo {
) )
return &model.Repo{ return &model.Repo{
ForgeRemoteID: model.ForgeRemoteID(fmt.Sprint(from.ID)), ForgeRemoteID: model.ForgeRemoteID(fmt.Sprint(from.ID)),
SCMKind: model.RepoGit,
Name: name, Name: name,
Owner: from.Owner.UserName, Owner: from.Owner.UserName,
FullName: from.FullName, FullName: from.FullName,

View file

@ -56,7 +56,6 @@ func TestGiteaParser(t *testing.T) {
Clone: "https://codeberg.org/meisam/woodpecktester.git", Clone: "https://codeberg.org/meisam/woodpecktester.git",
CloneSSH: "git@codeberg.org:meisam/woodpecktester.git", CloneSSH: "git@codeberg.org:meisam/woodpecktester.git",
Branch: "main", Branch: "main",
SCMKind: "git",
PREnabled: true, PREnabled: true,
Perm: &model.Perm{ Perm: &model.Perm{
Pull: true, Pull: true,
@ -91,7 +90,6 @@ func TestGiteaParser(t *testing.T) {
ForgeURL: "http://gitea.golang.org/gordon/hello-world", ForgeURL: "http://gitea.golang.org/gordon/hello-world",
Clone: "http://gitea.golang.org/gordon/hello-world.git", Clone: "http://gitea.golang.org/gordon/hello-world.git",
CloneSSH: "git@gitea.golang.org:gordon/hello-world.git", CloneSSH: "git@gitea.golang.org:gordon/hello-world.git",
SCMKind: "git",
IsSCMPrivate: true, IsSCMPrivate: true,
Perm: &model.Perm{ Perm: &model.Perm{
Pull: true, Pull: true,
@ -127,7 +125,6 @@ func TestGiteaParser(t *testing.T) {
Clone: "http://127.0.0.1:3000/Test-CI/multi-line-secrets.git", Clone: "http://127.0.0.1:3000/Test-CI/multi-line-secrets.git",
CloneSSH: "ssh://git@127.0.0.1:2200/Test-CI/multi-line-secrets.git", CloneSSH: "ssh://git@127.0.0.1:2200/Test-CI/multi-line-secrets.git",
Branch: "main", Branch: "main",
SCMKind: "git",
Perm: &model.Perm{ Perm: &model.Perm{
Pull: true, Pull: true,
Push: true, Push: true,
@ -162,7 +159,6 @@ func TestGiteaParser(t *testing.T) {
Clone: "http://gitea.golang.org/gordon/hello-world.git", Clone: "http://gitea.golang.org/gordon/hello-world.git",
CloneSSH: "git@gitea.golang.org:gordon/hello-world.git", CloneSSH: "git@gitea.golang.org:gordon/hello-world.git",
Branch: "main", Branch: "main",
SCMKind: "git",
IsSCMPrivate: true, IsSCMPrivate: true,
Perm: &model.Perm{ Perm: &model.Perm{
Pull: true, Pull: true,
@ -196,7 +192,6 @@ func TestGiteaParser(t *testing.T) {
Clone: "https://gitea.golang.org/gordon/hello-world.git", Clone: "https://gitea.golang.org/gordon/hello-world.git",
CloneSSH: "", CloneSSH: "",
Branch: "main", Branch: "main",
SCMKind: "git",
IsSCMPrivate: true, IsSCMPrivate: true,
Perm: &model.Perm{ Perm: &model.Perm{
Pull: true, Pull: true,
@ -234,7 +229,6 @@ func TestGiteaParser(t *testing.T) {
Clone: "http://127.0.0.1:3000/Test-CI/multi-line-secrets.git", Clone: "http://127.0.0.1:3000/Test-CI/multi-line-secrets.git",
CloneSSH: "ssh://git@127.0.0.1:2200/Test-CI/multi-line-secrets.git", CloneSSH: "ssh://git@127.0.0.1:2200/Test-CI/multi-line-secrets.git",
Branch: "main", Branch: "main",
SCMKind: "git",
PREnabled: true, PREnabled: true,
IsSCMPrivate: false, IsSCMPrivate: false,
Perm: &model.Perm{ Perm: &model.Perm{
@ -276,7 +270,6 @@ func TestGiteaParser(t *testing.T) {
Clone: "https://gitea.com/anbraten/test-repo.git", Clone: "https://gitea.com/anbraten/test-repo.git",
CloneSSH: "git@gitea.com:anbraten/test-repo.git", CloneSSH: "git@gitea.com:anbraten/test-repo.git",
Branch: "main", Branch: "main",
SCMKind: "git",
PREnabled: true, PREnabled: true,
Perm: &model.Perm{ Perm: &model.Perm{
Pull: true, Pull: true,
@ -314,7 +307,6 @@ func TestGiteaParser(t *testing.T) {
Clone: "https://gitea.com/anbraten/test-repo.git", Clone: "https://gitea.com/anbraten/test-repo.git",
CloneSSH: "git@gitea.com:anbraten/test-repo.git", CloneSSH: "git@gitea.com:anbraten/test-repo.git",
Branch: "main", Branch: "main",
SCMKind: "git",
PREnabled: true, PREnabled: true,
Perm: &model.Perm{ Perm: &model.Perm{
Pull: true, Pull: true,
@ -352,7 +344,6 @@ func TestGiteaParser(t *testing.T) {
Clone: "https://git.xxx/anbraten/demo.git", Clone: "https://git.xxx/anbraten/demo.git",
CloneSSH: "ssh://git@git.xxx:22/anbraten/demo.git", CloneSSH: "ssh://git@git.xxx:22/anbraten/demo.git",
Branch: "main", Branch: "main",
SCMKind: "git",
PREnabled: true, PREnabled: true,
IsSCMPrivate: true, IsSCMPrivate: true,
Perm: &model.Perm{ Perm: &model.Perm{

View file

@ -94,7 +94,6 @@ func convertRepo(from *github.Repository) *model.Repo {
Owner: from.GetOwner().GetLogin(), Owner: from.GetOwner().GetLogin(),
Avatar: from.GetOwner().GetAvatarURL(), Avatar: from.GetOwner().GetAvatarURL(),
Perm: convertPerm(from.GetPermissions()), Perm: convertPerm(from.GetPermissions()),
SCMKind: model.RepoGit,
PREnabled: true, PREnabled: true,
} }
return repo return repo
@ -152,7 +151,6 @@ func convertRepoHook(eventRepo *github.PushEventRepository) *model.Repo {
Clone: eventRepo.GetCloneURL(), Clone: eventRepo.GetCloneURL(),
CloneSSH: eventRepo.GetSSHURL(), CloneSSH: eventRepo.GetSSHURL(),
Branch: eventRepo.GetDefaultBranch(), Branch: eventRepo.GetDefaultBranch(),
SCMKind: model.RepoGit,
PREnabled: true, PREnabled: true,
} }
if repo.FullName == "" { if repo.FullName == "" {

View file

@ -115,7 +115,6 @@ func Test_helper(t *testing.T) {
g.Assert(to.Owner).Equal("octocat") g.Assert(to.Owner).Equal("octocat")
g.Assert(to.Name).Equal("hello-world") g.Assert(to.Name).Equal("hello-world")
g.Assert(to.Branch).Equal("develop") g.Assert(to.Branch).Equal("develop")
g.Assert(string(to.SCMKind)).Equal("git")
g.Assert(to.IsSCMPrivate).IsTrue() g.Assert(to.IsSCMPrivate).IsTrue()
g.Assert(to.Clone).Equal("https://github.com/octocat/hello-world.git") g.Assert(to.Clone).Equal("https://github.com/octocat/hello-world.git")
g.Assert(to.ForgeURL).Equal("https://github.com/octocat/hello-world") g.Assert(to.ForgeURL).Equal("https://github.com/octocat/hello-world")

View file

@ -77,16 +77,6 @@ func (s StatusValue) Validate() error {
} }
} }
// SCMKind represent different version control systems.
type SCMKind string // @name SCMKind
const (
RepoGit SCMKind = "git"
RepoHg SCMKind = "hg"
RepoFossil SCMKind = "fossil"
RepoPerforce SCMKind = "perforce"
)
// RepoVisibility represent to what state a repo in woodpecker is visible to others. // RepoVisibility represent to what state a repo in woodpecker is visible to others.
type RepoVisibility string // @name RepoVisibility type RepoVisibility string // @name RepoVisibility

View file

@ -57,7 +57,6 @@ type Repo struct {
Clone string `json:"clone_url,omitempty" xorm:"varchar(1000) 'clone'"` Clone string `json:"clone_url,omitempty" xorm:"varchar(1000) 'clone'"`
CloneSSH string `json:"clone_url_ssh" xorm:"varchar(1000) 'clone_ssh'"` CloneSSH string `json:"clone_url_ssh" xorm:"varchar(1000) 'clone_ssh'"`
Branch string `json:"default_branch,omitempty" xorm:"varchar(500) 'branch'"` Branch string `json:"default_branch,omitempty" xorm:"varchar(500) 'branch'"`
SCMKind SCMKind `json:"scm,omitempty" xorm:"varchar(50) 'scm'"`
PREnabled bool `json:"pr_enabled" xorm:"DEFAULT TRUE 'pr_enabled'"` PREnabled bool `json:"pr_enabled" xorm:"DEFAULT TRUE 'pr_enabled'"`
Timeout int64 `json:"timeout,omitempty" xorm:"timeout"` Timeout int64 `json:"timeout,omitempty" xorm:"timeout"`
Visibility RepoVisibility `json:"visibility" xorm:"varchar(10) 'visibility'"` Visibility RepoVisibility `json:"visibility" xorm:"varchar(10) 'visibility'"`
@ -108,7 +107,6 @@ func (r *Repo) Update(from *Repo) {
r.FullName = from.FullName r.FullName = from.FullName
r.Avatar = from.Avatar r.Avatar = from.Avatar
r.ForgeURL = from.ForgeURL r.ForgeURL = from.ForgeURL
r.SCMKind = from.SCMKind
r.PREnabled = from.PREnabled r.PREnabled = from.PREnabled
if len(from.Clone) > 0 { if len(from.Clone) > 0 {
r.Clone = from.Clone r.Clone = from.Clone

View file

@ -48,7 +48,6 @@ func MetadataFromStruct(forge metadata.ServerForge, repo *model.Repo, pipeline,
Owner: repo.Owner, Owner: repo.Owner,
RemoteID: fmt.Sprint(repo.ForgeRemoteID), RemoteID: fmt.Sprint(repo.ForgeRemoteID),
ForgeURL: repo.ForgeURL, ForgeURL: repo.ForgeURL,
SCM: string(repo.SCMKind),
CloneURL: repo.Clone, CloneURL: repo.Clone,
CloneSSHURL: repo.CloneSSH, CloneSSHURL: repo.CloneSSH,
Private: repo.IsSCMPrivate, Private: repo.IsSCMPrivate,

View file

@ -57,7 +57,7 @@ func TestMetadataFromStruct(t *testing.T) {
{ {
name: "Test with forge", name: "Test with forge",
forge: forge, forge: forge,
repo: &model.Repo{FullName: "testUser/testRepo", ForgeURL: "https://gitea.com/testUser/testRepo", Clone: "https://gitea.com/testUser/testRepo.git", CloneSSH: "git@gitea.com:testUser/testRepo.git", Branch: "main", IsSCMPrivate: true, SCMKind: "git"}, repo: &model.Repo{FullName: "testUser/testRepo", ForgeURL: "https://gitea.com/testUser/testRepo", Clone: "https://gitea.com/testUser/testRepo.git", CloneSSH: "git@gitea.com:testUser/testRepo.git", Branch: "main", IsSCMPrivate: true},
pipeline: &model.Pipeline{Number: 3, ChangedFiles: []string{"test.go", "markdown file.md"}}, pipeline: &model.Pipeline{Number: 3, ChangedFiles: []string{"test.go", "markdown file.md"}},
prev: &model.Pipeline{Number: 2}, prev: &model.Pipeline{Number: 2},
workflow: &model.Workflow{Name: "hello"}, workflow: &model.Workflow{Name: "hello"},
@ -65,7 +65,7 @@ func TestMetadataFromStruct(t *testing.T) {
expectedMetadata: metadata.Metadata{ expectedMetadata: metadata.Metadata{
Forge: metadata.Forge{Type: "gitea", URL: "https://gitea.com"}, Forge: metadata.Forge{Type: "gitea", URL: "https://gitea.com"},
Sys: metadata.System{Name: "woodpecker", Host: "example.com", URL: "https://example.com"}, Sys: metadata.System{Name: "woodpecker", Host: "example.com", URL: "https://example.com"},
Repo: metadata.Repo{Owner: "testUser", Name: "testRepo", ForgeURL: "https://gitea.com/testUser/testRepo", CloneURL: "https://gitea.com/testUser/testRepo.git", CloneSSHURL: "git@gitea.com:testUser/testRepo.git", Branch: "main", Private: true, SCM: "git"}, Repo: metadata.Repo{Owner: "testUser", Name: "testRepo", ForgeURL: "https://gitea.com/testUser/testRepo", CloneURL: "https://gitea.com/testUser/testRepo.git", CloneSSHURL: "git@gitea.com:testUser/testRepo.git", Branch: "main", Private: true},
Curr: metadata.Pipeline{ Curr: metadata.Pipeline{
Number: 3, Number: 3,
Commit: metadata.Commit{ChangedFiles: []string{"test.go", "markdown file.md"}}, Commit: metadata.Commit{ChangedFiles: []string{"test.go", "markdown file.md"}},
@ -82,7 +82,7 @@ func TestMetadataFromStruct(t *testing.T) {
"CI_PREV_PIPELINE_FINISHED": "0", "CI_PREV_PIPELINE_NUMBER": "2", "CI_PREV_PIPELINE_PARENT": "0", "CI_PREV_PIPELINE_FINISHED": "0", "CI_PREV_PIPELINE_NUMBER": "2", "CI_PREV_PIPELINE_PARENT": "0",
"CI_PREV_PIPELINE_STARTED": "0", "CI_PREV_PIPELINE_URL": "https://example.com/repos/0/pipeline/2", "CI_REPO": "testUser/testRepo", "CI_REPO_CLONE_URL": "https://gitea.com/testUser/testRepo.git", "CI_REPO_CLONE_SSH_URL": "git@gitea.com:testUser/testRepo.git", "CI_PREV_PIPELINE_STARTED": "0", "CI_PREV_PIPELINE_URL": "https://example.com/repos/0/pipeline/2", "CI_REPO": "testUser/testRepo", "CI_REPO_CLONE_URL": "https://gitea.com/testUser/testRepo.git", "CI_REPO_CLONE_SSH_URL": "git@gitea.com:testUser/testRepo.git",
"CI_REPO_DEFAULT_BRANCH": "main", "CI_REPO_NAME": "testRepo", "CI_REPO_OWNER": "testUser", "CI_REPO_PRIVATE": "true", "CI_REPO_DEFAULT_BRANCH": "main", "CI_REPO_NAME": "testRepo", "CI_REPO_OWNER": "testUser", "CI_REPO_PRIVATE": "true",
"CI_REPO_SCM": "git", "CI_REPO_TRUSTED": "false", "CI_REPO_TRUSTED_NETWORK": "false", "CI_REPO_TRUSTED_SECURITY": "false", "CI_REPO_TRUSTED_VOLUMES": "false", "CI_REPO_TRUSTED": "false", "CI_REPO_TRUSTED_NETWORK": "false", "CI_REPO_TRUSTED_SECURITY": "false", "CI_REPO_TRUSTED_VOLUMES": "false",
"CI_REPO_URL": "https://gitea.com/testUser/testRepo", "CI_STEP_NUMBER": "0", "CI_STEP_URL": "https://example.com/repos/0/pipeline/3", "CI_SYSTEM_HOST": "example.com", "CI_REPO_URL": "https://gitea.com/testUser/testRepo", "CI_STEP_NUMBER": "0", "CI_STEP_URL": "https://example.com/repos/0/pipeline/3", "CI_SYSTEM_HOST": "example.com",
"CI_SYSTEM_NAME": "woodpecker", "CI_SYSTEM_URL": "https://example.com", "CI_WORKFLOW_NAME": "hello", "CI_WORKFLOW_NUMBER": "0", "CI_SYSTEM_NAME": "woodpecker", "CI_SYSTEM_URL": "https://example.com", "CI_WORKFLOW_NAME": "hello", "CI_WORKFLOW_NUMBER": "0",
}, },

View file

@ -56,7 +56,6 @@ type repoV008 struct {
Clone string `xorm:"varchar(1000) 'repo_clone'"` Clone string `xorm:"varchar(1000) 'repo_clone'"`
CloneSSH string `xorm:"varchar(1000) 'repo_clone_ssh'"` CloneSSH string `xorm:"varchar(1000) 'repo_clone_ssh'"`
Branch string `xorm:"varchar(500) 'repo_branch'"` Branch string `xorm:"varchar(500) 'repo_branch'"`
SCMKind model.SCMKind `xorm:"varchar(50) 'repo_scm'"`
PREnabled bool `xorm:"DEFAULT TRUE 'repo_pr_enabled'"` PREnabled bool `xorm:"DEFAULT TRUE 'repo_pr_enabled'"`
Timeout int64 `xorm:"repo_timeout"` Timeout int64 `xorm:"repo_timeout"`
Visibility model.RepoVisibility `xorm:"varchar(10) 'repo_visibility'"` Visibility model.RepoVisibility `xorm:"varchar(10) 'repo_visibility'"`

View file

@ -0,0 +1,36 @@
// Copyright 2024 Woodpecker Authors
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package migration
import (
"src.techknowlogick.com/xormigrate"
"xorm.io/xorm"
)
var removeRepoScm = xormigrate.Migration{
ID: "remove-repo-scm",
MigrateSession: func(sess *xorm.Session) (err error) {
type repos struct {
SCMKind string `xorm:"varchar(50) 'scm'"`
}
// ensure columns to drop exist
if err := sess.Sync(new(repos)); err != nil {
return err
}
return dropTableColumns(sess, "repos", "scm")
},
}

View file

@ -51,6 +51,7 @@ var migrationTasks = []*xormigrate.Migration{
&removeRepoNetrcOnlyTrusted, &removeRepoNetrcOnlyTrusted,
&renameTokenFields, &renameTokenFields,
&setNewDefaultsForRequireApproval, &setNewDefaultsForRequireApproval,
&removeRepoScm,
} }
var allBeans = []any{ var allBeans = []any{