| // Copyright 2014 The Chromium OS Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| #ifndef LIBCHROMEOS_BRILLO_FILE_UTILS_H_ |
| #define LIBCHROMEOS_BRILLO_FILE_UTILS_H_ |
| |
| #include <sys/types.h> |
| |
| #include <base/files/file_path.h> |
| #include <brillo/brillo_export.h> |
| |
| namespace brillo { |
| |
| // Ensures a regular file owned by user |uid| and group |gid| exists at |path|. |
| // Any other entity at |path| will be deleted and replaced with an empty |
| // regular file. If a new file is needed, any missing parent directories will |
| // be created, and the file will be assigned |new_file_permissions|. |
| // Should be safe to use in all directories, including tmpdirs with the sticky |
| // bit set. |
| // Returns true if the file existed or was able to be created. |
| BRILLO_EXPORT bool TouchFile(const base::FilePath& path, |
| int new_file_permissions, |
| uid_t uid, |
| gid_t gid); |
| |
| // Convenience version of TouchFile() defaulting to 600 permissions and the |
| // current euid/egid. |
| // Should be safe to use in all directories, including tmpdirs with the sticky |
| // bit set. |
| BRILLO_EXPORT bool TouchFile(const base::FilePath& path); |
| |
| } // namespace brillo |
| |
| #endif // LIBCHROMEOS_BRILLO_FILE_UTILS_H_ |