1*6777b538SAndroid Build Coastguard Worker // Copyright 2012 The Chromium Authors
2*6777b538SAndroid Build Coastguard Worker // Use of this source code is governed by a BSD-style license that can be
3*6777b538SAndroid Build Coastguard Worker // found in the LICENSE file.
4*6777b538SAndroid Build Coastguard Worker
5*6777b538SAndroid Build Coastguard Worker #ifndef BASE_MAC_MAC_UTIL_H_
6*6777b538SAndroid Build Coastguard Worker #define BASE_MAC_MAC_UTIL_H_
7*6777b538SAndroid Build Coastguard Worker
8*6777b538SAndroid Build Coastguard Worker #include <AvailabilityMacros.h>
9*6777b538SAndroid Build Coastguard Worker #import <CoreGraphics/CoreGraphics.h>
10*6777b538SAndroid Build Coastguard Worker #include <stdint.h>
11*6777b538SAndroid Build Coastguard Worker
12*6777b538SAndroid Build Coastguard Worker #include <string>
13*6777b538SAndroid Build Coastguard Worker #include <string_view>
14*6777b538SAndroid Build Coastguard Worker #include <vector>
15*6777b538SAndroid Build Coastguard Worker
16*6777b538SAndroid Build Coastguard Worker #include "base/base_export.h"
17*6777b538SAndroid Build Coastguard Worker
18*6777b538SAndroid Build Coastguard Worker namespace base {
19*6777b538SAndroid Build Coastguard Worker class FilePath;
20*6777b538SAndroid Build Coastguard Worker }
21*6777b538SAndroid Build Coastguard Worker
22*6777b538SAndroid Build Coastguard Worker namespace base::mac {
23*6777b538SAndroid Build Coastguard Worker
24*6777b538SAndroid Build Coastguard Worker // Returns an sRGB color space. The return value is a static value; do not
25*6777b538SAndroid Build Coastguard Worker // release it!
26*6777b538SAndroid Build Coastguard Worker BASE_EXPORT CGColorSpaceRef GetSRGBColorSpace();
27*6777b538SAndroid Build Coastguard Worker
28*6777b538SAndroid Build Coastguard Worker // Adds the specified application to the set of Login Items with specified
29*6777b538SAndroid Build Coastguard Worker // "hide" flag. This has the same effect as adding/removing the application in
30*6777b538SAndroid Build Coastguard Worker // SystemPreferences->Accounts->LoginItems or marking Application in the Dock
31*6777b538SAndroid Build Coastguard Worker // as "Options->Open on Login".
32*6777b538SAndroid Build Coastguard Worker // Does nothing if the application is already set up as Login Item with
33*6777b538SAndroid Build Coastguard Worker // specified hide flag.
34*6777b538SAndroid Build Coastguard Worker BASE_EXPORT void AddToLoginItems(const FilePath& app_bundle_file_path,
35*6777b538SAndroid Build Coastguard Worker bool hide_on_startup);
36*6777b538SAndroid Build Coastguard Worker
37*6777b538SAndroid Build Coastguard Worker // Removes the specified application from the list of Login Items.
38*6777b538SAndroid Build Coastguard Worker BASE_EXPORT void RemoveFromLoginItems(const FilePath& app_bundle_file_path);
39*6777b538SAndroid Build Coastguard Worker
40*6777b538SAndroid Build Coastguard Worker // Returns true if the current process was automatically launched as a
41*6777b538SAndroid Build Coastguard Worker // 'Login Item' or via Lion's Resume. Used to suppress opening windows.
42*6777b538SAndroid Build Coastguard Worker BASE_EXPORT bool WasLaunchedAsLoginOrResumeItem();
43*6777b538SAndroid Build Coastguard Worker
44*6777b538SAndroid Build Coastguard Worker // Returns true if the current process was automatically launched as a
45*6777b538SAndroid Build Coastguard Worker // 'Login Item' or via Resume, and the 'Reopen windows when logging back in'
46*6777b538SAndroid Build Coastguard Worker // checkbox was selected by the user. This indicates that the previous
47*6777b538SAndroid Build Coastguard Worker // session should be restored.
48*6777b538SAndroid Build Coastguard Worker BASE_EXPORT bool WasLaunchedAsLoginItemRestoreState();
49*6777b538SAndroid Build Coastguard Worker
50*6777b538SAndroid Build Coastguard Worker // Returns true if the current process was automatically launched as a
51*6777b538SAndroid Build Coastguard Worker // 'Login Item' with 'hide on startup' flag. Used to suppress opening windows.
52*6777b538SAndroid Build Coastguard Worker BASE_EXPORT bool WasLaunchedAsHiddenLoginItem();
53*6777b538SAndroid Build Coastguard Worker
54*6777b538SAndroid Build Coastguard Worker // Remove the quarantine xattr from the given file. Returns false if there was
55*6777b538SAndroid Build Coastguard Worker // an error, or true otherwise.
56*6777b538SAndroid Build Coastguard Worker BASE_EXPORT bool RemoveQuarantineAttribute(const FilePath& file_path);
57*6777b538SAndroid Build Coastguard Worker
58*6777b538SAndroid Build Coastguard Worker // Sets the tags on a given file or folder.
59*6777b538SAndroid Build Coastguard Worker BASE_EXPORT void SetFileTags(const FilePath& file_path,
60*6777b538SAndroid Build Coastguard Worker const std::vector<std::string>& file_tags);
61*6777b538SAndroid Build Coastguard Worker
62*6777b538SAndroid Build Coastguard Worker // The following two functions return the version of the macOS currently
63*6777b538SAndroid Build Coastguard Worker // running. MacOSVersion() returns the full trio of version numbers, packed into
64*6777b538SAndroid Build Coastguard Worker // one int (e.g. macOS 12.6.5 returns 12'06'05), and MacOSMajorVersion() returns
65*6777b538SAndroid Build Coastguard Worker // only the major version number (e.g. macOS 12.6.5 returns 12). Use for runtime
66*6777b538SAndroid Build Coastguard Worker // OS version checking. Prefer to use @available in Objective-C files. Note that
67*6777b538SAndroid Build Coastguard Worker // this does not include any Rapid Security Response (RSR) suffixes (the "(a)"
68*6777b538SAndroid Build Coastguard Worker // at the end of version numbers.)
69*6777b538SAndroid Build Coastguard Worker BASE_EXPORT __attribute__((const)) int MacOSVersion();
MacOSMajorVersion()70*6777b538SAndroid Build Coastguard Worker inline __attribute__((const)) int MacOSMajorVersion() {
71*6777b538SAndroid Build Coastguard Worker return MacOSVersion() / 1'00'00;
72*6777b538SAndroid Build Coastguard Worker }
73*6777b538SAndroid Build Coastguard Worker
74*6777b538SAndroid Build Coastguard Worker enum class CPUType {
75*6777b538SAndroid Build Coastguard Worker kIntel,
76*6777b538SAndroid Build Coastguard Worker kTranslatedIntel, // Rosetta
77*6777b538SAndroid Build Coastguard Worker kArm,
78*6777b538SAndroid Build Coastguard Worker };
79*6777b538SAndroid Build Coastguard Worker
80*6777b538SAndroid Build Coastguard Worker // Returns the type of CPU this is being executed on.
81*6777b538SAndroid Build Coastguard Worker BASE_EXPORT CPUType GetCPUType();
82*6777b538SAndroid Build Coastguard Worker
83*6777b538SAndroid Build Coastguard Worker // Returns an OS name + version string. e.g.:
84*6777b538SAndroid Build Coastguard Worker //
85*6777b538SAndroid Build Coastguard Worker // "macOS Version 10.14.3 (Build 18D109)"
86*6777b538SAndroid Build Coastguard Worker //
87*6777b538SAndroid Build Coastguard Worker // Parts of this string change based on OS locale, so it's only useful for
88*6777b538SAndroid Build Coastguard Worker // displaying to the user.
89*6777b538SAndroid Build Coastguard Worker BASE_EXPORT std::string GetOSDisplayName();
90*6777b538SAndroid Build Coastguard Worker
91*6777b538SAndroid Build Coastguard Worker // Returns the serial number of the macOS device.
92*6777b538SAndroid Build Coastguard Worker BASE_EXPORT std::string GetPlatformSerialNumber();
93*6777b538SAndroid Build Coastguard Worker
94*6777b538SAndroid Build Coastguard Worker // System Settings (née System Preferences) pane or subpanes to open via
95*6777b538SAndroid Build Coastguard Worker // `OpenSystemSettingsPane()`, below. The naming is based on the naming in the
96*6777b538SAndroid Build Coastguard Worker // System Settings app in the latest macOS release, macOS 13 Ventura.
97*6777b538SAndroid Build Coastguard Worker enum class SystemSettingsPane {
98*6777b538SAndroid Build Coastguard Worker // Accessibility > Captions
99*6777b538SAndroid Build Coastguard Worker kAccessibility_Captions,
100*6777b538SAndroid Build Coastguard Worker
101*6777b538SAndroid Build Coastguard Worker // Date & Time
102*6777b538SAndroid Build Coastguard Worker kDateTime,
103*6777b538SAndroid Build Coastguard Worker
104*6777b538SAndroid Build Coastguard Worker // Network > Proxies
105*6777b538SAndroid Build Coastguard Worker kNetwork_Proxies,
106*6777b538SAndroid Build Coastguard Worker
107*6777b538SAndroid Build Coastguard Worker // Notifications; optionally pass a bundle identifier as `id_param` to
108*6777b538SAndroid Build Coastguard Worker // directly open the notification settings page for the given app.
109*6777b538SAndroid Build Coastguard Worker kNotifications,
110*6777b538SAndroid Build Coastguard Worker
111*6777b538SAndroid Build Coastguard Worker // Printers & Scanners
112*6777b538SAndroid Build Coastguard Worker kPrintersScanners,
113*6777b538SAndroid Build Coastguard Worker
114*6777b538SAndroid Build Coastguard Worker // Privacy & Security > Accessibility
115*6777b538SAndroid Build Coastguard Worker kPrivacySecurity_Accessibility,
116*6777b538SAndroid Build Coastguard Worker
117*6777b538SAndroid Build Coastguard Worker // Privacy & Security > Bluetooth
118*6777b538SAndroid Build Coastguard Worker // Available on macOS 11 and later.
119*6777b538SAndroid Build Coastguard Worker kPrivacySecurity_Bluetooth,
120*6777b538SAndroid Build Coastguard Worker
121*6777b538SAndroid Build Coastguard Worker // Privacy & Security > Camera
122*6777b538SAndroid Build Coastguard Worker kPrivacySecurity_Camera,
123*6777b538SAndroid Build Coastguard Worker
124*6777b538SAndroid Build Coastguard Worker // Privacy & Security > Extensions > Sharing
125*6777b538SAndroid Build Coastguard Worker kPrivacySecurity_Extensions_Sharing,
126*6777b538SAndroid Build Coastguard Worker
127*6777b538SAndroid Build Coastguard Worker // Privacy & Security > Location Services
128*6777b538SAndroid Build Coastguard Worker kPrivacySecurity_LocationServices,
129*6777b538SAndroid Build Coastguard Worker
130*6777b538SAndroid Build Coastguard Worker // Privacy & Security > Microphone
131*6777b538SAndroid Build Coastguard Worker kPrivacySecurity_Microphone,
132*6777b538SAndroid Build Coastguard Worker
133*6777b538SAndroid Build Coastguard Worker // Privacy & Security > Screen Recording
134*6777b538SAndroid Build Coastguard Worker kPrivacySecurity_ScreenRecording,
135*6777b538SAndroid Build Coastguard Worker
136*6777b538SAndroid Build Coastguard Worker // Trackpad
137*6777b538SAndroid Build Coastguard Worker kTrackpad,
138*6777b538SAndroid Build Coastguard Worker };
139*6777b538SAndroid Build Coastguard Worker
140*6777b538SAndroid Build Coastguard Worker // Opens the specified System Settings pane. If the specified subpane does not
141*6777b538SAndroid Build Coastguard Worker // exist on the release of macOS that is running, the parent pane will open
142*6777b538SAndroid Build Coastguard Worker // instead. For some panes, `id_param` can be used to specify a subpane. See the
143*6777b538SAndroid Build Coastguard Worker // various SystemSettingsPane values for details.
144*6777b538SAndroid Build Coastguard Worker BASE_EXPORT void OpenSystemSettingsPane(SystemSettingsPane pane,
145*6777b538SAndroid Build Coastguard Worker const std::string& id_param = "");
146*6777b538SAndroid Build Coastguard Worker
147*6777b538SAndroid Build Coastguard Worker // ------- For testing --------
148*6777b538SAndroid Build Coastguard Worker
149*6777b538SAndroid Build Coastguard Worker // An implementation detail of `MacOSVersion()` above, exposed for testing.
150*6777b538SAndroid Build Coastguard Worker BASE_EXPORT int ParseOSProductVersionForTesting(
151*6777b538SAndroid Build Coastguard Worker const std::string_view& version);
152*6777b538SAndroid Build Coastguard Worker
153*6777b538SAndroid Build Coastguard Worker } // namespace base::mac
154*6777b538SAndroid Build Coastguard Worker
155*6777b538SAndroid Build Coastguard Worker #endif // BASE_MAC_MAC_UTIL_H_
156