blob: 03ff3db0ddd769a2d3e3b81fb76e65a15308ef7f [file] [log] [blame]
Brandon Wyman2ad76bd2019-08-26 17:15:04 -05001/**
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 */
Brandon Wyman2bac8602019-09-12 18:12:21 -050016#include "psu_manager.hpp"
17
Brandon Wyman2ad76bd2019-08-26 17:15:04 -050018#include <CLI/CLI.hpp>
Brandon Wyman57939e82019-08-26 17:53:57 -050019#include <phosphor-logging/log.hpp>
Brandon Wyman2bac8602019-09-12 18:12:21 -050020#include <sdbusplus/bus.hpp>
21#include <sdeventplus/event.hpp>
Brandon Wyman57939e82019-08-26 17:53:57 -050022
23#include <filesystem>
Brandon Wyman2ad76bd2019-08-26 17:15:04 -050024
Brandon Wyman2fe51862019-11-25 16:43:21 -060025using namespace phosphor::power;
Brandon Wymana0f33ce2019-10-17 18:32:29 -050026
Brandon Wyman2ad76bd2019-08-26 17:15:04 -050027int main(int argc, char* argv[])
28{
Brandon Wymana0f33ce2019-10-17 18:32:29 -050029 try
Brandon Wyman57939e82019-08-26 17:53:57 -050030 {
Brandon Wymana0f33ce2019-10-17 18:32:29 -050031 using namespace phosphor::logging;
Brandon Wyman2ad76bd2019-08-26 17:15:04 -050032
Brandon Wymana0f33ce2019-10-17 18:32:29 -050033 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
Brandon Wyman2fe51862019-11-25 16:43:21 -060060 manager::PSUManager manager(bus, event, configfile);
Brandon Wymana0f33ce2019-10-17 18:32:29 -050061
62 return manager.run();
63 }
64 catch (const std::exception& e)
Brandon Wyman57939e82019-08-26 17:53:57 -050065 {
Brandon Wymana0f33ce2019-10-17 18:32:29 -050066 log<level::ERR>(e.what());
67 return -2;
Brandon Wyman57939e82019-08-26 17:53:57 -050068 }
Brandon Wymana0f33ce2019-10-17 18:32:29 -050069 catch (...)
70 {
71 log<level::ERR>("Caught unexpected exception type");
72 return -3;
73 }
Brandon Wyman2ad76bd2019-08-26 17:15:04 -050074}