2022-07-30 16:25:26 +03:00
// Copyright 2022 The Gitea Authors. All rights reserved.
2022-11-27 21:20:29 +03:00
// SPDX-License-Identifier: MIT
2022-07-30 16:25:26 +03:00
2022-12-08 11:21:37 +03:00
package v1_17 //nolint
2022-07-30 16:25:26 +03:00
import (
"context"
"fmt"
2022-11-02 11:54:36 +03:00
"code.gitea.io/gitea/models/migrations/base"
2022-07-30 16:25:26 +03:00
"code.gitea.io/gitea/modules/setting"
"code.gitea.io/gitea/modules/timeutil"
"xorm.io/xorm"
)
2022-11-02 11:54:36 +03:00
func RenameCredentialIDBytes ( x * xorm . Engine ) error {
2022-07-30 16:25:26 +03: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 {
credentialIDBytesExists , err := x . Dialect ( ) . IsColumnExist ( x . DB ( ) , context . Background ( ) , "webauthn_credential" , "credential_id_bytes" )
if err != nil {
return err
}
if ! credentialIDBytesExists {
return nil
}
}
err = func ( ) error {
// webauthnCredential table
type webauthnCredential struct {
ID int64 ` xorm:"pk autoincr" `
Name string
LowerName string ` xorm:"unique(s)" `
UserID int64 ` xorm:"INDEX unique(s)" `
// Note the lack of INDEX here
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" `
}
sess := x . NewSession ( )
defer sess . Close ( )
if err := sess . Begin ( ) ; err != nil {
return err
}
2023-08-13 22:17:21 +03:00
if err := sess . Sync ( new ( webauthnCredential ) ) ; err != nil {
return fmt . Errorf ( "error on Sync: %w" , err )
2022-07-30 16:25:26 +03:00
}
if credentialIDExist {
// if both errors and message exist, drop message at first
2022-11-02 11:54:36 +03:00
if err := base . DropTableColumns ( sess , "webauthn_credential" , "credential_id" ) ; err != nil {
2022-07-30 16:25:26 +03:00
return err
}
}
switch {
2023-03-07 13:51:06 +03:00
case setting . Database . Type . IsMySQL ( ) :
2022-07-30 16:25:26 +03:00
if _ , err := sess . Exec ( "ALTER TABLE `webauthn_credential` CHANGE credential_id_bytes credential_id VARBINARY(1024)" ) ; err != nil {
return err
}
2023-03-07 13:51:06 +03:00
case setting . Database . Type . IsMSSQL ( ) :
2022-07-30 16:25:26 +03:00
if _ , err := sess . Exec ( "sp_rename 'webauthn_credential.credential_id_bytes', 'credential_id', 'COLUMN'" ) ; err != nil {
return err
}
default :
if _ , err := sess . Exec ( "ALTER TABLE `webauthn_credential` RENAME COLUMN credential_id_bytes TO credential_id" ) ; err != nil {
return err
}
}
return sess . Commit ( )
} ( )
if err != nil {
return err
}
// 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 [ ] byte ` xorm:"INDEX 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 22:17:21 +03:00
return x . Sync ( & webauthnCredential { } )
2022-07-30 16:25:26 +03:00
}