123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187 |
- package common
- import (
- "fmt"
- "testing"
- "github.com/stretchr/testify/assert"
- "github.com/stretchr/testify/require"
- "github.com/drakkan/sftpgo/v2/dataprovider"
- "github.com/drakkan/sftpgo/v2/sdk"
- )
- func TestRetentionValidation(t *testing.T) {
- check := RetentionCheck{}
- check.Folders = append(check.Folders, FolderRetention{
- Path: "relative",
- Retention: 10,
- })
- err := check.Validate()
- require.Error(t, err)
- assert.Contains(t, err.Error(), "please specify an absolute POSIX path")
- check.Folders = []FolderRetention{
- {
- Path: "/",
- Retention: -1,
- },
- }
- err = check.Validate()
- require.Error(t, err)
- assert.Contains(t, err.Error(), "invalid folder retention")
- check.Folders = []FolderRetention{
- {
- Path: "/ab/..",
- Retention: 0,
- },
- }
- err = check.Validate()
- require.Error(t, err)
- assert.Contains(t, err.Error(), "nothing to delete")
- assert.Equal(t, "/", check.Folders[0].Path)
- check.Folders = append(check.Folders, FolderRetention{
- Path: "/../..",
- Retention: 24,
- })
- err = check.Validate()
- require.Error(t, err)
- assert.Contains(t, err.Error(), `duplicated folder path "/"`)
- check.Folders = []FolderRetention{
- {
- Path: "/dir1",
- Retention: 48,
- },
- {
- Path: "/dir2",
- Retention: 96,
- },
- }
- err = check.Validate()
- assert.NoError(t, err)
- }
- func TestRetentionPermissionsAndGetFolder(t *testing.T) {
- user := dataprovider.User{
- BaseUser: sdk.BaseUser{
- Username: "user1",
- },
- }
- user.Permissions = make(map[string][]string)
- user.Permissions["/"] = []string{dataprovider.PermListItems, dataprovider.PermDelete}
- user.Permissions["/dir1"] = []string{dataprovider.PermListItems}
- user.Permissions["/dir2/sub1"] = []string{dataprovider.PermCreateDirs}
- user.Permissions["/dir2/sub2"] = []string{dataprovider.PermDelete}
- check := RetentionCheck{
- Folders: []FolderRetention{
- {
- Path: "/dir2",
- Retention: 24 * 7,
- IgnoreUserPermissions: true,
- },
- {
- Path: "/dir3",
- Retention: 24 * 7,
- IgnoreUserPermissions: false,
- },
- {
- Path: "/dir2/sub1/sub",
- Retention: 24,
- IgnoreUserPermissions: true,
- },
- },
- }
- conn := NewBaseConnection("", "", "", "", user)
- conn.ID = fmt.Sprintf("retention_check_%v", user.Username)
- check.conn = conn
- check.updateUserPermissions()
- assert.Equal(t, []string{dataprovider.PermListItems, dataprovider.PermDelete}, conn.User.Permissions["/"])
- assert.Equal(t, []string{dataprovider.PermListItems}, conn.User.Permissions["/dir1"])
- assert.Equal(t, []string{dataprovider.PermAny}, conn.User.Permissions["/dir2"])
- assert.Equal(t, []string{dataprovider.PermAny}, conn.User.Permissions["/dir2/sub1/sub"])
- assert.Equal(t, []string{dataprovider.PermCreateDirs}, conn.User.Permissions["/dir2/sub1"])
- assert.Equal(t, []string{dataprovider.PermDelete}, conn.User.Permissions["/dir2/sub2"])
- _, err := check.getFolderRetention("/")
- assert.Error(t, err)
- folder, err := check.getFolderRetention("/dir3")
- assert.NoError(t, err)
- assert.Equal(t, "/dir3", folder.Path)
- folder, err = check.getFolderRetention("/dir2/sub3")
- assert.NoError(t, err)
- assert.Equal(t, "/dir2", folder.Path)
- folder, err = check.getFolderRetention("/dir2/sub2")
- assert.NoError(t, err)
- assert.Equal(t, "/dir2", folder.Path)
- folder, err = check.getFolderRetention("/dir2/sub1")
- assert.NoError(t, err)
- assert.Equal(t, "/dir2", folder.Path)
- folder, err = check.getFolderRetention("/dir2/sub1/sub/sub")
- assert.NoError(t, err)
- assert.Equal(t, "/dir2/sub1/sub", folder.Path)
- }
- func TestRetentionCheckAddRemove(t *testing.T) {
- username := "username"
- user := dataprovider.User{
- BaseUser: sdk.BaseUser{
- Username: username,
- },
- }
- user.Permissions = make(map[string][]string)
- user.Permissions["/"] = []string{dataprovider.PermAny}
- check := RetentionCheck{
- Folders: []FolderRetention{
- {
- Path: "/",
- Retention: 48,
- },
- },
- }
- assert.NotNil(t, RetentionChecks.Add(check, &user))
- checks := RetentionChecks.Get()
- require.Len(t, checks, 1)
- assert.Equal(t, username, checks[0].Username)
- assert.Greater(t, checks[0].StartTime, int64(0))
- require.Len(t, checks[0].Folders, 1)
- assert.Equal(t, check.Folders[0].Path, checks[0].Folders[0].Path)
- assert.Equal(t, check.Folders[0].Retention, checks[0].Folders[0].Retention)
- assert.Nil(t, RetentionChecks.Add(check, &user))
- assert.True(t, RetentionChecks.remove(username))
- require.Len(t, RetentionChecks.Get(), 0)
- assert.False(t, RetentionChecks.remove(username))
- }
- func TestCleanupErrors(t *testing.T) {
- user := dataprovider.User{
- BaseUser: sdk.BaseUser{
- Username: "u",
- },
- }
- user.Permissions = make(map[string][]string)
- user.Permissions["/"] = []string{dataprovider.PermAny}
- check := &RetentionCheck{
- Folders: []FolderRetention{
- {
- Path: "/path",
- Retention: 48,
- },
- },
- }
- check = RetentionChecks.Add(*check, &user)
- require.NotNil(t, check)
- err := check.removeFile("missing file", nil)
- assert.Error(t, err)
- err = check.cleanupFolder("/")
- assert.Error(t, err)
- assert.True(t, RetentionChecks.remove(user.Username))
- }
|