| 
									
										
										
										
											2022-07-30 14:25:26 +01:00
										 |  |  | // Copyright 2022 The Gitea Authors. All rights reserved. | 
					
						
							| 
									
										
										
										
											2022-11-27 13:20:29 -05:00
										 |  |  | // SPDX-License-Identifier: MIT | 
					
						
							| 
									
										
										
										
											2022-07-30 14:25:26 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-12-08 09:21:37 +01:00
										 |  |  | package v1_17 //nolint | 
					
						
							| 
									
										
										
										
											2022-07-30 14:25:26 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							|  |  |  | 	"context" | 
					
						
							|  |  |  | 	"fmt" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-11-02 16:54:36 +08:00
										 |  |  | 	"code.gitea.io/gitea/models/migrations/base" | 
					
						
							| 
									
										
										
										
											2022-07-30 14:25:26 +01:00
										 |  |  | 	"code.gitea.io/gitea/modules/timeutil" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	"xorm.io/xorm" | 
					
						
							|  |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-11-02 16:54:36 +08:00
										 |  |  | func DropOldCredentialIDColumn(x *xorm.Engine) error { | 
					
						
							| 
									
										
										
										
											2022-07-30 14:25:26 +01:00
										 |  |  | 	// This migration maybe rerun so that we should check if it has been run | 
					
						
							|  |  |  | 	credentialIDExist, err := x.Dialect().IsColumnExist(x.DB(), context.Background(), "webauthn_credential", "credential_id") | 
					
						
							|  |  |  | 	if err != nil { | 
					
						
							|  |  |  | 		return err | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if !credentialIDExist { | 
					
						
							|  |  |  | 		// Column is already non-extant | 
					
						
							|  |  |  | 		return nil | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	credentialIDBytesExists, err := x.Dialect().IsColumnExist(x.DB(), context.Background(), "webauthn_credential", "credential_id_bytes") | 
					
						
							|  |  |  | 	if err != nil { | 
					
						
							|  |  |  | 		return err | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if !credentialIDBytesExists { | 
					
						
							|  |  |  | 		// looks like 221 hasn't properly run | 
					
						
							|  |  |  | 		return fmt.Errorf("webauthn_credential does not have a credential_id_bytes column... it is not safe to run this migration") | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// Create webauthnCredential table | 
					
						
							|  |  |  | 	type webauthnCredential struct { | 
					
						
							|  |  |  | 		ID           int64 `xorm:"pk autoincr"` | 
					
						
							|  |  |  | 		Name         string | 
					
						
							|  |  |  | 		LowerName    string `xorm:"unique(s)"` | 
					
						
							|  |  |  | 		UserID       int64  `xorm:"INDEX unique(s)"` | 
					
						
							|  |  |  | 		CredentialID string `xorm:"INDEX VARCHAR(410)"` | 
					
						
							|  |  |  | 		// Note the lack of the INDEX on CredentialIDBytes - we will add this in v223.go | 
					
						
							|  |  |  | 		CredentialIDBytes []byte `xorm:"VARBINARY(1024)"` // CredentialID is at most 1023 bytes as per spec released 20 July 2022 | 
					
						
							|  |  |  | 		PublicKey         []byte | 
					
						
							|  |  |  | 		AttestationType   string | 
					
						
							|  |  |  | 		AAGUID            []byte | 
					
						
							|  |  |  | 		SignCount         uint32 `xorm:"BIGINT"` | 
					
						
							|  |  |  | 		CloneWarning      bool | 
					
						
							|  |  |  | 		CreatedUnix       timeutil.TimeStamp `xorm:"INDEX created"` | 
					
						
							|  |  |  | 		UpdatedUnix       timeutil.TimeStamp `xorm:"INDEX updated"` | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2023-08-13 21:17:21 +02:00
										 |  |  | 	if err := x.Sync(&webauthnCredential{}); err != nil { | 
					
						
							| 
									
										
										
										
											2022-07-30 14:25:26 +01:00
										 |  |  | 		return err | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// Drop the old credential ID | 
					
						
							|  |  |  | 	sess := x.NewSession() | 
					
						
							|  |  |  | 	defer sess.Close() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-11-02 16:54:36 +08:00
										 |  |  | 	if err := base.DropTableColumns(sess, "webauthn_credential", "credential_id"); err != nil { | 
					
						
							| 
									
										
										
										
											2022-07-30 14:25:26 +01:00
										 |  |  | 		return fmt.Errorf("unable to drop old credentialID column: %w", err) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return sess.Commit() | 
					
						
							|  |  |  | } |