| 
									
										
										
										
											2019-06-08 21:53:45 +08:00
										 |  |  | // Copyright 2019 The Gitea Authors. All rights reserved. | 
					
						
							| 
									
										
										
										
											2022-11-27 13:20:29 -05:00
										 |  |  | // SPDX-License-Identifier: MIT | 
					
						
							| 
									
										
										
										
											2019-06-08 21:53:45 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-09-19 19:49:59 +08:00
										 |  |  | package db | 
					
						
							| 
									
										
										
										
											2019-06-08 21:53:45 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-24 17:24:45 +08:00
										 |  |  | import ( | 
					
						
							|  |  |  | 	"fmt" | 
					
						
							| 
									
										
										
										
											2022-01-02 21:12:35 +08:00
										 |  |  | 	"strconv" | 
					
						
							| 
									
										
										
										
											2019-08-24 17:24:45 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-02 21:12:35 +08:00
										 |  |  | 	"code.gitea.io/gitea/modules/log" | 
					
						
							| 
									
										
										
										
											2019-08-24 17:24:45 +08:00
										 |  |  | 	"code.gitea.io/gitea/modules/setting" | 
					
						
							| 
									
										
										
										
											2021-06-29 23:00:02 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-02 21:12:35 +08:00
										 |  |  | 	"xorm.io/xorm" | 
					
						
							| 
									
										
										
										
											2021-06-29 23:00:02 +02:00
										 |  |  | 	"xorm.io/xorm/schemas" | 
					
						
							| 
									
										
										
										
											2019-08-24 17:24:45 +08:00
										 |  |  | ) | 
					
						
							| 
									
										
										
										
											2019-06-08 21:53:45 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-11 09:25:06 +01:00
										 |  |  | // ConvertUtf8ToUtf8mb4 converts database and tables from utf8 to utf8mb4 if it's mysql and set ROW_FORMAT=dynamic | 
					
						
							| 
									
										
										
										
											2019-06-08 21:53:45 +08:00
										 |  |  | func ConvertUtf8ToUtf8mb4() error { | 
					
						
							| 
									
										
										
										
											2021-06-29 23:00:02 +02:00
										 |  |  | 	if x.Dialect().URI().DBType != schemas.MYSQL { | 
					
						
							|  |  |  | 		return nil | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-24 17:24:45 +08:00
										 |  |  | 	_, err := x.Exec(fmt.Sprintf("ALTER DATABASE `%s` CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci", setting.Database.Name)) | 
					
						
							| 
									
										
										
										
											2019-06-08 21:53:45 +08:00
										 |  |  | 	if err != nil { | 
					
						
							|  |  |  | 		return err | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	tables, err := x.DBMetas() | 
					
						
							|  |  |  | 	if err != nil { | 
					
						
							|  |  |  | 		return err | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	for _, table := range tables { | 
					
						
							| 
									
										
										
										
											2020-09-11 09:25:06 +01:00
										 |  |  | 		if _, err := x.Exec(fmt.Sprintf("ALTER TABLE `%s` ROW_FORMAT=dynamic;", table.Name)); err != nil { | 
					
						
							|  |  |  | 			return err | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-08 21:53:45 +08:00
										 |  |  | 		if _, err := x.Exec(fmt.Sprintf("ALTER TABLE `%s` CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;", table.Name)); err != nil { | 
					
						
							|  |  |  | 			return err | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return nil | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2022-01-02 21:12:35 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | // Cell2Int64 converts a xorm.Cell type to int64, | 
					
						
							|  |  |  | // and handles possible irregular cases. | 
					
						
							|  |  |  | func Cell2Int64(val xorm.Cell) int64 { | 
					
						
							|  |  |  | 	switch (*val).(type) { | 
					
						
							|  |  |  | 	case []uint8: | 
					
						
							|  |  |  | 		log.Trace("Cell2Int64 ([]uint8): %v", *val) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		v, _ := strconv.ParseInt(string((*val).([]uint8)), 10, 64) | 
					
						
							|  |  |  | 		return v | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return (*val).(int64) | 
					
						
							|  |  |  | } |