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

Not working in custom favicon directory scenario #297

Open
Kr1shna4garwal opened this issue Apr 26, 2024 · 8 comments
Open

Not working in custom favicon directory scenario #297

Kr1shna4garwal opened this issue Apr 26, 2024 · 8 comments
Labels
enhancement New feature or request good first issue Good for newcomers hacktoberfest

Comments

@Kr1shna4garwal
Copy link

Is your feature request related to a problem? Please describe.
Tool is really good, but it seems not working in some scenarios, like if a site has placed it's favicon.ico file in a directory (Example: http://example[.]com/images/favicon.ico), tool will miss out the favicon. So instead of statically requesting just favicon.ico, it is recommend to first locate the path of favicon.ico in the source and then request it.

Describe the solution you'd like
The Tool should grep for .ico extension in page source, and then request that path for catching actual favicon.ico file

@edoardottt
Copy link
Owner

Hi @Kr1shna4garwal , thanks for your contribution!

I thought about that, I was putting the effort in increasing the size of the database .
can you provide an example of URLs to test this functionality once implemented?

thanks

@Kr1shna4garwal
Copy link
Author

Hi @edoardottt,
I have one such example url: https://drata.com/images/favicon.ico
Current version is unable to fetch this favicon

@edoardottt
Copy link
Owner

Thanks :)
Do you have any advice on how to obtain html tag values? I'd like to avoid any regex et similia... I'd prefer parsing html and get an exact value.

@Kr1shna4garwal
Copy link
Author

Hello @edoardottt,

I'm not a Golang programmer, So I don't much knowledge in Go

But in general, I think steps should be:

  1. send a GET request to "/"
  2. parse it using golang html library
  3. Loop through each token -> extract the attribute's value if attribute's key is href
  4. Filter the results to match for .ico extension
  5. extract the value
  6. request the exact path
  7. Then do further processing with that

@edoardottt
Copy link
Owner

It may not the best solution. Now the tool performs 1 request per target. with that solution all of the targets will get 2 requests, resulting in double time and resources needed. If the vast majority of the domains use /favicon.ico, this is definitely not a good solution.

@Kr1shna4garwal
Copy link
Author

That's right, It maybe not the best solution but still we can implement it in different way!
Like we can first check for /favicon.ico (Primary option), If found it will process it (1 request). If not found, then it will make 2 requests (1st request to find .ico path in page source, then 2nd to request and process that favicon.ico path). This way I believe tool's efficiency and usefulness both will be maintained. Currently no favicon analysis tool is doing this job.

@edoardottt
Copy link
Owner

I agree @Kr1shna4garwal . I was thinking the same. issue prioritized:)

@edoardottt edoardottt pinned this issue Apr 28, 2024
@edoardottt edoardottt added enhancement New feature or request good first issue Good for newcomers hacktoberfest labels Oct 18, 2024
@edoardottt
Copy link
Owner

Like we can first check for /favicon.ico (Primary option), If found it will process it (1 request).
The doubt here is how we can check if the favicon is found? Maybe the content-type must be image/x-icon ?
I'm thinking if the second option would be the best in any case

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request good first issue Good for newcomers hacktoberfest
Projects
None yet
Development

No branches or pull requests

2 participants