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.
5 #ifndef NET_SOCKET_UNIX_DOMAIN_SOCKET_POSIX_H_
6 #define NET_SOCKET_UNIX_DOMAIN_SOCKET_POSIX_H_
10 #include "base/basictypes.h"
11 #include "base/callback_forward.h"
12 #include "base/compiler_specific.h"
13 #include "build/build_config.h"
14 #include "net/base/net_export.h"
15 #include "net/socket/stream_listen_socket.h"
17 #if defined(OS_ANDROID) || defined(OS_LINUX)
18 // Feature only supported on Linux currently. This lets the Unix Domain Socket
19 // not be backed by the file system.
20 #define SOCKET_ABSTRACT_NAMESPACE_SUPPORTED
25 // Unix Domain Socket Implementation. Supports abstract namespaces on Linux.
26 class NET_EXPORT UnixDomainSocket
: public StreamListenSocket
{
28 virtual ~UnixDomainSocket();
30 // Callback that returns whether the already connected client, identified by
31 // its process |user_id| and |group_id|, is allowed to keep the connection
32 // open. Note that the socket is closed immediately in case the callback
34 typedef base::Callback
<bool (uid_t user_id
, gid_t group_id
)> AuthCallback
;
36 // Returns an authentication callback that always grants access for
37 // convenience in case you don't want to use authentication.
38 static AuthCallback
NoAuthentication();
40 // Note that the returned UnixDomainSocket instance does not take ownership of
42 static scoped_ptr
<UnixDomainSocket
> CreateAndListen(
43 const std::string
& path
,
44 StreamListenSocket::Delegate
* del
,
45 const AuthCallback
& auth_callback
);
47 #if defined(SOCKET_ABSTRACT_NAMESPACE_SUPPORTED)
48 // Same as above except that the created socket uses the abstract namespace
49 // which is a Linux-only feature. If |fallback_path| is not empty,
50 // make the second attempt with the provided fallback name.
51 static scoped_ptr
<UnixDomainSocket
> CreateAndListenWithAbstractNamespace(
52 const std::string
& path
,
53 const std::string
& fallback_path
,
54 StreamListenSocket::Delegate
* del
,
55 const AuthCallback
& auth_callback
);
59 UnixDomainSocket(SocketDescriptor s
,
60 StreamListenSocket::Delegate
* del
,
61 const AuthCallback
& auth_callback
);
63 static scoped_ptr
<UnixDomainSocket
> CreateAndListenInternal(
64 const std::string
& path
,
65 const std::string
& fallback_path
,
66 StreamListenSocket::Delegate
* del
,
67 const AuthCallback
& auth_callback
,
68 bool use_abstract_namespace
);
70 static SocketDescriptor
CreateAndBind(const std::string
& path
,
71 bool use_abstract_namespace
);
73 // StreamListenSocket:
74 virtual void Accept() OVERRIDE
;
76 AuthCallback auth_callback_
;
78 DISALLOW_COPY_AND_ASSIGN(UnixDomainSocket
);
81 // Factory that can be used to instantiate UnixDomainSocket.
82 class NET_EXPORT UnixDomainSocketFactory
: public StreamListenSocketFactory
{
84 // Note that this class does not take ownership of the provided delegate.
85 UnixDomainSocketFactory(const std::string
& path
,
86 const UnixDomainSocket::AuthCallback
& auth_callback
);
87 virtual ~UnixDomainSocketFactory();
89 // StreamListenSocketFactory:
90 virtual scoped_ptr
<StreamListenSocket
> CreateAndListen(
91 StreamListenSocket::Delegate
* delegate
) const OVERRIDE
;
94 const std::string path_
;
95 const UnixDomainSocket::AuthCallback auth_callback_
;
98 DISALLOW_COPY_AND_ASSIGN(UnixDomainSocketFactory
);
101 #if defined(SOCKET_ABSTRACT_NAMESPACE_SUPPORTED)
102 // Use this factory to instantiate UnixDomainSocket using the abstract
103 // namespace feature (only supported on Linux).
104 class NET_EXPORT UnixDomainSocketWithAbstractNamespaceFactory
105 : public UnixDomainSocketFactory
{
107 UnixDomainSocketWithAbstractNamespaceFactory(
108 const std::string
& path
,
109 const std::string
& fallback_path
,
110 const UnixDomainSocket::AuthCallback
& auth_callback
);
111 virtual ~UnixDomainSocketWithAbstractNamespaceFactory();
113 // UnixDomainSocketFactory:
114 virtual scoped_ptr
<StreamListenSocket
> CreateAndListen(
115 StreamListenSocket::Delegate
* delegate
) const OVERRIDE
;
118 std::string fallback_path_
;
120 DISALLOW_COPY_AND_ASSIGN(UnixDomainSocketWithAbstractNamespaceFactory
);
126 #endif // NET_SOCKET_UNIX_DOMAIN_SOCKET_POSIX_H_