]> ruderich.org/simon Gitweb - safcm/safcm.git/blobdiff - cmd/safcm/config/files.go
safcm: add experimental support to sync from Windows hosts
[safcm/safcm.git] / cmd / safcm / config / files.go
index 7ffa8b201cfeb5548cb0d2356f19677931218542..143a678ac15653254d28ac8b42b4c1046cfb81dd 100644 (file)
@@ -40,6 +40,9 @@ confusion files must be manually chmodded 0644/0755 and directories 0755 or
 via "safcm fixperms".
 `
 
+       // No permission checks on windows which doesn't track them.
+       windows := runtime.GOOS == "windows"
+
        files := make(map[string]*safcm.File)
        err := filepath.WalkDir(basePath, func(path string, d fs.DirEntry,
                err error) error {
@@ -60,6 +63,11 @@ via "safcm fixperms".
                // permissions they could assume that these permissions are
                // respected. This is not the case.
                if typ == 0 /* regular file */ {
+                       if windows {
+                               perm = 0644
+                               // 0755 must be set via permissions.yaml if
+                               // windows is used
+                       }
                        if perm != 0644 && perm != 0755 {
                                return fmt.Errorf(
                                        "%q: invalid permissions %#o%s",
@@ -70,6 +78,9 @@ via "safcm fixperms".
                                return err
                        }
                } else if typ == fs.ModeDir {
+                       if windows {
+                               perm = 0755
+                       }
                        if perm != 0755 {
                                return fmt.Errorf(
                                        "%q: invalid permissions %#o%s",