xref: /openbmc/phosphor-bmc-code-mgmt/sync_watch.hpp (revision cc74233cbe5b4d99787eb30d85c34d7d8e7aafb7)
1 #pragma once
2 
3 #include <systemd/sd-event.h>
4 
5 #include <filesystem>
6 #include <functional>
7 #include <map>
8 
9 namespace phosphor
10 {
11 namespace software
12 {
13 namespace manager
14 {
15 
16 namespace fs = std::filesystem;
17 
18 /** @class SyncWatch
19  *
20  *  @brief Adds inotify watch on persistent files to be synced
21  *
22  *  The inotify watch is hooked up with sd-event, so that on call back,
23  *  appropriate actions related to syncing files can be taken.
24  */
25 class SyncWatch
26 {
27   public:
28     /** @brief ctor - hook inotify watch with sd-event
29      *
30      *  @param[in] loop - sd-event object
31      *  @param[in] syncCallback - The callback function for processing
32      *                            files
33      */
34     SyncWatch(sd_event& loop, std::function<int(int, fs::path&)> syncCallback);
35 
36     SyncWatch(const SyncWatch&) = delete;
37     SyncWatch& operator=(const SyncWatch&) = delete;
38     SyncWatch(SyncWatch&&) = default;
39     SyncWatch& operator=(SyncWatch&&) = default;
40 
41     /** @brief dtor - remove inotify watch and close fd's
42      */
43     ~SyncWatch();
44 
45   private:
46     /** @brief sd-event callback
47      *
48      *  @param[in] s - event source, floating (unused) in our case
49      *  @param[in] fd - inotify fd
50      *  @param[in] revents - events that matched for fd
51      *  @param[in] userdata - pointer to SyncWatch object
52      *  @returns 0 on success, -1 on fail
53      */
54     static int callback(sd_event_source* s, int fd, uint32_t revents,
55                         void* userdata);
56 
57     /** @brief Adds an inotify watch to the specified file or directory path
58      *
59      *  @param[in] path - The path to the file or directory
60      */
61     void addInotifyWatch(const fs::path& path);
62 
63     /** @brief Map of file descriptors, watch descriptors, and file paths */
64     using fd = int;
65     using wd = int;
66     fd inotifyFd;
67     std::map<wd, fs::path> fileMap;
68 
69     /** @brief The callback function for processing the inotify event */
70     std::function<int(int, fs::path&)> syncCallback;
71 
72     /** @brief Persistent sd_event loop */
73     sd_event& loop;
74 };
75 
76 } // namespace manager
77 } // namespace software
78 } // namespace phosphor
79