1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
|
// Copyright (c) 2006-2008 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.
//
// 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 <string>
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__
|