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;
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             if (std::filesystem::exists(
44                     "/etc/phosphor-psu-monitor/psu_config.json"))
45             {
46                 configfile = "/etc/phosphor-psu-monitor/psu_config.json";
47             }
48             else
49             {
50                 configfile = "/usr/share/phosphor-psu-monitor/psu_config.json";
51             }
52         }
53 
54         if (!std::filesystem::exists(configfile))
55         {
56             log<level::ERR>("Configuration file does not exist",
57                             entry("FILENAME=%s", configfile.c_str()));
58             return -1;
59         }
60 
61         auto bus = sdbusplus::bus::new_default();
62         auto event = sdeventplus::Event::get_default();
63 
64         // Attach the event object to the bus object so we can
65         // handle both sd_events (for the timers) and dbus signals.
66         bus.attach_event(event.get(), SD_EVENT_PRIORITY_NORMAL);
67 
68         manager::PSUManager manager(bus, event, configfile);
69 
70         return manager.run();
71     }
72     catch (const std::exception& e)
73     {
74         log<level::ERR>(e.what());
75         return -2;
76     }
77     catch (...)
78     {
79         log<level::ERR>("Caught unexpected exception type");
80         return -3;
81     }
82 }
83