1 /**
2  * Copyright © 2019 IBM Corporation
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *     http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 #include "psu_manager.hpp"
17 
18 #include <CLI/CLI.hpp>
19 #include <phosphor-logging/log.hpp>
20 #include <sdbusplus/bus.hpp>
21 #include <sdeventplus/event.hpp>
22 
23 #include <filesystem>
24 
25 using namespace phosphor::power::manager;
26 
27 int main(int argc, char* argv[])
28 {
29     try
30     {
31         using namespace phosphor::logging;
32 
33         CLI::App app{"OpenBMC Power Supply Unit Monitor"};
34 
35         std::string configfile;
36         app.add_option("-c,--config", configfile,
37                        "JSON configuration file path");
38 
39         // Read the arguments.
40         CLI11_PARSE(app, argc, argv);
41         if (configfile.empty())
42         {
43             configfile = "/etc/phosphor-psu-monitor/psu_config.json";
44         }
45 
46         if (!std::filesystem::exists(configfile))
47         {
48             log<level::ERR>("Configuration file does not exist",
49                             entry("FILENAME=%s", configfile.c_str()));
50             return -1;
51         }
52 
53         auto bus = sdbusplus::bus::new_default();
54         auto event = sdeventplus::Event::get_default();
55 
56         // Attach the event object to the bus object so we can
57         // handle both sd_events (for the timers) and dbus signals.
58         bus.attach_event(event.get(), SD_EVENT_PRIORITY_NORMAL);
59 
60         // TODO: Should get polling interval from JSON file.
61         auto pollInterval = std::chrono::milliseconds(1000);
62         PSUManager manager(bus, event, pollInterval);
63 
64         return manager.run();
65     }
66     catch (const std::exception& e)
67     {
68         log<level::ERR>(e.what());
69         return -2;
70     }
71     catch (...)
72     {
73         log<level::ERR>("Caught unexpected exception type");
74         return -3;
75     }
76 }
77