Chromium Code Reviews| Index: chrome/browser/extensions/api/diagnostics/diagnostics_api.cc |
| diff --git a/chrome/browser/extensions/api/diagnostics/diagnostics_api.cc b/chrome/browser/extensions/api/diagnostics/diagnostics_api.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..25b3b909b7981c6e2ed49802d8b3bee6c4347e5f |
| --- /dev/null |
| +++ b/chrome/browser/extensions/api/diagnostics/diagnostics_api.cc |
| @@ -0,0 +1,68 @@ |
| +// Copyright (c) 2013 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#include "chrome/browser/extensions/api/diagnostics/diagnostics_api.h" |
| + |
| +#include "chrome/browser/extensions/api/diagnostics/send_ping_packet.h" |
| + |
| +namespace SendPacket = extensions::api::diagnostics::SendPacket; |
| + |
| +using base::Callback; |
|
not at google - send to devlin
2013/06/20 23:32:12
not used
Bei Zhang
2013/06/21 08:31:07
Done.
|
| + |
| +namespace { |
| + |
| +const char kErrorPingNotImplemented[] = "Not implemented."; |
| +const char kErrorPingFailed[] = "Failed to send ping packet."; |
| + |
| +} |
| + |
| +namespace extensions { |
| + |
| +DiagnosticsSendPacketFunction::DiagnosticsSendPacketFunction() {} |
| + |
| +DiagnosticsSendPacketFunction::~DiagnosticsSendPacketFunction() {} |
| + |
| +bool DiagnosticsSendPacketFunction::Prepare() { |
| + parameters_ = SendPacket::Params::Create(*args_); |
| + EXTENSION_FUNCTION_VALIDATE(parameters_.get()); |
| + return true; |
| +} |
| + |
| +void DiagnosticsSendPacketFunction::AsyncWorkStart() { |
| + extensions::SendPingPacket( |
| + parameters_->options.ip, |
| + parameters_->options.ttl.get(), |
| + parameters_->options.timeout.get(), |
| + parameters_->options.size.get(), |
|
not at google - send to devlin
2013/06/20 23:32:12
maybe you can just pass parameters->options() into
Bei Zhang
2013/06/21 08:31:07
Done.
|
| + base::Bind(&DiagnosticsSendPacketFunction::OnComplete, this)); |
| +} |
| + |
| +bool DiagnosticsSendPacketFunction::Respond() { |
| + return error_.empty(); |
| +} |
| + |
| +void DiagnosticsSendPacketFunction::OnComplete( |
| + SendPingPacketResultCode result_code, |
| + const std::string& ip, |
| + double latency) { |
| + |
|
not at google - send to devlin
2013/06/20 23:32:12
no blank line
Bei Zhang
2013/06/21 08:31:07
Done.
|
| + switch (result_code) { |
| + case extensions::SEND_PING_PACKET_OK: { |
| + extensions::api::diagnostics::SendPacketResult result; |
|
not at google - send to devlin
2013/06/20 23:32:12
extensions:: unnecessary
also, decide whether to
Bei Zhang
2013/06/21 08:31:07
Done.
|
| + result.ip = ip; |
| + result.latency = latency; |
| + SetResult(result.ToValue().release()); |
|
not at google - send to devlin
2013/06/20 23:32:12
IIRC the "results" are actually a list, the argume
Bei Zhang
2013/06/21 08:31:07
SetResult creates a new ListValue and appends the
not at google - send to devlin
2013/06/21 17:13:24
Ah I see. Right. What I'm thinking of is SendPacke
Bei Zhang
2013/06/21 19:31:44
Yeah that makes sense. Done.
On 2013/06/21 17:13:
|
| + break; |
| + } |
| + case extensions::SEND_PING_PACKET_NOT_IMPLEMENTED: |
| + SetError(kErrorPingNotImplemented); |
| + break; |
| + case extensions::SEND_PING_PACKET_FAILED: |
| + SetError(kErrorPingFailed); |
| + break; |
| + } |
| + AsyncWorkCompleted(); |
| +} |
| + |
| +} // namespace extensions |