Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(151)

Side by Side Diff: chrome/browser/extensions/api/socket/tcp_socket.cc

Issue 10692160: Support socket endpoint permissions for AppsV2 Socket API. (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: Fix compile issues.wq Created 8 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 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 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "chrome/browser/extensions/api/socket/tcp_socket.h" 5 #include "chrome/browser/extensions/api/socket/tcp_socket.h"
6 6
7 #include "chrome/browser/extensions/api/api_resource.h" 7 #include "chrome/browser/extensions/api/api_resource.h"
8 #include "chrome/browser/extensions/api/api_resource_event_notifier.h" 8 #include "chrome/browser/extensions/api/api_resource_event_notifier.h"
9 #include "net/base/address_list.h" 9 #include "net/base/address_list.h"
10 #include "net/base/ip_endpoint.h" 10 #include "net/base/ip_endpoint.h"
(...skipping 122 matching lines...) Expand 10 before | Expand all | Expand 10 after
133 return false; 133 return false;
134 return socket_->SetKeepAlive(enable, delay); 134 return socket_->SetKeepAlive(enable, delay);
135 } 135 }
136 136
137 bool TCPSocket::SetNoDelay(bool no_delay) { 137 bool TCPSocket::SetNoDelay(bool no_delay) {
138 if (!socket_.get()) 138 if (!socket_.get())
139 return false; 139 return false;
140 return socket_->SetNoDelay(no_delay); 140 return socket_->SetNoDelay(no_delay);
141 } 141 }
142 142
143 bool TCPSocket::IsTCPSocket() {
144 return true;
145 }
146
147 bool TCPSocket::GetPeerAddress(net::IPEndPoint* address) { 143 bool TCPSocket::GetPeerAddress(net::IPEndPoint* address) {
148 if (!socket_.get()) 144 if (!socket_.get())
149 return false; 145 return false;
150 return !socket_->GetPeerAddress(address); 146 return !socket_->GetPeerAddress(address);
151 } 147 }
152 148
153 bool TCPSocket::GetLocalAddress(net::IPEndPoint* address) { 149 bool TCPSocket::GetLocalAddress(net::IPEndPoint* address) {
154 if (!socket_.get()) 150 if (!socket_.get())
155 return false; 151 return false;
156 return !socket_->GetLocalAddress(address); 152 return !socket_->GetLocalAddress(address);
157 } 153 }
158 154
155 Socket::SocketType TCPSocket::socket_type() const {
156 return Socket::TYPE_TCP;
157 }
159 158
160 int TCPSocket::WriteImpl(net::IOBuffer* io_buffer, 159 int TCPSocket::WriteImpl(net::IOBuffer* io_buffer,
161 int io_buffer_size, 160 int io_buffer_size,
162 const net::CompletionCallback& callback) { 161 const net::CompletionCallback& callback) {
163 if (!socket_.get() || !socket_->IsConnected()) 162 if (!socket_.get() || !socket_->IsConnected())
164 return net::ERR_SOCKET_NOT_CONNECTED; 163 return net::ERR_SOCKET_NOT_CONNECTED;
165 else 164 else
166 return socket_->Write(io_buffer, io_buffer_size, callback); 165 return socket_->Write(io_buffer, io_buffer_size, callback);
167 } 166 }
168 167
169 void TCPSocket::OnConnectComplete(int result) { 168 void TCPSocket::OnConnectComplete(int result) {
170 DCHECK(!connect_callback_.is_null()); 169 DCHECK(!connect_callback_.is_null());
171 DCHECK(!is_connected_); 170 DCHECK(!is_connected_);
172 is_connected_ = result == net::OK; 171 is_connected_ = result == net::OK;
173 connect_callback_.Run(result); 172 connect_callback_.Run(result);
174 connect_callback_.Reset(); 173 connect_callback_.Reset();
175 } 174 }
176 175
177 void TCPSocket::OnReadComplete(scoped_refptr<net::IOBuffer> io_buffer, 176 void TCPSocket::OnReadComplete(scoped_refptr<net::IOBuffer> io_buffer,
178 int result) { 177 int result) {
179 DCHECK(!read_callback_.is_null()); 178 DCHECK(!read_callback_.is_null());
180 read_callback_.Run(result, io_buffer); 179 read_callback_.Run(result, io_buffer);
181 read_callback_.Reset(); 180 read_callback_.Reset();
182 } 181 }
183 182
184 } // namespace extensions 183 } // namespace extensions
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698