| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "mojo/services/view_manager/view_manager_service_impl.h" | 5 #include "mojo/services/view_manager/view_manager_service_impl.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "mojo/services/public/cpp/geometry/geometry_type_converters.h" | 8 #include "mojo/services/public/cpp/geometry/geometry_type_converters.h" |
| 9 #include "mojo/services/public/cpp/input_events/input_events_type_converters.h" | 9 #include "mojo/services/public/cpp/input_events/input_events_type_converters.h" |
| 10 #include "mojo/services/view_manager/connection_manager.h" |
| 10 #include "mojo/services/view_manager/default_access_policy.h" | 11 #include "mojo/services/view_manager/default_access_policy.h" |
| 11 #include "mojo/services/view_manager/node.h" | 12 #include "mojo/services/view_manager/server_view.h" |
| 12 #include "mojo/services/view_manager/root_node_manager.h" | |
| 13 #include "mojo/services/view_manager/window_manager_access_policy.h" | 13 #include "mojo/services/view_manager/window_manager_access_policy.h" |
| 14 #include "third_party/skia/include/core/SkBitmap.h" | 14 #include "third_party/skia/include/core/SkBitmap.h" |
| 15 #include "ui/aura/window.h" | 15 #include "ui/aura/window.h" |
| 16 #include "ui/gfx/codec/png_codec.h" | 16 #include "ui/gfx/codec/png_codec.h" |
| 17 | 17 |
| 18 namespace mojo { | 18 namespace mojo { |
| 19 namespace service { | 19 namespace service { |
| 20 | 20 |
| 21 ViewManagerServiceImpl::ViewManagerServiceImpl( | 21 ViewManagerServiceImpl::ViewManagerServiceImpl( |
| 22 RootNodeManager* root_node_manager, | 22 ConnectionManager* connection_manager, |
| 23 ConnectionSpecificId creator_id, | 23 ConnectionSpecificId creator_id, |
| 24 const std::string& creator_url, | 24 const std::string& creator_url, |
| 25 const std::string& url, | 25 const std::string& url, |
| 26 const NodeId& root_id, | 26 const ViewId& root_id, |
| 27 InterfaceRequest<ServiceProvider> service_provider) | 27 InterfaceRequest<ServiceProvider> service_provider) |
| 28 : root_node_manager_(root_node_manager), | 28 : connection_manager_(connection_manager), |
| 29 id_(root_node_manager_->GetAndAdvanceNextConnectionId()), | 29 id_(connection_manager_->GetAndAdvanceNextConnectionId()), |
| 30 url_(url), | 30 url_(url), |
| 31 creator_id_(creator_id), | 31 creator_id_(creator_id), |
| 32 creator_url_(creator_url), | 32 creator_url_(creator_url), |
| 33 delete_on_connection_error_(false), | 33 delete_on_connection_error_(false), |
| 34 service_provider_(service_provider.Pass()) { | 34 service_provider_(service_provider.Pass()) { |
| 35 CHECK(GetNode(root_id)); | 35 CHECK(GetView(root_id)); |
| 36 roots_.insert(NodeIdToTransportId(root_id)); | 36 roots_.insert(ViewIdToTransportId(root_id)); |
| 37 if (root_id == RootNodeId()) | 37 if (root_id == RootViewId()) |
| 38 access_policy_.reset(new WindowManagerAccessPolicy(id_, this)); | 38 access_policy_.reset(new WindowManagerAccessPolicy(id_, this)); |
| 39 else | 39 else |
| 40 access_policy_.reset(new DefaultAccessPolicy(id_, this)); | 40 access_policy_.reset(new DefaultAccessPolicy(id_, this)); |
| 41 } | 41 } |
| 42 | 42 |
| 43 ViewManagerServiceImpl::~ViewManagerServiceImpl() { | 43 ViewManagerServiceImpl::~ViewManagerServiceImpl() { |
| 44 // Delete any nodes we created. | 44 // Delete any views we created. |
| 45 if (!node_map_.empty()) { | 45 if (!view_map_.empty()) { |
| 46 RootNodeManager::ScopedChange change(this, root_node_manager_, true); | 46 ConnectionManager::ScopedChange change(this, connection_manager_, true); |
| 47 while (!node_map_.empty()) | 47 while (!view_map_.empty()) |
| 48 delete node_map_.begin()->second; | 48 delete view_map_.begin()->second; |
| 49 } | 49 } |
| 50 | 50 |
| 51 root_node_manager_->RemoveConnection(this); | 51 connection_manager_->RemoveConnection(this); |
| 52 } | 52 } |
| 53 | 53 |
| 54 const Node* ViewManagerServiceImpl::GetNode(const NodeId& id) const { | 54 const ServerView* ViewManagerServiceImpl::GetView(const ViewId& id) const { |
| 55 if (id_ == id.connection_id) { | 55 if (id_ == id.connection_id) { |
| 56 NodeMap::const_iterator i = node_map_.find(id.node_id); | 56 ViewMap::const_iterator i = view_map_.find(id.view_id); |
| 57 return i == node_map_.end() ? NULL : i->second; | 57 return i == view_map_.end() ? NULL : i->second; |
| 58 } | 58 } |
| 59 return root_node_manager_->GetNode(id); | 59 return connection_manager_->GetView(id); |
| 60 } | 60 } |
| 61 | 61 |
| 62 bool ViewManagerServiceImpl::HasRoot(const NodeId& id) const { | 62 bool ViewManagerServiceImpl::HasRoot(const ViewId& id) const { |
| 63 return roots_.find(NodeIdToTransportId(id)) != roots_.end(); | 63 return roots_.find(ViewIdToTransportId(id)) != roots_.end(); |
| 64 } | 64 } |
| 65 | 65 |
| 66 void ViewManagerServiceImpl::OnViewManagerServiceImplDestroyed( | 66 void ViewManagerServiceImpl::OnViewManagerServiceImplDestroyed( |
| 67 ConnectionSpecificId id) { | 67 ConnectionSpecificId id) { |
| 68 if (creator_id_ == id) | 68 if (creator_id_ == id) |
| 69 creator_id_ = kInvalidConnectionId; | 69 creator_id_ = kInvalidConnectionId; |
| 70 } | 70 } |
| 71 | 71 |
| 72 void ViewManagerServiceImpl::ProcessNodeBoundsChanged( | 72 void ViewManagerServiceImpl::ProcessViewBoundsChanged( |
| 73 const Node* node, | 73 const ServerView* view, |
| 74 const gfx::Rect& old_bounds, | 74 const gfx::Rect& old_bounds, |
| 75 const gfx::Rect& new_bounds, | 75 const gfx::Rect& new_bounds, |
| 76 bool originated_change) { | 76 bool originated_change) { |
| 77 if (originated_change || !IsNodeKnown(node)) | 77 if (originated_change || !IsViewKnown(view)) |
| 78 return; | 78 return; |
| 79 client()->OnViewBoundsChanged(NodeIdToTransportId(node->id()), | 79 client()->OnViewBoundsChanged(ViewIdToTransportId(view->id()), |
| 80 Rect::From(old_bounds), | 80 Rect::From(old_bounds), |
| 81 Rect::From(new_bounds)); | 81 Rect::From(new_bounds)); |
| 82 } | 82 } |
| 83 | 83 |
| 84 void ViewManagerServiceImpl::ProcessNodeHierarchyChanged( | 84 void ViewManagerServiceImpl::ProcessViewHierarchyChanged( |
| 85 const Node* node, | 85 const ServerView* view, |
| 86 const Node* new_parent, | 86 const ServerView* new_parent, |
| 87 const Node* old_parent, | 87 const ServerView* old_parent, |
| 88 bool originated_change) { | 88 bool originated_change) { |
| 89 if (originated_change && !IsNodeKnown(node) && new_parent && | 89 if (originated_change && !IsViewKnown(view) && new_parent && |
| 90 IsNodeKnown(new_parent)) { | 90 IsViewKnown(new_parent)) { |
| 91 std::vector<const Node*> unused; | 91 std::vector<const ServerView*> unused; |
| 92 GetUnknownNodesFrom(node, &unused); | 92 GetUnknownViewsFrom(view, &unused); |
| 93 } | 93 } |
| 94 if (originated_change || root_node_manager_->is_processing_delete_node() || | 94 if (originated_change || connection_manager_->is_processing_delete_view() || |
| 95 root_node_manager_->DidConnectionMessageClient(id_)) { | 95 connection_manager_->DidConnectionMessageClient(id_)) { |
| 96 return; | 96 return; |
| 97 } | 97 } |
| 98 | 98 |
| 99 if (!access_policy_->ShouldNotifyOnHierarchyChange( | 99 if (!access_policy_->ShouldNotifyOnHierarchyChange( |
| 100 node, &new_parent, &old_parent)) { | 100 view, &new_parent, &old_parent)) { |
| 101 return; | 101 return; |
| 102 } | 102 } |
| 103 // Inform the client of any new nodes and update the set of nodes we know | 103 // Inform the client of any new views and update the set of views we know |
| 104 // about. | 104 // about. |
| 105 std::vector<const Node*> to_send; | 105 std::vector<const ServerView*> to_send; |
| 106 if (!IsNodeKnown(node)) | 106 if (!IsViewKnown(view)) |
| 107 GetUnknownNodesFrom(node, &to_send); | 107 GetUnknownViewsFrom(view, &to_send); |
| 108 const NodeId new_parent_id(new_parent ? new_parent->id() : NodeId()); | 108 const ViewId new_parent_id(new_parent ? new_parent->id() : ViewId()); |
| 109 const NodeId old_parent_id(old_parent ? old_parent->id() : NodeId()); | 109 const ViewId old_parent_id(old_parent ? old_parent->id() : ViewId()); |
| 110 client()->OnViewHierarchyChanged(NodeIdToTransportId(node->id()), | 110 client()->OnViewHierarchyChanged(ViewIdToTransportId(view->id()), |
| 111 NodeIdToTransportId(new_parent_id), | 111 ViewIdToTransportId(new_parent_id), |
| 112 NodeIdToTransportId(old_parent_id), | 112 ViewIdToTransportId(old_parent_id), |
| 113 NodesToViewDatas(to_send)); | 113 ViewsToViewDatas(to_send)); |
| 114 root_node_manager_->OnConnectionMessagedClient(id_); | 114 connection_manager_->OnConnectionMessagedClient(id_); |
| 115 } | 115 } |
| 116 | 116 |
| 117 void ViewManagerServiceImpl::ProcessNodeReorder(const Node* node, | 117 void ViewManagerServiceImpl::ProcessViewReorder(const ServerView* view, |
| 118 const Node* relative_node, | 118 const ServerView* relative_view, |
| 119 OrderDirection direction, | 119 OrderDirection direction, |
| 120 bool originated_change) { | 120 bool originated_change) { |
| 121 if (originated_change || !IsNodeKnown(node) || !IsNodeKnown(relative_node)) | 121 if (originated_change || !IsViewKnown(view) || !IsViewKnown(relative_view)) |
| 122 return; | 122 return; |
| 123 | 123 |
| 124 client()->OnViewReordered(NodeIdToTransportId(node->id()), | 124 client()->OnViewReordered(ViewIdToTransportId(view->id()), |
| 125 NodeIdToTransportId(relative_node->id()), | 125 ViewIdToTransportId(relative_view->id()), |
| 126 direction); | 126 direction); |
| 127 } | 127 } |
| 128 | 128 |
| 129 void ViewManagerServiceImpl::ProcessNodeDeleted(const NodeId& node, | 129 void ViewManagerServiceImpl::ProcessViewDeleted(const ViewId& view, |
| 130 bool originated_change) { | 130 bool originated_change) { |
| 131 node_map_.erase(node.node_id); | 131 view_map_.erase(view.view_id); |
| 132 | 132 |
| 133 const bool in_known = known_nodes_.erase(NodeIdToTransportId(node)) > 0; | 133 const bool in_known = known_views_.erase(ViewIdToTransportId(view)) > 0; |
| 134 roots_.erase(NodeIdToTransportId(node)); | 134 roots_.erase(ViewIdToTransportId(view)); |
| 135 | 135 |
| 136 if (originated_change) | 136 if (originated_change) |
| 137 return; | 137 return; |
| 138 | 138 |
| 139 if (in_known) { | 139 if (in_known) { |
| 140 client()->OnViewDeleted(NodeIdToTransportId(node)); | 140 client()->OnViewDeleted(ViewIdToTransportId(view)); |
| 141 root_node_manager_->OnConnectionMessagedClient(id_); | 141 connection_manager_->OnConnectionMessagedClient(id_); |
| 142 } | 142 } |
| 143 } | 143 } |
| 144 | 144 |
| 145 void ViewManagerServiceImpl::OnConnectionError() { | 145 void ViewManagerServiceImpl::OnConnectionError() { |
| 146 if (delete_on_connection_error_) | 146 if (delete_on_connection_error_) |
| 147 delete this; | 147 delete this; |
| 148 } | 148 } |
| 149 | 149 |
| 150 bool ViewManagerServiceImpl::IsNodeKnown(const Node* node) const { | 150 bool ViewManagerServiceImpl::IsViewKnown(const ServerView* view) const { |
| 151 return known_nodes_.count(NodeIdToTransportId(node->id())) > 0; | 151 return known_views_.count(ViewIdToTransportId(view->id())) > 0; |
| 152 } | 152 } |
| 153 | 153 |
| 154 bool ViewManagerServiceImpl::CanReorderNode(const Node* node, | 154 bool ViewManagerServiceImpl::CanReorderView(const ServerView* view, |
| 155 const Node* relative_node, | 155 const ServerView* relative_view, |
| 156 OrderDirection direction) const { | 156 OrderDirection direction) const { |
| 157 if (!node || !relative_node) | 157 if (!view || !relative_view) |
| 158 return false; | 158 return false; |
| 159 | 159 |
| 160 if (!node->parent() || node->parent() != relative_node->parent()) | 160 if (!view->parent() || view->parent() != relative_view->parent()) |
| 161 return false; | 161 return false; |
| 162 | 162 |
| 163 if (!access_policy_->CanReorderNode(node, relative_node, direction)) | 163 if (!access_policy_->CanReorderView(view, relative_view, direction)) |
| 164 return false; | 164 return false; |
| 165 | 165 |
| 166 std::vector<const Node*> children = node->parent()->GetChildren(); | 166 std::vector<const ServerView*> children = view->parent()->GetChildren(); |
| 167 const size_t child_i = | 167 const size_t child_i = |
| 168 std::find(children.begin(), children.end(), node) - children.begin(); | 168 std::find(children.begin(), children.end(), view) - children.begin(); |
| 169 const size_t target_i = | 169 const size_t target_i = |
| 170 std::find(children.begin(), children.end(), relative_node) - | 170 std::find(children.begin(), children.end(), relative_view) - |
| 171 children.begin(); | 171 children.begin(); |
| 172 if ((direction == ORDER_DIRECTION_ABOVE && child_i == target_i + 1) || | 172 if ((direction == ORDER_DIRECTION_ABOVE && child_i == target_i + 1) || |
| 173 (direction == ORDER_DIRECTION_BELOW && child_i + 1 == target_i)) { | 173 (direction == ORDER_DIRECTION_BELOW && child_i + 1 == target_i)) { |
| 174 return false; | 174 return false; |
| 175 } | 175 } |
| 176 | 176 |
| 177 return true; | 177 return true; |
| 178 } | 178 } |
| 179 | 179 |
| 180 bool ViewManagerServiceImpl::DeleteNodeImpl(ViewManagerServiceImpl* source, | 180 bool ViewManagerServiceImpl::DeleteViewImpl(ViewManagerServiceImpl* source, |
| 181 Node* node) { | 181 ServerView* view) { |
| 182 DCHECK(node); | 182 DCHECK(view); |
| 183 DCHECK_EQ(node->id().connection_id, id_); | 183 DCHECK_EQ(view->id().connection_id, id_); |
| 184 RootNodeManager::ScopedChange change(source, root_node_manager_, true); | 184 ConnectionManager::ScopedChange change(source, connection_manager_, true); |
| 185 delete node; | 185 delete view; |
| 186 return true; | 186 return true; |
| 187 } | 187 } |
| 188 | 188 |
| 189 void ViewManagerServiceImpl::GetUnknownNodesFrom( | 189 void ViewManagerServiceImpl::GetUnknownViewsFrom( |
| 190 const Node* node, | 190 const ServerView* view, |
| 191 std::vector<const Node*>* nodes) { | 191 std::vector<const ServerView*>* views) { |
| 192 if (IsNodeKnown(node) || !access_policy_->CanGetNodeTree(node)) | 192 if (IsViewKnown(view) || !access_policy_->CanGetViewTree(view)) |
| 193 return; | 193 return; |
| 194 nodes->push_back(node); | 194 views->push_back(view); |
| 195 known_nodes_.insert(NodeIdToTransportId(node->id())); | 195 known_views_.insert(ViewIdToTransportId(view->id())); |
| 196 if (!access_policy_->CanDescendIntoNodeForNodeTree(node)) | 196 if (!access_policy_->CanDescendIntoViewForViewTree(view)) |
| 197 return; | 197 return; |
| 198 std::vector<const Node*> children(node->GetChildren()); | 198 std::vector<const ServerView*> children(view->GetChildren()); |
| 199 for (size_t i = 0 ; i < children.size(); ++i) | 199 for (size_t i = 0 ; i < children.size(); ++i) |
| 200 GetUnknownNodesFrom(children[i], nodes); | 200 GetUnknownViewsFrom(children[i], views); |
| 201 } | 201 } |
| 202 | 202 |
| 203 void ViewManagerServiceImpl::RemoveFromKnown(const Node* node, | 203 void ViewManagerServiceImpl::RemoveFromKnown( |
| 204 std::vector<Node*>* local_nodes) { | 204 const ServerView* view, |
| 205 if (node->id().connection_id == id_) { | 205 std::vector<ServerView*>* local_views) { |
| 206 if (local_nodes) | 206 if (view->id().connection_id == id_) { |
| 207 local_nodes->push_back(GetNode(node->id())); | 207 if (local_views) |
| 208 local_views->push_back(GetView(view->id())); |
| 208 return; | 209 return; |
| 209 } | 210 } |
| 210 known_nodes_.erase(NodeIdToTransportId(node->id())); | 211 known_views_.erase(ViewIdToTransportId(view->id())); |
| 211 std::vector<const Node*> children = node->GetChildren(); | 212 std::vector<const ServerView*> children = view->GetChildren(); |
| 212 for (size_t i = 0; i < children.size(); ++i) | 213 for (size_t i = 0; i < children.size(); ++i) |
| 213 RemoveFromKnown(children[i], local_nodes); | 214 RemoveFromKnown(children[i], local_views); |
| 214 } | 215 } |
| 215 | 216 |
| 216 void ViewManagerServiceImpl::AddRoot( | 217 void ViewManagerServiceImpl::AddRoot( |
| 217 const NodeId& node_id, | 218 const ViewId& view_id, |
| 218 InterfaceRequest<ServiceProvider> service_provider) { | 219 InterfaceRequest<ServiceProvider> service_provider) { |
| 219 const Id transport_node_id(NodeIdToTransportId(node_id)); | 220 const Id transport_view_id(ViewIdToTransportId(view_id)); |
| 220 CHECK(roots_.count(transport_node_id) == 0); | 221 CHECK(roots_.count(transport_view_id) == 0); |
| 221 | 222 |
| 222 CHECK_EQ(creator_id_, node_id.connection_id); | 223 CHECK_EQ(creator_id_, view_id.connection_id); |
| 223 roots_.insert(transport_node_id); | 224 roots_.insert(transport_view_id); |
| 224 const Node* node = GetNode(node_id); | 225 const ServerView* view = GetView(view_id); |
| 225 CHECK(node); | 226 CHECK(view); |
| 226 std::vector<const Node*> to_send; | 227 std::vector<const ServerView*> to_send; |
| 227 if (!IsNodeKnown(node)) { | 228 if (!IsViewKnown(view)) { |
| 228 GetUnknownNodesFrom(node, &to_send); | 229 GetUnknownViewsFrom(view, &to_send); |
| 229 } else { | 230 } else { |
| 230 // Even though the connection knows about the new root we need to tell it | 231 // Even though the connection knows about the new root we need to tell it |
| 231 // |node| is now a root. | 232 // |view| is now a root. |
| 232 to_send.push_back(node); | 233 to_send.push_back(view); |
| 233 } | 234 } |
| 234 | 235 |
| 235 client()->OnEmbed(id_, creator_url_, NodeToViewData(to_send.front()), | 236 client()->OnEmbed(id_, |
| 237 creator_url_, |
| 238 ViewToViewData(to_send.front()), |
| 236 service_provider.Pass()); | 239 service_provider.Pass()); |
| 237 root_node_manager_->OnConnectionMessagedClient(id_); | 240 connection_manager_->OnConnectionMessagedClient(id_); |
| 238 } | 241 } |
| 239 | 242 |
| 240 void ViewManagerServiceImpl::RemoveRoot(const NodeId& node_id) { | 243 void ViewManagerServiceImpl::RemoveRoot(const ViewId& view_id) { |
| 241 const Id transport_node_id(NodeIdToTransportId(node_id)); | 244 const Id transport_view_id(ViewIdToTransportId(view_id)); |
| 242 CHECK(roots_.count(transport_node_id) > 0); | 245 CHECK(roots_.count(transport_view_id) > 0); |
| 243 | 246 |
| 244 roots_.erase(transport_node_id); | 247 roots_.erase(transport_view_id); |
| 245 | 248 |
| 246 // No need to do anything if we created the node. | 249 // No need to do anything if we created the view. |
| 247 if (node_id.connection_id == id_) | 250 if (view_id.connection_id == id_) |
| 248 return; | 251 return; |
| 249 | 252 |
| 250 client()->OnViewDeleted(transport_node_id); | 253 client()->OnViewDeleted(transport_view_id); |
| 251 root_node_manager_->OnConnectionMessagedClient(id_); | 254 connection_manager_->OnConnectionMessagedClient(id_); |
| 252 | 255 |
| 253 // This connection no longer knows about the node. Unparent any nodes that | 256 // This connection no longer knows about the view. Unparent any views that |
| 254 // were parented to nodes in the root. | 257 // were parented to views in the root. |
| 255 std::vector<Node*> local_nodes; | 258 std::vector<ServerView*> local_views; |
| 256 RemoveFromKnown(GetNode(node_id), &local_nodes); | 259 RemoveFromKnown(GetView(view_id), &local_views); |
| 257 for (size_t i = 0; i < local_nodes.size(); ++i) | 260 for (size_t i = 0; i < local_views.size(); ++i) |
| 258 local_nodes[i]->parent()->Remove(local_nodes[i]); | 261 local_views[i]->parent()->Remove(local_views[i]); |
| 259 } | 262 } |
| 260 | 263 |
| 261 void ViewManagerServiceImpl::RemoveChildrenAsPartOfEmbed( | 264 void ViewManagerServiceImpl::RemoveChildrenAsPartOfEmbed( |
| 262 const NodeId& node_id) { | 265 const ViewId& view_id) { |
| 263 Node* node = GetNode(node_id); | 266 ServerView* view = GetView(view_id); |
| 264 CHECK(node); | 267 CHECK(view); |
| 265 CHECK(node->id().connection_id == node_id.connection_id); | 268 CHECK(view->id().connection_id == view_id.connection_id); |
| 266 std::vector<Node*> children = node->GetChildren(); | 269 std::vector<ServerView*> children = view->GetChildren(); |
| 267 for (size_t i = 0; i < children.size(); ++i) | 270 for (size_t i = 0; i < children.size(); ++i) |
| 268 node->Remove(children[i]); | 271 view->Remove(children[i]); |
| 269 } | 272 } |
| 270 | 273 |
| 271 Array<ViewDataPtr> ViewManagerServiceImpl::NodesToViewDatas( | 274 Array<ViewDataPtr> ViewManagerServiceImpl::ViewsToViewDatas( |
| 272 const std::vector<const Node*>& nodes) { | 275 const std::vector<const ServerView*>& views) { |
| 273 Array<ViewDataPtr> array(nodes.size()); | 276 Array<ViewDataPtr> array(views.size()); |
| 274 for (size_t i = 0; i < nodes.size(); ++i) | 277 for (size_t i = 0; i < views.size(); ++i) |
| 275 array[i] = NodeToViewData(nodes[i]).Pass(); | 278 array[i] = ViewToViewData(views[i]).Pass(); |
| 276 return array.Pass(); | 279 return array.Pass(); |
| 277 } | 280 } |
| 278 | 281 |
| 279 ViewDataPtr ViewManagerServiceImpl::NodeToViewData(const Node* node) { | 282 ViewDataPtr ViewManagerServiceImpl::ViewToViewData(const ServerView* view) { |
| 280 DCHECK(IsNodeKnown(node)); | 283 DCHECK(IsViewKnown(view)); |
| 281 const Node* parent = node->parent(); | 284 const ServerView* parent = view->parent(); |
| 282 // If the parent isn't known, it means the parent is not visible to us (not | 285 // If the parent isn't known, it means the parent is not visible to us (not |
| 283 // in roots), and should not be sent over. | 286 // in roots), and should not be sent over. |
| 284 if (parent && !IsNodeKnown(parent)) | 287 if (parent && !IsViewKnown(parent)) |
| 285 parent = NULL; | 288 parent = NULL; |
| 286 ViewDataPtr view_data(ViewData::New()); | 289 ViewDataPtr view_data(ViewData::New()); |
| 287 view_data->parent_id = NodeIdToTransportId(parent ? parent->id() : NodeId()); | 290 view_data->parent_id = ViewIdToTransportId(parent ? parent->id() : ViewId()); |
| 288 view_data->view_id = NodeIdToTransportId(node->id()); | 291 view_data->view_id = ViewIdToTransportId(view->id()); |
| 289 view_data->bounds = Rect::From(node->bounds()); | 292 view_data->bounds = Rect::From(view->bounds()); |
| 290 return view_data.Pass(); | 293 return view_data.Pass(); |
| 291 } | 294 } |
| 292 | 295 |
| 293 void ViewManagerServiceImpl::GetNodeTreeImpl( | 296 void ViewManagerServiceImpl::GetViewTreeImpl( |
| 294 const Node* node, | 297 const ServerView* view, |
| 295 std::vector<const Node*>* nodes) const { | 298 std::vector<const ServerView*>* views) const { |
| 296 DCHECK(node); | 299 DCHECK(view); |
| 297 | 300 |
| 298 if (!access_policy_->CanGetNodeTree(node)) | 301 if (!access_policy_->CanGetViewTree(view)) |
| 299 return; | 302 return; |
| 300 | 303 |
| 301 nodes->push_back(node); | 304 views->push_back(view); |
| 302 | 305 |
| 303 if (!access_policy_->CanDescendIntoNodeForNodeTree(node)) | 306 if (!access_policy_->CanDescendIntoViewForViewTree(view)) |
| 304 return; | 307 return; |
| 305 | 308 |
| 306 std::vector<const Node*> children(node->GetChildren()); | 309 std::vector<const ServerView*> children(view->GetChildren()); |
| 307 for (size_t i = 0 ; i < children.size(); ++i) | 310 for (size_t i = 0 ; i < children.size(); ++i) |
| 308 GetNodeTreeImpl(children[i], nodes); | 311 GetViewTreeImpl(children[i], views); |
| 309 } | 312 } |
| 310 | 313 |
| 311 void ViewManagerServiceImpl::CreateView( | 314 void ViewManagerServiceImpl::CreateView( |
| 312 Id transport_view_id, | 315 Id transport_view_id, |
| 313 const Callback<void(ErrorCode)>& callback) { | 316 const Callback<void(ErrorCode)>& callback) { |
| 314 const NodeId node_id(NodeIdFromTransportId(transport_view_id)); | 317 const ViewId view_id(ViewIdFromTransportId(transport_view_id)); |
| 315 ErrorCode error_code = ERROR_CODE_NONE; | 318 ErrorCode error_code = ERROR_CODE_NONE; |
| 316 if (node_id.connection_id != id_) { | 319 if (view_id.connection_id != id_) { |
| 317 error_code = ERROR_CODE_ILLEGAL_ARGUMENT; | 320 error_code = ERROR_CODE_ILLEGAL_ARGUMENT; |
| 318 } else if (node_map_.find(node_id.node_id) != node_map_.end()) { | 321 } else if (view_map_.find(view_id.view_id) != view_map_.end()) { |
| 319 error_code = ERROR_CODE_VALUE_IN_USE; | 322 error_code = ERROR_CODE_VALUE_IN_USE; |
| 320 } else { | 323 } else { |
| 321 node_map_[node_id.node_id] = new Node(root_node_manager_, node_id); | 324 view_map_[view_id.view_id] = new ServerView(connection_manager_, view_id); |
| 322 known_nodes_.insert(transport_view_id); | 325 known_views_.insert(transport_view_id); |
| 323 } | 326 } |
| 324 callback.Run(error_code); | 327 callback.Run(error_code); |
| 325 } | 328 } |
| 326 | 329 |
| 327 void ViewManagerServiceImpl::DeleteView( | 330 void ViewManagerServiceImpl::DeleteView( |
| 328 Id transport_view_id, | 331 Id transport_view_id, |
| 329 const Callback<void(bool)>& callback) { | 332 const Callback<void(bool)>& callback) { |
| 330 Node* node = GetNode(NodeIdFromTransportId(transport_view_id)); | 333 ServerView* view = GetView(ViewIdFromTransportId(transport_view_id)); |
| 331 bool success = false; | 334 bool success = false; |
| 332 if (node && access_policy_->CanDeleteNode(node)) { | 335 if (view && access_policy_->CanDeleteView(view)) { |
| 333 ViewManagerServiceImpl* connection = root_node_manager_->GetConnection( | 336 ViewManagerServiceImpl* connection = |
| 334 node->id().connection_id); | 337 connection_manager_->GetConnection(view->id().connection_id); |
| 335 success = connection && connection->DeleteNodeImpl(this, node); | 338 success = connection && connection->DeleteViewImpl(this, view); |
| 336 } | 339 } |
| 337 callback.Run(success); | 340 callback.Run(success); |
| 338 } | 341 } |
| 339 | 342 |
| 340 void ViewManagerServiceImpl::AddView( | 343 void ViewManagerServiceImpl::AddView( |
| 341 Id parent_id, | 344 Id parent_id, |
| 342 Id child_id, | 345 Id child_id, |
| 343 const Callback<void(bool)>& callback) { | 346 const Callback<void(bool)>& callback) { |
| 344 bool success = false; | 347 bool success = false; |
| 345 Node* parent = GetNode(NodeIdFromTransportId(parent_id)); | 348 ServerView* parent = GetView(ViewIdFromTransportId(parent_id)); |
| 346 Node* child = GetNode(NodeIdFromTransportId(child_id)); | 349 ServerView* child = GetView(ViewIdFromTransportId(child_id)); |
| 347 if (parent && child && child->parent() != parent && | 350 if (parent && child && child->parent() != parent && |
| 348 !child->Contains(parent) && access_policy_->CanAddNode(parent, child)) { | 351 !child->Contains(parent) && access_policy_->CanAddView(parent, child)) { |
| 349 success = true; | 352 success = true; |
| 350 RootNodeManager::ScopedChange change(this, root_node_manager_, false); | 353 ConnectionManager::ScopedChange change(this, connection_manager_, false); |
| 351 parent->Add(child); | 354 parent->Add(child); |
| 352 } | 355 } |
| 353 callback.Run(success); | 356 callback.Run(success); |
| 354 } | 357 } |
| 355 | 358 |
| 356 void ViewManagerServiceImpl::RemoveViewFromParent( | 359 void ViewManagerServiceImpl::RemoveViewFromParent( |
| 357 Id view_id, | 360 Id view_id, |
| 358 const Callback<void(bool)>& callback) { | 361 const Callback<void(bool)>& callback) { |
| 359 bool success = false; | 362 bool success = false; |
| 360 Node* node = GetNode(NodeIdFromTransportId(view_id)); | 363 ServerView* view = GetView(ViewIdFromTransportId(view_id)); |
| 361 if (node && node->parent() && | 364 if (view && view->parent() && access_policy_->CanRemoveViewFromParent(view)) { |
| 362 access_policy_->CanRemoveNodeFromParent(node)) { | |
| 363 success = true; | 365 success = true; |
| 364 RootNodeManager::ScopedChange change(this, root_node_manager_, false); | 366 ConnectionManager::ScopedChange change(this, connection_manager_, false); |
| 365 node->parent()->Remove(node); | 367 view->parent()->Remove(view); |
| 366 } | 368 } |
| 367 callback.Run(success); | 369 callback.Run(success); |
| 368 } | 370 } |
| 369 | 371 |
| 370 void ViewManagerServiceImpl::ReorderView(Id view_id, | 372 void ViewManagerServiceImpl::ReorderView(Id view_id, |
| 371 Id relative_view_id, | 373 Id relative_view_id, |
| 372 OrderDirection direction, | 374 OrderDirection direction, |
| 373 const Callback<void(bool)>& callback) { | 375 const Callback<void(bool)>& callback) { |
| 374 bool success = false; | 376 bool success = false; |
| 375 Node* node = GetNode(NodeIdFromTransportId(view_id)); | 377 ServerView* view = GetView(ViewIdFromTransportId(view_id)); |
| 376 Node* relative_node = GetNode(NodeIdFromTransportId(relative_view_id)); | 378 ServerView* relative_view = GetView(ViewIdFromTransportId(relative_view_id)); |
| 377 if (CanReorderNode(node, relative_node, direction)) { | 379 if (CanReorderView(view, relative_view, direction)) { |
| 378 success = true; | 380 success = true; |
| 379 RootNodeManager::ScopedChange change(this, root_node_manager_, false); | 381 ConnectionManager::ScopedChange change(this, connection_manager_, false); |
| 380 node->parent()->Reorder(node, relative_node, direction); | 382 view->parent()->Reorder(view, relative_view, direction); |
| 381 root_node_manager_->ProcessNodeReorder(node, relative_node, direction); | 383 connection_manager_->ProcessViewReorder(view, relative_view, direction); |
| 382 } | 384 } |
| 383 callback.Run(success); | 385 callback.Run(success); |
| 384 } | 386 } |
| 385 | 387 |
| 386 void ViewManagerServiceImpl::GetViewTree( | 388 void ViewManagerServiceImpl::GetViewTree( |
| 387 Id view_id, | 389 Id view_id, |
| 388 const Callback<void(Array<ViewDataPtr>)>& callback) { | 390 const Callback<void(Array<ViewDataPtr>)>& callback) { |
| 389 Node* node = GetNode(NodeIdFromTransportId(view_id)); | 391 ServerView* view = GetView(ViewIdFromTransportId(view_id)); |
| 390 std::vector<const Node*> nodes; | 392 std::vector<const ServerView*> views; |
| 391 if (node) { | 393 if (view) { |
| 392 GetNodeTreeImpl(node, &nodes); | 394 GetViewTreeImpl(view, &views); |
| 393 // TODO(sky): this should map in nodes that weren't none. | 395 // TODO(sky): this should map in views that weren't none. |
| 394 } | 396 } |
| 395 callback.Run(NodesToViewDatas(nodes)); | 397 callback.Run(ViewsToViewDatas(views)); |
| 396 } | 398 } |
| 397 | 399 |
| 398 void ViewManagerServiceImpl::SetViewContents( | 400 void ViewManagerServiceImpl::SetViewContents( |
| 399 Id view_id, | 401 Id view_id, |
| 400 ScopedSharedBufferHandle buffer, | 402 ScopedSharedBufferHandle buffer, |
| 401 uint32_t buffer_size, | 403 uint32_t buffer_size, |
| 402 const Callback<void(bool)>& callback) { | 404 const Callback<void(bool)>& callback) { |
| 403 // TODO(sky): add coverage of not being able to set for random node. | 405 // TODO(sky): add coverage of not being able to set for random view. |
| 404 Node* node = GetNode(NodeIdFromTransportId(view_id)); | 406 ServerView* view = GetView(ViewIdFromTransportId(view_id)); |
| 405 if (!node || !access_policy_->CanSetNodeContents(node)) { | 407 if (!view || !access_policy_->CanSetViewContents(view)) { |
| 406 callback.Run(false); | 408 callback.Run(false); |
| 407 return; | 409 return; |
| 408 } | 410 } |
| 409 void* handle_data; | 411 void* handle_data; |
| 410 if (MapBuffer(buffer.get(), 0, buffer_size, &handle_data, | 412 if (MapBuffer(buffer.get(), 0, buffer_size, &handle_data, |
| 411 MOJO_MAP_BUFFER_FLAG_NONE) != MOJO_RESULT_OK) { | 413 MOJO_MAP_BUFFER_FLAG_NONE) != MOJO_RESULT_OK) { |
| 412 callback.Run(false); | 414 callback.Run(false); |
| 413 return; | 415 return; |
| 414 } | 416 } |
| 415 SkBitmap bitmap; | 417 SkBitmap bitmap; |
| 416 gfx::PNGCodec::Decode(static_cast<const unsigned char*>(handle_data), | 418 gfx::PNGCodec::Decode(static_cast<const unsigned char*>(handle_data), |
| 417 buffer_size, &bitmap); | 419 buffer_size, &bitmap); |
| 418 node->SetBitmap(bitmap); | 420 view->SetBitmap(bitmap); |
| 419 UnmapBuffer(handle_data); | 421 UnmapBuffer(handle_data); |
| 420 callback.Run(true); | 422 callback.Run(true); |
| 421 } | 423 } |
| 422 | 424 |
| 423 void ViewManagerServiceImpl::SetViewBounds( | 425 void ViewManagerServiceImpl::SetViewBounds( |
| 424 Id view_id, | 426 Id view_id, |
| 425 RectPtr bounds, | 427 RectPtr bounds, |
| 426 const Callback<void(bool)>& callback) { | 428 const Callback<void(bool)>& callback) { |
| 427 Node* node = GetNode(NodeIdFromTransportId(view_id)); | 429 ServerView* view = GetView(ViewIdFromTransportId(view_id)); |
| 428 const bool success = node && access_policy_->CanSetNodeBounds(node); | 430 const bool success = view && access_policy_->CanSetViewBounds(view); |
| 429 if (success) { | 431 if (success) { |
| 430 RootNodeManager::ScopedChange change(this, root_node_manager_, false); | 432 ConnectionManager::ScopedChange change(this, connection_manager_, false); |
| 431 node->SetBounds(bounds.To<gfx::Rect>()); | 433 view->SetBounds(bounds.To<gfx::Rect>()); |
| 432 } | 434 } |
| 433 callback.Run(success); | 435 callback.Run(success); |
| 434 } | 436 } |
| 435 | 437 |
| 436 void ViewManagerServiceImpl::SetViewVisibility( | 438 void ViewManagerServiceImpl::SetViewVisibility( |
| 437 Id transport_view_id, | 439 Id transport_view_id, |
| 438 bool visible, | 440 bool visible, |
| 439 const Callback<void(bool)>& callback) { | 441 const Callback<void(bool)>& callback) { |
| 440 Node* node = GetNode(NodeIdFromTransportId(transport_view_id)); | 442 ServerView* view = GetView(ViewIdFromTransportId(transport_view_id)); |
| 441 const bool success = node && node->visible() != visible && | 443 const bool success = view && view->visible() != visible && |
| 442 access_policy_->CanChangeNodeVisibility(node); | 444 access_policy_->CanChangeViewVisibility(view); |
| 443 if (success) { | 445 if (success) { |
| 444 DCHECK(node); | 446 DCHECK(view); |
| 445 node->SetVisible(visible); | 447 view->SetVisible(visible); |
| 446 } | 448 } |
| 447 // TODO(sky): need to notify of visibility changes. | 449 // TODO(sky): need to notify of visibility changes. |
| 448 callback.Run(success); | 450 callback.Run(success); |
| 449 } | 451 } |
| 450 | 452 |
| 451 void ViewManagerServiceImpl::Embed( | 453 void ViewManagerServiceImpl::Embed( |
| 452 const String& url, | 454 const String& url, |
| 453 Id transport_view_id, | 455 Id transport_view_id, |
| 454 ServiceProviderPtr service_provider, | 456 ServiceProviderPtr service_provider, |
| 455 const Callback<void(bool)>& callback) { | 457 const Callback<void(bool)>& callback) { |
| 456 InterfaceRequest<ServiceProvider> spir; | 458 InterfaceRequest<ServiceProvider> spir; |
| 457 spir.Bind(service_provider.PassMessagePipe()); | 459 spir.Bind(service_provider.PassMessagePipe()); |
| 458 | 460 |
| 459 if (NodeIdFromTransportId(transport_view_id) == InvalidNodeId()) { | 461 if (ViewIdFromTransportId(transport_view_id) == InvalidViewId()) { |
| 460 root_node_manager_->EmbedRoot(url, spir.Pass()); | 462 connection_manager_->EmbedRoot(url, spir.Pass()); |
| 461 callback.Run(true); | 463 callback.Run(true); |
| 462 return; | 464 return; |
| 463 } | 465 } |
| 464 const Node* node = GetNode(NodeIdFromTransportId(transport_view_id)); | 466 const ServerView* view = GetView(ViewIdFromTransportId(transport_view_id)); |
| 465 bool success = node && access_policy_->CanEmbed(node); | 467 bool success = view && access_policy_->CanEmbed(view); |
| 466 if (success) { | 468 if (success) { |
| 467 // Only allow a node to be the root for one connection. | 469 // Only allow a view to be the root for one connection. |
| 468 const NodeId node_id(NodeIdFromTransportId(transport_view_id)); | 470 const ViewId view_id(ViewIdFromTransportId(transport_view_id)); |
| 469 ViewManagerServiceImpl* connection_by_url = | 471 ViewManagerServiceImpl* connection_by_url = |
| 470 root_node_manager_->GetConnectionByCreator(id_, url.To<std::string>()); | 472 connection_manager_->GetConnectionByCreator(id_, url.To<std::string>()); |
| 471 ViewManagerServiceImpl* connection_with_node_as_root = | 473 ViewManagerServiceImpl* connection_with_view_as_root = |
| 472 root_node_manager_->GetConnectionWithRoot(node_id); | 474 connection_manager_->GetConnectionWithRoot(view_id); |
| 473 if ((connection_by_url != connection_with_node_as_root || | 475 if ((connection_by_url != connection_with_view_as_root || |
| 474 (!connection_by_url && !connection_with_node_as_root)) && | 476 (!connection_by_url && !connection_with_view_as_root)) && |
| 475 (!connection_by_url || !connection_by_url->HasRoot(node_id))) { | 477 (!connection_by_url || !connection_by_url->HasRoot(view_id))) { |
| 476 RootNodeManager::ScopedChange change(this, root_node_manager_, true); | 478 ConnectionManager::ScopedChange change(this, connection_manager_, true); |
| 477 RemoveChildrenAsPartOfEmbed(node_id); | 479 RemoveChildrenAsPartOfEmbed(view_id); |
| 478 // Never message the originating connection. | 480 // Never message the originating connection. |
| 479 root_node_manager_->OnConnectionMessagedClient(id_); | 481 connection_manager_->OnConnectionMessagedClient(id_); |
| 480 if (connection_with_node_as_root) | 482 if (connection_with_view_as_root) |
| 481 connection_with_node_as_root->RemoveRoot(node_id); | 483 connection_with_view_as_root->RemoveRoot(view_id); |
| 482 if (connection_by_url) { | 484 if (connection_by_url) { |
| 483 connection_by_url->AddRoot(node_id, spir.Pass()); | 485 connection_by_url->AddRoot(view_id, spir.Pass()); |
| 484 } else { | 486 } else { |
| 485 root_node_manager_->Embed(id_, url, transport_view_id, spir.Pass()); | 487 connection_manager_->Embed(id_, url, transport_view_id, spir.Pass()); |
| 486 } | 488 } |
| 487 } else { | 489 } else { |
| 488 success = false; | 490 success = false; |
| 489 } | 491 } |
| 490 } | 492 } |
| 491 callback.Run(success); | 493 callback.Run(success); |
| 492 } | 494 } |
| 493 | 495 |
| 494 void ViewManagerServiceImpl::DispatchOnViewInputEvent(Id transport_view_id, | 496 void ViewManagerServiceImpl::DispatchOnViewInputEvent(Id transport_view_id, |
| 495 EventPtr event) { | 497 EventPtr event) { |
| 496 // We only allow the WM to dispatch events. At some point this function will | 498 // We only allow the WM to dispatch events. At some point this function will |
| 497 // move to a separate interface and the check can go away. | 499 // move to a separate interface and the check can go away. |
| 498 if (id_ != kWindowManagerConnection) | 500 if (id_ != kWindowManagerConnection) |
| 499 return; | 501 return; |
| 500 | 502 |
| 501 const NodeId node_id(NodeIdFromTransportId(transport_view_id)); | 503 const ViewId view_id(ViewIdFromTransportId(transport_view_id)); |
| 502 | 504 |
| 503 // If another app is embedded at this node, we forward the input event to the | 505 // If another app is embedded at this view, we forward the input event to the |
| 504 // embedded app, rather than the app that created the node. | 506 // embedded app, rather than the app that created the view. |
| 505 ViewManagerServiceImpl* connection = | 507 ViewManagerServiceImpl* connection = |
| 506 root_node_manager_->GetConnectionWithRoot(node_id); | 508 connection_manager_->GetConnectionWithRoot(view_id); |
| 507 if (!connection) | 509 if (!connection) |
| 508 connection = root_node_manager_->GetConnection(node_id.connection_id); | 510 connection = connection_manager_->GetConnection(view_id.connection_id); |
| 509 if (connection) { | 511 if (connection) { |
| 510 connection->client()->OnViewInputEvent( | 512 connection->client()->OnViewInputEvent( |
| 511 transport_view_id, | 513 transport_view_id, |
| 512 event.Pass(), | 514 event.Pass(), |
| 513 base::Bind(&base::DoNothing)); | 515 base::Bind(&base::DoNothing)); |
| 514 } | 516 } |
| 515 } | 517 } |
| 516 | 518 |
| 517 void ViewManagerServiceImpl::OnConnectionEstablished() { | 519 void ViewManagerServiceImpl::OnConnectionEstablished() { |
| 518 root_node_manager_->AddConnection(this); | 520 connection_manager_->AddConnection(this); |
| 519 | 521 |
| 520 std::vector<const Node*> to_send; | 522 std::vector<const ServerView*> to_send; |
| 521 for (NodeIdSet::const_iterator i = roots_.begin(); i != roots_.end(); ++i) | 523 for (ViewIdSet::const_iterator i = roots_.begin(); i != roots_.end(); ++i) |
| 522 GetUnknownNodesFrom(GetNode(NodeIdFromTransportId(*i)), &to_send); | 524 GetUnknownViewsFrom(GetView(ViewIdFromTransportId(*i)), &to_send); |
| 523 | 525 |
| 524 client()->OnEmbed(id_, creator_url_, NodeToViewData(to_send.front()), | 526 client()->OnEmbed(id_, |
| 527 creator_url_, |
| 528 ViewToViewData(to_send.front()), |
| 525 service_provider_.Pass()); | 529 service_provider_.Pass()); |
| 526 } | 530 } |
| 527 | 531 |
| 528 const base::hash_set<Id>& | 532 const base::hash_set<Id>& |
| 529 ViewManagerServiceImpl::GetRootsForAccessPolicy() const { | 533 ViewManagerServiceImpl::GetRootsForAccessPolicy() const { |
| 530 return roots_; | 534 return roots_; |
| 531 } | 535 } |
| 532 | 536 |
| 533 bool ViewManagerServiceImpl::IsNodeKnownForAccessPolicy( | 537 bool ViewManagerServiceImpl::IsViewKnownForAccessPolicy( |
| 534 const Node* node) const { | 538 const ServerView* view) const { |
| 535 return IsNodeKnown(node); | 539 return IsViewKnown(view); |
| 536 } | 540 } |
| 537 | 541 |
| 538 bool ViewManagerServiceImpl::IsNodeRootOfAnotherConnectionForAccessPolicy( | 542 bool ViewManagerServiceImpl::IsViewRootOfAnotherConnectionForAccessPolicy( |
| 539 const Node* node) const { | 543 const ServerView* view) const { |
| 540 ViewManagerServiceImpl* connection = | 544 ViewManagerServiceImpl* connection = |
| 541 root_node_manager_->GetConnectionWithRoot(node->id()); | 545 connection_manager_->GetConnectionWithRoot(view->id()); |
| 542 return connection && connection != this; | 546 return connection && connection != this; |
| 543 } | 547 } |
| 544 | 548 |
| 545 } // namespace service | 549 } // namespace service |
| 546 } // namespace mojo | 550 } // namespace mojo |
| OLD | NEW |