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

Too many reports received (startDate and/or endDate ignored?) #7

Open
olivluca opened this issue Aug 18, 2022 · 27 comments
Open

Too many reports received (startDate and/or endDate ignored?) #7

olivluca opened this issue Aug 18, 2022 · 27 comments
Labels

Comments

@olivluca
Copy link
Contributor

olivluca commented Aug 18, 2022

No matter the value I put in startDate (I first removed the *7 to get just one day, then I tried 3600000, i.e. an hour) I seem to receive always all the reports.
(I mean, I changed

data = '{"search": [{"endDate": %d, "startDate": %d, "ids": %s}]}' % (unixEpoch *1000, (unixEpoch *1000) -(86400000 *7), ids.keys())

first to

data = '{"search": [{"endDate": %d, "startDate": %d, "ids": %s}]}' % (unixEpoch *1000, (unixEpoch *1000) -(86400000), ids.keys())

then to

data = '{"search": [{"endDate": %d, "startDate": %d, "ids": %s}]}' % (unixEpoch *1000, (unixEpoch *1000) -3600000, ids.keys())
)

I don't know if it's a problem with apple servers or the parameters aren't properly formatted, I checked and apparently it's the same format used in the mobile application of openhaystack.

@biemster
Copy link
Owner

Odd stuff. I never tinkered with this, but I noticed now receiving reports from 12 days ago with these default values.

@olivluca
Copy link
Contributor Author

Well, no matter what I put in startDate and endDate (I tried using cocoa timestamps instead of unix timestamps, seconds instead of microseconds, nanoseconds instead of seconds, 0, etc.) I always get back all the available reports.

@biemster
Copy link
Owner

Leaving them out completely will result in a lot less reports (40 for me atm)..

@olivluca
Copy link
Contributor Author

I think I tried that too, let me check....

@biemster
Copy link
Owner

it's actually max 20 per tag if you leave out the date fields I see now. In my last test there were 2 tags with reports.
So it seems that with the fields it returns max 2000 reports per hash, without the fields 20.

@olivluca
Copy link
Contributor Author

Mmh, 2383 reports received with StartDate/EndDate, 1688 without.
I have 100 virtual tags.
Also, the filtering isn't working right: I requested reports with -H 1 and the first one is from 3 days ago.

@biemster
Copy link
Owner

Are there any tags in your batch of 100 that have more than 20 reports, when calling without the startDate/endDate?

@olivluca
Copy link
Contributor Author

Scratch that, my virtual mac still thinks it's monday 😉

@olivluca
Copy link
Contributor Author

Since I rotate the key every hour usually I get far less than 20 reports per tag.

@olivluca
Copy link
Contributor Author

In any case the StartDate/EndDate values must be wrong, since even with those present I get many reports before the StartDate

@olivluca
Copy link
Contributor Author

i.e., now that my mac is on the correct time, with -H 1 I (and StartDate/EndDate) I get 2380 reports, 0 used (my tag has been off since yesterday night).

@biemster
Copy link
Owner

Yeah it's about time the OpenHaystack people came back to work, the academic year started two weeks ago lazy bums. @dakhnod asked there as well a while ago seemoo-lab/openhaystack#137 but they don't seem to have answered to issues all summer.

@olivluca
Copy link
Contributor Author

I tried:

  • formating the StartDate as isodatetime
  • as YYYYMMDDHHNNSS
  • as a raw unix timestampo
  • as the same multiplied by 1000000
  • multiplied by 1000000000
  • multiplied by 1000000000000

and I always get the same number of reports and they are more than if I leave the StartDate field out altogether.
I also left out the EndDate, guessing that if it isn't there it should give you until the last report received.

@olivluca
Copy link
Contributor Author

If I'm looking at the right file file it seems that openhaystack is using a unix timestamp multiplied by 1000 (I don't know if the format modifier %lli adds some zeroes), I tried it too (the "1000" multiplier was missing from my last round of tests) but the result is the same.
In any case what they do there doesn't make much sense, since they're using the current timestamp as the startDate and a timestamp in the future as endDate (and, yes, I also tried that).

@biemster
Copy link
Owner

In any case what they do there doesn't make much sense, since they're using the current timestamp as the startDate and a timestamp in the future as endDate (and, yes, I also tried that).

Haha well spotted, that does not make much sense indeed..

@dakhnod
Copy link

dakhnod commented Sep 16, 2022

Please don't forget that apple is using 1.1.2001 as second 0 for some timestamps in the AirTags

@olivluca
Copy link
Contributor Author

olivluca commented Sep 16, 2022

Yes, that's taken into account by using 978307200 at various places in request_reports.py, but that code in OpenHaystack is using timeIntervalSince1970 (due to the results and the fact that they inverted startDate and endDate I wouldn't trust it too much).

@dakhnod
Copy link

dakhnod commented Dec 3, 2022

Is there something like a limit parameter? So something like limit=1 only gives one report max?

Also, is there a limit to how many hashes we can request per request?

@biemster
Copy link
Owner

biemster commented Dec 3, 2022

I don't know of a limit parameter or anything besides what the OpenHaystack people found.
And I seem to remember there was a hash count limit of 256 but I can't find the source of that anymore. But this is easy to check of course with the request_reports script, I might do that once.

@davesenior9
Copy link

Thanks mate. Apologies for the double up.

@biemster
Copy link
Owner

The startDate and endDate now seem to be interpreted by the apple servers, I need to do a bit of follow up research if it now works as expected.

@dakhnod
Copy link

dakhnod commented Aug 17, 2023

@biemster damn, that's big. I'll test it out.

@biemster
Copy link
Owner

Allright I jumped the gun here a bit. I noticed that "startDate": 0, "endDate": 0 gave me only the last 20 reports per tag now, while it used to give me everything they had. So I started typing two new dates to give me 10 days of reports, and that worked! All reports since August 8!
So without checking I assumed that that's how it works now, but in a more truer sense it just gives me all those reports, no matter what dates I give. As long as it is not two zeros..
sorry for the noise @dakhnod , I hope I did not get you too excited.

@smierd
Copy link

smierd commented Jan 25, 2024

Has anyone made progress on this? Right now with only 3 tags I'm getting around ~3000 reports per query when I'm only searching for a few. I'm worried about requesting too much and getting blocked. Has anyone had issues with too many queries?

@Itheras
Copy link

Itheras commented Feb 15, 2024

Has anyone made progress on this? Right now with only 3 tags I'm getting around ~3000 reports per query when I'm only searching for a few. I'm worried about requesting too much and getting blocked. Has anyone had issues with too many queries?

Just remove start and end date you will get the newest 20.

@aircable
Copy link

aircable commented Apr 8, 2024

@biemster

So I started typing two new dates to give me 10 days of reports, and that worked!

I could not figure out what the new syntax for the start-endDate is you were trying. Can you please elaborate?
For now, I always get one week of data, not 10 days.

@biemster
Copy link
Owner

biemster commented Apr 9, 2024

@aircable if I remember correctly I just tried what's already in the current code (maybe switched to seconds, or microseconds, or that weird Cocoa epoch), that's all. It was just a red herring, didn't work.

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

No branches or pull requests

7 participants