mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-10-31 14:31:02 +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
 | |
| }
 |