Skip to content

Commit

Permalink
fix: ignore base64 encoded src attributes
Browse files Browse the repository at this point in the history
  • Loading branch information
fczbkk committed Oct 24, 2024
1 parent 3262864 commit 68859e9
Show file tree
Hide file tree
Showing 2 changed files with 15 additions and 3 deletions.
11 changes: 8 additions & 3 deletions src/selector-attribute.ts
Original file line number Diff line number Diff line change
Expand Up @@ -35,10 +35,10 @@ export function attributeNodeToSelector({
}

/**
* Checks whether attribute should be used as a selector.
* Checks whether an attribute should be used as a selector.
*/
export function isValidAttributeNode(
{ nodeName }: Node,
{ nodeName, nodeValue }: Node,
element: Element,
): boolean {
// form input value should not be used as a selector
Expand All @@ -47,6 +47,11 @@ export function isValidAttributeNode(
return false;
}

// ignore Base64-encoded strings as 'src' attribute values (e.g. in tags like img, audio, video, iframe, object, embed).
if (nodeName === "src" && nodeValue?.startsWith("data:")) {
return false;
}

return !attributeBlacklistMatch(nodeName);
}

Expand All @@ -56,7 +61,7 @@ export function isValidAttributeNode(
function sanitizeAttributeData({ nodeName, nodeValue }: Node): AttributeData {
return {
name: sanitizeSelectorItem(nodeName),
value: sanitizeSelectorItem(nodeValue),
value: sanitizeSelectorItem(nodeValue ?? undefined),
};
}

Expand Down
7 changes: 7 additions & 0 deletions test/selector-attribute.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -130,4 +130,11 @@ describe("selector - attribute", function () {
assert.equal(document.querySelector(selector), element);
});
});

it("should ignore base64 encoded 'src' attribute values", () => {
root.innerHTML =
'<img src="" />';
const result = getAttributeSelectors([root.firstElementChild]);
assert.sameMembers(result, []);
});
});

0 comments on commit 68859e9

Please sign in to comment.