blob: 2622c6a8a8148c14cbb5944fefec81370235ef0e [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 Wymana0f33ce2019-10-17 18:32:29 -050025using namespace phosphor::power::manager;
26
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
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)
Brandon Wyman57939e82019-08-26 17:53:57 -050067 {
Brandon Wymana0f33ce2019-10-17 18:32:29 -050068 log<level::ERR>(e.what());
69 return -2;
Brandon Wyman57939e82019-08-26 17:53:57 -050070 }
Brandon Wymana0f33ce2019-10-17 18:32:29 -050071 catch (...)
72 {
73 log<level::ERR>("Caught unexpected exception type");
74 return -3;
75 }
Brandon Wyman2ad76bd2019-08-26 17:15:04 -050076}