public static async Task <RequestResult> SendTweet(string text, List <string> media_ids) { var parameters = new HttpParameterCollection(); parameters.AddFormParameter("status", text); // images if (media_ids != null && media_ids.Count > 0) { parameters.AddFormParameter("media_ids", String.Join(",", media_ids)); } var t = Task.Run <RequestResult>(() => { return(OAuthUtility.Post ( "https://api.twitter.com/1.1/statuses/update.json", parameters: parameters, authorization: TwitterApi.GetAuth(), contentType: "application/x-www-form-urlencoded" )); }); return(await t); }
/// <summary> /// Sends a request to refresh the access token. /// </summary> /// <param name="accessToken">May contain an access token, which should be refreshed.</param> /// <remarks> /// <para>If <paramref name="accessToken"/> parameter is not specified, it will use the current access token from the same property of the current class instance.</para> /// <para>Token must contain the <b>refresh_token</b>, which was received together with the access token.</para> /// </remarks> /// <exception cref="NotSupportedException"> /// <para>Provider does not support refreshing the access token, or the method is not implemented.</para> /// <para>Use the property <see cref="OAuthBase.SupportRefreshToken"/>, to check the possibility of calling this method.</para> /// </exception> /// <exception cref="AccessTokenException"> /// <para>Access token is not found or is not specified.</para> /// <para>-or-</para> /// <para><b>refresh_token</b> value is empty.</para> /// </exception> /// <exception cref="RequestException">Error during execution of a web request.</exception> public override AccessToken RefreshToken(AccessToken accessToken = null) { if (!this.SupportRefreshToken) { throw new NotSupportedException(); } var token = (OAuth2AccessToken)base.GetSpecifiedTokenOrCurrent(accessToken, refreshTokenRequired: true); var parameters = new HttpParameterCollection(); parameters.AddFormParameter("access_token", token.Value); parameters.AddFormParameter("client_id", this.ApplicationId); parameters.AddFormParameter("client_secret", this.ApplicationSecret); parameters.AddFormParameter("grant_type", GrantType.RefreshToken); parameters.AddFormParameter("refresh_token", token.RefreshToken); var result = OAuthUtility.Post ( this.AccessTokenUrl, parameters: parameters ); return(new OAuth2AccessToken(result)); }
public string GetTumbNail(string id) { var parameter = new HttpParameterCollection() { { "access_token", driveinfo.token.access_token } }; var result = OAuthUtility.Get(string.Format("https://api.onedrive.com/v1.0/drive/items/{0}/thumbnails", id), parameter); var map = new ApiDataMapping(); map.Add("medium", "Thumnail"); FileInfo fi = null; foreach (var item in result.Result.CollectionItems.Items["value"].CollectionItems.Items.Values) { fi = new FileInfo(item, map); } if (fi != null) { int index = fi.Thumnail.IndexOf("url"); int last = fi.Thumnail.LastIndexOf(","); fi.Thumnail = fi.Thumnail.Substring(index, last - index); fi.Thumnail = fi.Thumnail.Substring(7, (fi.Thumnail.Length - 3) - 5); return(fi.Thumnail); } else { return(null); } }
public void ExecuteRequestTest() { var parameters = new HttpParameterCollection { { "content", "hello world!" }, { "contentType", "text/plain" } }; var result = OAuthUtility.Get("http://api.foxtools.ru/v2/Http", parameters); Assert.True(result.Contains("hello world!")); parameters = new HttpParameterCollection { { Convert.FromBase64String("iVBORw0KGgoAAAANSUhEUgAAAFUAAABVCAYAAAA49ahaAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsIAAA7CARUoSoAAAAR/SURBVHhe7ZDRbiMxDAPv/3+6px62gDomzGVsb+4hA0wNiJSS5k/x9aSO3X3mp70+U4endOzuMz/t9Zk6PKVjd5/5aa/P1OEpHbv7zE97feY43Im7n+ZO4vJV1P16x+FO3P00dxKXr6Lu1zsOd+Lup7mTuHwVdb/ecbgTdz/NncTlq6j79Y7DDnMnSXNKVKdL0txJVF7vOOwwd5I0p0R1uiTNnUTl9Y7DDnMnSXNKVKdL0txJVF7vOOwwd5I0p0R1uiTNnUTl9Y7DDnMnSfNUh+szdxKV1zsOO8ydJM1THa7P3ElUXu847DB3kjRPdbg+cydReb3jsMPcSdI81eH6zJ1E5fWOww5zJ3E5cX3mlKS5k6i83nHYYe4kLieuz5ySNHcSldc7DjvMncTlxPWZU5LmTqLyesdhh7mTuJy4PnNK0txJVF7vONzJu++7fBV1v95xuJN333f5Kup+veNwJ+++7/JV1P16x+FO3n3f5auo+/X+Hp6WPJ2f9vpMHZ6SPJ2f9vpMHZ6SPJ2f9vpMHZ6SPJ2f9t9n/vv7RtSXmsE+/R/4/KgH+PyoB/j8qAeo73H2S7n7zKlD7cx0qJ2Zipr70gruPnPqUDszHWpnpqLmvrSCu8+cOtTOTIfamamouS+t4O4zpw61M9OhdmYq7KeoQzMdaqebom50HWpn5h0+P6rYmXmHz48qdmbe4fOjip2Zd6ieXv5xFXWzm+L2mVOH2pmpqLku/7iKutlNcfvMqUPtzFTUXJd/XEXd7Ka4febUoXZmKmquyz+uom52U9w+c+pQOzMVy7/anQ+ZwX2aku6z7yQqz781UEcTuE9T0n32nUTl+bcG6mgC92lKus++k6g8/9ZAHU3gPk1J99l3EpXn3xqoox2XO9J99qkj7Ste22q4L+FyR7rPPnWkfcVrWw33JVzuSPfZp460r3htq+G+hMsd6T771JH2Fa9tbYT/hJO43MF9+gqfHxX79BU+Pyr26St8flTs01eoPX3slClunzklae5U1FyXT5ni9plTkuZORc11+ZQpbp85JWnuVNRcl0+Z4vaZU5LmTkXNfWmFp++nEtXpEpXXOw538vT9VKI6XaLyesfhTp6+n0pUp0tUXu843MnT91OJ6nSJyusdhx3mTuJywj51qJ0ucTlhn16dcdhh7iQuJ+xTh9rpEpcT9unVGYcd5k7icsI+daidLnE5YZ9enXHYYe4kLifsU4fa6RKXE/bp1RmHHeZO4nJHun+6f4e6Mz/K3Elc7kj3T/fvUHfmR5k7icsd6f7p/h3qzvwocydxuSPdP92/Q92ZH2XuJC53uP2nc+e1Mw47zJ3E5Q63/3TuvHbGYYe5k7jc4fafzp3XzjjsMHcSlzvc/tO589oZhztJ77NPiep0HWpn5h2qly8lpPfZp0R1ug61M/MO1cuXEtL77FOiOl2H2pl5h+rlSwnpffYpUZ2uQ+3MvEP19PIpSZrvlqzm39T8d+m0JM13S1bzb2r+u3Rakua7Jav5NzX/XTotSfPdktX8Gz39sMDX11/4Q2CGtGAk5wAAAABJRU5ErkJggg==") }, { "test", 123 }, { new HttpFormParameter("x", "y") }, { new HttpFormParameter("a", "bc") }, { "contentType", "text/plain" } }; result = OAuthUtility.Post("http://api.foxtools.ru/v2/Http", parameters); Assert.True(result.ToString().IndexOf("PNG") != -1); parameters = new HttpParameterCollection { { new HttpFile("file1", "test.png", "image/png", Convert.FromBase64String("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")) }, { "dd", 20 }, { "id", 13 }, { new HttpFormParameter("key", "e91268b7-1162-4044-9236-7191c8c3b5d2") }, { "contentType", "text/plain" } }; result = OAuthUtility.Post("http://api.foxtools.ru/v2/Http", parameters); Assert.True(result.ToString().Contains("test.png")); Assert.True(result.ToString().Contains("e91268b7-1162-4044-9236-7191c8c3b5d2")); using (var fs = new FileStream(Path.Combine(AppDomain.CurrentDomain.SetupInformation.ApplicationBase, "oauth.dat"), FileMode.Open, FileAccess.Read, FileShare.ReadWrite)) { parameters = new HttpParameterCollection { { new HttpFile("file1", "123.png", "image/png", fs) }, { "dd", 20 }, { "id", 13 }, { "key", "e91268b7-1162-4044-9236-7191c8c3b5d2" }, { "contentType", "text/plain" } }; result = OAuthUtility.ExecuteRequest("POST", "http://api.foxtools.ru/v2/Http", parameters); Assert.True(result.ToString().Contains("123.png")); } result = OAuthUtility.Get("https://github.com/alekseynemiro/nemiro.oauth.dll/archive/master.zip"); Assert.True(result.IsFile); Assert.Contains("master.zip", result.FileName); }
private async void AllSerach() { foreach (var item in Setting.driveinfo) { CloudFiles files = null; if (item.token.Drive == "Google") { string query = "title = " + "'" + serchname + "'"; var parameter = new Dictionary <string, string> { { "q", query } }; var result = await HttpHelper.RequstHttp("GET", "https://www.googleapis.com/drive/v2/files", parameter, item.token.access_token); Dictionary <string, object> fileinfo = HttpHelper.DerealizeJson(result.GetResponseStream()); object[] items = (object[])fileinfo["items"]; googlecloud1.Folder.GoogleFolder folder = new Folder.GoogleFolder(item); foreach (var fi in items) { files = folder.AddFiles((Dictionary <string, object>)fi); file.Add(files); } } else if (item.token.Drive == "OneDrive") { var parameter = new Dictionary <string, string> { { "q", serchname } }; var result = await HttpHelper.RequstHttp("GET", "https://api.onedrive.com/v1.0/drive/root/view.search", parameter, item.token.access_token); Dictionary <string, object> fileinfo = HttpHelper.DerealizeJson(result.GetResponseStream()); object[] items = (object[])fileinfo["value"]; googlecloud1.Folder.OneDriveFolder folder = new Folder.OneDriveFolder(item); foreach (var fi in items) { files = folder.AddFiles((Dictionary <string, object>)fi); file.Add(files); } } else if (item.token.Drive == "DropBox") { var parameter = new HttpParameterCollection() { { "query", serchname }, { "access_token", item.token.access_token } }; var result = OAuthUtility.Get("https://api.dropboxapi.com/1/search/auto//", parameter); googlecloud1.Folder.DropBoxFolder folder = new Folder.DropBoxFolder(item); foreach (RequestResult re in result) { files = folder.AddFiles(re.ToDictionary()); file.Add(files); } } } }
public static void DeleteAsync(string endpoint = null, HttpParameterCollection parameters = null, HttpAuthorization authorization = null, NameValueCollection headers = null, string contentType = null, AccessToken accessToken = null, ExecuteRequestAsyncCallback callback = null, bool allowWriteStreamBuffering = false, bool allowSendChunked = true, long contentLength = -1, HttpWriteRequestStream streamWriteCallback = null, int writeBufferSize = 4096, int readBufferSize = 4096, bool donotEncodeKeys = false) { NewOAuthUtility.ExecuteRequestAsync("DELETE", endpoint, parameters, authorization, headers, contentType, accessToken, callback, allowWriteStreamBuffering, allowSendChunked, contentLength, streamWriteCallback, writeBufferSize, readBufferSize, donotEncodeKeys); }
protected void btnUpload_Click(object sender, EventArgs e) { if (Session["AccessToken"] == null) { Response.Write("Error. Access token not found.<br /><a href=\"/\">Try again</a>."); pnlUpload.Visible = false; return; } // help: https://developers.google.com/drive/v2/reference/files/insert var token = Session["AccessToken"].ToString(); try { /* * // simple upload * var result = OAuthUtility.Post * ( * "https://www.googleapis.com/upload/drive/v2/files", * new HttpParameterCollection * { * { "uploadType", "media" }, * { FileUpload1.PostedFile } * }, * new HttpAuthorization(AuthorizationType.Bearer, token) * ); */ var parameters = new HttpParameterCollection(); parameters.Add("uploadType", "multipart"); parameters.AddContent("application/json", new { title = FileUpload1.FileName }); parameters.AddContent(FileUpload1.PostedFile); var result = OAuthUtility.Post ( "https://www.googleapis.com/upload/drive/v2/files", parameters, authorization: new HttpAuthorization(AuthorizationType.Bearer, token), contentType: "multipart/related" ); // ok hlResult.NavigateUrl = result["webContentLink"].ToString(); hlResult.Text = hlResult.NavigateUrl; pnlSuccess.Visible = true; pnlUpload.Visible = false; } catch (Exception ex) { Response.Write(ex.Message); } }
protected void btnUpload_Click(object sender, EventArgs e) { if (Session["AccessToken"] == null) { Response.Write("Error. Access token not found.<br /><a href=\"/\">Try again</a>."); pnlUpload.Visible = false; return; } // help: https://developers.google.com/drive/v2/reference/files/insert var token = Session["AccessToken"].ToString(); try { /* // simple upload var result = OAuthUtility.Post ( "https://www.googleapis.com/upload/drive/v2/files", new HttpParameterCollection { { "uploadType", "media" }, { FileUpload1.PostedFile } }, new HttpAuthorization(AuthorizationType.Bearer, token) ); */ var parameters = new HttpParameterCollection(); parameters.Add("uploadType", "multipart"); parameters.AddContent("application/json", new { title = FileUpload1.FileName }); parameters.AddContent(FileUpload1.PostedFile); var result = OAuthUtility.Post ( "https://www.googleapis.com/upload/drive/v2/files", parameters, authorization: new HttpAuthorization(AuthorizationType.Bearer, token), contentType: "multipart/related" ); // ok hlResult.NavigateUrl = result["webContentLink"].ToString(); hlResult.Text = hlResult.NavigateUrl; pnlSuccess.Visible = true; pnlUpload.Visible = false; } catch (Exception ex) { Response.Write(ex.Message); } }
/// <summary> /// Uploads media (only photos). /// </summary> /// <remarks> /// <see href="https://dev.twitter.com/rest/reference/post/media/upload-init"/> /// </remarks> /// <param name="path">File path.</param> public static async Task <RequestResult> UploadMedia(string path, MeadiaUploadEventHandler uploadingCallback) { var file = new FileInfo(path); string media_type = "image/jpeg"; switch (file.Extension.ToLower()) { case ".png": media_type = "image/png"; break; case ".gif": media_type = "image/gif"; break; case ".bmp": media_type = "image/bmp"; break; } var parameters = new HttpParameterCollection(); parameters.AddFormParameter("command", "INIT"); parameters.AddFormParameter("total_bytes", file.Length.ToString()); parameters.AddFormParameter("media_type", media_type); parameters.AddFormParameter("media_category", "tweet_image"); var t = Task.Run <RequestResult>(() => { return(OAuthUtility.Post ( "https://upload.twitter.com/1.1/media/upload.json", parameters: parameters, authorization: TwitterApi.GetAuth(), contentType: "multipart/form-data" )); }); var result = await t; if (result.IsSuccessfully) { return(await TwitterApi.MeadiaUploadAppend(path, result["media_id"].ToString(), 0, uploadingCallback)); } else { return(result); } }
public async Task AddFiles(string id) { try { GoogleFiles.Clear(); string query = "'" + id + "' in parents"; var parameter = new HttpParameterCollection { { "q", query }, { "access_token", driveinfo.token.access_token } }; var result = OAuthUtility.Get("https://www.googleapis.com/drive/v2/files", parameter); var map = new ApiDataMapping(); map.Add("id", "FileID"); map.Add("title", "FileName"); map.Add("fileExtension", "Extention"); map.Add("downloadUrl", "DownUrl"); map.Add("thumbnailLink", "Thumnail"); map.Add("fileSize", "FileSize", typeof(long)); map.Add("description", "Description"); map.Add("modifiedDate", "modifiedDate"); foreach (var item in result.CollectionItems.Items["items"].CollectionItems.Items.Values) { FileInfo fi = new FileInfo(item, map); fi.driveinfo = driveinfo; if (id == "root") { fi.Path = "Google/"; } if (fi.Extention != null) { fi.DownUrl = "https://www.googleapis.com/drive/v2/files/" + fi.FileID + "?alt=media"; fi.IsFile = true; } else { fi.Path += fi.FileName + "/"; fi.IsFile = false; } GoogleFile itemss = new GoogleFile(fi); GoogleFiles.Add(itemss); } } catch (Exception e) { MessageBox.Show(string.Format("구글 파일 불러오기 오류 : {0}", e)); } }
private void button2_Click(object sender, EventArgs e) { progressBar1.Value = 0; if (openFileDialog1.ShowDialog() != System.Windows.Forms.DialogResult.OK) { return; } object parents = null; if (!String.IsNullOrEmpty(this.CurrentFolderId)) { parents = new object[] { new { id = this.CurrentFolderId } }; } UniValue properties = UniValue.Create ( new { title = Path.GetFileName(openFileDialog1.FileName), parents = parents } ); var file = openFileDialog1.OpenFile(); this.CurrentFileLength = file.Length; var parameters = new HttpParameterCollection(); parameters.Add("uploadType", "multipart"); parameters.AddContent("application/json", properties.ToString()); parameters.AddContent("application/octet-stream", file); OAuthUtility.PostAsync ( "https://www.googleapis.com/upload/drive/v2/files", parameters, authorization: new HttpAuthorization(AuthorizationType.Bearer, Properties.Settings.Default.AccessToken), contentType: "multipart/related", // handler of result callback: Upload_Result, // handler of uploading streamWriteCallback: Upload_Processing ); }
public async Task AddFiles(string id) { try { var parameter = new HttpParameterCollection() { { "access_token", driveinfo.token.access_token } }; var result = OAuthUtility.Get(string.Format("https://api.onedrive.com/v1.0/drive/items/{0}/children", id), parameter); var map = new ApiDataMapping(); map.Add("id", "FileID"); map.Add("name", "FileName"); map.Add("@content.downloadUrl", "DownUrl"); map.Add("size", "FileSize", typeof(long)); map.Add("lastModifiedDateTime", "modifiedDate"); foreach (var item in result.Result.CollectionItems.Items["value"].CollectionItems.Items.Values) { FileInfo fi = new FileInfo(item, map); fi.driveinfo = driveinfo; if (id == "root") { fi.Path = "OneDrive/"; } if (fi.Items.CollectionItems.ContainsKey("folder")) { fi.IsFile = false; fi.Path += fi.FileName + "/"; } else { fi.IsFile = true; fi.Extention = GetExtension(fi.FileName); fi.DownUrl = item.CollectionItems["@content.downloadUrl"].ToString(); } fi.Thumnail = GetTumbNail(fi.FileID); OneDriveFile items = new OneDriveFile(fi); files.Add(items); } } catch (Exception e) { MessageBox.Show(string.Format("원드라이브 파일 불러오기 오류 : {0}", e)); } }
private void GetTweets() { this.Cursor = Cursors.WaitCursor; var parameters = new HttpParameterCollection(); if (!String.IsNullOrEmpty(this.LastTweetId)) { parameters.AddUrlParameter("max_id", this.LastTweetId); } OAuthUtility.GetAsync ( "https://api.twitter.com/1.1/statuses/user_timeline.json", parameters: parameters, authorization: this.GetAuth(), callback: GetTweets_Result ); }
/// <summary> /// https://dev.twitter.com/rest/reference/post/media/upload-finalize /// </summary> /// <param name="media_id">Media id.</param> private static async Task <RequestResult> MeadiaUploadFinalize(string path, string media_id) { var parameters = new HttpParameterCollection(); parameters.AddFormParameter("command", "FINALIZE"); parameters.AddFormParameter("media_id", media_id); var t = Task.Run <RequestResult>(() => { return(OAuthUtility.Post ( "https://upload.twitter.com/1.1/media/upload.json", parameters: parameters, authorization: TwitterApi.GetAuth(), contentType: "multipart/form-data" )); }); return(await t); }
/// <summary> /// Sends a request to refresh the access token. /// </summary> /// <param name="accessToken">May contain an access token, which should be refreshed.</param> /// <param name="returnUrl">Callback address that was used in obtaining the access token.</param> /// <remarks> /// <para>If <paramref name="accessToken"/> parameter is not specified, it will use the current access token from the same property of the current class instance.</para> /// <para>Token must contain the <b>refresh_token</b>, which was received together with the access token.</para> /// <list type="table"> /// <item> /// <term><img src="../img/warning.png" alt="(!)" title="" /></term> /// <term><b>To update the access token, you must specify the return address that was used in obtaining the access token.</b></term> /// </item> /// </list> /// </remarks> /// <exception cref="NotSupportedException"> /// <para>Provider does not support refreshing the access token, or the method is not implemented.</para> /// <para>Use the property <see cref="OAuthBase.SupportRefreshToken"/>, to check the possibility of calling this method.</para> /// </exception> /// <exception cref="AccessTokenException"> /// <para>Access token is not found or is not specified.</para> /// <para>-or-</para> /// <para><b>refresh_token</b> value is empty.</para> /// </exception> /// <exception cref="RequestException">Error during execution of a web request.</exception> /// <exception cref="ArgumentNullException">An exception occurs if there is no authorization code.</exception> public AccessToken RefreshToken(AccessToken accessToken, string returnUrl) { var token = (OAuth2AccessToken)base.GetSpecifiedTokenOrCurrent(accessToken, refreshTokenRequired: true); var parameters = new HttpParameterCollection(); parameters.AddFormParameter("client_id", this.ApplicationId); parameters.AddFormParameter("client_secret", this.ApplicationSecret); parameters.AddFormParameter("redirect_uri", returnUrl); parameters.AddFormParameter("grant_type", GrantType.RefreshToken); parameters.AddFormParameter("refresh_token", token.RefreshToken); var result = OAuthUtility.Post ( this.AccessTokenUrl, parameters: parameters, authorization: new HttpAuthorization(AuthorizationType.Basic, OAuthUtility.ToBase64String("{0}:{1}", this.ApplicationId, this.ApplicationSecret)) ); return(new OAuth2AccessToken(result)); }
private static readonly int MediaUploadChunkSize = (3 * 1024 * 1024); // 3 MB /// <summary> /// Checks access token. /// </summary> public static async Task <bool> CheckAccessToken() { var parameters = new HttpParameterCollection { new HttpUrlParameter("user_id", Properties.Settings.Default.UserId), new HttpUrlParameter("include_entities", "false") }; var t = Task.Run <bool>(() => { var result = OAuthUtility.Get ( "https://api.twitter.com/1.1/users/show.json", parameters: parameters, authorization: TwitterApi.GetAuth() ); return(result.IsSuccessfully); }); return(await t); }
/// <summary> /// Gets tweets. /// </summary> /// <param name="lastTweetId"></param> /// <remarks> /// <see href="https://dev.twitter.com/rest/reference/get/statuses/user_timeline"/> /// </remarks> public static async Task <RequestResult> GetTweets(string lastTweetId) { HttpParameterCollection parameters = null; if (!String.IsNullOrEmpty(lastTweetId)) { parameters = new HttpParameterCollection { new HttpUrlParameter("max_id", lastTweetId) }; } var t = Task.Run <RequestResult>(() => { return(OAuthUtility.Get ( "https://api.twitter.com/1.1/statuses/user_timeline.json", parameters: parameters, authorization: TwitterApi.GetAuth() )); }); return(await t); }
/// <summary> /// Gets the user details. /// </summary> /// <param name="accessToken">May contain an access token, which will have to be used in obtaining information about the user.</param> public override UserInfo GetUserInfo(AccessToken accessToken = null) { // help: https://dev.twitter.com/rest/reference/get/users/show accessToken = base.GetSpecifiedTokenOrCurrent(accessToken); string url = "https://api.twitter.com/1.1/users/show.json"; // query parameters var parameters = new HttpParameterCollection(); parameters.AddUrlParameter("user_id", accessToken["user_id"].ToString()); parameters.AddUrlParameter("screen_name", accessToken["screen_name"].ToString()); parameters.AddUrlParameter("include_entities", "false"); this.Authorization["oauth_token"] = accessToken["oauth_token"].ToString(); this.Authorization.TokenSecret = accessToken["oauth_token_secret"].ToString(); // execute the request var result = OAuthUtility.Get(url, parameters, this.Authorization); // field mapping var map = new ApiDataMapping(); map.Add("id_str", "UserId", typeof(string)); map.Add("name", "DisplayName"); map.Add("screen_name", "UserName"); map.Add("profile_image_url", "Userpic"); map.Add("url", "Url"); map.Add("birthday", "Birthday", typeof(DateTime), @"dd\.MM\.yyyy"); map.Add("lang", "Language"); //map.Add("verified", "Url"); //map.Add("location", "Url"); // parse the server response and returns the UserInfo instance return(new UserInfo(result, map)); }
private void button1_Click(object sender, EventArgs e) { // help: https://developers.google.com/drive/v2/reference/files/insert object parents = null; if (!String.IsNullOrEmpty(this.CurrentFolderId)) { parents = new object[] { new { id = this.CurrentFolderId } }; } UniValue content = UniValue.Create ( new { mimeType = "application/vnd.google-apps.folder", title = textBox1.Text, parents = parents } ); var parameters = new HttpParameterCollection(); parameters.Encoding = Encoding.UTF8; parameters.Add("uploadType", "multipart"); parameters.AddContent("application/json", content.ToString()); OAuthUtility.PostAsync ( "https://www.googleapis.com/upload/drive/v2/files", parameters: parameters, authorization: new HttpAuthorization(AuthorizationType.Bearer, Properties.Settings.Default.AccessToken), contentType: "multipart/related", callback: CreateFolder_Result ); }
/// <summary> /// Performs an async request. /// </summary> /// <param name="method">HTTP Method: <b>POST</b> (default), <b>PUT</b>, <b>GET</b> or <b>DELETE</b>.</param> /// <param name="endpoint">URL to which will be sent to request.</param> /// <param name="parameters">Parameters to be passed to request.</param> /// <param name="authorization">Authorization header value.</param> /// <param name="headers">HTTP headers for request.</param> /// <param name="contentType">The value of the <b>Content-Type</b> HTTP header.</param> /// <param name="callback">A delegate that, if provided, is called when an async web request is completed.</param> /// <param name="accessToken">Access token to be used in the request.</param> /// <remarks> /// <para>Can not be used simultaneously <paramref name="accessToken"/> and <paramref name="authorization"/>. Use only one of these parameters.</para> /// </remarks> /// <returns>Returns an instance of the <see cref="RequestResult"/> class, which contains the result of the request.</returns> /// <exception cref="System.ArgumentNullException"></exception> /// <exception cref="RequestException"></exception> /// <exception cref="ArgumentException"> /// <para>The exception occurs when the query parameters are specified at the same time <paramref name="authorization"/> and <paramref name="accessToken"/>.</para> /// </exception> public static void ExecuteRequestAsync(string method = "POST", string endpoint = null, HttpParameterCollection parameters = null, HttpAuthorization authorization = null, NameValueCollection headers = null, string contentType = null, AccessToken accessToken = null, ExecuteRequestAsyncCallback callback = null) { var t = new Thread (() => { RequestResult result = null; try { result = OAuthUtility.ExecuteRequest(method, endpoint, parameters, authorization, headers, contentType, accessToken); } catch (RequestException ex) { result = ex.RequestResult; } if (callback != null) { callback(result); } } ); t.IsBackground = true; t.Start(); }
/// <summary> /// https://dev.twitter.com/rest/reference/post/media/upload-append /// </summary> /// <param name="path">File path.</param> /// <param name="media_id">Media id.</param> /// <param name="chunk">Chunk. Default: 0.</param> /// <param name="uploadingCallback">Uploading callback.</param> private static async Task <RequestResult> MeadiaUploadAppend(string path, string media_id, int chunk, MeadiaUploadEventHandler uploadingCallback) { var file = new FileInfo(path); bool isUploded = false; byte[] media = null; if (chunk > 0) { // multiple chunks using (var stream = file.Open(FileMode.Open, FileAccess.Read, FileShare.Inheritable)) using (var reader = new BinaryReader(stream)) { stream.Position = (TwitterApi.MediaUploadChunkSize * chunk); media = reader.ReadBytes(TwitterApi.MediaUploadChunkSize); isUploded = (stream.Position == stream.Length); } } else { if (file.Length <= TwitterApi.MediaUploadChunkSize) { // one chunk using (var reader = new BinaryReader(file.Open(FileMode.Open, FileAccess.Read, FileShare.Inheritable))) { media = reader.ReadBytes(Convert.ToInt32(file.Length)); isUploded = true; } } else { // multiple chunks using (var stream = file.Open(FileMode.Open, FileAccess.Read, FileShare.Inheritable)) using (var reader = new BinaryReader(stream)) { media = reader.ReadBytes(TwitterApi.MediaUploadChunkSize); isUploded = (stream.Position == stream.Length); } } } var parameters = new HttpParameterCollection(); parameters.AddFormParameter("command", "APPEND"); parameters.AddFormParameter("media_id", media_id); parameters.AddFormParameter("segment_index", chunk.ToString()); parameters.Add("media", Path.GetFileName(path), media); var t = Task.Run <RequestResult>(() => { return(OAuthUtility.Post ( "https://upload.twitter.com/1.1/media/upload.json", parameters: parameters, authorization: TwitterApi.GetAuth(), contentType: "multipart/form-data", streamWriteCallback: (object s, StreamWriteEventArgs e) => { int progressPercentage = 0; long totalUploaded = 0; if (chunk > 0) { totalUploaded = TwitterApi.MediaUploadChunkSize * chunk; } totalUploaded += e.TotalBytesWritten; progressPercentage = Convert.ToInt32((totalUploaded * 100) / file.Length); uploadingCallback?.Invoke(s, new ProgressChangedEventArgs(progressPercentage, null)); } )); }); var result = await t; if (!result.IsSuccessfully) { // error return(result); } if (file.Length > TwitterApi.MediaUploadChunkSize && !isUploded) { // next chunk return(await TwitterApi.MeadiaUploadAppend(path, media_id, chunk + 1, uploadingCallback)); } else { // finalize return(await TwitterApi.MeadiaUploadFinalize(path, media_id)); } }
protected void btnUpload_Click(object sender, EventArgs e) { if (Session["AccessToken"] == null) { Response.Write("Error. Access token not found.<br /><a href=\"/\">Try again</a>."); pnlUpload.Visible = false; return; } // help: https://developers.google.com/drive/v2/reference/files/insert var token = Session["AccessToken"].ToString(); var filePath = Server.MapPath(String.Format("~/Temp/{0}.tmp", Guid.NewGuid())); try { /* * // simple upload * var result = OAuthUtility.Post * ( * "https://www.googleapis.com/upload/drive/v2/files", * new HttpParameterCollection * { * { "uploadType", "media" }, * { FileUpload1.PostedFile } * }, * new HttpAuthorization(AuthorizationType.Bearer, token) * ); */ // save file if (!Directory.Exists(Server.MapPath("~/Temp"))) { Directory.CreateDirectory(Server.MapPath("~/Temp")); } using (var file = new FileStream(filePath, FileMode.CreateNew, FileAccess.Write, FileShare.Inheritable)) using (var writer = new BinaryWriter(file)) { using (var reader = new BinaryReader(FileUpload1.PostedFile.InputStream)) { byte[] buffer = new byte[4096]; int readBytes = 0; while ((readBytes = reader.Read(buffer, 0, buffer.Length)) != 0) { writer.Write(buffer, 0, readBytes); } } } var fileToSend = File.OpenRead(filePath); // send saved file var parameters = new HttpParameterCollection(); parameters.Add("uploadType", "multipart"); parameters.AddContent("application/json", new { title = FileUpload1.FileName }); parameters.AddContent ( FileUpload1.PostedFile.ContentType ?? "application/octet-stream", fileToSend ); var result = OAuthUtility.Post ( "https://www.googleapis.com/upload/drive/v2/files", parameters, authorization: new HttpAuthorization(AuthorizationType.Bearer, token), contentType: "multipart/related" ); fileToSend.Close(); // ok hlResult.NavigateUrl = result["webContentLink"].ToString(); hlResult.Text = hlResult.NavigateUrl; pnlSuccess.Visible = true; pnlUpload.Visible = false; } catch (Exception ex) { Response.Write(ex.Message); } finally { // remove temp file if (File.Exists(filePath)) { File.Delete(filePath); } } }
/// <summary> /// Sends a request to refresh the access token. /// </summary> /// <param name="accessToken">May contain an access token, which should be refreshed.</param> /// <param name="returnUrl">Callback address that was used in obtaining the access token.</param> /// <remarks> /// <para>If <paramref name="accessToken"/> parameter is not specified, it will use the current access token from the same property of the current class instance.</para> /// <para>Token must contain the <b>refresh_token</b>, which was received together with the access token.</para> /// <list type="table"> /// <item> /// <term><img src="../img/warning.png" alt="(!)" title="" /></term> /// <term><b>To update the access token, you must specify the return address that was used in obtaining the access token.</b></term> /// </item> /// </list> /// </remarks> /// <exception cref="NotSupportedException"> /// <para>Provider does not support refreshing the access token, or the method is not implemented.</para> /// <para>Use the property <see cref="OAuthBase.SupportRefreshToken"/>, to check the possibility of calling this method.</para> /// </exception> /// <exception cref="AccessTokenException"> /// <para>Access token is not found or is not specified.</para> /// <para>-or-</para> /// <para><b>refresh_token</b> value is empty.</para> /// </exception> /// <exception cref="RequestException">Error during execution of a web request.</exception> /// <exception cref="ArgumentNullException">An exception occurs if there is no authorization code.</exception> public AccessToken RefreshToken(AccessToken accessToken, string returnUrl) { var token = (OAuth2AccessToken)base.GetSpecifiedTokenOrCurrent(accessToken, refreshTokenRequired: true); var parameters = new HttpParameterCollection(); parameters.AddFormParameter("client_id", this.ApplicationId); parameters.AddFormParameter("client_secret", this.ApplicationSecret); parameters.AddFormParameter("redirect_uri", returnUrl); parameters.AddFormParameter("grant_type", GrantType.RefreshToken); parameters.AddFormParameter("refresh_token", token.RefreshToken); var result = OAuthUtility.Post ( this.AccessTokenUrl, parameters: parameters, authorization: new HttpAuthorization(AuthorizationType.Basic, OAuthUtility.ToBase64String("{0}:{1}", this.ApplicationId, this.ApplicationSecret)) ); return new OAuth2AccessToken(result); }
/// <summary> /// Gets the user details. /// </summary> /// <param name="accessToken">May contain an access token, which will have to be used in obtaining information about the user.</param> public override UserInfo GetUserInfo(AccessToken accessToken = null) { // help: https://dev.twitter.com/docs/api/1/get/users/show accessToken = base.GetSpecifiedTokenOrCurrent(accessToken); string url = "https://api.twitter.com/1.1/users/show.json"; // query parameters var parameters = new HttpParameterCollection(); parameters.AddUrlParameter("user_id", accessToken["user_id"].ToString()); parameters.AddUrlParameter("screen_name", accessToken["screen_name"].ToString()); parameters.AddUrlParameter("include_entities", "false"); this.Authorization["oauth_token"] = accessToken["oauth_token"].ToString(); this.Authorization.TokenSecret = accessToken["oauth_token_secret"].ToString(); // execute the request var result = OAuthUtility.Get(url, parameters, this.Authorization); // field mapping var map = new ApiDataMapping(); map.Add("id_str", "UserId", typeof(string)); map.Add("name", "DisplayName"); map.Add("screen_name", "UserName"); map.Add("profile_image_url", "Userpic"); map.Add("url", "Url"); map.Add("birthday", "Birthday", typeof(DateTime), @"dd\.MM\.yyyy"); //map.Add("verified", "Url"); //map.Add("location", "Url"); // parse the server response and returns the UserInfo instance return new UserInfo(result, map); }
/// <summary> /// Performs a request using a <b>PUT</b> method. /// </summary> /// <param name="endpoint">URL to which will be sent to the request.</param> /// <param name="parameters">Parameters to be passed to the request.</param> /// <param name="authorization">Authorization header value.</param> /// <param name="headers">HTTP headers for the request.</param> /// <param name="contentType">The value of the <b>Content-Type</b> HTTP header.</param> /// <param name="accessToken">Access token to be used in the request.</param> /// <remarks> /// <para>Can not be used simultaneously <paramref name="accessToken"/> and <paramref name="authorization"/>. Use only one of these parameters.</para> /// </remarks> /// <returns>Returns an instance of the <see cref="RequestResult"/> class, which contains the result of the request.</returns> /// <exception cref="System.ArgumentNullException"></exception> /// <exception cref="RequestException"></exception> /// <exception cref="ArgumentException"> /// <para>The exception occurs when the query parameters are specified at the same time <paramref name="authorization"/> and <paramref name="accessToken"/>.</para> /// </exception> public static RequestResult Put(string endpoint = null, HttpParameterCollection parameters = null, HttpAuthorization authorization = null, NameValueCollection headers = null, string contentType = null, AccessToken accessToken = null) { return OAuthUtility.ExecuteRequest("PUT", endpoint, parameters, authorization, headers, contentType, accessToken); }
public void HttpParametersWriteTest() { Console.WriteLine("Test 1"); object obj = null; string str = null; int? @int = null; var parameters = new HttpParameterCollection { { "test", obj }, { "test2", str }, { "test3", @int } }; foreach (var p in parameters) { Assert.AreEqual(HttpParameterType.Unformed, p.ParameterType); Console.WriteLine("{0} is {1}", p.Name, p.GetType().Name); } var req = (HttpWebRequest)WebRequest.Create("http://api.foxtools.ru/v2/hash"); req.Method = "POST"; parameters.WriteToRequestStream(req); string r = parameters.ToStringParameters(); Assert.AreEqual("test=&test2=&test3=", r); Console.WriteLine(r); Console.WriteLine("-------------------------------------"); Console.WriteLine("Test 2"); parameters = new HttpParameterCollection { new HttpUrlParameter("test", "123"), new HttpFormParameter("test2", null), new HttpFormParameter("text", "test") }; for (int i = 0; i < parameters.Count; i++) { var p = parameters[i]; if (i == 0) { Assert.AreEqual(HttpParameterType.Url, p.ParameterType); } else { Assert.AreEqual(HttpParameterType.Form, p.ParameterType); } Console.WriteLine("{0} is {1}", p.Name, p.GetType().Name); } req = (HttpWebRequest)WebRequest.Create("http://api.foxtools.ru/v2/hash"); req.Method = "POST"; parameters.WriteToRequestStream(req); r = parameters.ToStringParameters(HttpParameterType.Url); Assert.AreEqual("test=123", r); Console.WriteLine("-------------------------------------"); Console.WriteLine("Test 3"); parameters = new HttpParameterCollection { new { a = 1, b = 2, c = "abc" } }; for (int i = 0; i < parameters.Count; i++) { var p = parameters[i]; Assert.AreEqual(HttpParameterType.RequestBody, p.ParameterType); Console.WriteLine("{0} is {1}", p.Name, p.GetType().Name); } req = (HttpWebRequest)WebRequest.Create("http://api.foxtools.ru/v2/hash"); req.Method = "POST"; req.ContentType = "application/json"; parameters.WriteToRequestStream(req); req.GetResponse(); req = (HttpWebRequest)WebRequest.Create("http://api.foxtools.ru/v2/hash"); req.Method = "POST"; parameters.WriteToRequestStream(req); req.GetResponse(); Console.WriteLine("-------------------------------------"); }
/// <summary> /// Performs an async request using a <b>PUT</b> method. /// </summary> /// <param name="endpoint">URL to which will be sent to request.</param> /// <param name="parameters">Parameters to be passed to request.</param> /// <param name="authorization">Authorization header value.</param> /// <param name="headers">HTTP headers for request.</param> /// <param name="contentType">The value of the <b>Content-Type</b> HTTP header.</param> /// <param name="callback">A delegate that, if provided, is called when an async request is completed.</param> /// <param name="accessToken">Access token to be used in the request.</param> /// <remarks> /// <para>Can not be used simultaneously <paramref name="accessToken"/> and <paramref name="authorization"/>. Use only one of these parameters.</para> /// </remarks> /// <returns>Returns an instance of the <see cref="RequestResult"/> class, which contains the result of the request.</returns> /// <exception cref="System.ArgumentNullException"></exception> /// <exception cref="RequestException"></exception> /// <exception cref="ArgumentException"> /// <para>The exception occurs when the query parameters are specified at the same time <paramref name="authorization"/> and <paramref name="accessToken"/>.</para> /// </exception> public static void PutAsync(string endpoint = null, HttpParameterCollection parameters = null, HttpAuthorization authorization = null, NameValueCollection headers = null, string contentType = null, AccessToken accessToken = null, ExecuteRequestAsyncCallback callback = null) { OAuthUtility.ExecuteRequestAsync("PUT", endpoint, parameters, authorization, headers, contentType, accessToken, callback); }
public void SetSignature(string httpMethod, string url, string applicationSecret, string tokenSecret, HttpParameterCollection parameters) { this.SetSignature(httpMethod, url, applicationSecret, tokenSecret, parameters); }
/// <summary> /// Invoked before sending a web request. /// </summary> /// <param name="httpMethod">HTTP Method of the request: <b>POST</b>, <b>PUT</b>, <b>GET</b> or <b>DELETE</b>.</param> /// <param name="url">URL of the web request.</param> /// <param name="contentType">The value of the <b>Content-Type</b> HTTP header.</param> /// <param name="parameters">>Parameters of the web request.</param> internal virtual void Build(string httpMethod, string url, string contentType, HttpParameterCollection parameters) { }
/// <summary> /// Sends a request to refresh the access token. /// </summary> /// <param name="accessToken">May contain an access token, which should be refreshed.</param> /// <remarks> /// <para>If <paramref name="accessToken"/> parameter is not specified, it will use the current access token from the same property of the current class instance.</para> /// <para>Token must contain the <b>refresh_token</b>, which was received together with the access token.</para> /// </remarks> /// <exception cref="NotSupportedException"> /// <para>Provider does not support refreshing the access token, or the method is not implemented.</para> /// <para>Use the property <see cref="OAuthBase.SupportRefreshToken"/>, to check the possibility of calling this method.</para> /// </exception> /// <exception cref="AccessTokenException"> /// <para>Access token is not found or is not specified.</para> /// <para>-or-</para> /// <para><b>refresh_token</b> value is empty.</para> /// </exception> /// <exception cref="RequestException">Error during execution of a web request.</exception> public override AccessToken RefreshToken(AccessToken accessToken = null) { if (!this.SupportRefreshToken) { throw new NotSupportedException(); } var token = (OAuth2AccessToken)base.GetSpecifiedTokenOrCurrent(accessToken, refreshTokenRequired: true); var parameters = new HttpParameterCollection(); parameters.AddFormParameter("access_token", token.Value); parameters.AddFormParameter("client_id", this.ApplicationId); parameters.AddFormParameter("client_secret", this.ApplicationSecret); parameters.AddFormParameter("grant_type", GrantType.RefreshToken); parameters.AddFormParameter("refresh_token", token.RefreshToken); var result = OAuthUtility.Post ( this.AccessTokenUrl, parameters: parameters ); return new OAuth2AccessToken(result); }
public void HttpParametersTest() { Console.WriteLine("Test 1"); object obj = null; string str = null; int? @int = null; var parameters = new HttpParameterCollection { { "test", obj }, { "test2", str }, { "test3", @int } }; foreach (var p in parameters) { Console.WriteLine("{0} is {1}", p.Name, p.GetType().Name); } Console.WriteLine(parameters.ToStringParameters()); Console.WriteLine("-------------------------------------"); Console.WriteLine("Test 2"); parameters = new HttpParameterCollection { { "n", 1 }, { "n", 2 }, { "n", 3 } }; foreach (var p in parameters) { Console.WriteLine("{0} is {1}", p.Name, p.GetType().Name); } Console.WriteLine(parameters.ToStringParameters()); Console.WriteLine("-------------------------------------"); Console.WriteLine("Test 3"); parameters = new HttpParameterCollection { { "n[]", 1 }, { "n[]", 2 }, { "n[]", 3 } }; foreach (var p in parameters) { Console.WriteLine("{0} is {1}", p.Name, p.GetType().Name); } Console.WriteLine(parameters.ToStringParameters()); Console.WriteLine("-------------------------------------"); Console.WriteLine("Test 4"); var constructorInfo = typeof(System.Web.HttpPostedFile).GetConstructors(BindingFlags.NonPublic | BindingFlags.Instance).First(); var f = (System.Web.HttpPostedFile)constructorInfo.Invoke(new object[] { "oauth.png", "image/png", null }); parameters = new HttpParameterCollection { { "file", "test.dat", "text/plain", new byte[] { 1, 2, 3, 4, 5 } }, { "file2", "test2.dat", new byte[] { 1, 2, 3, 4, 5 } }, { "file3", "test3.dat", new MemoryStream(Properties.Resources.oauth) }, { "file4", f }, { "x", 123 }, { "y", 456 } }; foreach (var p in parameters) { Console.WriteLine("{0} is {1}", p.Name, p.GetType().Name); } Console.WriteLine(parameters.ToStringParameters()); Console.WriteLine("-------------------------------------"); Console.WriteLine("Test 5"); parameters = new HttpParameterCollection { { new byte[] { 1, 2, 3, 4, 5 } }, { "x", 123 }, { "y", 456 } }; foreach (var p in parameters) { Console.WriteLine("{0} is {1}", p.Name, p.GetType().Name); } Console.WriteLine(parameters.ToStringParameters()); Console.WriteLine("-------------------------------------"); Console.WriteLine("Test 6"); parameters = new HttpParameterCollection { { f }, { "x", 123 }, { "y", 456 } }; foreach (var p in parameters) { Console.WriteLine("{0} is {1}", p.Name, p.GetType().Name); } Console.WriteLine(parameters.ToStringParameters()); Console.WriteLine("-------------------------------------"); Console.WriteLine("Test 7"); parameters = new HttpParameterCollection { { Properties.Resources.oauth }, { "x", 123 }, { "x", 789 }, { "y", 456 } }; foreach (var p in parameters) { Console.WriteLine("{0} is {1}", p.Name, p.GetType().Name); } Console.WriteLine(parameters.ToStringParameters()); Console.WriteLine("-------------------------------------"); Console.WriteLine("Test 8"); object obj2 = Properties.Resources.oauth; parameters = new HttpParameterCollection { { obj2 } }; foreach (var p in parameters) { Console.WriteLine("{0} is {1}", p.Name, p.GetType().Name); } Console.WriteLine(parameters.ToStringParameters()); Console.WriteLine("-------------------------------------"); Console.WriteLine("Test 9"); var parameters2 = new NameValueCollection { { "a", "123" }, { "a", "245" }, { "b", "abc" } }; foreach (var p in (HttpParameterCollection)parameters2) { Console.WriteLine("{0} is {1}", p.Name, p.GetType().Name); } Console.WriteLine(((HttpParameterCollection)parameters2).ToStringParameters()); }
public void HttpParametersTest() { Console.WriteLine("Test 1"); object obj = null; string str = null; int? @int = null; var parameters = new HttpParameterCollection { { "test", obj }, { "test2", str }, { "test3", @int } }; foreach (var p in parameters) { Console.WriteLine("{0} is {1}", p.Name, p.GetType().Name); } Console.WriteLine(parameters.ToStringParameters()); Console.WriteLine("-------------------------------------"); Console.WriteLine("Test 2"); parameters = new HttpParameterCollection { { "n", 1 }, { "n", 2 }, { "n", 3 } }; foreach (var p in parameters) { Console.WriteLine("{0} is {1}", p.Name, p.GetType().Name); } Console.WriteLine(parameters.ToStringParameters()); Console.WriteLine("-------------------------------------"); Console.WriteLine("Test 3"); parameters = new HttpParameterCollection { { "n[]", 1 }, { "n[]", 2 }, { "n[]", 3 } }; foreach (var p in parameters) { Console.WriteLine("{0} is {1}", p.Name, p.GetType().Name); } Console.WriteLine(parameters.ToStringParameters()); Console.WriteLine("-------------------------------------"); Console.WriteLine("Test 4"); var constructorInfo = typeof(System.Web.HttpPostedFile).GetConstructors(BindingFlags.NonPublic | BindingFlags.Instance).First(); var f = (System.Web.HttpPostedFile)constructorInfo.Invoke(new object[] { "oauth.png", "image/png", null }); parameters = new HttpParameterCollection { { "file", "test.dat", "text/plain", new byte[] {1, 2, 3, 4, 5} }, { "file2", "test2.dat", new byte[] {1, 2, 3, 4, 5} }, { "file3", "test3.dat", new MemoryStream(Properties.Resources.oauth) }, { "file4", f }, { "x", 123 }, { "y", 456 } }; foreach (var p in parameters) { Console.WriteLine("{0} is {1}", p.Name, p.GetType().Name); } Console.WriteLine(parameters.ToStringParameters()); Console.WriteLine("-------------------------------------"); Console.WriteLine("Test 5"); parameters = new HttpParameterCollection { { new byte[] {1, 2, 3, 4, 5} }, { "x", 123 }, { "y", 456 } }; foreach (var p in parameters) { Console.WriteLine("{0} is {1}", p.Name, p.GetType().Name); } Console.WriteLine(parameters.ToStringParameters()); Console.WriteLine("-------------------------------------"); Console.WriteLine("Test 6"); parameters = new HttpParameterCollection { { f }, { "x", 123 }, { "y", 456 } }; foreach (var p in parameters) { Console.WriteLine("{0} is {1}", p.Name, p.GetType().Name); } Console.WriteLine(parameters.ToStringParameters()); Console.WriteLine("-------------------------------------"); Console.WriteLine("Test 7"); parameters = new HttpParameterCollection { { Properties.Resources.oauth }, { "x", 123 }, { "x", 789 }, { "y", 456 } }; foreach (var p in parameters) { Console.WriteLine("{0} is {1}", p.Name, p.GetType().Name); } Console.WriteLine(parameters.ToStringParameters()); Console.WriteLine("-------------------------------------"); Console.WriteLine("Test 8"); object obj2 = Properties.Resources.oauth; parameters = new HttpParameterCollection { { obj2 } }; foreach (var p in parameters) { Console.WriteLine("{0} is {1}", p.Name, p.GetType().Name); } Console.WriteLine(parameters.ToStringParameters()); Console.WriteLine("-------------------------------------"); Console.WriteLine("Test 9"); var parameters2 = new NameValueCollection { { "a", "123" }, { "a", "245" }, { "b", "abc" } }; foreach (var p in (HttpParameterCollection)parameters2) { Console.WriteLine("{0} is {1}", p.Name, p.GetType().Name); } Console.WriteLine(((HttpParameterCollection)parameters2).ToStringParameters()); }
public void ExecuteRequestTest() { Console.WriteLine("Test GET"); var parameters = new HttpParameterCollection { { "content", "hello world!" }, { "contentType", "text/plain" } }; var result = OAuthUtility.Get("http://api.foxtools.ru/v2/Http", parameters); if (result.ToString().IndexOf("hello world!") != -1) { Console.WriteLine("OK"); } else { Console.WriteLine(result); } Console.WriteLine("-------------------------------------"); Console.WriteLine("Test POST RequestBody"); parameters = new HttpParameterCollection { { Convert.FromBase64String("iVBORw0KGgoAAAANSUhEUgAAAFUAAABVCAYAAAA49ahaAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsIAAA7CARUoSoAAAAR/SURBVHhe7ZDRbiMxDAPv/3+6px62gDomzGVsb+4hA0wNiJSS5k/x9aSO3X3mp70+U4endOzuMz/t9Zk6PKVjd5/5aa/P1OEpHbv7zE97feY43Im7n+ZO4vJV1P16x+FO3P00dxKXr6Lu1zsOd+Lup7mTuHwVdb/ecbgTdz/NncTlq6j79Y7DDnMnSXNKVKdL0txJVF7vOOwwd5I0p0R1uiTNnUTl9Y7DDnMnSXNKVKdL0txJVF7vOOwwd5I0p0R1uiTNnUTl9Y7DDnMnSfNUh+szdxKV1zsOO8ydJM1THa7P3ElUXu847DB3kjRPdbg+cydReb3jsMPcSdI81eH6zJ1E5fWOww5zJ3E5cX3mlKS5k6i83nHYYe4kLieuz5ySNHcSldc7DjvMncTlxPWZU5LmTqLyesdhh7mTuJy4PnNK0txJVF7vONzJu++7fBV1v95xuJN333f5Kup+veNwJ+++7/JV1P16x+FO3n3f5auo+/X+Hp6WPJ2f9vpMHZ6SPJ2f9vpMHZ6SPJ2f9vpMHZ6SPJ2f9t9n/vv7RtSXmsE+/R/4/KgH+PyoB/j8qAeo73H2S7n7zKlD7cx0qJ2Zipr70gruPnPqUDszHWpnpqLmvrSCu8+cOtTOTIfamamouS+t4O4zpw61M9OhdmYq7KeoQzMdaqebom50HWpn5h0+P6rYmXmHz48qdmbe4fOjip2Zd6ieXv5xFXWzm+L2mVOH2pmpqLku/7iKutlNcfvMqUPtzFTUXJd/XEXd7Ka4febUoXZmKmquyz+uom52U9w+c+pQOzMVy7/anQ+ZwX2aku6z7yQqz781UEcTuE9T0n32nUTl+bcG6mgC92lKus++k6g8/9ZAHU3gPk1J99l3EpXn3xqoox2XO9J99qkj7Ste22q4L+FyR7rPPnWkfcVrWw33JVzuSPfZp460r3htq+G+hMsd6T771JH2Fa9tbYT/hJO43MF9+gqfHxX79BU+Pyr26St8flTs01eoPX3slClunzklae5U1FyXT5ni9plTkuZORc11+ZQpbp85JWnuVNRcl0+Z4vaZU5LmTkXNfWmFp++nEtXpEpXXOw538vT9VKI6XaLyesfhTp6+n0pUp0tUXu843MnT91OJ6nSJyusdhx3mTuJywj51qJ0ucTlhn16dcdhh7iQuJ+xTh9rpEpcT9unVGYcd5k7icsI+daidLnE5YZ9enXHYYe4kLifsU4fa6RKXE/bp1RmHHeZO4nJHun+6f4e6Mz/K3Elc7kj3T/fvUHfmR5k7icsd6f7p/h3qzvwocydxuSPdP92/Q92ZH2XuJC53uP2nc+e1Mw47zJ3E5Q63/3TuvHbGYYe5k7jc4fafzp3XzjjsMHcSlzvc/tO589oZhztJ77NPiep0HWpn5h2qly8lpPfZp0R1ug61M/MO1cuXEtL77FOiOl2H2pl5h+rlSwnpffYpUZ2uQ+3MvEP19PIpSZrvlqzm39T8d+m0JM13S1bzb2r+u3Rakua7Jav5NzX/XTotSfPdktX8Gz39sMDX11/4Q2CGtGAk5wAAAABJRU5ErkJggg==") }, { "test", 123 }, { new HttpFormParameter("x", "y") }, { new HttpFormParameter("a", "bc") }, { "contentType", "text/plain" } }; result = OAuthUtility.Post("http://api.foxtools.ru/v2/Http", parameters); Assert.IsTrue(result.ToString().IndexOf("PNG") != -1); Console.WriteLine("-------------------------------------"); Console.WriteLine("Test POST File"); parameters = new HttpParameterCollection { { new HttpFile("file1", "test.png", "image/png", Convert.FromBase64String("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")) }, { "dd", 20 }, { "id", 13 }, { new HttpFormParameter("key", "e91268b7-1162-4044-9236-7191c8c3b5d2") }, { "contentType", "text/plain" } }; result = OAuthUtility.Post("http://api.foxtools.ru/v2/Http", parameters); Assert.IsTrue(result.ToString().IndexOf("test.png") != -1); Assert.IsTrue(result.ToString().IndexOf("e91268b7-1162-4044-9236-7191c8c3b5d2") != -1); Console.WriteLine("OK"); Console.WriteLine("-------------------------------------"); Console.WriteLine("Test POST File from stream"); using (var fs = new FileStream(Path.Combine(AppDomain.CurrentDomain.SetupInformation.ApplicationBase, "oauth.dat"), FileMode.Open, FileAccess.Read, FileShare.ReadWrite)) { parameters = new HttpParameterCollection { { new HttpFile("file1", "123.png", "image/png", fs) }, { "dd", 20 }, { "id", 13 }, { "key", "e91268b7-1162-4044-9236-7191c8c3b5d2" }, { "contentType", "text/plain" } }; result = OAuthUtility.ExecuteRequest("POST", "http://api.foxtools.ru/v2/Http", parameters); Assert.IsTrue(result.ToString().IndexOf("123.png") != -1); Console.WriteLine("OK"); } Console.WriteLine("-------------------------------------"); Console.WriteLine("Test GET File"); result = OAuthUtility.Get("https://github.com/alekseynemiro/nemiro.oauth.dll/archive/master.zip"); if (result.IsFile) { Console.WriteLine("File: {0}", result.FileName); var b = (byte[])result; // test of type conversion Console.WriteLine("Size: {0} Kb", b.Length / 1024); } else { Console.WriteLine(result.ToString()); Assert.Fail(); } }
/// <summary> /// Performs an async request using a <b>DELETE</b> method. /// </summary> /// <param name="endpoint">URL to which will be sent to request.</param> /// <param name="parameters">Parameters to be passed to request.</param> /// <param name="authorization">Authorization header value.</param> /// <param name="headers">HTTP headers for request.</param> /// <param name="callback">A delegate that, if provided, is called when an async request is completed.</param> /// <param name="accessToken">Access token to be used in the request.</param> /// <remarks> /// <para>Can not be used simultaneously <paramref name="accessToken"/> and <paramref name="authorization"/>. Use only one of these parameters.</para> /// </remarks> /// <returns>Returns an instance of the <see cref="RequestResult"/> class, which contains the result of the request.</returns> /// <exception cref="System.ArgumentNullException"></exception> /// <exception cref="RequestException"></exception> /// <exception cref="ArgumentException"> /// <para>The exception occurs when the query parameters are specified at the same time <paramref name="authorization"/> and <paramref name="accessToken"/>.</para> /// </exception> public static void DeleteAsync(string endpoint = null, HttpParameterCollection parameters = null, HttpAuthorization authorization = null, NameValueCollection headers = null, AccessToken accessToken = null, ExecuteRequestAsyncCallback callback = null) { OAuthUtility.ExecuteRequestAsync("DELETE", endpoint, parameters, authorization, headers, null, accessToken, callback); }
public void HttpParametersTest() { Console.WriteLine("Test 1"); object obj = null; string str = null; int? @int = null; var parameters = new HttpParameterCollection { { "test", obj }, { "test2", str }, { "test3", @int } }; foreach (var p in parameters) { Assert.AreEqual(HttpParameterType.Unformed, p.ParameterType); Console.WriteLine("{0} is {1}", p.Name, p.GetType().Name); } string r = parameters.ToStringParameters(); Assert.AreEqual("test=&test2=&test3=", r); Console.WriteLine(r); Console.WriteLine("-------------------------------------"); Console.WriteLine("Test 2"); parameters = new HttpParameterCollection { { "n", 1 }, { "n", 2 }, { "n", 3 } }; foreach (var p in parameters) { Console.WriteLine("{0} is {1}", p.Name, p.GetType().Name); } r = parameters.ToStringParameters(); Assert.AreEqual("n=1&n=2&n=3", r); Console.WriteLine(r); Console.WriteLine("-------------------------------------"); Console.WriteLine("Test 3"); parameters = new HttpParameterCollection { { "n[]", 1 }, { "n[]", 2 }, { "n[]", 3 } }; foreach (var p in parameters) { Console.WriteLine("{0} is {1}", p.Name, p.GetType().Name); } r = parameters.ToStringParameters(); Assert.AreEqual("n%5b%5d=1&n%5b%5d=2&n%5b%5d=3", r); Console.WriteLine(r); Console.WriteLine("-------------------------------------"); Console.WriteLine("Test 4"); var constructorInfo = typeof(System.Web.HttpPostedFile).GetConstructors(BindingFlags.NonPublic | BindingFlags.Instance).First(); var f = (System.Web.HttpPostedFile)constructorInfo.Invoke(new object[] { "oauth.png", "image/png", null }); parameters = new HttpParameterCollection { { "file", "test.dat", "text/plain", new byte[] { 1, 2, 3, 4, 5 } }, { "file2", "test2.dat", new byte[] { 1, 2, 3, 4, 5 } }, { "file3", "test3.dat", new MemoryStream(Properties.Resources.oauth) }, { "file4", f }, { "x", 123 }, { "y", 456 } }; for (int i = 0; i < parameters.Count; i++) { var p = parameters[i]; if (i < 3) { Assert.AreEqual(HttpParameterType.File, p.ParameterType); } Console.WriteLine("{0} is {1}", p.Name, p.GetType().Name); } r = parameters.ToStringParameters(); Assert.AreEqual("x=123&y=456", r); Console.WriteLine(r); Console.WriteLine("-------------------------------------"); Console.WriteLine("Test 5"); parameters = new HttpParameterCollection { { new byte[] { 1, 2, 3, 4, 5 } }, { "x", 123 }, { "y", 456 } }; for (int i = 0; i < parameters.Count; i++) { var p = parameters[i]; if (i == 0) { Assert.AreEqual(HttpParameterType.RequestBody, p.ParameterType); } Console.WriteLine("{0} is {1}", p.Name, p.GetType().Name); } r = parameters.ToStringParameters(); Assert.AreEqual("x=123&y=456", r); Console.WriteLine(r); Console.WriteLine("-------------------------------------"); Console.WriteLine("Test 6"); parameters = new HttpParameterCollection { { f }, { "x", 123 }, { "y", 456 } }; for (int i = 0; i < parameters.Count; i++) { var p = parameters[i]; if (i == 0) { Assert.AreEqual(HttpParameterType.RequestBody, p.ParameterType); } Console.WriteLine("{0} is {1}", p.Name, p.GetType().Name); } r = parameters.ToStringParameters(); Assert.AreEqual("x=123&y=456", r); Console.WriteLine(r); Console.WriteLine("-------------------------------------"); Console.WriteLine("Test 7"); parameters = new HttpParameterCollection { { Properties.Resources.oauth }, { "x", 123 }, { "x", 789 }, { "y", 456 } }; foreach (var p in parameters) { Console.WriteLine("{0} is {1}", p.Name, p.GetType().Name); } r = parameters.ToStringParameters(); Assert.AreEqual("x=123&x=789&y=456", r); Console.WriteLine(r); Console.WriteLine("-------------------------------------"); Console.WriteLine("Test 8"); object obj2 = Properties.Resources.oauth; parameters = new HttpParameterCollection { { obj2 } }; for (int i = 0; i < parameters.Count; i++) { var p = parameters[i]; if (i == 0) { Assert.AreEqual(HttpParameterType.RequestBody, p.ParameterType); } Console.WriteLine("{0} is {1}", p.Name, p.GetType().Name); } Console.WriteLine(parameters.ToStringParameters()); Console.WriteLine("-------------------------------------"); Console.WriteLine("Test 9"); var parameters2 = new NameValueCollection { { "a", "123" }, { "a", "245" }, { "b", "abc" } }; foreach (var p in (HttpParameterCollection)parameters2) { Console.WriteLine("{0} is {1}", p.Name, p.GetType().Name); } r = ((HttpParameterCollection)parameters2).ToStringParameters(); Assert.AreEqual("a=123%2c245&b=abc", r); Console.WriteLine(r); }
public static void ExecuteRequestAsync(string method = "POST", string endpoint = null, HttpParameterCollection parameters = null, HttpAuthorization authorization = null, NameValueCollection headers = null, string contentType = null, AccessToken accessToken = null, ExecuteRequestAsyncCallback callback = null, bool allowWriteStreamBuffering = false, bool allowSendChunked = true, long contentLength = -1, HttpWriteRequestStream streamWriteCallback = null, int writeBufferSize = 4096, int readBufferSize = 4096, bool donotEncodeKeys = false) { new Thread((ThreadStart)(() => { RequestResult result; try { result = OAuthUtility.ExecuteRequest(method, endpoint, parameters, authorization, headers, contentType, accessToken, allowWriteStreamBuffering, allowSendChunked, contentLength, streamWriteCallback, writeBufferSize, readBufferSize, donotEncodeKeys); } catch (RequestException ex) { result = ex.RequestResult; } if (callback == null) { return; } callback(result); })) { IsBackground = true }.Start(); }
/// <summary> /// Performs a request using a <b>DELETE</b> method. /// </summary> /// <param name="endpoint">URL to which will be sent to the request.</param> /// <param name="parameters">Parameters to be passed to the request.</param> /// <param name="authorization">Authorization header value.</param> /// <param name="headers">HTTP headers for the request.</param> /// <param name="accessToken">Access token to be used in the request.</param> /// <returns>Returns an instance of the <see cref="RequestResult"/> class, which contains the result of the request.</returns> /// <remarks> /// <para>Can not be used simultaneously <paramref name="accessToken"/> and <paramref name="authorization"/>. Use only one of these parameters.</para> /// </remarks> /// <exception cref="System.ArgumentNullException"></exception> /// <exception cref="RequestException"></exception> /// <exception cref="ArgumentException"> /// <para>The exception occurs when the query parameters are specified at the same time <paramref name="authorization"/> and <paramref name="accessToken"/>.</para> /// </exception> public static RequestResult Delete(string endpoint = null, HttpParameterCollection parameters = null, HttpAuthorization authorization = null, NameValueCollection headers = null, AccessToken accessToken = null) { return OAuthUtility.ExecuteRequest("DELETE", endpoint, parameters, authorization, headers, null, accessToken); }
internal override void Build(string httpMethod, string url, string contentType, HttpParameterCollection parameters) { NameValueCollection param = null; if (parameters != null) { if (!String.IsNullOrEmpty(contentType) && contentType.ToLower().Contains("multipart/form-data")) { param = ((HttpParameterCollection)parameters.Where(itm => itm.ParameterType == HttpParameterType.Url).ToArray()).ToNameValueCollection(); } else { param = parameters.ToNameValueCollection(); } } this.Signature = new OAuthSignature ( this.SignatureMethod.ToString(), String.Format("{0}&{1}", this.ConsumerSecret, this.TokenSecret), OAuthAuthorization.GetSignatureBaseString(httpMethod, url, param, this) ).ToString(); }
/// <summary> /// Performs a request. /// </summary> /// <param name="method">HTTP Method: <b>POST</b> (default), <b>PUT</b>, <b>GET</b> or <b>DELETE</b>.</param> /// <param name="endpoint">URL to which will be sent to request.</param> /// <param name="parameters">Parameters to be passed to request.</param> /// <param name="authorization">Authorization header value.</param> /// <param name="headers">HTTP headers for web request.</param> /// <param name="contentType">The value of the <b>Content-Type</b> HTTP header.</param> /// <param name="accessToken">Access token to be used in the request.</param> /// <remarks> /// <para>Can not be used simultaneously <paramref name="accessToken"/> and <paramref name="authorization"/>. Use only one of these parameters.</para> /// </remarks> /// <returns>Returns an instance of the <see cref="RequestResult"/> class, which contains the result of the request.</returns> /// <exception cref="System.ArgumentNullException"></exception> /// <exception cref="RequestException"></exception> /// <exception cref="ArgumentException"> /// <para>The exception occurs when the query parameters are specified at the same time <paramref name="authorization"/> and <paramref name="accessToken"/>.</para> /// </exception> public static RequestResult ExecuteRequest(string method = "POST", string endpoint = null, HttpParameterCollection parameters = null, HttpAuthorization authorization = null, NameValueCollection headers = null, string contentType = null, AccessToken accessToken = null) { // checking if (String.IsNullOrEmpty(endpoint)) { throw new ArgumentNullException("endpoint"); } if (!AccessToken.IsNullOrEmpty(accessToken) && authorization != null) { throw new ArgumentException("The request can not contain both authorization headers and access token."); } // set default values if (!String.IsNullOrEmpty(method)) { method = method.ToUpper(); } string[] post = { "POST", "PUT" }; if (String.IsNullOrEmpty(method) || (parameters != null && (parameters.HasFiles || parameters.IsRequestBody) && Array.IndexOf(post, method) == -1)) { method = "POST"; } bool isPost = Array.IndexOf(post, method) != -1; // set protocols ServicePointManager.SecurityProtocol = SecurityProtocolType.Tls; // ignore errors ServicePointManager.ServerCertificateValidationCallback = (sender, cert, chain, sslPolicyErrors) => true; // -- // access token if (!AccessToken.IsNullOrEmpty(accessToken)) { if (accessToken.GetType() == typeof(OAuth2AccessToken) || accessToken.GetType().IsSubclassOf(typeof(OAuth2AccessToken))) { // is oauth 2.0 var token = (OAuth2AccessToken)accessToken; if (!String.IsNullOrEmpty(token.TokenType) && (token.TokenType.Equals(AccessTokenType.Bearer, StringComparison.OrdinalIgnoreCase))) // || token.TokenType.Equals(AccessTokenType.OAuth, StringComparison.OrdinalIgnoreCase) { // bearer authorization = new HttpAuthorization(AuthorizationType.Bearer, accessToken.Value); } else { // other if (parameters == null) { parameters = new HttpParameterCollection(); } parameters.AddUrlParameter("access_token", accessToken.Value); } } else if (accessToken.GetType() == typeof(OAuthAccessToken) || accessToken.GetType().IsSubclassOf(typeof(OAuthAccessToken))) { // is oauth 1.0 authorization = new OAuthAuthorization(accessToken); } else { // I do not know that. But it's definitely need to consider. if (parameters == null) { parameters = new HttpParameterCollection(); } parameters.AddUrlParameter("access_token", accessToken.Value); } } // -- string requestUrl = endpoint; // need source endpoint for signature if (!isPost && parameters != null && parameters.Count > 0) { // set parameters to the URL if the request is executed using the GET method requestUrl += (requestUrl.Contains("?") ? "&" : "?"); requestUrl += parameters.ToStringParameters(); } else if (isPost && parameters != null && parameters.Count > 0) { // is POST or PUT method if (parameters.IsRequestBody) { // all parameters to url HttpParameterCollection p = parameters.Where(itm => itm.ParameterType != HttpParameterType.RequestBody).ToArray(); if (p.Count > 0) { requestUrl += (requestUrl.Contains("?") ? "&" : "?"); requestUrl += p.ToStringParameters(); } } else { // url parameters to endpoint HttpParameterCollection p = parameters.Where(itm => itm.ParameterType == HttpParameterType.Url).ToArray(); if (p.Count > 0) { requestUrl += (requestUrl.Contains("?") ? "&" : "?"); requestUrl += p.ToStringParameters(); } } } // create request var req = (HttpWebRequest)HttpWebRequest.Create(requestUrl); // http method req.Method = method; // req.ProtocolVersion = HttpVersion.Version10; // user-agent (required for some providers) req.UserAgent = "Nemiro.OAuth"; // json format acceptable for the response req.Accept = "application/json"; // set parameters to the body if the request is executed using the POST method if (isPost) { if (parameters != null && parameters.Count > 0) { req.ContentType = contentType; parameters.WriteToRequestStream(req); } else { // for some servers req.ContentLength = 0; } } // set authorization header if (authorization != null) { // build authorization authorization.Build(method, endpoint, req.ContentType, parameters); // add authorization to headers if (headers == null) { headers = new NameValueCollection(); } if (String.IsNullOrEmpty(headers["Authorization"])) { headers.Add("Authorization", authorization.ToString()); } else { headers["Authorization"] = authorization.ToString(); } } // headers if (headers != null) { req.Headers.Add(headers); } WebHeaderCollection rh = null; Exception exception = null; string ct = ""; int status = 0; byte[] result; try { // executes the request using (var resp = (HttpWebResponse)req.GetResponse()) { ct = resp.ContentType; rh = resp.Headers; status = (int)resp.StatusCode; result = OAuthUtility.ReadResponseStream(resp); } } catch (WebException ex) { // web exception, if (ex.Response != null) { // reading contents of the response using (var resp = (HttpWebResponse)ex.Response) { ct = resp.ContentType; rh = resp.Headers; status = (int)resp.StatusCode; result = OAuthUtility.ReadResponseStream(resp); } } else { // no response, get error message result = Encoding.UTF8.GetBytes(ex.Message); } exception = ex; } catch (Exception ex) { // other exception result = Encoding.UTF8.GetBytes(ex.Message); exception = ex; } // exception if (exception != null) { throw new RequestException(ct, result, exception, rh, status); } // result return new RequestResult(ct, result, rh, status); }