// Copyright 2008, Google Inc. // All rights reserved. // // Redistribution and use in source and binary forms, with or without // modification, are permitted provided that the following conditions are // met: // // * Redistributions of source code must retain the above copyright // notice, this list of conditions and the following disclaimer. // * Redistributions in binary form must reproduce the above // copyright notice, this list of conditions and the following disclaimer // in the documentation and/or other materials provided with the // distribution. // * Neither the name of Google Inc. nor the names of its // contributors may be used to endorse or promote products derived from // this software without specific prior written permission. // // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. // // Thes file contains stuff that should be shared among projects that do some // special handling with ActiveX. #ifndef WEBKIT_ACTIVEX_SHIM_ACTIVEX_SHARED_H__ #define WEBKIT_ACTIVEX_SHIM_ACTIVEX_SHARED_H__ #include class GURL; namespace activex_shim { // Well known ActiveX control types that we may need to do special processing // to support them better. enum ActiveXTypes { ACTIVEX_GENERIC, ACTIVEX_FLASH, ACTIVEX_WMP, ACTIVEX_REALPLAYER, ACTIVEX_QUICKTIME, ACTIVEX_SHOCKWAVE, ACTIVEX_TESTCONTROL, // Internal test control. }; // Given a clsid, map it to ActiveXTypes. The given clsid must be in format // as: d27cdb6e-ae6d-11cf-96b8-444553540000. i.e. no {} at both ends, // no spaces, case insensitive. ActiveXTypes MapClassIdToType(const std::string& clsid); // Parse out the real clsid given from a classid attribute of an object tag. // the classid string should be in format as: // clsid:XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX bool GetClsidFromClassidAttribute(const std::string& classid, std::string* clsid); // Get version string from codebase attribute of an object tag. e.g.: // codebase="https://site.cmbchina.com/download/CMBEdit.cab#version=1,2,0,1", // then we will return "1,2,0,1". if the version part doesn't exist, // returns empty string. std::string GetVersionFromCodebaseAttribute(const std::string& codebase); // Look up the registry to see if ActiveX is installed. Here clsid could be just // clsid, e.g. "0CA54D3F-CEAE-48AF-9A2B-31909CB9515D". Or it could be combined // with a version string comes from the codebase: // "0CA54D3F-CEAE-48AF-9A2B-31909CB9515D#1,2,0,1". In the latter case, we need // to look up the version info of the dll to see if it meets the version // requirement. bool IsActiveXInstalled(const std::string& combined_clsid); // If an ActiveX control is allowed to run from a specific URL. bool IsActiveXAllowed(const std::string& clsid, const GURL& url); // If an ActiveX control's codebase comes from allowed websites. bool IsCodebaseAllowed(const std::string& clsid, const std::string& codebase); // Check If a given mimetype is of "application/x-oleobject" or // "application/oleobject" bool IsMimeTypeActiveX(const std::string& mimetype); } // namespace activex_shim #endif // #ifndef WEBKIT_ACTIVEX_SHIM_ACTIVEX_SHARED_H__