1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
base / mac / scoped_authorizationref.h [blame]
// Copyright 2012 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef BASE_MAC_SCOPED_AUTHORIZATIONREF_H_
#define BASE_MAC_SCOPED_AUTHORIZATIONREF_H_
#include <Security/Authorization.h>
#include <utility>
#include "base/base_export.h"
#include "base/check.h"
// `ScopedAuthorizationRef` maintains ownership of an `AuthorizationRef`. It is
// patterned after the `unique_ptr` interface.
namespace base::mac {
class BASE_EXPORT ScopedAuthorizationRef {
public:
explicit ScopedAuthorizationRef(AuthorizationRef authorization = nullptr)
: authorization_(authorization) {}
ScopedAuthorizationRef(const ScopedAuthorizationRef&) = delete;
ScopedAuthorizationRef& operator=(const ScopedAuthorizationRef&) = delete;
ScopedAuthorizationRef(ScopedAuthorizationRef&& that)
: authorization_(std::exchange(that.authorization_, nullptr)) {}
ScopedAuthorizationRef& operator=(ScopedAuthorizationRef&& that) {
authorization_ = std::exchange(that.authorization_, nullptr);
return *this;
}
~ScopedAuthorizationRef() {
if (authorization_) {
FreeInternal();
}
}
void reset(AuthorizationRef authorization = nullptr) {
if (authorization_ != authorization) {
if (authorization_) {
FreeInternal();
}
authorization_ = authorization;
}
}
bool operator==(AuthorizationRef that) const {
return authorization_ == that;
}
bool operator!=(AuthorizationRef that) const {
return authorization_ != that;
}
operator AuthorizationRef() const {
return authorization_;
}
explicit operator bool() const { return authorization_ != nullptr; }
// This is to be used only to take ownership of objects that are created
// by pass-by-pointer create functions. To enforce this, require that the
// object be reset to NULL before this may be used.
[[nodiscard]] AuthorizationRef* InitializeInto() {
DCHECK(!authorization_);
return &authorization_;
}
AuthorizationRef get() const {
return authorization_;
}
// ScopedAuthorizationRef::release() is like std::unique_ptr<>::release. It is
// NOT a wrapper for AuthorizationFree(). To force a ScopedAuthorizationRef
// object to call AuthorizationFree(), use ScopedAuthorizationRef::reset().
[[nodiscard]] AuthorizationRef release() {
AuthorizationRef temp = authorization_;
authorization_ = nullptr;
return temp;
}
private:
// Calling AuthorizationFree, defined in Security.framework, from an inline
// function, results in link errors when linking dynamically with
// libbase.dylib. So wrap the call in an un-inlined method. This method
// doesn't check if |authorization_| is null; that check should be in the
// inlined callers.
void FreeInternal();
AuthorizationRef authorization_;
};
} // namespace base::mac
#endif // BASE_MAC_SCOPED_AUTHORIZATIONREF_H_