1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4 
5 #ifndef BASE_ANDROID_BUILD_INFO_H_
6 #define BASE_ANDROID_BUILD_INFO_H_
7 
8 #include <jni.h>
9 
10 #include <string>
11 #include <vector>
12 
13 #include "base/base_export.h"
14 #include "base/macros.h"
15 #include "base/memory/singleton.h"
16 
17 namespace base {
18 namespace android {
19 
20 // This enumeration maps to the values returned by BuildInfo::sdk_int(),
21 // indicating the Android release associated with a given SDK version.
22 enum SdkVersion {
23   SDK_VERSION_JELLY_BEAN = 16,
24   SDK_VERSION_JELLY_BEAN_MR1 = 17,
25   SDK_VERSION_JELLY_BEAN_MR2 = 18,
26   SDK_VERSION_KITKAT = 19,
27   SDK_VERSION_KITKAT_WEAR = 20,
28   SDK_VERSION_LOLLIPOP = 21,
29   SDK_VERSION_LOLLIPOP_MR1 = 22,
30   SDK_VERSION_MARSHMALLOW = 23,
31   SDK_VERSION_NOUGAT = 24,
32   SDK_VERSION_NOUGAT_MR1 = 25,
33   SDK_VERSION_OREO = 26,
34 };
35 
36 // BuildInfo is a singleton class that stores android build and device
37 // information. It will be called from Android specific code and gets used
38 // primarily in crash reporting.
39 class BASE_EXPORT BuildInfo {
40  public:
41 
~BuildInfo()42   ~BuildInfo() {}
43 
44   // Static factory method for getting the singleton BuildInfo instance.
45   // Note that ownership is not conferred on the caller and the BuildInfo in
46   // question isn't actually freed until shutdown. This is ok because there
47   // should only be one instance of BuildInfo ever created.
48   static BuildInfo* GetInstance();
49 
50   // Const char* is used instead of std::strings because these values must be
51   // available even if the process is in a crash state. Sadly
52   // std::string.c_str() doesn't guarantee that memory won't be allocated when
53   // it is called.
device()54   const char* device() const {
55     return device_;
56   }
57 
manufacturer()58   const char* manufacturer() const {
59     return manufacturer_;
60   }
61 
model()62   const char* model() const {
63     return model_;
64   }
65 
brand()66   const char* brand() const {
67     return brand_;
68   }
69 
android_build_id()70   const char* android_build_id() const {
71     return android_build_id_;
72   }
73 
android_build_fp()74   const char* android_build_fp() const {
75     return android_build_fp_;
76   }
77 
gms_version_code()78   const char* gms_version_code() const {
79     return gms_version_code_;
80   }
81 
host_package_name()82   const char* host_package_name() const { return host_package_name_; }
83 
host_version_code()84   const char* host_version_code() const { return host_version_code_; }
85 
host_package_label()86   const char* host_package_label() const { return host_package_label_; }
87 
package_version_code()88   const char* package_version_code() const {
89     return package_version_code_;
90   }
91 
package_version_name()92   const char* package_version_name() const {
93     return package_version_name_;
94   }
95 
package_name()96   const char* package_name() const {
97     return package_name_;
98   }
99 
100   // Will be empty string if no app id is assigned.
firebase_app_id()101   const char* firebase_app_id() const { return firebase_app_id_; }
102 
custom_themes()103   const char* custom_themes() const { return custom_themes_; }
104 
resources_version()105   const char* resources_version() const { return resources_version_; }
106 
build_type()107   const char* build_type() const {
108     return build_type_;
109   }
110 
board()111   const char* board() const { return board_; }
112 
installer_package_name()113   const char* installer_package_name() const { return installer_package_name_; }
114 
abi_name()115   const char* abi_name() const { return abi_name_; }
116 
extracted_file_suffix()117   std::string extracted_file_suffix() const { return extracted_file_suffix_; }
118 
sdk_int()119   int sdk_int() const {
120     return sdk_int_;
121   }
122 
is_at_least_p()123   bool is_at_least_p() const { return is_at_least_p_; }
124 
125  private:
126   friend struct BuildInfoSingletonTraits;
127 
128   explicit BuildInfo(const std::vector<std::string>& params);
129 
130   // Const char* is used instead of std::strings because these values must be
131   // available even if the process is in a crash state. Sadly
132   // std::string.c_str() doesn't guarantee that memory won't be allocated when
133   // it is called.
134   const char* const brand_;
135   const char* const device_;
136   const char* const android_build_id_;
137   const char* const manufacturer_;
138   const char* const model_;
139   const int sdk_int_;
140   const char* const build_type_;
141   const char* const board_;
142   const char* const host_package_name_;
143   const char* const host_version_code_;
144   const char* const host_package_label_;
145   const char* const package_name_;
146   const char* const package_version_code_;
147   const char* const package_version_name_;
148   const char* const android_build_fp_;
149   const char* const gms_version_code_;
150   const char* const installer_package_name_;
151   const char* const abi_name_;
152   const char* const firebase_app_id_;
153   const char* const custom_themes_;
154   const char* const resources_version_;
155   // Not needed by breakpad.
156   const std::string extracted_file_suffix_;
157   const int is_at_least_p_;
158 
159   DISALLOW_COPY_AND_ASSIGN(BuildInfo);
160 };
161 
162 }  // namespace android
163 }  // namespace base
164 
165 #endif  // BASE_ANDROID_BUILD_INFO_H_
166