Ian Coolidge | 611fcf9 | 2015-06-03 17:20:30 -0700 | [diff] [blame] | 1 | // |
Jakub Pawlowski | 5b790fe | 2017-09-18 09:00:20 -0700 | [diff] [blame] | 2 | // Copyright 2015 Google, Inc. |
Ian Coolidge | 611fcf9 | 2015-06-03 17:20:30 -0700 | [diff] [blame] | 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 | // |
Arman Uguray | ae43de6 | 2015-09-24 15:05:21 -0700 | [diff] [blame] | 16 | |
Arman Uguray | 065d0f7 | 2015-07-16 18:12:13 -0700 | [diff] [blame] | 17 | #include <base/at_exit.h> |
| 18 | #include <base/command_line.h> |
| 19 | #include <base/files/scoped_file.h> |
Pavlin Radoslavov | 1377f93 | 2016-02-11 19:44:47 -0800 | [diff] [blame] | 20 | #include <base/logging.h> |
Arman Uguray | 065d0f7 | 2015-07-16 18:12:13 -0700 | [diff] [blame] | 21 | |
Bluetooth Build Test | b4a42e7 | 2016-04-07 14:10:40 +0200 | [diff] [blame] | 22 | #include "osi/include/properties.h" |
Arman Uguray | fe65fb7 | 2015-07-24 19:14:42 -0700 | [diff] [blame] | 23 | #include "service/daemon.h" |
Arman Uguray | 065d0f7 | 2015-07-16 18:12:13 -0700 | [diff] [blame] | 24 | #include "service/switches.h" |
Ian Coolidge | 611fcf9 | 2015-06-03 17:20:30 -0700 | [diff] [blame] | 25 | |
| 26 | namespace { |
| 27 | |
Arman Uguray | f2d6434 | 2015-07-08 15:47:39 -0700 | [diff] [blame] | 28 | // TODO(armansito): None of these should be hardcoded here. Instead, pass these |
| 29 | // via commandline. |
Ian Coolidge | 611fcf9 | 2015-06-03 17:20:30 -0700 | [diff] [blame] | 30 | const char kDisableProperty[] = "persist.bluetooth.disable"; |
Ian Coolidge | 611fcf9 | 2015-06-03 17:20:30 -0700 | [diff] [blame] | 31 | |
| 32 | } // namespace |
| 33 | |
Myles Watson | 911d1ae | 2016-11-28 16:44:40 -0800 | [diff] [blame] | 34 | int main(int argc, char* argv[]) { |
Arman Uguray | 065d0f7 | 2015-07-16 18:12:13 -0700 | [diff] [blame] | 35 | base::AtExitManager exit_manager; |
| 36 | base::CommandLine::Init(argc, argv); |
| 37 | |
Arman Uguray | 503baaa | 2015-08-20 11:49:00 -0700 | [diff] [blame] | 38 | logging::LoggingSettings log_settings; |
| 39 | if (!logging::InitLogging(log_settings)) { |
| 40 | LOG(ERROR) << "Failed to set up logging"; |
| 41 | return EXIT_FAILURE; |
| 42 | } |
| 43 | |
Arman Uguray | 065d0f7 | 2015-07-16 18:12:13 -0700 | [diff] [blame] | 44 | // TODO(armansito): Initialize base/logging. By default it will dump to stdout |
| 45 | // but we might want to change that based on a command-line switch. Figure out |
| 46 | // how to route the logging to Android's syslog. Once that's done, we won't |
| 47 | // need to use osi/include/log.h anymore. |
| 48 | |
| 49 | // TODO(armansito): Register exit-time clean-up handlers for the IPC sockets. |
| 50 | // Register signal handlers. |
| 51 | auto command_line = base::CommandLine::ForCurrentProcess(); |
| 52 | if (command_line->HasSwitch(bluetooth::switches::kHelpLong) || |
| 53 | command_line->HasSwitch(bluetooth::switches::kHelpShort)) { |
| 54 | LOG(INFO) << bluetooth::switches::kHelpMessage; |
| 55 | return EXIT_SUCCESS; |
| 56 | } |
| 57 | |
Arman Uguray | 065d0f7 | 2015-07-16 18:12:13 -0700 | [diff] [blame] | 58 | // TODO(armansito): Remove Chromecast specific property out of here. This |
| 59 | // should just be obtained from global config. |
Ian Coolidge | 611fcf9 | 2015-06-03 17:20:30 -0700 | [diff] [blame] | 60 | char disable_value[PROPERTY_VALUE_MAX]; |
Myles Watson | 158fe8e | 2018-02-16 13:11:04 -0800 | [diff] [blame] | 61 | int status = osi_property_get(kDisableProperty, disable_value, nullptr); |
Ian Coolidge | 611fcf9 | 2015-06-03 17:20:30 -0700 | [diff] [blame] | 62 | if (status && !strcmp(disable_value, "1")) { |
Arman Uguray | 065d0f7 | 2015-07-16 18:12:13 -0700 | [diff] [blame] | 63 | LOG(INFO) << "service disabled"; |
Ian Coolidge | 611fcf9 | 2015-06-03 17:20:30 -0700 | [diff] [blame] | 64 | return EXIT_SUCCESS; |
| 65 | } |
| 66 | |
Arman Uguray | fe65fb7 | 2015-07-24 19:14:42 -0700 | [diff] [blame] | 67 | if (!bluetooth::Daemon::Initialize()) { |
| 68 | LOG(ERROR) << "Failed to initialize Daemon"; |
Arman Uguray | f2d6434 | 2015-07-08 15:47:39 -0700 | [diff] [blame] | 69 | return EXIT_FAILURE; |
| 70 | } |
| 71 | |
Arman Uguray | fe65fb7 | 2015-07-24 19:14:42 -0700 | [diff] [blame] | 72 | // Start the main event loop. |
| 73 | bluetooth::Daemon::Get()->StartMainLoop(); |
Arman Uguray | f2d6434 | 2015-07-08 15:47:39 -0700 | [diff] [blame] | 74 | |
Arman Uguray | fe65fb7 | 2015-07-24 19:14:42 -0700 | [diff] [blame] | 75 | // The main message loop has exited; clean up the Daemon. |
| 76 | bluetooth::Daemon::Get()->ShutDown(); |
Ian Coolidge | 611fcf9 | 2015-06-03 17:20:30 -0700 | [diff] [blame] | 77 | |
Ian Coolidge | 611fcf9 | 2015-06-03 17:20:30 -0700 | [diff] [blame] | 78 | return EXIT_SUCCESS; |
| 79 | } |