arozfs.go 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. package arozfs
  2. /*
  3. arozfs.go
  4. This package handle error related to file systems.
  5. See comments below for usage.
  6. */
  7. import (
  8. "errors"
  9. "io"
  10. "io/fs"
  11. "strings"
  12. )
  13. type File interface {
  14. Chdir() error
  15. Chmod(mode fs.FileMode) error
  16. Chown(uid, gid int) error
  17. Close() error
  18. Name() string
  19. Read(b []byte) (n int, err error)
  20. ReadAt(b []byte, off int64) (n int, err error)
  21. Readdirnames(n int) (names []string, err error)
  22. ReadFrom(r io.Reader) (n int64, err error)
  23. Readdir(n int) ([]fs.FileInfo, error)
  24. Seek(offset int64, whence int) (ret int64, err error)
  25. Stat() (fs.FileInfo, error)
  26. Sync() error
  27. Truncate(size int64) error
  28. Write(b []byte) (n int, err error)
  29. WriteAt(b []byte, off int64) (n int, err error)
  30. WriteString(s string) (n int, err error)
  31. }
  32. //A shortcut representing struct
  33. type ShortcutData struct {
  34. Type string //The type of shortcut
  35. Name string //The name of the shortcut
  36. Path string //The path of shortcut
  37. Icon string //The icon of shortcut
  38. }
  39. var (
  40. /*
  41. READ WRITE PERMISSIONS
  42. */
  43. FsReadOnly = "readonly"
  44. FsWriteOnly = "writeonly"
  45. FsReadWrite = "readwrite"
  46. FsDenied = "denied"
  47. /*
  48. ERROR TYPES
  49. */
  50. //Redirective Error
  51. ErrRedirectParent = errors.New("Redirect:parent")
  52. ErrRedirectCurrentRoot = errors.New("Redirect:root")
  53. ErrRedirectUserRoot = errors.New("Redirect:userroot")
  54. //Resolve errors
  55. ErrVpathResolveFailed = errors.New("FS_VPATH_RESOLVE_FAILED")
  56. ErrRpathResolveFailed = errors.New("FS_RPATH_RESOLVE_FAILED")
  57. ErrFSHNotFOund = errors.New("FS_FILESYSTEM_HANDLER_NOT_FOUND")
  58. //Operation errors
  59. ErrOperationNotSupported = errors.New("FS_OPR_NOT_SUPPORTED")
  60. ErrNullOperation = errors.New("FS_NULL_OPR")
  61. )
  62. //Generate a File Manager redirection error message
  63. func NewRedirectionError(targetVpath string) error {
  64. return errors.New("Redirect:" + targetVpath)
  65. }
  66. //Check if a file system is network drive
  67. func IsNetworkDrive(fstype string) bool {
  68. if fstype == "webdav" || fstype == "ftp" || fstype == "smb" {
  69. return true
  70. }
  71. return false
  72. }
  73. //Get a list of supported file system types for mounting via arozos
  74. func GetSupportedFileSystemTypes() []string {
  75. return []string{"ext4", "ext2", "ext3", "fat", "vfat", "ntfs", "webdav", "ftp", "smb"}
  76. }
  77. func ToSlash(filename string) string {
  78. return strings.ReplaceAll(filename, "\\", "/")
  79. }
  80. func Base(filename string) string {
  81. filename = ToSlash(filename)
  82. if filename == "" {
  83. return "."
  84. }
  85. if filename == "/" {
  86. return filename
  87. }
  88. for len(filename) > 0 && filename[len(filename)-1] == '/' {
  89. filename = filename[0 : len(filename)-1]
  90. }
  91. c := strings.Split(filename, "/")
  92. if len(c) == 1 {
  93. return c[0]
  94. } else {
  95. return c[len(c)-1]
  96. }
  97. }