mirror of
				https://gitcode.com/gitea/gitea.git
				synced 2025-10-25 12:26:40 +08:00 
			
		
		
		
	Refactor setting.Database.UseXXX to methods (#23354)
				
					
				
			Replace #23350. Refactor `setting.Database.UseMySQL` to `setting.Database.Type.IsMySQL()`. To avoid mismatching between `Type` and `UseXXX`. This refactor can fix the bug mentioned in #23350, so it should be backported.
This commit is contained in:
		| @ -89,7 +89,7 @@ func RecreateTable(sess *xorm.Session, bean interface{}) error { | ||||
| 		hasID = hasID || (column.IsPrimaryKey && column.IsAutoIncrement) | ||||
| 	} | ||||
|  | ||||
| 	if hasID && setting.Database.UseMSSQL { | ||||
| 	if hasID && setting.Database.Type.IsMSSQL() { | ||||
| 		if _, err := sess.Exec(fmt.Sprintf("SET IDENTITY_INSERT `%s` ON", tempTableName)); err != nil { | ||||
| 			log.Error("Unable to set identity insert for table %s. Error: %v", tempTableName, err) | ||||
| 			return err | ||||
| @ -143,7 +143,7 @@ func RecreateTable(sess *xorm.Session, bean interface{}) error { | ||||
| 		return err | ||||
| 	} | ||||
|  | ||||
| 	if hasID && setting.Database.UseMSSQL { | ||||
| 	if hasID && setting.Database.Type.IsMSSQL() { | ||||
| 		if _, err := sess.Exec(fmt.Sprintf("SET IDENTITY_INSERT `%s` OFF", tempTableName)); err != nil { | ||||
| 			log.Error("Unable to switch off identity insert for table %s. Error: %v", tempTableName, err) | ||||
| 			return err | ||||
| @ -151,7 +151,7 @@ func RecreateTable(sess *xorm.Session, bean interface{}) error { | ||||
| 	} | ||||
|  | ||||
| 	switch { | ||||
| 	case setting.Database.UseSQLite3: | ||||
| 	case setting.Database.Type.IsSQLite3(): | ||||
| 		// SQLite will drop all the constraints on the old table | ||||
| 		if _, err := sess.Exec(fmt.Sprintf("DROP TABLE `%s`", tableName)); err != nil { | ||||
| 			log.Error("Unable to drop old table %s. Error: %v", tableName, err) | ||||
| @ -178,7 +178,7 @@ func RecreateTable(sess *xorm.Session, bean interface{}) error { | ||||
| 			return err | ||||
| 		} | ||||
|  | ||||
| 	case setting.Database.UseMySQL: | ||||
| 	case setting.Database.Type.IsMySQL(): | ||||
| 		// MySQL will drop all the constraints on the old table | ||||
| 		if _, err := sess.Exec(fmt.Sprintf("DROP TABLE `%s`", tableName)); err != nil { | ||||
| 			log.Error("Unable to drop old table %s. Error: %v", tableName, err) | ||||
| @ -205,7 +205,7 @@ func RecreateTable(sess *xorm.Session, bean interface{}) error { | ||||
| 			log.Error("Unable to recreate uniques on table %s. Error: %v", tableName, err) | ||||
| 			return err | ||||
| 		} | ||||
| 	case setting.Database.UsePostgreSQL: | ||||
| 	case setting.Database.Type.IsPostgreSQL(): | ||||
| 		var originalSequences []string | ||||
| 		type sequenceData struct { | ||||
| 			LastValue int  `xorm:"'last_value'"` | ||||
| @ -296,7 +296,7 @@ func RecreateTable(sess *xorm.Session, bean interface{}) error { | ||||
|  | ||||
| 		} | ||||
|  | ||||
| 	case setting.Database.UseMSSQL: | ||||
| 	case setting.Database.Type.IsMSSQL(): | ||||
| 		// MSSQL will drop all the constraints on the old table | ||||
| 		if _, err := sess.Exec(fmt.Sprintf("DROP TABLE `%s`", tableName)); err != nil { | ||||
| 			log.Error("Unable to drop old table %s. Error: %v", tableName, err) | ||||
| @ -323,7 +323,7 @@ func DropTableColumns(sess *xorm.Session, tableName string, columnNames ...strin | ||||
| 	// TODO: This will not work if there are foreign keys | ||||
|  | ||||
| 	switch { | ||||
| 	case setting.Database.UseSQLite3: | ||||
| 	case setting.Database.Type.IsSQLite3(): | ||||
| 		// First drop the indexes on the columns | ||||
| 		res, errIndex := sess.Query(fmt.Sprintf("PRAGMA index_list(`%s`)", tableName)) | ||||
| 		if errIndex != nil { | ||||
| @ -405,7 +405,7 @@ func DropTableColumns(sess *xorm.Session, tableName string, columnNames ...strin | ||||
| 			return err | ||||
| 		} | ||||
|  | ||||
| 	case setting.Database.UsePostgreSQL: | ||||
| 	case setting.Database.Type.IsPostgreSQL(): | ||||
| 		cols := "" | ||||
| 		for _, col := range columnNames { | ||||
| 			if cols != "" { | ||||
| @ -416,7 +416,7 @@ func DropTableColumns(sess *xorm.Session, tableName string, columnNames ...strin | ||||
| 		if _, err := sess.Exec(fmt.Sprintf("ALTER TABLE `%s` %s", tableName, cols)); err != nil { | ||||
| 			return fmt.Errorf("Drop table `%s` columns %v: %v", tableName, columnNames, err) | ||||
| 		} | ||||
| 	case setting.Database.UseMySQL: | ||||
| 	case setting.Database.Type.IsMySQL(): | ||||
| 		// Drop indexes on columns first | ||||
| 		sql := fmt.Sprintf("SHOW INDEX FROM %s WHERE column_name IN ('%s')", tableName, strings.Join(columnNames, "','")) | ||||
| 		res, err := sess.Query(sql) | ||||
| @ -444,7 +444,7 @@ func DropTableColumns(sess *xorm.Session, tableName string, columnNames ...strin | ||||
| 		if _, err := sess.Exec(fmt.Sprintf("ALTER TABLE `%s` %s", tableName, cols)); err != nil { | ||||
| 			return fmt.Errorf("Drop table `%s` columns %v: %v", tableName, columnNames, err) | ||||
| 		} | ||||
| 	case setting.Database.UseMSSQL: | ||||
| 	case setting.Database.Type.IsMSSQL(): | ||||
| 		cols := "" | ||||
| 		for _, col := range columnNames { | ||||
| 			if cols != "" { | ||||
| @ -543,13 +543,13 @@ func newXORMEngine() (*xorm.Engine, error) { | ||||
|  | ||||
| func deleteDB() error { | ||||
| 	switch { | ||||
| 	case setting.Database.UseSQLite3: | ||||
| 	case setting.Database.Type.IsSQLite3(): | ||||
| 		if err := util.Remove(setting.Database.Path); err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 		return os.MkdirAll(path.Dir(setting.Database.Path), os.ModePerm) | ||||
|  | ||||
| 	case setting.Database.UseMySQL: | ||||
| 	case setting.Database.Type.IsMySQL(): | ||||
| 		db, err := sql.Open("mysql", fmt.Sprintf("%s:%s@tcp(%s)/", | ||||
| 			setting.Database.User, setting.Database.Passwd, setting.Database.Host)) | ||||
| 		if err != nil { | ||||
| @ -565,7 +565,7 @@ func deleteDB() error { | ||||
| 			return err | ||||
| 		} | ||||
| 		return nil | ||||
| 	case setting.Database.UsePostgreSQL: | ||||
| 	case setting.Database.Type.IsPostgreSQL(): | ||||
| 		db, err := sql.Open("postgres", fmt.Sprintf("postgres://%s:%s@%s/?sslmode=%s", | ||||
| 			setting.Database.User, setting.Database.Passwd, setting.Database.Host, setting.Database.SSLMode)) | ||||
| 		if err != nil { | ||||
| @ -612,7 +612,7 @@ func deleteDB() error { | ||||
| 			} | ||||
| 			return nil | ||||
| 		} | ||||
| 	case setting.Database.UseMSSQL: | ||||
| 	case setting.Database.Type.IsMSSQL(): | ||||
| 		host, port := setting.ParseMSSQLHostPort(setting.Database.Host) | ||||
| 		db, err := sql.Open("mssql", fmt.Sprintf("server=%s; port=%s; database=%s; user id=%s; password=%s;", | ||||
| 			host, port, "master", setting.Database.User, setting.Database.Passwd)) | ||||
|  | ||||
| @ -13,9 +13,9 @@ func PrependRefsHeadsToIssueRefs(x *xorm.Engine) error { | ||||
| 	var query string | ||||
|  | ||||
| 	switch { | ||||
| 	case setting.Database.UseMSSQL: | ||||
| 	case setting.Database.Type.IsMSSQL(): | ||||
| 		query = "UPDATE `issue` SET `ref` = 'refs/heads/' + `ref` WHERE `ref` IS NOT NULL AND `ref` <> '' AND `ref` NOT LIKE 'refs/%'" | ||||
| 	case setting.Database.UseMySQL: | ||||
| 	case setting.Database.Type.IsMySQL(): | ||||
| 		query = "UPDATE `issue` SET `ref` = CONCAT('refs/heads/', `ref`) WHERE `ref` IS NOT NULL AND `ref` <> '' AND `ref` NOT LIKE 'refs/%';" | ||||
| 	default: | ||||
| 		query = "UPDATE `issue` SET `ref` = 'refs/heads/' || `ref` WHERE `ref` IS NOT NULL AND `ref` <> '' AND `ref` NOT LIKE 'refs/%'" | ||||
|  | ||||
| @ -41,7 +41,7 @@ func FixLanguageStatsToSaveSize(x *xorm.Engine) error { | ||||
|  | ||||
| 	// Delete language stat statuses | ||||
| 	truncExpr := "TRUNCATE TABLE" | ||||
| 	if setting.Database.UseSQLite3 { | ||||
| 	if setting.Database.Type.IsSQLite3() { | ||||
| 		truncExpr = "DELETE FROM" | ||||
| 	} | ||||
|  | ||||
|  | ||||
| @ -21,7 +21,7 @@ func IncreaseLanguageField(x *xorm.Engine) error { | ||||
| 		return err | ||||
| 	} | ||||
|  | ||||
| 	if setting.Database.UseSQLite3 { | ||||
| 	if setting.Database.Type.IsSQLite3() { | ||||
| 		// SQLite maps VARCHAR to TEXT without size so we're done | ||||
| 		return nil | ||||
| 	} | ||||
| @ -41,11 +41,11 @@ func IncreaseLanguageField(x *xorm.Engine) error { | ||||
| 	} | ||||
|  | ||||
| 	switch { | ||||
| 	case setting.Database.UseMySQL: | ||||
| 	case setting.Database.Type.IsMySQL(): | ||||
| 		if _, err := sess.Exec(fmt.Sprintf("ALTER TABLE language_stat MODIFY COLUMN language %s", sqlType)); err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	case setting.Database.UseMSSQL: | ||||
| 	case setting.Database.Type.IsMSSQL(): | ||||
| 		// Yet again MSSQL just has to be awkward. | ||||
| 		// Here we have to drop the constraints first and then rebuild them | ||||
| 		constraints := make([]string, 0) | ||||
| @ -71,7 +71,7 @@ func IncreaseLanguageField(x *xorm.Engine) error { | ||||
| 		if err := sess.CreateUniques(new(LanguageStat)); err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	case setting.Database.UsePostgreSQL: | ||||
| 	case setting.Database.Type.IsPostgreSQL(): | ||||
| 		if _, err := sess.Exec(fmt.Sprintf("ALTER TABLE language_stat ALTER COLUMN language TYPE %s", sqlType)); err != nil { | ||||
| 			return err | ||||
| 		} | ||||
|  | ||||
| @ -17,13 +17,13 @@ import ( | ||||
|  | ||||
| func SetDefaultPasswordToArgon2(x *xorm.Engine) error { | ||||
| 	switch { | ||||
| 	case setting.Database.UseMySQL: | ||||
| 	case setting.Database.Type.IsMySQL(): | ||||
| 		_, err := x.Exec("ALTER TABLE `user` ALTER passwd_hash_algo SET DEFAULT 'argon2';") | ||||
| 		return err | ||||
| 	case setting.Database.UsePostgreSQL: | ||||
| 	case setting.Database.Type.IsPostgreSQL(): | ||||
| 		_, err := x.Exec("ALTER TABLE `user` ALTER COLUMN passwd_hash_algo SET DEFAULT 'argon2';") | ||||
| 		return err | ||||
| 	case setting.Database.UseMSSQL: | ||||
| 	case setting.Database.Type.IsMSSQL(): | ||||
| 		// need to find the constraint and drop it, then recreate it. | ||||
| 		sess := x.NewSession() | ||||
| 		defer sess.Close() | ||||
| @ -53,7 +53,7 @@ func SetDefaultPasswordToArgon2(x *xorm.Engine) error { | ||||
| 		} | ||||
| 		return sess.Commit() | ||||
|  | ||||
| 	case setting.Database.UseSQLite3: | ||||
| 	case setting.Database.Type.IsSQLite3(): | ||||
| 		// drop through | ||||
| 	default: | ||||
| 		log.Fatal("Unrecognized DB") | ||||
|  | ||||
| @ -62,7 +62,7 @@ func UpdateCodeCommentReplies(x *xorm.Engine) error { | ||||
| 			return err | ||||
| 		} | ||||
|  | ||||
| 		if setting.Database.UseMSSQL { | ||||
| 		if setting.Database.Type.IsMSSQL() { | ||||
| 			if _, err := sess.Exec(sqlSelect + " INTO #temp_comments" + sqlTail); err != nil { | ||||
| 				log.Error("unable to create temporary table") | ||||
| 				return err | ||||
| @ -72,13 +72,13 @@ func UpdateCodeCommentReplies(x *xorm.Engine) error { | ||||
| 		comments := make([]*Comment, 0, batchSize) | ||||
|  | ||||
| 		switch { | ||||
| 		case setting.Database.UseMySQL: | ||||
| 		case setting.Database.Type.IsMySQL(): | ||||
| 			sqlCmd = sqlSelect + sqlTail + " LIMIT " + strconv.Itoa(batchSize) + ", " + strconv.Itoa(start) | ||||
| 		case setting.Database.UsePostgreSQL: | ||||
| 		case setting.Database.Type.IsPostgreSQL(): | ||||
| 			fallthrough | ||||
| 		case setting.Database.UseSQLite3: | ||||
| 		case setting.Database.Type.IsSQLite3(): | ||||
| 			sqlCmd = sqlSelect + sqlTail + " LIMIT " + strconv.Itoa(batchSize) + " OFFSET " + strconv.Itoa(start) | ||||
| 		case setting.Database.UseMSSQL: | ||||
| 		case setting.Database.Type.IsMSSQL(): | ||||
| 			sqlCmd = "SELECT TOP " + strconv.Itoa(batchSize) + " * FROM #temp_comments WHERE " + | ||||
| 				"(id NOT IN ( SELECT TOP " + strconv.Itoa(start) + " id FROM #temp_comments ORDER BY id )) ORDER BY id" | ||||
| 		default: | ||||
|  | ||||
| @ -14,7 +14,7 @@ import ( | ||||
| ) | ||||
|  | ||||
| func FixPostgresIDSequences(x *xorm.Engine) error { | ||||
| 	if !setting.Database.UsePostgreSQL { | ||||
| 	if !setting.Database.Type.IsPostgreSQL() { | ||||
| 		return nil | ||||
| 	} | ||||
|  | ||||
|  | ||||
| @ -54,11 +54,11 @@ func RenameTaskErrorsToMessage(x *xorm.Engine) error { | ||||
| 	} | ||||
|  | ||||
| 	switch { | ||||
| 	case setting.Database.UseMySQL: | ||||
| 	case setting.Database.Type.IsMySQL(): | ||||
| 		if _, err := sess.Exec("ALTER TABLE `task` CHANGE errors message text"); err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	case setting.Database.UseMSSQL: | ||||
| 	case setting.Database.Type.IsMSSQL(): | ||||
| 		if _, err := sess.Exec("sp_rename 'task.errors', 'message', 'COLUMN'"); err != nil { | ||||
| 			return err | ||||
| 		} | ||||
|  | ||||
| @ -16,7 +16,7 @@ func AlterIssueAndCommentTextFieldsToLongText(x *xorm.Engine) error { | ||||
| 		return err | ||||
| 	} | ||||
|  | ||||
| 	if setting.Database.UseMySQL { | ||||
| 	if setting.Database.Type.IsMySQL() { | ||||
| 		if _, err := sess.Exec("ALTER TABLE `issue` CHANGE `content` `content` LONGTEXT"); err != nil { | ||||
| 			return err | ||||
| 		} | ||||
|  | ||||
| @ -16,7 +16,7 @@ func AlterHookTaskTextFieldsToLongText(x *xorm.Engine) error { | ||||
| 		return err | ||||
| 	} | ||||
|  | ||||
| 	if setting.Database.UseMySQL { | ||||
| 	if setting.Database.Type.IsMySQL() { | ||||
| 		if _, err := sess.Exec("ALTER TABLE `hook_task` CHANGE `payload_content` `payload_content` LONGTEXT, CHANGE `request_content` `request_content` LONGTEXT, change `response_content` `response_content` LONGTEXT"); err != nil { | ||||
| 			return err | ||||
| 		} | ||||
|  | ||||
| @ -38,7 +38,7 @@ func (*improveActionTableIndicesAction) TableIndices() []*schemas.Index { | ||||
| 	actUserIndex := schemas.NewIndex("au_r_c_u_d", schemas.IndexType) | ||||
| 	actUserIndex.AddColumn("act_user_id", "repo_id", "created_unix", "user_id", "is_deleted") | ||||
| 	indices := []*schemas.Index{actUserIndex, repoIndex} | ||||
| 	if setting.Database.UsePostgreSQL { | ||||
| 	if setting.Database.Type.IsPostgreSQL() { | ||||
| 		cudIndex := schemas.NewIndex("c_u_d", schemas.IndexType) | ||||
| 		cudIndex.AddColumn("created_unix", "user_id", "is_deleted") | ||||
| 		indices = append(indices, cudIndex) | ||||
|  | ||||
| @ -65,11 +65,11 @@ func RenameCredentialIDBytes(x *xorm.Engine) error { | ||||
| 		} | ||||
|  | ||||
| 		switch { | ||||
| 		case setting.Database.UseMySQL: | ||||
| 		case setting.Database.Type.IsMySQL(): | ||||
| 			if _, err := sess.Exec("ALTER TABLE `webauthn_credential` CHANGE credential_id_bytes credential_id VARBINARY(1024)"); err != nil { | ||||
| 				return err | ||||
| 			} | ||||
| 		case setting.Database.UseMSSQL: | ||||
| 		case setting.Database.Type.IsMSSQL(): | ||||
| 			if _, err := sess.Exec("sp_rename 'webauthn_credential.credential_id_bytes', 'credential_id', 'COLUMN'"); err != nil { | ||||
| 				return err | ||||
| 			} | ||||
|  | ||||
| @ -16,7 +16,7 @@ func AlterPublicGPGKeyContentFieldsToMediumText(x *xorm.Engine) error { | ||||
| 		return err | ||||
| 	} | ||||
|  | ||||
| 	if setting.Database.UseMySQL { | ||||
| 	if setting.Database.Type.IsMySQL() { | ||||
| 		if _, err := sess.Exec("ALTER TABLE `gpg_key` CHANGE `content` `content` MEDIUMTEXT"); err != nil { | ||||
| 			return err | ||||
| 		} | ||||
|  | ||||
| @ -16,7 +16,7 @@ func AlterPackageVersionMetadataToLongText(x *xorm.Engine) error { | ||||
| 		return err | ||||
| 	} | ||||
|  | ||||
| 	if setting.Database.UseMySQL { | ||||
| 	if setting.Database.Type.IsMySQL() { | ||||
| 		if _, err := sess.Exec("ALTER TABLE `package_version` MODIFY COLUMN `metadata_json` LONGTEXT"); err != nil { | ||||
| 			return err | ||||
| 		} | ||||
|  | ||||
| @ -17,7 +17,7 @@ func AlterPublicGPGKeyImportContentFieldToMediumText(x *xorm.Engine) error { | ||||
| 		return err | ||||
| 	} | ||||
|  | ||||
| 	if setting.Database.UseMySQL { | ||||
| 	if setting.Database.Type.IsMySQL() { | ||||
| 		if _, err := sess.Exec("ALTER TABLE `gpg_key_import` CHANGE `content` `content` MEDIUMTEXT"); err != nil { | ||||
| 			return err | ||||
| 		} | ||||
|  | ||||
		Reference in New Issue
	
	Block a user
	 Jason Song
					Jason Song