Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

How can I match a fingerprint against HTML body? #469

Open
szvvo opened this issue Jul 27, 2022 · 5 comments
Open

How can I match a fingerprint against HTML body? #469

szvvo opened this issue Jul 27, 2022 · 5 comments

Comments

@szvvo
Copy link

szvvo commented Jul 27, 2022

As the question states. is there any way to match against an HTML body.

Can I use something like this? :

<fingerprints matches="html_body" protocol="http" database_type="service" preference="0.90">`

@mkienow-r7
Copy link
Contributor

@stoneface919 We do not currently have a database for matching against HTML bodies. Regular expressions are not ideal here. We have plans to explore XPath based solutions in the future.

@szvvo
Copy link
Author

szvvo commented Jul 27, 2022

I see now thank you for your reply. Do you happen to know if this recog is being used on InsightVM?

@mkienow-r7
Copy link
Contributor

Yes, recog is in use in InsightVM. Checkout this older blog post, Self-Isolation, Home Networking, and Open Source: Recog and Rumble, which mentioned this detail and other products using the recog project!

@jvoisin
Copy link
Contributor

jvoisin commented Jan 8, 2024

XPath wouldn't be able to match things like this:

<script type="text/javascript">//<![CDATA[
        FbxConf = {};
        FbxConf.apiBaseUrl = '/api/latest/';
        FbxConf.uploadBaseUrl = '/api/latest/upload/';
        FbxConf.websocketBaseUrl =
            (document.location.protocol == "https:" ? "wss://" : "ws://") +
            document.location.host + '/api/latest/ws/';
        FbxConf.csrfToken = '';
        FbxConf.firmwareVersionMajor = '4';
        FbxConf.firmwareVersionMinor = '7';
        // […]
//]]></script>

it's from the landing page of a freebox, leaking its major and minor version.

@dabdine
Copy link
Contributor

dabdine commented Apr 24, 2024

XPath wouldn't be able to match things like this:

<script type="text/javascript">//<![CDATA[
        FbxConf = {};
        FbxConf.apiBaseUrl = '/api/latest/';
        FbxConf.uploadBaseUrl = '/api/latest/upload/';
        FbxConf.websocketBaseUrl =
            (document.location.protocol == "https:" ? "wss://" : "ws://") +
            document.location.host + '/api/latest/ws/';
        FbxConf.csrfToken = '';
        FbxConf.firmwareVersionMajor = '4';
        FbxConf.firmwareVersionMinor = '7';
        // […]
//]]></script>

it's from the landing page of a freebox, leaking its major and minor version.

XPath could be useful for filtering the document before passing it to a pattern for evaluation. Something like:

<fingerprint pattern="FbxConf.firmwareVersionMajor = '(\d+)'\s+FbxConf.firmwareVersionMinor = '(\d+)'" flags="REG_MULTILINE">
  <content-filter xpath="//script[@type='text/javascript']"/>
  <description>Freebox...</description>
  <example><![CDATA[
      <script type="text/javascript">
              FbxConf = {};
              FbxConf.apiBaseUrl = '/api/latest/';
              FbxConf.uploadBaseUrl = '/api/latest/upload/';
              FbxConf.websocketBaseUrl =
                  (document.location.protocol == "https:" ? "wss://" : "ws://") +
                  document.location.host + '/api/latest/ws/';
              FbxConf.csrfToken = '';
              FbxConf.firmwareVersionMajor = '4';
              FbxConf.firmwareVersionMinor = '7';
              // […]
      </script>
    ]]>
  </example>
  <param pos="1" name="ver.maj"/>
  <param pos="2" name="ver.min"/>
  <param pos="0" name="service.version" value="{ver.maj}.{ver.min}" />
</fingerprint>

Then evaluate any input HTML doc against the content-filter. For each Xpath match, run the pattern, maybe bailing after the first pattern match. Interesting in that it could be helpful to avoid matching over the entire document...

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

4 participants