Home | History | Annotate | Download | only in shared_impl
      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.
      4 
      5 #include "ppapi/shared_impl/ppb_instance_shared.h"
      6 
      7 #include <string>
      8 
      9 #include "base/debug/trace_event.h"
     10 #include "base/threading/platform_thread.h"
     11 #include "ppapi/c/pp_errors.h"
     12 #include "ppapi/c/ppb_input_event.h"
     13 #include "ppapi/shared_impl/ppapi_globals.h"
     14 #include "ppapi/shared_impl/ppb_image_data_shared.h"
     15 #include "ppapi/shared_impl/var.h"
     16 #include "ppapi/thunk/enter.h"
     17 #include "ppapi/thunk/ppb_image_data_api.h"
     18 
     19 namespace ppapi {
     20 
     21 // static
     22 const int PPB_Instance_Shared::kExtraCharsForTextInput = 100;
     23 
     24 PPB_Instance_Shared::~PPB_Instance_Shared() {
     25 }
     26 
     27 void PPB_Instance_Shared::Log(PP_Instance instance,
     28                               PP_LogLevel level,
     29                               PP_Var value) {
     30   LogWithSource(instance, level, PP_MakeUndefined(), value);
     31 }
     32 
     33 void PPB_Instance_Shared::LogWithSource(PP_Instance instance,
     34                                         PP_LogLevel level,
     35                                         PP_Var source,
     36                                         PP_Var value) {
     37   // The source defaults to empty if it's not a string. The PpapiGlobals
     38   // implementation will convert the empty string to the module name if
     39   // possible.
     40   std::string source_str;
     41   if (source.type == PP_VARTYPE_STRING)
     42     source_str = Var::PPVarToLogString(source);
     43   std::string value_str = Var::PPVarToLogString(value);
     44   PpapiGlobals::Get()->LogWithSource(instance, level, source_str, value_str);
     45 }
     46 
     47 int32_t PPB_Instance_Shared::ValidateRequestInputEvents(
     48     bool is_filtering,
     49     uint32_t event_classes) {
     50   // See if any bits are set we don't know about.
     51   if (event_classes &
     52       ~static_cast<uint32_t>(PP_INPUTEVENT_CLASS_MOUSE |
     53                              PP_INPUTEVENT_CLASS_KEYBOARD |
     54                              PP_INPUTEVENT_CLASS_WHEEL |
     55                              PP_INPUTEVENT_CLASS_TOUCH |
     56                              PP_INPUTEVENT_CLASS_IME))
     57     return PP_ERROR_NOTSUPPORTED;
     58 
     59   // Everything else is valid.
     60   return PP_OK;
     61 }
     62 
     63 bool PPB_Instance_Shared::ValidateSetCursorParams(PP_MouseCursor_Type type,
     64                                                   PP_Resource image,
     65                                                   const PP_Point* hot_spot) {
     66   if (static_cast<int>(type) < static_cast<int>(PP_MOUSECURSOR_TYPE_CUSTOM) ||
     67       static_cast<int>(type) > static_cast<int>(PP_MOUSECURSOR_TYPE_GRABBING))
     68     return false;  // Cursor type out of range.
     69   if (type != PP_MOUSECURSOR_TYPE_CUSTOM) {
     70     // The image must not be specified if the type isn't custom. However, we
     71     // don't require that the hot spot be null since the C++ wrappers and proxy
     72     // pass the point by reference and it will normally be specified.
     73     return image == 0;
     74   }
     75 
     76   if (!hot_spot)
     77     return false;  // Hot spot must be specified for custom cursor.
     78 
     79   thunk::EnterResourceNoLock<thunk::PPB_ImageData_API> enter(image, true);
     80   if (enter.failed())
     81     return false;  // Invalid image resource.
     82 
     83   // Validate the image size. A giant cursor can arbitrarily overwrite parts
     84   // of the screen resulting in potential spoofing attacks. So we force the
     85   // cursor to be a reasonably-sized image.
     86   PP_ImageDataDesc desc;
     87   if (!PP_ToBool(enter.object()->Describe(&desc)))
     88     return false;
     89   if (desc.size.width > 32 || desc.size.height > 32)
     90     return false;
     91 
     92   // Validate image format.
     93   if (desc.format != PPB_ImageData_Shared::GetNativeImageDataFormat())
     94     return false;
     95 
     96   // Validate the hot spot location.
     97   if (hot_spot->x < 0 || hot_spot->x >= desc.size.width ||
     98       hot_spot->y < 0 || hot_spot->y >= desc.size.height)
     99     return false;
    100   return true;
    101 }
    102 
    103 }  // namespace ppapi
    104