This source file includes following definitions.
- createForPage
- createForWorker
- m_inspectedStateAccessCheck
- disconnect
- injectedScriptHost
- injectedScriptForId
- injectedScriptIdFor
- injectedScriptForObjectId
- discardInjectedScripts
- discardInjectedScriptsFor
- canAccessInspectedWorkerGlobalScope
- releaseObjectGroup
- injectedScriptSource
- injectedScriptFor
#include "config.h"
#include "core/inspector/InjectedScriptManager.h"
#include "InjectedScriptSource.h"
#include "bindings/v8/ScriptObject.h"
#include "core/inspector/InjectedScript.h"
#include "core/inspector/InjectedScriptHost.h"
#include "core/inspector/JSONParser.h"
#include "platform/JSONValues.h"
#include "wtf/PassOwnPtr.h"
namespace WebCore {
PassOwnPtr<InjectedScriptManager> InjectedScriptManager::createForPage()
{
return adoptPtr(new InjectedScriptManager(&InjectedScriptManager::canAccessInspectedWindow));
}
PassOwnPtr<InjectedScriptManager> InjectedScriptManager::createForWorker()
{
return adoptPtr(new InjectedScriptManager(&InjectedScriptManager::canAccessInspectedWorkerGlobalScope));
}
InjectedScriptManager::InjectedScriptManager(InspectedStateAccessCheck accessCheck)
: m_nextInjectedScriptId(1)
, m_injectedScriptHost(InjectedScriptHost::create())
, m_inspectedStateAccessCheck(accessCheck)
{
}
InjectedScriptManager::~InjectedScriptManager()
{
}
void InjectedScriptManager::disconnect()
{
m_injectedScriptHost->disconnect();
m_injectedScriptHost.clear();
}
InjectedScriptHost* InjectedScriptManager::injectedScriptHost()
{
return m_injectedScriptHost.get();
}
InjectedScript InjectedScriptManager::injectedScriptForId(int id)
{
IdToInjectedScriptMap::iterator it = m_idToInjectedScript.find(id);
if (it != m_idToInjectedScript.end())
return it->value;
for (ScriptStateToId::iterator it = m_scriptStateToId.begin(); it != m_scriptStateToId.end(); ++it) {
if (it->value == id)
return injectedScriptFor(it->key);
}
return InjectedScript();
}
int InjectedScriptManager::injectedScriptIdFor(ScriptState* scriptState)
{
ScriptStateToId::iterator it = m_scriptStateToId.find(scriptState);
if (it != m_scriptStateToId.end())
return it->value;
int id = m_nextInjectedScriptId++;
m_scriptStateToId.set(scriptState, id);
return id;
}
InjectedScript InjectedScriptManager::injectedScriptForObjectId(const String& objectId)
{
RefPtr<JSONValue> parsedObjectId = parseJSON(objectId);
if (parsedObjectId && parsedObjectId->type() == JSONValue::TypeObject) {
long injectedScriptId = 0;
bool success = parsedObjectId->asObject()->getNumber("injectedScriptId", &injectedScriptId);
if (success)
return m_idToInjectedScript.get(injectedScriptId);
}
return InjectedScript();
}
void InjectedScriptManager::discardInjectedScripts()
{
m_idToInjectedScript.clear();
m_scriptStateToId.clear();
}
void InjectedScriptManager::discardInjectedScriptsFor(DOMWindow* window)
{
if (m_scriptStateToId.isEmpty())
return;
Vector<long> idsToRemove;
IdToInjectedScriptMap::iterator end = m_idToInjectedScript.end();
for (IdToInjectedScriptMap::iterator it = m_idToInjectedScript.begin(); it != end; ++it) {
ScriptState* scriptState = it->value.scriptState();
if (window != scriptState->domWindow())
continue;
m_scriptStateToId.remove(scriptState);
idsToRemove.append(it->key);
}
for (size_t i = 0; i < idsToRemove.size(); i++)
m_idToInjectedScript.remove(idsToRemove[i]);
Vector<ScriptState*> scriptStatesToRemove;
for (ScriptStateToId::iterator it = m_scriptStateToId.begin(); it != m_scriptStateToId.end(); ++it) {
ScriptState* scriptState = it->key;
if (window == scriptState->domWindow())
scriptStatesToRemove.append(scriptState);
}
for (size_t i = 0; i < scriptStatesToRemove.size(); i++)
m_scriptStateToId.remove(scriptStatesToRemove[i]);
}
bool InjectedScriptManager::canAccessInspectedWorkerGlobalScope(ScriptState*)
{
return true;
}
void InjectedScriptManager::releaseObjectGroup(const String& objectGroup)
{
Vector<int> keys;
keys.appendRange(m_idToInjectedScript.keys().begin(), m_idToInjectedScript.keys().end());
for (Vector<int>::iterator k = keys.begin(); k != keys.end(); ++k) {
IdToInjectedScriptMap::iterator s = m_idToInjectedScript.find(*k);
if (s != m_idToInjectedScript.end())
s->value.releaseObjectGroup(objectGroup);
}
}
String InjectedScriptManager::injectedScriptSource()
{
return String(reinterpret_cast<const char*>(InjectedScriptSource_js), sizeof(InjectedScriptSource_js));
}
InjectedScript InjectedScriptManager::injectedScriptFor(ScriptState* inspectedScriptState)
{
ScriptStateToId::iterator it = m_scriptStateToId.find(inspectedScriptState);
if (it != m_scriptStateToId.end()) {
IdToInjectedScriptMap::iterator it1 = m_idToInjectedScript.find(it->value);
if (it1 != m_idToInjectedScript.end())
return it1->value;
}
if (!m_inspectedStateAccessCheck(inspectedScriptState))
return InjectedScript();
int id = injectedScriptIdFor(inspectedScriptState);
ScriptObject injectedScriptObject = createInjectedScript(injectedScriptSource(), inspectedScriptState, id);
InjectedScript result(injectedScriptObject, m_inspectedStateAccessCheck);
m_idToInjectedScript.set(id, result);
return result;
}
}