mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-29 10:57:44 +09:00 
			
		
		
		
	Add a storage layer for attachments (#11387)
* Add a storage layer for attachments * Fix some bug * fix test * Fix copyright head and lint * Fix bug * Add setting for minio and flags for migrate-storage * Add documents * fix lint * Add test for minio store type on attachments * fix test * fix test * Apply suggestions from code review Co-authored-by: guillep2k <18600385+guillep2k@users.noreply.github.com> * Add warning when storage migrated successfully * Fix drone * fix test * rebase * Fix test * display the error on console * Move minio test to amd64 since minio docker don't support arm64 * refactor the codes * add trace * Fix test * remove log on xorm * Fi download bug * Add a storage layer for attachments * Add setting for minio and flags for migrate-storage * fix lint * Add test for minio store type on attachments * Apply suggestions from code review Co-authored-by: guillep2k <18600385+guillep2k@users.noreply.github.com> * Fix drone * fix test * Fix test * display the error on console * Move minio test to amd64 since minio docker don't support arm64 * refactor the codes * add trace * Fix test * Add URL function to serve attachments directly from S3/Minio * Add ability to enable/disable redirection in attachment configuration * Fix typo * Add a storage layer for attachments * Add setting for minio and flags for migrate-storage * fix lint * Add test for minio store type on attachments * Apply suggestions from code review Co-authored-by: guillep2k <18600385+guillep2k@users.noreply.github.com> * Fix drone * fix test * Fix test * display the error on console * Move minio test to amd64 since minio docker don't support arm64 * don't change unrelated files * Fix lint * Fix build * update go.mod and go.sum * Use github.com/minio/minio-go/v6 * Remove unused function * Upgrade minio to v7 and some other improvements * fix lint * Fix go mod Co-authored-by: guillep2k <18600385+guillep2k@users.noreply.github.com> Co-authored-by: Tyler <tystuyfzand@gmail.com>
This commit is contained in:
		
							
								
								
									
										58
									
								
								vendor/github.com/modern-go/reflect2/safe_field.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										58
									
								
								vendor/github.com/modern-go/reflect2/safe_field.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,58 @@ | ||||
| package reflect2 | ||||
|  | ||||
| import ( | ||||
| 	"reflect" | ||||
| 	"unsafe" | ||||
| ) | ||||
|  | ||||
| type safeField struct { | ||||
| 	reflect.StructField | ||||
| } | ||||
|  | ||||
| func (field *safeField) Offset() uintptr { | ||||
| 	return field.StructField.Offset | ||||
| } | ||||
|  | ||||
| func (field *safeField) Name() string { | ||||
| 	return field.StructField.Name | ||||
| } | ||||
|  | ||||
| func (field *safeField) PkgPath() string { | ||||
| 	return field.StructField.PkgPath | ||||
| } | ||||
|  | ||||
| func (field *safeField) Type() Type { | ||||
| 	panic("not implemented") | ||||
| } | ||||
|  | ||||
| func (field *safeField) Tag() reflect.StructTag { | ||||
| 	return field.StructField.Tag | ||||
| } | ||||
|  | ||||
| func (field *safeField) Index() []int { | ||||
| 	return field.StructField.Index | ||||
| } | ||||
|  | ||||
| func (field *safeField) Anonymous() bool { | ||||
| 	return field.StructField.Anonymous | ||||
| } | ||||
|  | ||||
| func (field *safeField) Set(obj interface{}, value interface{}) { | ||||
| 	val := reflect.ValueOf(obj).Elem() | ||||
| 	val.FieldByIndex(field.Index()).Set(reflect.ValueOf(value).Elem()) | ||||
| } | ||||
|  | ||||
| func (field *safeField) UnsafeSet(obj unsafe.Pointer, value unsafe.Pointer) { | ||||
| 	panic("unsafe operation is not supported") | ||||
| } | ||||
|  | ||||
| func (field *safeField) Get(obj interface{}) interface{} { | ||||
| 	val := reflect.ValueOf(obj).Elem().FieldByIndex(field.Index()) | ||||
| 	ptr := reflect.New(val.Type()) | ||||
| 	ptr.Elem().Set(val) | ||||
| 	return ptr.Interface() | ||||
| } | ||||
|  | ||||
| func (field *safeField) UnsafeGet(obj unsafe.Pointer) unsafe.Pointer { | ||||
| 	panic("does not support unsafe operation") | ||||
| } | ||||
		Reference in New Issue
	
	Block a user