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

Requests with POST is not cached #2

Open
AshwinTayson opened this issue Nov 9, 2017 · 14 comments
Open

Requests with POST is not cached #2

AshwinTayson opened this issue Nov 9, 2017 · 14 comments

Comments

@AshwinTayson
Copy link

POST requests are not cached. It is requested for every request. Is there some limitation or Do I need to configure it differently?

@kuitos
Copy link
Owner

kuitos commented Nov 9, 2017

POST requests are not supported, and I think to fetch data with POST request was not a good idea...

@kuitos
Copy link
Owner

kuitos commented Nov 16, 2017

closed

@kuitos kuitos closed this as completed Nov 16, 2017
@hongbo-miao
Copy link

Hi @kuitos

I think sometimes it makes sense to cache POST requests.

One example I can find is

POST https://graph.microsoft.com/api/beta/me/getMailTips

{
    "EmailAddresses": [
        "[email protected]", 
        "[email protected]"
    ],
    "MailTipsOptions": "automaticReplies, mailboxFullStatus"
}

It returns Jack and Rose's mailtip.

BTW, thanks for brining us this library!

@kuitos
Copy link
Owner

kuitos commented Mar 16, 2018

This api was served by graphql?

@hongbo-miao
Copy link

No, it is REST API. Sorry, forget the link. https://developer.microsoft.com/en-us/graph/docs/api-reference/beta/api/user_getmailtips

@kuitos
Copy link
Owner

kuitos commented Mar 19, 2018

@hongbo-miao
Basically POST is not an idempotent operation in semantics. So caching for post request will not be provided imo. See https://stackoverflow.com/questions/626057/is-it-possible-to-cache-post-methods-in-http

@hongbo-miao
Copy link

@kuitos got it, thank you for the info!

@brendanmatkin
Copy link

For the sake of discussion:

Technically the HTTP/1.1 RFC document says that POST is a cacheable method: https://tools.ietf.org/html/rfc7231#section-4.2.3.
MDN also says it is cacheable if freshness information is included: https://developer.mozilla.org/en-US/docs/Web/HTTP/Methods/POST

In my case I need to send data to be analyzed (as a big JSON) to the server in order to get a response (which can take several minutes to process) - I'd like to cache that response as long as the request body is the same. I don't mind having to manually forceUpdate, but it would be super nice to be able to cache the response to a POST.
It's also possible that this pattern shouldn't be a RESTful interface..

I guess it might be a big change though, since it looks like this library is really structured around GETs and the buildURL helper - how would we handle the POST body if we were to update this project, right?

Anyway I'd like to help but it's a bit over my head. If anyone can give me a few pointers, I can work on it and try to contribute. Thoughts?

@kuitos
Copy link
Owner

kuitos commented Aug 14, 2019

@brendanmatkin
Thanks for your valuable information!
As more than one person had asked for the post cacheable feature, we may need to provide a mechanism to make user can define the cacheable logic by himself.
I'm going to think about how to do that in the near feature, and you can make any suggestion at any time.

@kuitos kuitos reopened this Aug 14, 2019
@brendanmatkin
Copy link

@kuitos ok thanks! I'll chew on it.

For now I'm thinking (since it seems to be needed in only a few edge cases), that checking if the body has changed happens in the implementation (maybe using force-update), and axios-extensions just allows us to use POST as a method. (I guess this is probably what you mean by "define the caceable logic by himself").

This would probably be way easier to build but might lead to some confusion when things are automatically caching even though something has changed... maybe we add another option to flag it as manual caching logic?

@abhipanda
Copy link

abhipanda commented Sep 26, 2019

@kuitos I feel a generic library like "axios-extensions" should cater to all the methods that axios supports without introducing any subjective presumptions about any methods. It should be on the user to determine which rule of theory they follow. It should let the user choose ingredients of the hash e.g. query, params, body, headers etc. You could just have "cache":true and additional hashing inputs from user.

Doing that would give this library a more generic, free from any assumptions.

@lkounadis
Copy link

@kuitos have a look a cachios, it has a nice implementation of it. mostly due to being able to cache the post request/response with a custom key you want
Good work though!

@gustavo-h-freitas
Copy link

POST requests are not supported, and I think to fetch data with POST request was not a good idea...

I've created an package at npm to cache post and get request, just look for axios-post-cache

@gongjianh
Copy link

@brendanmatkin Thanks for your valuable information! As more than one person had asked for the post cacheable feature, we may need to provide a mechanism to make user can define the cacheable logic by himself. I'm going to think about how to do that in the near feature, and you can make any suggestion at any time.

Excuse me, has this function been added?

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

8 participants