| Index: mojo/shell/public/cpp/lib/connector_impl.cc
|
| diff --git a/mojo/shell/public/cpp/lib/connector_impl.cc b/mojo/shell/public/cpp/lib/connector_impl.cc
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..989382ee1a0192353de1dd044464fa63d977a3f8
|
| --- /dev/null
|
| +++ b/mojo/shell/public/cpp/lib/connector_impl.cc
|
| @@ -0,0 +1,74 @@
|
| +// Copyright 2016 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 "mojo/shell/public/cpp/lib/connector_impl.h"
|
| +
|
| +#include "mojo/shell/public/cpp/lib/connection_impl.h"
|
| +
|
| +namespace mojo {
|
| +
|
| +Connector::ConnectParams::ConnectParams(const std::string& url)
|
| + : url_(url),
|
| + filter_(shell::mojom::CapabilityFilter::New()),
|
| + user_id_(shell::mojom::Connector::kUserInherit) {
|
| + filter_->filter.SetToEmpty();
|
| +}
|
| +Connector::ConnectParams::~ConnectParams() {}
|
| +
|
| +ConnectorImpl::ConnectorImpl(shell::mojom::ConnectorPtrInfo unbound_state)
|
| + : unbound_state_(std::move(unbound_state)) {}
|
| +ConnectorImpl::~ConnectorImpl() {}
|
| +
|
| +scoped_ptr<Connection> ConnectorImpl::Connect(const std::string& url) {
|
| + ConnectParams params(url);
|
| + params.set_filter(CreatePermissiveCapabilityFilter());
|
| + return Connect(¶ms);
|
| +}
|
| +
|
| +scoped_ptr<Connection> ConnectorImpl::Connect(ConnectParams* params) {
|
| + // Bind this object to the current thread the first time it is used to
|
| + // connect.
|
| + if (!connector_.is_bound()) {
|
| + if (!unbound_state_.is_valid())
|
| + return nullptr;
|
| + connector_.Bind(std::move(unbound_state_));
|
| + thread_checker_.reset(new base::ThreadChecker);
|
| + }
|
| + DCHECK(thread_checker_->CalledOnValidThread());
|
| +
|
| + DCHECK(params);
|
| + std::string application_url = params->url().spec();
|
| + // We allow all interfaces on outgoing connections since we are presumably in
|
| + // a position to know who we're talking to.
|
| + // TODO(beng): is this a valid assumption or do we need to figure some way to
|
| + // filter here too?
|
| + std::set<std::string> allowed;
|
| + allowed.insert("*");
|
| + shell::mojom::InterfaceProviderPtr local_interfaces;
|
| + shell::mojom::InterfaceProviderRequest local_request =
|
| + GetProxy(&local_interfaces);
|
| + shell::mojom::InterfaceProviderPtr remote_interfaces;
|
| + shell::mojom::InterfaceProviderRequest remote_request =
|
| + GetProxy(&remote_interfaces);
|
| + scoped_ptr<internal::ConnectionImpl> registry(new internal::ConnectionImpl(
|
| + application_url, application_url,
|
| + shell::mojom::Connector::kInvalidApplicationID, params->user_id(),
|
| + std::move(remote_interfaces), std::move(local_request), allowed));
|
| + connector_->Connect(application_url,
|
| + params->user_id(),
|
| + std::move(remote_request),
|
| + std::move(local_interfaces),
|
| + params->TakeFilter(),
|
| + registry->GetConnectCallback());
|
| + return std::move(registry);
|
| +}
|
| +
|
| +scoped_ptr<Connector> ConnectorImpl::Clone() {
|
| + shell::mojom::ConnectorPtr connector;
|
| + connector_->Clone(GetProxy(&connector));
|
| + return make_scoped_ptr(
|
| + new ConnectorImpl(connector.PassInterface()));
|
| +}
|
| +
|
| +} // namespace mojo
|
|
|