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