/* Copyright © 2009 Jim Porter This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see . */ #pragma once #include "common.h" #include "http.h" #include "twitter.h" std::string b64encode(const std::string &s); class mir_twitter : public twitter { public: mir_twitter() : twitter(), handle_(NULL), httpPOST_(NULL) {} void set_handle(PROTO_INTERFACE *ppro, HANDLE h) { ppro_ = ppro; handle_ = h; } // OAuthWebRequest used for all OAuth related queries // // consumerKey and consumerSecret - must be provided for every call, they identify the application // oauthToken and oauthTokenSecret - need to be provided for every call, except for the first token request before authorizing // pin - only used during authorization, when the user enters the PIN they received from the twitter website std::wstring OAuthWebRequestSubmit( const std::wstring& url, const std::wstring& httpMethod, const OAuthParameters *postData, const std::wstring& consumerKey, const std::wstring& consumerSecret, const std::wstring& oauthToken = L"", const std::wstring& oauthTokenSecret = L"", const std::wstring& pin = L"" ); std::wstring OAuthWebRequestSubmit( const OAuthParameters& parameters, const std::wstring& url ); std::wstring UrlGetQuery( const std::wstring& url ); OAuthParameters BuildSignedOAuthParameters( const OAuthParameters& requestParameters, const std::wstring& url, const std::wstring& httpMethod, const OAuthParameters *postData, const std::wstring& consumerKey, const std::wstring& consumerSecret, const std::wstring& requestToken, const std::wstring& requestTokenSecret, const std::wstring& pin ); std::wstring BuildQueryString( const OAuthParameters ¶meters ) ; std::wstring OAuthConcatenateRequestElements( const std::wstring& httpMethod, std::wstring url, const std::wstring& parameters ); std::map CrackURL(std::wstring ); std::wstring brook_httpsend(std::wstring, std::wstring, std::wstring, std::wstring); void Disconnect(void) { if (httpPOST_) Netlib_CloseHandle(httpPOST_); httpPOST_ = NULL; } std::wstring OAuthNormalizeUrl( const std::wstring& url ); std::wstring OAuthNormalizeRequestParameters( const OAuthParameters& requestParameters ); OAuthParameters ParseQueryString( const std::wstring& url ); std::wstring OAuthCreateNonce(); std::wstring OAuthCreateTimestamp(); std::wstring OAuthCreateSignature( const std::wstring& signatureBase, const std::wstring& consumerSecret, const std::wstring& requestTokenSecret ); protected: http::response slurp(const std::string &,http::method, OAuthParameters ); HANDLE httpPOST_; HANDLE handle_; PROTO_INTERFACE *ppro_; }; inline void mbcs_to_tcs(UINT code_page,const char *mbstr,TCHAR *tstr,int tlen) { MultiByteToWideChar(code_page,0,mbstr,-1,tstr,tlen); } inline void wcs_to_tcs(UINT code_page,const wchar_t *wstr,TCHAR *tstr,int tlen) { wcsncpy(tstr,wstr,tlen); } class ScopedLock { public: ScopedLock(HANDLE h) : handle_(h) { WaitForSingleObject(handle_,INFINITE); } ~ScopedLock() { if(handle_) ReleaseMutex(handle_); } void Unlock() { ReleaseMutex(handle_); handle_ = 0; } private: HANDLE handle_; }; bool save_url(HANDLE hNetlib,const std::string &url,const std::tstring &filename);