• Hi,

    After installing this plugin I tried to use it to send HTTP requests from an external app I’m making.

    https://mySite.com/oauth1/request?grant_type=password&oauth_consumer_key=myKeyHere&oauth_signature_method=HMAC-SHA1&oauth_timestamp=timeStampHere&oauth_nonce=randomGeneratedHere&oauth_version=1.0&oauth_signature=randGeneratedHere

    It gives “OAuth signature does not match” while Postman responds the request flawlessly.

    How can generate/get Signature and nonce correctly to be able to work with WordPress?
    Thanks

Viewing 15 replies - 1 through 15 (of 17 total)
  • Plugin Author Justin Greer

    (@justingreerbbi)

    Hi,

    Sorry for the issues. This plugin uses OAuth 2.0 and does not require the complicated signature and nonce in order to work.

    The endpoint for password grant type with this plugin is https://mysite.com/oauth/token. You can find more information about “User Credentials/Password” grat type by visiting https://wp-oauth.com/documentation/grant-types/user-credentials/.

    • This reply was modified 7 years, 1 month ago by Justin Greer.
    Thread Starter msitman

    (@msitman)

    Dash10 thanks for trying to help.

    I’m using the free version and it gives :
    {"error":"unsupported_grant_type","error_description":"Grant type \"password\" not supported"}

    using “token” gives the same error. as I read other posts, it seems users have to buy the Pro version for using grant types, right?

    If so, then what type is usable in the free version?

    Thread Starter msitman

    (@msitman)

    The above issue is resolved.

    Now I’m looking for endpoints.
    https://wp-oauth.com/documentation/overview/endpoints/

    Are these all I can use?
    Any chance to use WordPress endpoints?

    Plugin Author Justin Greer

    (@justingreerbbi)

    Yes, if you have an access token then you can use any endpoint that the REST API offers.

    Thread Starter msitman

    (@msitman)

    Buddy, you helped me a lot through this. I really appreciate that.

    I got the token. But as I just started to work with APIs, I’m a little confused here, should I use “request” or “access” to send requests via POST or JSON?

    "request": "https://mySite.com/oauth1/request",
    "authorize": "https://mySite.com/oauth1/authorize",
    "access": "https://mySite.com/oauth1/access",

    https://mySite.com/wp-json/wp/v2/posts

    Plugin Author Justin Greer

    (@justingreerbbi)

    Most requests are made with a simple REST type request which is simply either POST or GET. The parameters will be sent in the URL when you are making any request (most of the time).

    WordPress has documentation for this found at https://developer.www.ads-software.com/rest-api/.

    Thread Starter msitman

    (@msitman)

    Justin!

    It’s been days I tried to figure this issue out but I couldn’t so I thought to post here again.
    Everything goes well especially with GET requests that don’t modify anything but once I want to use POST, I get this:

    {"code":"rest_cannot_create","message":"Sorry, you are not allowed to create posts as this user.","data":{"status":401}}

    This seems to be a very common issue, but I couldn’t overcome.

    Example: POST request:
    https://mySite.com/wp-json/wp/v2/posts

    Body:
    title=TestPost

    Oops, posted here by mistake. Sorry.
    Can’t see how to delete it now.

    • This reply was modified 7 years, 1 month ago by asudakov.
    Plugin Author Justin Greer

    (@justingreerbbi)

    Hi @msitman,

    You will need to post using a Bearer Token in order to authenticate with the REST API. If you have your access token, simple POST with an Authorization header:

    Authorization: Bearer {your access token}. If you have WP OAuth Server installed, you should be able to authorize the request and POST.

    Thread Starter msitman

    (@msitman)

    @dash10

    You are my hero! It did the job so well, I’m so happy now ??

    For that last time (hopefully!) let me bother you.

    I see plugins in my WordPress backend installed, would you please tell me for this (API functionality) what plugins do I need to tell my customers to install on their backend?
    I have:

    JSON API
    WP OAUTH SERVER
    WP REST API
    WP REST API - OAUTH 1.0a SERVER

    And would you recommend using thing plugin as the best solution for API?
    I saw other plugins and methods out there, tried some and failed on all.

    Again I’m so grateful for your help.

    Plugin Author Justin Greer

    (@justingreerbbi)

    Hi,

    If you are getting your access token via the “/oauth/” endpoint and not “oauth1”, then all you need is WP OAuth Server.

    The WP REST API – OAuth 1.0a Server plugin is for OAuth 1.0a which you can keep but know that tokens are not exchangeable between Oauth 1 and Oauth 2.

    WordPress has most all the API’s built into it now so you should not need JSON API or WP REST API. If you did need one of them, I would say that you needed JSON API.

    Basically you only need, WP OAUth Server if you are wanting to use OAuth 2

    Thread Starter msitman

    (@msitman)

    Hi again Justin!

    Just updated the plugin to the latest version and the same error come up:
    {"code":"rest_cannot_create","message":"Sorry, you are not allowed to create posts as this user.","data":{"status":401}}

    The POST request: https://mySite.com/wp-json/wp/v2/posts

    Authorization: Bearer {your access token} is correctly included in the POST request. and was working before updating.
    In Settings OAuth Server Enabled is checked.
    In Client Settings, Authorization Code is checked.

    Status Page:
    WordPress Version : 4.8.3
    PHP Version (5.6.31): Ok
    Running CGI : Notice – Header ‘Authorization Basic’ may not work as expected.
    Certificates Generated: Certificates Found
    Secure Server: NOT SECURE – Get A SSL Certificate
    Running Windows OS: No
    Genuine: Yes

    What should I do now?
    Thanks

    Plugin Author Justin Greer

    (@justingreerbbi)

    Hi,
    Sorry for the issues. I will be investigating this issue. You are also able to send the access token in the url as a parameter.

    https://mySite.com/wp-json/wp/v2/posts?access_token={access_token}

    I have opened a ticket in our system to have a develop look into the bearer token issue. I will update this thread when I have some more news.

    Thread Starter msitman

    (@msitman)

    It just worked !!

    Buddy, I removed the Authorization Bearer from the header and did what you said in the URL section of the request and it worked.

    Is this change planned or is it something that should have happened? like a bug?

    I’m developing an app for my clients based on this plugin and imagining having all “It’s is not working” messages in my ticketing system, makes me scared to death !!

    Plugin Author Justin Greer

    (@justingreerbbi)

    This is not a changed planned. Some servers do not support authentication headers like a bearer token so we implanted a bypass. This is why the url works as well as a bearer.

    I am not sure what there is an issue with the bearer token but I am looking into today. Hopefully, we can get it tracked down today and ultimately fixed sooner than later.

Viewing 15 replies - 1 through 15 (of 17 total)
  • The topic ‘Oauth Signature and nonce’ is closed to new replies.