mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-11-04 08:21:11 +00:00 
			
		
		
		
	## Dropping SSPI auth support SSPI authentication relied on Microsoft Windows support, removal started in https://codeberg.org/forgejo/forgejo/pulls/5353, because it was broken anyway. We have no knowledge of any users using SSPI authentication. However, if you somehow managed to run Forgejo on Windows, or want to upgrade from a Gitea version which does, please ensure that you do not use SSPI as an authentication mechanism for user accounts. Feel free to reach out if you need assistance. Reviewed-on: https://codeberg.org/forgejo/forgejo/pulls/7148 Reviewed-by: Gusted <gusted@noreply.codeberg.org> Reviewed-by: 0ko <0ko@noreply.codeberg.org> Co-authored-by: Otto Richter <otto@codeberg.org> Co-committed-by: Otto Richter <otto@codeberg.org>
		
			
				
	
	
		
			83 lines
		
	
	
	
		
			1.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			83 lines
		
	
	
	
		
			1.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
// Copyright 2020 The Gitea Authors. All rights reserved.
 | 
						|
// SPDX-License-Identifier: MIT
 | 
						|
 | 
						|
package util
 | 
						|
 | 
						|
import (
 | 
						|
	"os"
 | 
						|
	"syscall"
 | 
						|
	"time"
 | 
						|
)
 | 
						|
 | 
						|
// Remove removes the named file or (empty) directory with at most 5 attempts.
 | 
						|
func Remove(name string) error {
 | 
						|
	var err error
 | 
						|
	for i := 0; i < 5; i++ {
 | 
						|
		err = os.Remove(name)
 | 
						|
		if err == nil {
 | 
						|
			break
 | 
						|
		}
 | 
						|
		unwrapped := err.(*os.PathError).Err
 | 
						|
		if unwrapped == syscall.EBUSY || unwrapped == syscall.ENOTEMPTY || unwrapped == syscall.EPERM || unwrapped == syscall.EMFILE || unwrapped == syscall.ENFILE {
 | 
						|
			// try again
 | 
						|
			<-time.After(100 * time.Millisecond)
 | 
						|
			continue
 | 
						|
		}
 | 
						|
 | 
						|
		if unwrapped == syscall.ENOENT {
 | 
						|
			// it's already gone
 | 
						|
			return nil
 | 
						|
		}
 | 
						|
	}
 | 
						|
	return err
 | 
						|
}
 | 
						|
 | 
						|
// RemoveAll removes the named file or (empty) directory with at most 5 attempts.
 | 
						|
func RemoveAll(name string) error {
 | 
						|
	var err error
 | 
						|
	for i := 0; i < 5; i++ {
 | 
						|
		err = os.RemoveAll(name)
 | 
						|
		if err == nil {
 | 
						|
			break
 | 
						|
		}
 | 
						|
		unwrapped := err.(*os.PathError).Err
 | 
						|
		if unwrapped == syscall.EBUSY || unwrapped == syscall.ENOTEMPTY || unwrapped == syscall.EPERM || unwrapped == syscall.EMFILE || unwrapped == syscall.ENFILE {
 | 
						|
			// try again
 | 
						|
			<-time.After(100 * time.Millisecond)
 | 
						|
			continue
 | 
						|
		}
 | 
						|
 | 
						|
		if unwrapped == syscall.ENOENT {
 | 
						|
			// it's already gone
 | 
						|
			return nil
 | 
						|
		}
 | 
						|
	}
 | 
						|
	return err
 | 
						|
}
 | 
						|
 | 
						|
// Rename renames (moves) oldpath to newpath with at most 5 attempts.
 | 
						|
func Rename(oldpath, newpath string) error {
 | 
						|
	var err error
 | 
						|
	for i := 0; i < 5; i++ {
 | 
						|
		err = os.Rename(oldpath, newpath)
 | 
						|
		if err == nil {
 | 
						|
			break
 | 
						|
		}
 | 
						|
		unwrapped := err.(*os.LinkError).Err
 | 
						|
		if unwrapped == syscall.EBUSY || unwrapped == syscall.ENOTEMPTY || unwrapped == syscall.EPERM || unwrapped == syscall.EMFILE || unwrapped == syscall.ENFILE {
 | 
						|
			// try again
 | 
						|
			<-time.After(100 * time.Millisecond)
 | 
						|
			continue
 | 
						|
		}
 | 
						|
 | 
						|
		if i == 0 && os.IsNotExist(err) {
 | 
						|
			return err
 | 
						|
		}
 | 
						|
 | 
						|
		if unwrapped == syscall.ENOENT {
 | 
						|
			// it's already gone
 | 
						|
			return nil
 | 
						|
		}
 | 
						|
	}
 | 
						|
	return err
 | 
						|
}
 |