mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-27 00:23:41 +09:00 
			
		
		
		
	Fix cli command restore-repo: "units" should be splitted to string slice, to match the old behavior and match the dump-repo's behavior (#20183)
This commit is contained in:
		| @@ -134,7 +134,9 @@ func runDumpRepository(ctx *cli.Context) error { | ||||
| 	} else { | ||||
| 		units := strings.Split(ctx.String("units"), ",") | ||||
| 		for _, unit := range units { | ||||
| 			switch strings.ToLower(unit) { | ||||
| 			switch strings.ToLower(strings.TrimSpace(unit)) { | ||||
| 			case "": | ||||
| 				continue | ||||
| 			case "wiki": | ||||
| 				opts.Wiki = true | ||||
| 			case "issues": | ||||
| @@ -151,6 +153,8 @@ func runDumpRepository(ctx *cli.Context) error { | ||||
| 				opts.Comments = true | ||||
| 			case "pull_requests": | ||||
| 				opts.PullRequests = true | ||||
| 			default: | ||||
| 				return errors.New("invalid unit: " + unit) | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
|   | ||||
| @@ -7,6 +7,7 @@ package cmd | ||||
| import ( | ||||
| 	"errors" | ||||
| 	"net/http" | ||||
| 	"strings" | ||||
|  | ||||
| 	"code.gitea.io/gitea/modules/log" | ||||
| 	"code.gitea.io/gitea/modules/private" | ||||
| @@ -37,10 +38,10 @@ var CmdRestoreRepository = cli.Command{ | ||||
| 			Value: "", | ||||
| 			Usage: "Restore destination repository name", | ||||
| 		}, | ||||
| 		cli.StringSliceFlag{ | ||||
| 		cli.StringFlag{ | ||||
| 			Name:  "units", | ||||
| 			Value: nil, | ||||
| 			Usage: `Which items will be restored, one or more units should be repeated with this flag. | ||||
| 			Value: "", | ||||
| 			Usage: `Which items will be restored, one or more units should be separated as comma. | ||||
| wiki, issues, labels, releases, release_assets, milestones, pull_requests, comments are allowed. Empty means all units.`, | ||||
| 		}, | ||||
| 		cli.BoolFlag{ | ||||
| @@ -55,13 +56,16 @@ func runRestoreRepository(c *cli.Context) error { | ||||
| 	defer cancel() | ||||
|  | ||||
| 	setting.LoadFromExisting() | ||||
|  | ||||
| 	var units []string | ||||
| 	if s := c.String("units"); s != "" { | ||||
| 		units = strings.Split(s, ",") | ||||
| 	} | ||||
| 	statusCode, errStr := private.RestoreRepo( | ||||
| 		ctx, | ||||
| 		c.String("repo_dir"), | ||||
| 		c.String("owner_name"), | ||||
| 		c.String("repo_name"), | ||||
| 		c.StringSlice("units"), | ||||
| 		units, | ||||
| 		c.Bool("validation"), | ||||
| 	) | ||||
| 	if statusCode == http.StatusOK { | ||||
|   | ||||
| @@ -590,7 +590,7 @@ func updateOptionsUnits(opts *base.MigrateOptions, units []string) error { | ||||
| 		opts.ReleaseAssets = true | ||||
| 	} else { | ||||
| 		for _, unit := range units { | ||||
| 			switch strings.ToLower(unit) { | ||||
| 			switch strings.ToLower(strings.TrimSpace(unit)) { | ||||
| 			case "": | ||||
| 				continue | ||||
| 			case "wiki": | ||||
|   | ||||
		Reference in New Issue
	
	Block a user