mirror of
				https://github.com/packwiz/packwiz.git
				synced 2025-10-26 02:04:31 +02:00 
			
		
		
		
	Add no-internal-hashes mode
This commit is contained in:
		| @@ -78,3 +78,5 @@ For use on servers, add the `-g` flag to disable the GUI and `-s server` to down | ||||
| - Additional options can be configured in the `[options]` section of `pack.toml`, as follows: | ||||
|     - `mods-folder` The folder to save mod metadata files into, for the install commands | ||||
|     - `acceptable-game-versions` A list of additional Minecraft versions to accept when installing or updating mods | ||||
|     - `no-internal-hashes` If this is set to true, packwiz will not generate hashes of local files, to prevent merge conflicts and inconsistent hashes when using git/etc. | ||||
|         - `packwiz refresh --build` can be used in this mode to generate internal hashes for distributing the pack with packwiz-installer | ||||
| @@ -157,7 +157,7 @@ var initCmd = &cobra.Command{ | ||||
| 			Index: struct { | ||||
| 				File       string `toml:"file"` | ||||
| 				HashFormat string `toml:"hash-format"` | ||||
| 				Hash       string `toml:"hash"` | ||||
| 				Hash       string `toml:"hash,omitempty"` | ||||
| 			}{ | ||||
| 				File: indexFilePath, | ||||
| 			}, | ||||
|   | ||||
| @@ -2,6 +2,7 @@ package cmd | ||||
|  | ||||
| import ( | ||||
| 	"fmt" | ||||
| 	"github.com/spf13/viper" | ||||
| 	"os" | ||||
|  | ||||
| 	"github.com/comp500/packwiz/core" | ||||
| @@ -20,6 +21,12 @@ var refreshCmd = &cobra.Command{ | ||||
| 			fmt.Println(err) | ||||
| 			os.Exit(1) | ||||
| 		} | ||||
| 		build, err := cmd.Flags().GetBool("build") | ||||
| 		if err == nil && build { | ||||
| 			viper.Set("no-internal-hashes", false) | ||||
| 		} else if viper.GetBool("no-internal-hashes") { | ||||
| 			fmt.Println("Note: no-internal-hashes mode is set, no hashes will be saved. Use --build to override this for distribution.") | ||||
| 		} | ||||
| 		index, err := pack.LoadIndex() | ||||
| 		if err != nil { | ||||
| 			fmt.Println(err) | ||||
| @@ -51,4 +58,6 @@ var refreshCmd = &cobra.Command{ | ||||
|  | ||||
| func init() { | ||||
| 	rootCmd.AddCommand(refreshCmd) | ||||
|  | ||||
| 	refreshCmd.Flags().Bool("build", false, "Only has an effect in no-internal-hashes mode: generates internal hashes for distribution with packwiz-installer") | ||||
| } | ||||
|   | ||||
| @@ -28,7 +28,7 @@ type Index struct { | ||||
| type IndexFile struct { | ||||
| 	// Files are stored in forward-slash format relative to the index file | ||||
| 	File           string `toml:"file"` | ||||
| 	Hash           string `toml:"hash"` | ||||
| 	Hash           string `toml:"hash,omitempty"` | ||||
| 	HashFormat     string `toml:"hash-format,omitempty"` | ||||
| 	Alias          string `toml:"alias,omitempty"` | ||||
| 	MetaFile       bool   `toml:"metafile,omitempty"` // True when it is a .toml metadata file | ||||
| @@ -121,6 +121,10 @@ func (in *Index) updateFileHashGiven(path, format, hash string, mod bool) error | ||||
|  | ||||
| // updateFile calculates the hash for a given path and updates it in the index | ||||
| func (in *Index) updateFile(path string) error { | ||||
| 	var hashString string | ||||
| 	if viper.GetBool("no-internal-hashes") { | ||||
| 		hashString = "" | ||||
| 	} else { | ||||
| 		f, err := os.Open(path) | ||||
| 		if err != nil { | ||||
| 			return err | ||||
| @@ -142,7 +146,8 @@ func (in *Index) updateFile(path string) error { | ||||
| 		if err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	hashString := hex.EncodeToString(h.Sum(nil)) | ||||
| 		hashString = hex.EncodeToString(h.Sum(nil)) | ||||
| 	} | ||||
|  | ||||
| 	mod := false | ||||
| 	// If the file has an extension of toml and is in the mods folder, set mod to true | ||||
| @@ -290,6 +295,9 @@ func (in Index) Write() error { | ||||
|  | ||||
| // RefreshFileWithHash updates a file in the index, given a file hash and whether it is a mod or not | ||||
| func (in *Index) RefreshFileWithHash(path, format, hash string, mod bool) error { | ||||
| 	if viper.GetBool("no-internal-hashes") { | ||||
| 		hash = "" | ||||
| 	} | ||||
| 	err := in.updateFileHashGiven(path, format, hash, mod) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| @@ -351,7 +359,7 @@ func (in Index) SaveFile(f IndexFile, dest io.Writer) error { | ||||
| 	} | ||||
|  | ||||
| 	calculatedHash := hex.EncodeToString(h.Sum(nil)) | ||||
| 	if calculatedHash != f.Hash { | ||||
| 	if calculatedHash != f.Hash && !viper.GetBool("no-internal-hashes") { | ||||
| 		return errors.New("hash of saved file is invalid") | ||||
| 	} | ||||
|  | ||||
|   | ||||
| @@ -20,7 +20,7 @@ type Pack struct { | ||||
| 		// Path is stored in forward slash format relative to pack.toml | ||||
| 		File       string `toml:"file"` | ||||
| 		HashFormat string `toml:"hash-format"` | ||||
| 		Hash       string `toml:"hash"` | ||||
| 		Hash       string `toml:"hash,omitempty"` | ||||
| 	} `toml:"index"` | ||||
| 	Versions map[string]string                 `toml:"versions"` | ||||
| 	Client   map[string]toml.Primitive         `toml:"client"` | ||||
| @@ -61,6 +61,12 @@ func (pack Pack) LoadIndex() (Index, error) { | ||||
|  | ||||
| // UpdateIndexHash recalculates the hash of the index file of this modpack | ||||
| func (pack *Pack) UpdateIndexHash() error { | ||||
| 	if viper.GetBool("no-internal-hashes") { | ||||
| 		pack.Index.HashFormat = "sha256" | ||||
| 		pack.Index.Hash = "" | ||||
| 		return nil | ||||
| 	} | ||||
|  | ||||
| 	fileNative := filepath.FromSlash(pack.Index.File) | ||||
| 	indexFile := filepath.Join(filepath.Dir(viper.GetString("pack-file")), fileNative) | ||||
| 	if filepath.IsAbs(pack.Index.File) { | ||||
|   | ||||
| @@ -158,7 +158,7 @@ var importCmd = &cobra.Command{ | ||||
| 				Index: struct { | ||||
| 					File       string `toml:"file"` | ||||
| 					HashFormat string `toml:"hash-format"` | ||||
| 					Hash       string `toml:"hash"` | ||||
| 					Hash       string `toml:"hash,omitempty"` | ||||
| 				}{ | ||||
| 					File: indexFilePath, | ||||
| 				}, | ||||
|   | ||||
		Reference in New Issue
	
	Block a user