/* * 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 };