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

Add ability to download popularity data for a given time frame #58

Closed
mutebat39 opened this issue May 15, 2020 · 2 comments
Closed

Add ability to download popularity data for a given time frame #58

mutebat39 opened this issue May 15, 2020 · 2 comments
Assignees
Labels

Comments

@mutebat39
Copy link

It would be nice if the popularity_history (and I suppose popularity_history_csv) API endpoint(s) supported the ability to return only data points in a given time frame (ex., "get me popularity data for TSLA between 2020-03-01 and 2020-03-06"). Currently, as far as I can tell from the source code, this endpoint only supports fetching the entire popularity history for a ticker (which for many tickers is years worth of several-times-a-day data). That makes it impossible to politely use your API to, say, keep daily tabs on a few tickers: if you want data for today (every day), you have to also fetch a couple of years worth of data (every day). Ouch.

The way I'd envision this is to add optional start_time and end_time query parameters to the endpoint(s), which (logically, at least) default to, say, the UNIX epoch (or first time when data was available for the ticker) and now, respectively, to maintain backwards compatibility with the current implementation (i.e., fetch all history). These parameters would both take some sort of encoding of a timestamp, say ISO-8601 or whatever is easy enough to get a parser for in Ruby. It should be easy enough (I think?) to plumb these further down into the get_history_for_symbol method and the MongoDB query that actually gets the data to service the endpoint call. This query gets modified to select based on the timestamp field being between start_time and end_time (inclusive).

I don't know what your bandwidth for working on Robintrack is these days, but if you think you wouldn't be able to get this feature out any time soon yourself, I'd be willing to (try to) cook up a pull request if you'd be willing to review it. (Assuming you want this feature yourself, that is, though I suspect it might help in your eventual implementation for #43.)

@Ameobea Ameobea self-assigned this May 16, 2020
@Ameobea
Copy link
Owner

Ameobea commented May 16, 2020

This has been implemented in #59 and has been deployed.

Example: https://robintrack.net/api/stocks/SPY/popularity_history?start_time=2019-04-03&end_time=2019-04-05%2002:40:22%20UTC

@Ameobea Ameobea closed this as completed May 16, 2020
@mutebat39
Copy link
Author

Thanks for such a quick implementation of the feature!

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

2 participants