244 lines
9.6 KiB
JavaScript
244 lines
9.6 KiB
JavaScript
/*
|
|
* Copyright (C) 2013, 2016 Apple 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:
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
* notice, this list of conditions and the following disclaimer.
|
|
* 2. 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.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS 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 APPLE INC. OR ITS 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.
|
|
*/
|
|
|
|
WI.IssueMessage = class IssueMessage extends WI.Object
|
|
{
|
|
constructor(consoleMessage)
|
|
{
|
|
super();
|
|
|
|
console.assert(consoleMessage instanceof WI.ConsoleMessage);
|
|
|
|
this._consoleMessage = consoleMessage;
|
|
|
|
this._text = this._issueText();
|
|
|
|
switch (this._consoleMessage.source) {
|
|
case WI.ConsoleMessage.MessageSource.JS:
|
|
// FIXME: It would be nice if we had this information (the specific type of JavaScript error)
|
|
// as part of the data passed from WebCore, instead of having to determine it ourselves.
|
|
var prefixRegex = /^([^:]+): (?:DOM Exception \d+: )?/;
|
|
var match = prefixRegex.exec(this._text);
|
|
if (match && match[1] in WI.IssueMessage.Type._prefixTypeMap) {
|
|
this._type = WI.IssueMessage.Type._prefixTypeMap[match[1]];
|
|
this._text = this._text.substring(match[0].length);
|
|
} else
|
|
this._type = WI.IssueMessage.Type.OtherIssue;
|
|
break;
|
|
|
|
case WI.ConsoleMessage.MessageSource.CSS:
|
|
case WI.ConsoleMessage.MessageSource.XML:
|
|
this._type = WI.IssueMessage.Type.PageIssue;
|
|
break;
|
|
|
|
case WI.ConsoleMessage.MessageSource.Network:
|
|
this._type = WI.IssueMessage.Type.NetworkIssue;
|
|
break;
|
|
|
|
case WI.ConsoleMessage.MessageSource.Security:
|
|
this._type = WI.IssueMessage.Type.SecurityIssue;
|
|
break;
|
|
|
|
case WI.ConsoleMessage.MessageSource.ConsoleAPI:
|
|
case WI.ConsoleMessage.MessageSource.Storage:
|
|
case WI.ConsoleMessage.MessageSource.Appcache:
|
|
case WI.ConsoleMessage.MessageSource.Rendering:
|
|
case WI.ConsoleMessage.MessageSource.Media:
|
|
case WI.ConsoleMessage.MessageSource.Mediasource:
|
|
case WI.ConsoleMessage.MessageSource.WebRTC:
|
|
case WI.ConsoleMessage.MessageSource.ITPDebug:
|
|
case WI.ConsoleMessage.MessageSource.PrivateClickMeasurement:
|
|
case WI.ConsoleMessage.MessageSource.PaymentRequest:
|
|
case WI.ConsoleMessage.MessageSource.AdClickAttribution: // COMPATIBILITY (iOS 14.0): `Console.ChannelSource.AdClickAttribution` was renamed to `Console.ChannelSource.PrivateClickMeasurement`.
|
|
case WI.ConsoleMessage.MessageSource.Other:
|
|
this._type = WI.IssueMessage.Type.OtherIssue;
|
|
break;
|
|
|
|
default:
|
|
console.error("Unknown issue source:", this._consoleMessage.source);
|
|
this._type = WI.IssueMessage.Type.OtherIssue;
|
|
}
|
|
|
|
this._sourceCodeLocation = consoleMessage.sourceCodeLocation;
|
|
if (this._sourceCodeLocation)
|
|
this._sourceCodeLocation.addEventListener(WI.SourceCodeLocation.Event.DisplayLocationChanged, this._sourceCodeLocationDisplayLocationChanged, this);
|
|
}
|
|
|
|
// Static
|
|
|
|
static displayName(type)
|
|
{
|
|
switch (type) {
|
|
case WI.IssueMessage.Type.SemanticIssue:
|
|
return WI.UIString("Semantic Issue");
|
|
case WI.IssueMessage.Type.RangeIssue:
|
|
return WI.UIString("Range Issue");
|
|
case WI.IssueMessage.Type.ReferenceIssue:
|
|
return WI.UIString("Reference Issue");
|
|
case WI.IssueMessage.Type.TypeIssue:
|
|
return WI.UIString("Type Issue");
|
|
case WI.IssueMessage.Type.PageIssue:
|
|
return WI.UIString("Page Issue");
|
|
case WI.IssueMessage.Type.NetworkIssue:
|
|
return WI.UIString("Network Issue");
|
|
case WI.IssueMessage.Type.SecurityIssue:
|
|
return WI.UIString("Security Issue");
|
|
case WI.IssueMessage.Type.OtherIssue:
|
|
return WI.UIString("Other Issue");
|
|
default:
|
|
console.error("Unknown issue message type:", type);
|
|
return WI.UIString("Other Issue");
|
|
}
|
|
}
|
|
|
|
// Public
|
|
|
|
get text() { return this._text; }
|
|
get type() { return this._type; }
|
|
get level() { return this._consoleMessage.level; }
|
|
get source() { return this._consoleMessage.source; }
|
|
get url() { return this._consoleMessage.url; }
|
|
get sourceCodeLocation() { return this._sourceCodeLocation; }
|
|
|
|
// Protected
|
|
|
|
saveIdentityToCookie(cookie)
|
|
{
|
|
cookie[WI.IssueMessage.URLCookieKey] = this.url;
|
|
cookie[WI.IssueMessage.LineNumberCookieKey] = this._sourceCodeLocation ? this._sourceCodeLocation.lineNumber : 0;
|
|
cookie[WI.IssueMessage.ColumnNumberCookieKey] = this._sourceCodeLocation ? this._sourceCodeLocation.columnNumber : 0;
|
|
}
|
|
|
|
// Private
|
|
|
|
_issueText()
|
|
{
|
|
let parameters = this._consoleMessage.parameters;
|
|
if (!parameters)
|
|
return this._consoleMessage.messageText;
|
|
|
|
if (parameters[0].type !== "string")
|
|
return this._consoleMessage.messageText;
|
|
|
|
function valueFormatter(obj)
|
|
{
|
|
return obj.description;
|
|
}
|
|
|
|
let formatters = {};
|
|
formatters.o = valueFormatter;
|
|
formatters.s = valueFormatter;
|
|
formatters.f = valueFormatter;
|
|
formatters.i = valueFormatter;
|
|
formatters.d = valueFormatter;
|
|
|
|
function append(a, b)
|
|
{
|
|
a += b;
|
|
return a;
|
|
}
|
|
|
|
let result = String.format(parameters[0].description, parameters.slice(1), formatters, "", append);
|
|
let resultText = result.formattedResult;
|
|
|
|
for (let i = 0; i < result.unusedSubstitutions.length; ++i)
|
|
resultText += " " + result.unusedSubstitutions[i].description;
|
|
|
|
return resultText;
|
|
}
|
|
|
|
_sourceCodeLocationDisplayLocationChanged(event)
|
|
{
|
|
this.dispatchEventToListeners(WI.IssueMessage.Event.DisplayLocationDidChange, event.data);
|
|
}
|
|
};
|
|
|
|
WI.IssueMessage.Level = {
|
|
Error: "error",
|
|
Warning: "warning"
|
|
};
|
|
|
|
WI.IssueMessage.Type = {
|
|
SemanticIssue: "issue-message-type-semantic-issue",
|
|
RangeIssue: "issue-message-type-range-issue",
|
|
ReferenceIssue: "issue-message-type-reference-issue",
|
|
TypeIssue: "issue-message-type-type-issue",
|
|
PageIssue: "issue-message-type-page-issue",
|
|
NetworkIssue: "issue-message-type-network-issue",
|
|
SecurityIssue: "issue-message-type-security-issue",
|
|
OtherIssue: "issue-message-type-other-issue"
|
|
};
|
|
|
|
WI.IssueMessage.TypeIdentifier = "issue-message";
|
|
WI.IssueMessage.URLCookieKey = "issue-message-url";
|
|
WI.IssueMessage.LineNumberCookieKey = "issue-message-line-number";
|
|
WI.IssueMessage.ColumnNumberCookieKey = "issue-message-column-number";
|
|
|
|
WI.IssueMessage.Event = {
|
|
LocationDidChange: "issue-message-location-did-change",
|
|
DisplayLocationDidChange: "issue-message-display-location-did-change"
|
|
};
|
|
|
|
WI.IssueMessage.Type._prefixTypeMap = {
|
|
"SyntaxError": WI.IssueMessage.Type.SemanticIssue,
|
|
"URIError": WI.IssueMessage.Type.SemanticIssue,
|
|
"AggregateError": WI.IssueMessage.Type.SemanticIssue,
|
|
"EvalError": WI.IssueMessage.Type.SemanticIssue,
|
|
"INVALID_CHARACTER_ERR": WI.IssueMessage.Type.SemanticIssue,
|
|
"SYNTAX_ERR": WI.IssueMessage.Type.SemanticIssue,
|
|
|
|
"RangeError": WI.IssueMessage.Type.RangeIssue,
|
|
"INDEX_SIZE_ERR": WI.IssueMessage.Type.RangeIssue,
|
|
"DOMSTRING_SIZE_ERR": WI.IssueMessage.Type.RangeIssue,
|
|
|
|
"ReferenceError": WI.IssueMessage.Type.ReferenceIssue,
|
|
"HIERARCHY_REQUEST_ERR": WI.IssueMessage.Type.ReferenceIssue,
|
|
"INVALID_STATE_ERR": WI.IssueMessage.Type.ReferenceIssue,
|
|
"NOT_FOUND_ERR": WI.IssueMessage.Type.ReferenceIssue,
|
|
"WRONG_DOCUMENT_ERR": WI.IssueMessage.Type.ReferenceIssue,
|
|
|
|
"TypeError": WI.IssueMessage.Type.TypeIssue,
|
|
"INVALID_NODE_TYPE_ERR": WI.IssueMessage.Type.TypeIssue,
|
|
"TYPE_MISMATCH_ERR": WI.IssueMessage.Type.TypeIssue,
|
|
|
|
"SECURITY_ERR": WI.IssueMessage.Type.SecurityIssue,
|
|
|
|
"NETWORK_ERR": WI.IssueMessage.Type.NetworkIssue,
|
|
|
|
"ABORT_ERR": WI.IssueMessage.Type.OtherIssue,
|
|
"DATA_CLONE_ERR": WI.IssueMessage.Type.OtherIssue,
|
|
"INUSE_ATTRIBUTE_ERR": WI.IssueMessage.Type.OtherIssue,
|
|
"INVALID_ACCESS_ERR": WI.IssueMessage.Type.OtherIssue,
|
|
"INVALID_MODIFICATION_ERR": WI.IssueMessage.Type.OtherIssue,
|
|
"NAMESPACE_ERR": WI.IssueMessage.Type.OtherIssue,
|
|
"NOT_SUPPORTED_ERR": WI.IssueMessage.Type.OtherIssue,
|
|
"NO_DATA_ALLOWED_ERR": WI.IssueMessage.Type.OtherIssue,
|
|
"NO_MODIFICATION_ALLOWED_ERR": WI.IssueMessage.Type.OtherIssue,
|
|
"QUOTA_EXCEEDED_ERR": WI.IssueMessage.Type.OtherIssue,
|
|
"TIMEOUT_ERR": WI.IssueMessage.Type.OtherIssue,
|
|
"URL_MISMATCH_ERR": WI.IssueMessage.Type.OtherIssue,
|
|
"VALIDATION_ERR": WI.IssueMessage.Type.OtherIssue
|
|
};
|