public void saveAccessToken(AccessToken token)
        {

            var accesstokenInsertQuery = Resource.ResourceManager.GetString("socialmedia_insert");
            sql_con = new SQLiteConnection(Common.localDatabasePath, true);
            sql_cmd = new SQLiteCommand(accesstokenInsertQuery, sql_con);

            sql_cmd.Parameters.Add("@id", DbType.String);
            sql_cmd.Parameters["@id"].Value = Common.userName;

            sql_cmd.Parameters.Add("@socialMediaType", DbType.String);
            sql_cmd.Parameters["@socialMediaType"].Value = token.tokenType;

            sql_cmd.Parameters.Add("@user_oauth_token", DbType.String);
            sql_cmd.Parameters["@user_oauth_token"].Value = token.tokenValue;

            sql_cmd.Parameters.Add("@is_user_oauth_done", DbType.Int16);
            sql_cmd.Parameters["@is_user_oauth_done"].Value = 1;

            sql_cmd.Parameters.Add("@user_oauth_token_expire_in", DbType.UInt64);
            sql_cmd.Parameters["@user_oauth_token_expire_in"].Value = 1;

            sql_cmd.Parameters.Add("@user_oauth_token_secret_key", DbType.String);
            sql_cmd.Parameters["@user_oauth_token_secret_key"].Value = token.tokenValue;

            sql_con.Open();
            sql_cmd.ExecuteNonQuery();
            sql_con.Close();

        }
Example #2
0
        public virtual void SetupClient()
        {
            Configure();

            FreeAgentClient.UseSandbox = KeyStorage.UseSandbox;
            if (KeyStorage.UseProxy) FreeAgentClient.Proxy = new WebProxy("127.0.0.1", 8888);

            Client = new FreeAgentClient(KeyStorage.AppKey, KeyStorage.AppSecret);

            var sandbox_bttest_token = new AccessToken
            {
                access_token = "",
                refresh_token = KeyStorage.RefreshToken,
                token_type = "bearer"
            };

            Client.CurrentAccessToken = sandbox_bttest_token;

            Token = Client.RefreshAccessToken();

            if (Token == null || string.IsNullOrEmpty(Token.access_token) || string.IsNullOrEmpty(Token.refresh_token))
            {
                throw new Exception("Could not setup the Token");
            }
        }
Example #3
0
        public override void After( object returnValue, MethodInfo method, object[] args, object target )
        {
            Microblog blog = args[0] as Microblog;

            if (blog == null || blog.ParentId > 0) return;
            if (blog.User == null || blog.User.Id <= 0) return;

            if (QQWeiboJobHelper.IsQQWeiboSync( blog.Id )) return; // 是否已经同步过

            UserConnect uc = connectService.GetConnectInfo( blog.User.Id, typeof( QQConnect ).FullName );

            // 1. 检查:用户是否绑定,是否允许同步
            if (uc == null) return; // 绑定
            if (uc.NoSync == 1) {
                logger.Info( "取消同步,因为用户明确禁止" );
                return;
            }

            // 2. 获取 access token
            AccessToken x = new AccessToken();
            x.Token = uc.AccessToken;
            x.Uid = uc.Uid;

            // 3. 同步
            QQConnect connect = AuthConnectFactory.GetConnect( typeof( QQConnect ).FullName ) as QQConnect;
            connect.Publish( x, _blogContent, getPicDiskPath( blog.Pic ) );

            // 设置已经同步标记
            QQWeiboJobHelper.AddQQWeiboSyncItem( blog.Id );
        }
Example #4
0
        public ActionResult Create(AccessToken accessToken)
        {
            var accessTokenToCreate = new AccessToken();

            Mapper.Map(accessToken, accessTokenToCreate);

            accessTokenToCreate.SetNewToken();

            accessTokenToCreate.TransferValidationMessagesTo(ModelState);

            if (ModelState.IsValid)
            {
                _accessTokenRepository.EnsurePersistent(accessTokenToCreate);

                Message = "AccessToken Created Successfully";

                return RedirectToAction("Details", new { id = accessTokenToCreate.Id });
            }
            else
            {
                var viewModel = AccessTokenViewModel.Create(Repository);
                viewModel.AccessToken = accessToken;

                return View(viewModel);
            }
        }
    protected void btnAddResources_Click(object sender, EventArgs e)
    {
        try
        {
            if (ddlGroupName.SelectedIndex != 0)
            {
                //GetPermission(TireTraxLib.ResourceType.PagePermissions, ref canView, ref canAdd, ref canUpdate, ref canDelete,ddlGroupName.SelectedValue);
                //if (!canUpdate)
                //{
                //    lblInfo.Text = "Sorry, you dont have right to change the premission";
                //}
                //else
                //{
                int groupId = Convert.ToInt32(ddlGroupName.SelectedValue.ToString());
                AccessToken token = new AccessToken();
                string accessToken = AccessToken.ReturnEmptyToken();
                if (chkAdmin.Checked)
                    accessToken = token.AdminToken(64, accessToken);
                else
                    accessToken = ReadPermissions(accessToken, token);

                RoleManagement.UpdateSecurityToken(groupId, accessToken);

                //it is used to update the Security token for Roles
                DataTable dt = RoleManagement.getDistinctRolesByGroupId(groupId);
                if (dt != null && dt.Rows.Count > 0)
                {
                    for (int i = 0; i < dt.Rows.Count; i++)
                    {
                        int TempRoleId = Conversion.ParseInt(dt.Rows[i]["RoleId"]);
                        int TempSubRoleId = Conversion.ParseInt(dt.Rows[i]["SubRoleId"]);
                        regenerateSecurityTokens(TempRoleId, TempSubRoleId);
                    }
                }
                lblInfo.ForeColor = System.Drawing.Color.Green;
                lblInfo.Text = "Permission is Successfully Added";

                //Update Cookies
                // UserInfo user = UserInfo.GetCurrentUserInfo();
                Response.Cookies["securityToken"].Expires = DateTime.Now.AddMinutes(-1);
                string securityToken = string.Empty;
                securityToken = RoleManagement.GetSecurityTokenByRoleId(groupId);
                //HttpCookie securityCookie = new HttpCookie("securityToken");
                //Decoder d= Encoding.UTF8.GetDecoder();

                //securityCookie.Value = Server.UrlEncode(securityToken);
                //HttpContext.Current.Response.Cookies.Add(securityCookie);
                // }
            }
            else
            {
                lblInfo.ForeColor = System.Drawing.Color.Red;
                lblInfo.Text = "Please Select the Group";
            }
        }
        catch (Exception ex)
        {
            new SqlLog().InsertSqlLog(0, "PagePermission.aspx btnAddResources_Click", ex);
        }
    }
        /// <summary>
        /// Saves the user access token.
        /// </summary>
        /// <param name="username">The username.</param>
        /// <param name="serviceId">The service id.</param>
        /// <param name="accessToken">The access token.</param>
        /// <param name="cancellationToken">The cancellation token.</param>
        /// <returns>The task that represents the save action.</returns>
        public Task SaveUserAccessToken(string username, string serviceId, AccessToken accessToken, CancellationToken cancellationToken)
        {
            Requires.NotNullOrEmpty(username, "username");
            Requires.NotNullOrEmpty(serviceId, "serviceId");
            Requires.NotNull(accessToken, "accessToken");

            return this.SaveAccessToken(NormalizeUsername(username), serviceId, accessToken, cancellationToken);
        }
Example #7
0
        public static string SendEmailNotifications()
        {
            StringBuilder output = new StringBuilder();

            NetflixConnection conn = new NetflixConnection(ConfigurationManager.AppSettings["NetflixConsumerKey"], ConfigurationManager.AppSettings["NetflixConsumerSecret"]);

            DatabaseDataContext db = new DatabaseDataContext();
            foreach (returnflix.Common.User u in db.Users)
            {
                try
                {
                    output.AppendFormat("Executing Netflix account for {0} {1}...<br />", u.FirstName, u.LastName);

                    AccessToken accTok = new AccessToken(u.NetflixUserID, u.NetflixAccessToken, u.NetflixAccessTokenSecret);

                    System.Xml.Linq.XElement atHomeFeed = conn.RequestXmlResource(NetflixUrls.GetUsersAtHome(accTok, 0, 10, DateTime.Now.AddDays(-7)), accTok);
                    string currentMovie = atHomeFeed.Elements("at_home_item").First().Element("title").Attribute("regular").Value;
                    int currentMovieDays = DateTime.Now.Subtract(UnixTimeToDateTime(atHomeFeed.Elements("at_home_item").First().Element("estimated_arrival_date").Value)).Days;

                    System.Xml.Linq.XElement queueFeed = conn.RequestXmlResource(NetflixUrls.GetUsersQueuesDiscAvailable(accTok, QueueSortOrder.QueueSequence, 0, 10, DateTime.Now.AddYears(-1)), accTok);
                    string nextMovie = queueFeed.Elements("queue_item").First().Element("title").Attribute("regular").Value;

                    output.AppendFormat("\"{0}\" has been at home for {1} days.<br />", currentMovie, currentMovieDays);

                    if (DateTime.Now.Subtract(u.LastNotificationDate).Days >= 3 &&
                        currentMovieDays >= 7)
                    {
                        System.Net.Mail.MailMessage msg = new System.Net.Mail.MailMessage();
                        msg.From = new System.Net.Mail.MailAddress(ConfigurationManager.AppSettings["SmtpEmailAddress"], "Returnflix");
                        msg.To.Add(u.EmailAddress);
                        msg.Subject = string.Format("Don't Forget to Return \"{0}\" to Netflix", currentMovie);
                        msg.Body = string.Format("Hi {0},\n\nHave you had a chance to watch \"{1}\"? This movie has been at home for a week now. You should return this DVD to Netflix soon so that you can receive your next movie, \"{2}\".\n\nThanks!\n\n--\nReturnflix\nhttp://returnflix.com\n\nTired of the reminders? Unsubscribe at http://returnflix.com/unsubscribe.aspx?id={3}", u.FirstName, currentMovie, nextMovie, u.NetflixUserID);
                        msg.IsBodyHtml = false;

                        System.Net.Mail.SmtpClient smtp = new System.Net.Mail.SmtpClient();
                        smtp.Host = ConfigurationManager.AppSettings["SmtpHost"];
                        smtp.Port = Convert.ToInt32(ConfigurationManager.AppSettings["SmtpPort"]);
                        smtp.Credentials = new System.Net.NetworkCredential(ConfigurationManager.AppSettings["SmtpUsername"], ConfigurationManager.AppSettings["SmtpPassword"]);

                        output.AppendFormat("Sending message to {0} {1} ({2}).<br />", u.FirstName, u.LastName, u.EmailAddress);

                        smtp.Send(msg);

                        u.LastNotificationDate = DateTime.Now;
                    }
                }
                catch (Exception ex)
                {
                    output.AppendFormat("Failed due to {0}.<br />", ex.Message);
                }

                output.AppendFormat("Done.<br /><br />");
            }

            db.SubmitChanges();

            return output.ToString();
        }
Example #8
0
 //-----------------------------------------------------------------------------
 public virtual JsonObject Publish( AccessToken accessToken, String content, String absPic )
 {
     if (strUtil.IsNullOrEmpty( absPic )) {
         return PublishPost( accessToken, content );
     }
     else {
         return PublishPic( accessToken, content, absPic );
     }
 }
Example #9
0
        public override BaseResponse Execute()
        {
            if (string.IsNullOrEmpty(appid))
            {
                throw new Exception("invalid appid");
            }

            if (string.IsNullOrEmpty(secret))
            {
                throw new Exception("invalid secret");
            }

            AccessTokenResponse tokenRes = null;
            NameValueCollection col = new NameValueCollection();
            col.Add("grant_type", "client_credential");
            col.Add("appid", this.appid);
            col.Add("secret", this.secret);
            DateTime now = DateTime.Now;
            string res = HttpSercice.PostHttpRequest(this.url, col, RequestType.GET, null);
            if(!string.IsNullOrEmpty(res))
            {
                JObject json = null;
                try
                {
                    json = JObject.Parse(res);
                    if(json!=null)
                    {
                        tokenRes = new AccessTokenResponse();
                        AccessToken accessToken = new AccessToken();
                        accessToken.Access_Token = json["access_token"]!=null? json["access_token"].ToString():"";
                        if(!string.IsNullOrEmpty(accessToken.Access_Token))
                        {
                            accessToken.ExpiresIn = json["expires_in"] != null ? int.Parse(json["expires_in"].ToString()) : 0;
                        }
                        accessToken.ExpiresTime = now.AddSeconds(accessToken.ExpiresIn);
                        if(!string.IsNullOrEmpty(accessToken.Access_Token) && accessToken.ExpiresIn>0)
                        {
                            tokenRes.Access_Token = accessToken;
                        }

                        if(json["errcode"]!=null)
                        {
                            tokenRes.err_code = json["errcode"].ToString();
                        }
                        if (json["errmsg"] != null)
                        {
                            tokenRes.err_code_des = json["errmsg"].ToString();
                        }
                    }
                }
                catch
                {
                }
            }
            return tokenRes;
        }
Example #10
0
        public static AccessToken AccessToken(int? counter)
        {
            var rtValue = new AccessToken();
            rtValue.Reason = "Reason" + counter.Extra();
            rtValue.SetNewToken();
            rtValue.ContactEmail = "test" + counter.Extra() + "@testy.com";
            rtValue.Application = new Application(); //Need to replace...

            return rtValue;
        }
Example #11
0
        public SinaWeiboService(string accessToken, string accessTokenSecret)
        {
            if (accessToken.IsNullOrEmpty())
                throw new ArgumentException("accessToken不能为空", "accessToken");

            if (accessTokenSecret.IsNullOrEmpty())
                throw new ArgumentException("accessTokenSecret不能为空", "accessTokenSecret");

            var token = new AccessToken(ConsumerFactory.SinaConsumer, accessToken, accessTokenSecret);
            _weiboClient = new WeiboClient(token, ResultFormat.json);
        }
Example #12
0
        /// <summary>
        /// <para>Direct auth with login and password.</para>
        /// <para>See also: <seealso cref="http://vk.com/pages?oid=-1&p=Прямая_авторизация"/></para>
        /// </summary>
        /// <param name="login">Login</param>
        /// <param name="password">Password</param>
        /// <param name="scopeSettings">Scope settings</param>
        /// <param name="captchaSid">Captcha sid</param>
        /// <param name="captchaKey">Captcha key</param>
        /// <returns><see cref="AccessToken"/></returns>
        public async Task<AccessToken> Login(string login, string password, VkScopeSettings scopeSettings = VkScopeSettings.CanAccessFriends, 
            string captchaSid = null, string captchaKey = null)
        {
            if (string.IsNullOrEmpty(_vkontakte.AppId))
                throw new NullReferenceException("App id must be specified.");

            if (string.IsNullOrEmpty(_vkontakte.ClientSecret))
                throw new NullReferenceException("Client secret must be specified.");

            var parameters = new Dictionary<string, string>
            {
                {"username", login},
                {"password", password},
                {"grant_type", "password"},
                {"scope", ((int) scopeSettings).ToString(CultureInfo.InvariantCulture)}
            };

            if (!string.IsNullOrEmpty(captchaSid) && !string.IsNullOrEmpty(captchaKey))
            {
                parameters.Add("captcha_sid", captchaSid);
                parameters.Add("captcha_key", captchaKey);
            }

            parameters.Add("client_id", _vkontakte.AppId);
            parameters.Add("client_secret", _vkontakte.ClientSecret);

            var request = new VkRequest(new Uri(VkConst.DirectAuthUrl), parameters);
            var response = await request.Execute();

            if (response["error"] != null)
            {
                switch (response["error"].Value<string>())
                {
                    case "need_captcha":
                        throw new VkCaptchaNeededException(response["captcha_sid"].Value<string>(), response["captcha_img"].Value<string>());

                    case "invalid_client":
                        throw new VkInvalidClientException();

                    case "need_validation":
                        throw new VkNeedValidationException() { RedirectUri = new Uri(response["redirect_uri"].Value<string>()) };
                }

                return null;
            }

            var token = new AccessToken();
            token.Token = response["access_token"].Value<string>();
            token.UserId = response["user_id"].Value<long>();
            token.ExpiresIn = response["expires_in"].Value<long>() == 0 ? DateTime.MaxValue : DateTimeExtensions.UnixTimeStampToDateTime(response["expires_in"].Value<long>());
            _vkontakte.AccessToken = token;
            return token;
        }
		/// <summary>
		/// Reads an access token to find out what data it authorizes access to.
		/// </summary>
		/// <param name="message">The message carrying the access token.</param>
		/// <param name="accessToken">The access token's serialized representation.</param>
		/// <returns>The deserialized, validated token.</returns>
		/// <exception cref="ProtocolException">Thrown if the access token is expired, invalid, or from an untrusted authorization server.</exception>
		public virtual AccessToken DeserializeAccessToken(IDirectedProtocolMessage message, string accessToken) {
			ErrorUtilities.VerifyProtocol(!string.IsNullOrEmpty(accessToken), ResourceServerStrings.MissingAccessToken);
			var accessTokenFormatter = AccessToken.CreateFormatter(this.AuthorizationServerPublicSigningKey, this.ResourceServerPrivateEncryptionKey);
			var token = new AccessToken();
			try {
				accessTokenFormatter.Deserialize(token, accessToken, message, Protocol.access_token);
			} catch (IOException ex) {
				throw new ProtocolException(ResourceServerStrings.InvalidAccessToken, ex);
			}

			return token;
		}
Example #14
0
		public IToken IssueAccessTokenForResourceOwner(ITokenContext context)
		{

			AccessToken token = new AccessToken
			{
				ExpiresIn = 120,
				Token = Guid.NewGuid().ToString(),
				RefreshToken = Guid.NewGuid().ToString(),
				Scope = new string[] { "create", "delete", "view" },
			};
			TokenRepo.AddAccessToken(token);
			return token;

		}
Example #15
0
 public static void SetLoginVk(AccessToken token)
 {
     if (token == null || token.Token == null)
     {
         throw new ArgumentException("AccessToken is empty");
     }
     else
     {
         _vkontakte.AccessToken = token;
         Settings.Instance.AccessToken = token;
         Settings.Instance.Save();
         Messenger.Default.Send(new LoginMessage() { Type = LoginType.LogIn, Service = "vk" });
     }
 }
Example #16
0
		public IToken IssueAccessTokenForResourceOwner(ITokenContext context)
		{
            var authorizationGrant = this.TokenRepo.FindAuthorizationGrant(context.AuthorizationCode);
			AccessToken token = new AccessToken
			{
				ExpiresIn = 120,
				Token = Guid.NewGuid().ToString(),
				RefreshToken = Guid.NewGuid().ToString(),
                //Scope = authorizationGrant.Scope.Split(' '),
			};
			TokenRepo.AddAccessToken(token);
			return token;

		}
Example #17
0
		public IToken IssueAccessToken(IAuthorizationGrant grant)
		{
			//typically here you'd fetch your access
			AccessToken token = new AccessToken
			{
				ExpiresIn = 120,
				Token = Guid.NewGuid().ToString(),
				Grant = (AuthorizationGrant)grant
			};
			token.Scope = ((AuthorizationGrant)grant).Scope.Split(' ');

			TokenRepo.AddAccessToken(token);
			return token;

		}
Example #18
0
		public IToken IssueAccessToken(ClientBase client)
		{

			AccessToken token = new AccessToken
			{
				ExpiresIn = 120,
				Token = Guid.NewGuid().ToString(),
				Scope = new string[] { "create-member" },
				Client = (Client)client
			};

			TokenRepo.AddAccessToken(token);

			return token;
		}
Example #19
0
        public static string GetAccessToken()
        {
            string newAccessToken = String.Empty;
            int weChatExpiresIn = 0;
            using (WeChatDbContext entity = new WeChatDbContext())
            {
                var accesstoken = (from item in entity.AccessTokens orderby item.AccessTokenId descending select item).FirstOrDefault();
                if (accesstoken == null)
                {
                    WebClient wc = new WebClient();
                    byte[] data = null;
                    data = wc.DownloadData(String.Format(WeChatWebAPI.GetAccessToken, appId, appSecret));
                    string strWebData = Encoding.Default.GetString(data);
                    var accessTokenModel = (JObject)JsonConvert.DeserializeObject(strWebData);
                    newAccessToken = accessTokenModel["access_token"].ToString();
                    weChatExpiresIn = Int32.Parse(accessTokenModel["expires_in"].ToString());

                    AccessToken at = new AccessToken();
                    at.AccessTokenStr = newAccessToken;
                    at.ExpiresIn = weChatExpiresIn;
                    at.LastUpdateTime = DateTime.Now;
                    entity.AccessTokens.Add(at);
                    entity.SaveChanges();
                }
                else
                {
                    newAccessToken = accesstoken.AccessTokenStr;
                    TimeSpan expires_in = DateTime.Now - accesstoken.LastUpdateTime;
                    if ((expires_in.TotalMinutes * 60) > (accesstoken.ExpiresIn - 100))
                    {
                        WebClient wc = new WebClient();
                        byte[] data = null;
                        data = wc.DownloadData(String.Format(WeChatWebAPI.GetAccessToken, appId, appSecret));
                        string strWebData = Encoding.Default.GetString(data);
                        var accessTokenModel = (JObject)JsonConvert.DeserializeObject(strWebData);
                        newAccessToken = accessTokenModel["access_token"].ToString();
                        weChatExpiresIn = Int32.Parse(accessTokenModel["expires_in"].ToString());

                        entity.Entry(accesstoken).State = System.Data.Entity.EntityState.Modified;
                        accesstoken.AccessTokenStr = newAccessToken;
                        accesstoken.ExpiresIn = weChatExpiresIn;
                        accesstoken.LastUpdateTime = DateTime.Now;
                        entity.SaveChanges();
                    }
                }
            }
            return newAccessToken;
        }
Example #20
0
    protected void bTwitter_Click(object sender, EventArgs e)
    {
        OAuthConsumer oauth = new OAuthConsumer();

        RequestToken requestToken = new RequestToken();
        AccessToken accessToken = new AccessToken();
        //string Token = "", TokenSecret = "";

        string authUrl = GeneralUtils.GetRouteableUrlFromRelativeUrl("AuthorizeServices.aspx/twitter/");
        requestToken = oauth.GetOAuthRequestToken(appSettings["Twitter_RequestURL"],
            appSettings["Twitter_Realm"], appSettings["Twitter_ConsumerKey"], appSettings["Twitter_ConsumerSecret"],
            authUrl);

        Session["TwitterToken"] = requestToken;
        Response.Redirect(appSettings["Twitter_AuthURL"] + "?oauth_token=" + requestToken.Token);
    }
        /// <summary>
        /// 获取通行令
        /// </summary>
        /// <param name="currentAccount">当前账号信息</param>
        /// <returns>通行令</returns>
        public static string GetAccessToken(Account currentAccount)
        {
            Monitor.Enter(DicAccessToken);
            try
            {
                AccessToken accessToken;
                if (DicAccessToken.ContainsKey(currentAccount.ID))
                {
                    accessToken = DicAccessToken[currentAccount.ID];
                    if (accessToken.ExpireTime > DateTime.Now)
                    {
                        return accessToken.Value;
                    }
                    DicAccessToken.Remove(currentAccount.ID);
                }

                var result =
                    HttpHelper.GetResponseResultByGet(
                        string.Format(GetTokenUrlFormat, currentAccount.AppID, currentAccount.AppSecret)
                        , timeout: 1000);
                if (result.Status != ResponseStatus.Success)
                {
                    return "";
                }
                JObject jObject = JsonConvert.DeserializeObject<JObject>(result.ResponseString);
                JToken value, time;
                if (!jObject.TryGetValue("access_token", out value) || !jObject.TryGetValue("expires_in", out time))
                {
                    return "";
                }

                accessToken = new AccessToken
                {
                    Value = value.ToString(),
                    ExpireTime = DateTime.Now.AddSeconds(time.ToObject<double>())
                };
                DicAccessToken.Add(currentAccount.ID, accessToken);

                return accessToken.Value;
            }
            finally
            {
                Monitor.Exit(DicAccessToken);
            }
        }
		public async void ProvisionAccessTokenAsync_TokenIsAlreadyCachedButIsWithinGracePeriod_NewTokenIsProvisionedAndCached() {

			IAccessToken accessToken = new AccessToken( BuildTestToken() );

			m_serviceTokenCacheMock.Setup( x => x.GetAsync( It.IsAny<string>() ) )
				.Returns( Task.FromResult( new CacheResponse( true, BuildTestToken( tokenExpiryInSeconds: 60 ) ) ) );
			m_serviceTokenCacheMock.Setup( x => x.SetAsync( It.IsAny<string>(), It.IsAny<string>(), It.IsAny<TimeSpan>() ) )
				.Returns( Task.FromResult( 0 ) );

			m_accessTokenProviderMock.Setup( x => x.ProvisionAccessTokenAsync( m_claims, m_scopes ) )
				.Returns( Task.FromResult( accessToken ) );

			const int gracePeriodThatIsBiggerThanTimeToExpiry = TOKEN_EXPIRY_IN_SECONDS + 60;
			IAccessTokenProvider cachedAccessTokenProvider = GetCachedAccessTokenProvider( gracePeriodThatIsBiggerThanTimeToExpiry );

			IAccessToken token =
				await cachedAccessTokenProvider.ProvisionAccessTokenAsync( m_claims, m_scopes, m_serviceTokenCacheMock.Object ).SafeAsync();
			Assert.NotNull( token );
		}
        public void CanGetList()
        {
            FreeAgentClient.UseSandbox = true;
            //FreeAgentClient.Proxy = new WebProxy("127.0.0.1", 8888);
            var sandbox_bttest_token = new AccessToken
            {
                access_token = "",
                refresh_token = KeyStorage.RefreshToken,
                token_type = "bearer"
            };

            {

                var Client = new FreeAgentClient(KeyStorage.AppKey, KeyStorage.AppSecret);

                Client.CurrentAccessToken = sandbox_bttest_token;

                try
                {
                    var co = Client.Company.Single();
                } catch
                {

                }

            }

            FreeAgentClient.UseSandbox = false;

                var LiveClient = new FreeAgentClient(KeyStorage.AppKey, KeyStorage.AppSecret);

                LiveClient.CurrentAccessToken = sandbox_bttest_token;

                try
                {
                    var co = LiveClient.Company.Single();
                } catch
                {

                }

            Assert.IsTrue(true);
        }
Example #24
0
 public void AddAccessToken(AccessToken token)
 {
     Models.AccessToken accessToken = new Models.AccessToken()
     {
         ClientId = Convert.ToInt32(token.Client.ClientId),
         ExpiresIn = token.ExpiresIn,
         IssuedOn = token.IssuedOn,
         RefreshToken = token.RefreshToken,
         Scope = string.Join(" ", token.Scope),
         Token = token.Token,
         TokenType = token.TokenType,
         AuthorizationGrantCode = token.Grant.Code,
     };
     using (Models.OAuthWebAPIContext context = new Models.OAuthWebAPIContext())
     {
         context.AccessTokens.Add(accessToken);
         context.SaveChanges();
     }
 }
		public async void ProvisionAccessTokenAsync_NotCached_CallsThroughToAccessTokenProviderAndValueIsThenCached() {

			IAccessToken accessToken = new AccessToken( BuildTestToken() );

			m_accessTokenProviderMock.Setup(
				x => x.ProvisionAccessTokenAsync( It.IsAny<IEnumerable<Claim>>(), It.IsAny<IEnumerable<Scope>>() )
				).Returns( Task.FromResult( accessToken ) );

			m_serviceTokenCacheMock.Setup( x => x.GetAsync( It.IsAny<string>() ) )
				.Returns( Task.FromResult( new CacheResponse( false, null ) ) );
			m_serviceTokenCacheMock.Setup( x => x.SetAsync( It.IsAny<string>(), It.IsAny<string>(), It.IsAny<TimeSpan>() ) )
				.Returns( Task.FromResult( 0 ) );

			IAccessTokenProvider cachedAccessTokenProvider = GetCachedAccessTokenProvider();

			IAccessToken token =
				await cachedAccessTokenProvider.ProvisionAccessTokenAsync( m_claims, m_scopes, m_serviceTokenCacheMock.Object ).SafeAsync();
			Assert.AreEqual( accessToken.Token, token.Token );
		}
Example #26
0
		public IToken IssueAccessToken(IAuthorizationGrant grant)
		{
            var authorizationGrant = (AuthorizationGrant)grant;
			//typically here you'd fetch your access
			AccessToken token = new AccessToken
			{
				ExpiresIn = 120,
				Token = Guid.NewGuid().ToString(),
				Grant = (AuthorizationGrant)grant                
			};
			token.Scope = ((AuthorizationGrant)grant).Scope.Split(' ');
            token.Client = authorizationGrant.Client;
            token.IssuedOn = SharpOAuth2.Provider.Utility.Epoch.ToEpoch(DateTime.Now);
            token.RefreshToken = Guid.NewGuid().ToString();           

			TokenRepo.AddAccessToken(token);
			return token;

		}
Example #27
0
        public override OAuthUserProfile GetUserProfile( AccessToken accessToken )
        {
            JsonObject user = OAuthClient.Init( this.UserProfileUrl, accessToken.Token, HttpMethod.Get )
                .AddParam( "uid", accessToken.Uid )
                .RunJson();

            if (user.Get<long>( "id" ) <= 0) {
                logger.Error( "无法获取正常 user profile" );
                return null;
            }

            OAuthUserProfile x = new OAuthUserProfile();
            x.Uid = accessToken.Uid;
            x.Name = user.Get( "name" );
            x.FriendlyUrl = user.Get( "domain" );
            x.PicUrlSmall = user.Get( "profile_image_url" );
            x.PicUrlBig = user.Get( "avatar_large" );

            return x;
        }
        public FakeProvider(string name) : base(name, "Fake/Custom")
        {
            // Defaults.
            AccessToken = new AccessToken
                          {
                              PublicToken = "EstSularusOthMithas-MyHonorIsMyLife",
                              ExpiresOn = DateTime.UtcNow.AddDays(30),
                          };

            UserInformation = UserInformation ?? new UserInformation
                                                 {
                                                     Gender = GenderType.Male,
                                                     Id = "FakeId-ABCDEFGHIJKLMNOPQRSTUVWXYZ",
                                                     Locale = "en-au",
                                                     Name = "Sturm Brightblade",
                                                     Picture =
                                                         "",
                                                     UserName = "******"
                                                 };
        }
 protected void Page_Load(object sender, EventArgs eventArgs)
 {
     LoginInfo loginInfo = (LoginInfo)Session["loginInfo"];
     if (loginInfo != null)
     {
         openID = loginInfo.openID;
         extensionData = loginInfo.extensionData;
         accessToken = loginInfo.accessToken;
     }
     else
     {
         openID = null;
         extensionData = null;
         accessToken = null;
     }
     if (Request["logout"] == "true")
     {
         Session.RemoveAll();
     }
 }
        /// <summary>
        /// Get the application's token. Renew it if needed.
        /// </summary>
        /// <param name="cancellationToken"></param>
        /// <returns></returns>
        public async Task<AccessToken> CheckAndRenewTokenAsync(CancellationToken cancellationToken)
        {
            if (token == null || token.Expiration < DateTime.UtcNow)
            {
                // This is not thread safe. Unfortunately, portable class library requirements prevent use of
                // asynchronous locking mechanisms. The risk here is authenticating multiple times in parallel
                // which is bad from a performance standpoint but is transparent from a functional standpoint.
                AzureDataMarketAuthenticationResponse authenticationResponse =
                    await client.AuthenticateAsync(clientId, clientSecret, cancellationToken);
                if (authenticationResponse != null)
                {
                    token = new AccessToken
                    {
                        Token = authenticationResponse.AccessToken,
                        Expiration = DateTime.UtcNow.AddSeconds(authenticationResponse.ExpiresIn)
                    };
                }
            }

            return token;
        }
Example #31
0
 /// <summary>
 /// 获取群发的视频MediaId
 /// </summary>
 /// <param name="token"></param>
 /// <param name="media_id">原视频的MediaId</param>
 /// <param name="title">群发视频标题</param>
 /// <param name="description">群发视频描述</param>
 /// <returns></returns>
 public static MediaUpload MassMessageGetVideoMediaId(this AccessToken token, string media_id, string title, string description) =>
 Api.Mass.SendVideoPreGetMediaId(token.access_token, media_id, title, description);
Example #32
0
 /// <summary>
 /// 群发视频消息
 /// </summary>
 /// <param name="token"></param>
 /// <param name="media_id">从方法AccessToken.MassMessageGetVideoMediaId获取到的MediaId</param>
 /// <param name="tag_id">群发到的标签的tag_id,参加用户管理中用户分组接口,可不填写tag_id以发送到全部用户</param>
 /// <returns></returns>
 public static MassResult MassVideo(this AccessToken token, string media_id, int tag_id = 0) =>
 Api.Mass.SendVideo(token.access_token, media_id, tag_id);
Example #33
0
 /// <summary>
 /// 群发视频消息
 /// </summary>
 /// <param name="token"></param>
 /// <param name="media_id">原视频的MediaId</param>
 /// <param name="title">群发视频标题</param>
 /// <param name="description">群发视频描述</param>
 /// <param name="openid">填写图文消息的接收者,一串OpenID列表,OpenID最少2个,最多10000个</param>
 /// <returns></returns>
 public static MassResult MassVideoByOpenId(this AccessToken token, string media_id, string title, string description, params string[] openid) => token.MassTextByOpenId(media_id, openid.ToList());
Example #34
0
 /// <summary>
 /// 上传图文消息素材
 /// </summary>
 /// <param name="token"></param>
 /// <param name="items">图文列表</param>
 /// <returns></returns>
 public static MediaUpload MassMessageNewsUpload(this AccessToken token, params Article[] items) =>
 token.MassMessageNewsUpload(items.ToList());
Example #35
0
 /// <summary>
 /// 群发卡券消息
 /// </summary>
 /// <param name="token"></param>
 /// <param name="card_id">需要通过卡券接口获得</param>
 /// <param name="tag_id">群发到的标签的tag_id,参加用户管理中用户分组接口,可不填写tag_id以发送到全部用户</param>
 /// <returns></returns>
 public static MassResult MassCard(this AccessToken token, string card_id, int tag_id = 0) =>
 Api.Mass.SendCard(token.access_token, card_id, tag_id);
Example #36
0
 /// <summary>
 /// 群发卡券消息
 /// </summary>
 /// <param name="token"></param>
 /// <param name="card_id">需要通过卡券接口获得</param>
 /// <param name="openid">填写图文消息的接收者,一串OpenID列表,OpenID最少2个,最多10000个</param>
 /// <returns></returns>
 public static MassResult MassCardByOpenId(this AccessToken token, string card_id, List <string> openid) =>
 Api.Mass.SendCard(token.access_token, card_id, openid);
Example #37
0
 /// <summary>
 /// 删除群发
 /// </summary>
 /// <param name="token"></param>
 /// <param name="msgId">发送出去的消息ID</param>
 /// <param name="article_idx">图文序号</param>
 /// <returns></returns>
 public static JsonResult MassMessageSentDelete(this AccessToken token, long msgId, byte?article_idx = null) =>
 Api.Mass.SentDelete(token.access_token, msgId, article_idx);
 public ChangePasswordResponse(AccessToken accessToken, string refreshToken)
 {
     AccessToken  = accessToken;
     RefreshToken = refreshToken;
 }
 protected override void OnCurrentAccessTokenChanged(AccessToken oldAccessToken, AccessToken currentAccessToken)
 {
     if (Element != null)
     {
         var session = Xamarin.Facebook.AccessToken.CurrentAccessToken;
         if (session == null)
         {
             Device.BeginInvokeOnMainThread(() =>
             {
                 Element.SendShowingLoggedOutUser();
             });
         }
     }
 }
Example #40
0
        private void handleFacebookAccessToken(AccessToken accessToken)
        {
            AuthCredential credential = FacebookAuthProvider.GetCredential(accessToken.Token);

            mAuth.SignInWithCredential(credential).AddOnCompleteListener(this, this);
        }
Example #41
0
 /// <summary>
 /// 群发文本消息
 /// </summary>
 /// <param name="token"></param>
 /// <param name="text">文本信息</param>
 /// <param name="tag_id">群发到的标签的tag_id,参加用户管理中用户分组接口,可不填写tag_id以发送到全部用户</param>
 /// <returns></returns>
 public static MassResult MassText(this AccessToken token, string text, int tag_id = 0) =>
 Api.Mass.SendText(token.access_token, text, tag_id);
Example #42
0
 /// <summary>
 /// 图文消息预览
 /// </summary>
 /// <param name="token"></param>
 /// <param name="media_id">图文Id</param>
 /// <param name="openid">预览账号的OpenId</param>
 /// <param name="wxname">预览微信账号</param>
 /// <returns></returns>
 public static MassResult MassNewsPreview(this AccessToken token, string media_id, string openid = null, string wxname = null) =>
 Api.Mass.PreviewMpNews(token.access_token, media_id, openid, wxname);
Example #43
0
 /// <summary>
 /// 群发图文消息
 /// </summary>
 /// <param name="token"></param>
 /// <param name="media_id">图文Id</param>
 /// <param name="sendIgnoreReprint">图文消息被判定为转载时,是否继续群发。true为继续群发(转载),false为停止群发。该参数默认为false。</param>
 /// <param name="openid">填写图文消息的接收者,一串OpenID列表,OpenID最少2个,最多10000个</param>
 /// <returns></returns>
 public static MassResult MassNewsByOpenId(this AccessToken token, string media_id, bool sendIgnoreReprint = false, List <string> openid = null) =>
 Api.Mass.SendMpNews(token.access_token, media_id, openid, sendIgnoreReprint);
Example #44
0
 /// <summary>
 /// 群发图文消息
 /// </summary>
 /// <param name="token"></param>
 /// <param name="media_id">图文Id</param>
 /// <param name="tag_id">群发到的标签的tag_id,参加用户管理中用户分组接口,可不填写tag_id以发送到全部用户</param>
 /// <param name="sendIgnoreReprint">图文消息被判定为转载时,是否继续群发。true为继续群发(转载),false为停止群发。该参数默认为false。</param>
 /// <returns></returns>
 public static MassResult MassNews(this AccessToken token, string media_id, int tag_id = 0, bool sendIgnoreReprint = false) =>
 Api.Mass.SendMpNews(token.access_token, media_id, tag_id, sendIgnoreReprint);
Example #45
0
 /// <summary>
 /// 查询群发消息发送状态
 /// </summary>
 /// <param name="token"></param>
 /// <param name="msgId">群发消息后返回的消息id</param>
 /// <returns></returns>
 public static MassState MassMessageSentStateQuery(this AccessToken token, long msgId) =>
 Api.Mass.MassMessageSentStateQuery(token.access_token, msgId);
Example #46
0
 public BdApiController(DataContext context, AccessToken accessToken)
 {
     _DbContext   = context;
     _accessToken = accessToken;
 }
Example #47
0
 /// <summary>
 /// 卡券消息预览
 /// </summary>
 /// <param name="token"></param>
 /// <param name="card_id">需要通过卡券接口获得</param>
 /// <param name="code"></param>
 /// <param name="timestamp"></param>
 /// <param name="signature"></param>
 /// <param name="openid">预览账号的OpenId</param>
 /// <param name="wxname">预览微信账号</param>
 /// <returns></returns>
 public static MassResult MassCardPreview(this AccessToken token, string card_id, string code, string timestamp, string signature, string openid = null, string wxname = null) =>
 Api.Mass.PreviewCard(token.access_token, card_id, code, timestamp, signature, openid, wxname);
Example #48
0
 internal HTTPClient(Configuration configuration)
 {
     accessToken        = new AccessToken(this);
     this.configuration = configuration;
 }
Example #49
0
 /// <summary>
 /// 群发卡券消息
 /// </summary>
 /// <param name="token"></param>
 /// <param name="card_id">需要通过卡券接口获得</param>
 /// <param name="openid">填写图文消息的接收者,一串OpenID列表,OpenID最少2个,最多10000个</param>
 /// <returns></returns>
 public static MassResult MassCardByOpenId(this AccessToken token, string card_id, params string[] openid) => token.MassTextByOpenId(card_id, openid.ToList());
        public static string AddInstagramAccount(string client_id, string client_secret, string redirect_uri, string code, long userId, long groupId, Model.DatabaseRepository dbr, ILogger _logger, Helper.Cache _redisCache, Helper.AppSettings _appSettings)
        {
            string           ret      = string.Empty;
            oAuthInstagram   objInsta = new oAuthInstagram();
            ConfigurationIns configi  = new ConfigurationIns("https://api.instagram.com/oauth/authorize/", client_id, client_secret, redirect_uri, "https://api.instagram.com/oauth/access_token", "https://api.instagram.com/v1/", "");
            oAuthInstagram   _api     = new oAuthInstagram();

            _api = oAuthInstagram.GetInstance(configi);
            AccessToken access = new AccessToken();

            access = _api.AuthGetAccessToken(code);
            UserController objusercontroller = new UserController();

            if (access != null)
            {
                Domain.Socioboard.Models.Instagramaccounts Instagramaccounts = new Domain.Socioboard.Models.Instagramaccounts();
                Domain.Socioboard.Models.Instagramaccounts objInstagramAccount;
                #region InstagramAccount
                InstagramResponse <User> objuser = objusercontroller.GetUserDetails(access.user.id, access.access_token);

                objInstagramAccount             = new Domain.Socioboard.Models.Instagramaccounts();
                objInstagramAccount.AccessToken = access.access_token;
                objInstagramAccount.InstagramId = access.user.id;
                try
                {
                    objInstagramAccount.bio = access.user.bio;
                }
                catch {
                    objInstagramAccount.bio = "";
                }
                try
                {
                    objInstagramAccount.ProfileUrl = access.user.profile_picture;
                }
                catch (Exception ex)
                {
                    _logger.LogError("Instagram.asmx.cs >> AddInstagramAccount >> " + ex.StackTrace);
                }
                try
                {
                    objInstagramAccount.InsUserName = access.user.username;
                }
                catch (Exception ex)
                {
                    _logger.LogError("Instagram.asmx.cs >> AddInstagramAccount >> " + ex.StackTrace);
                }
                try
                {
                    objInstagramAccount.TotalImages = objuser.data.counts.media;
                }
                catch (Exception ex)
                {
                    _logger.LogError("Instagram.asmx.cs >> AddInstagramAccount >> " + ex.StackTrace);
                }
                try
                {
                    objInstagramAccount.FollowedBy = objuser.data.counts.followed_by;
                }
                catch (Exception ex)
                {
                    _logger.LogError("Instagram.asmx.cs >> AddInstagramAccount >> " + ex.StackTrace);
                }
                try
                {
                    objInstagramAccount.Followers = objuser.data.counts.follows;
                }
                catch (Exception ex)
                {
                    _logger.LogError("Instagram.asmx.cs >> AddInstagramAccount >> " + ex.StackTrace);
                }
                objInstagramAccount.UserId     = userId;
                objInstagramAccount.IsActive   = true;
                objInstagramAccount.lastUpdate = DateTime.UtcNow;
                if (objInstagramAccount.InstagramId != null)
                {
                    Instagramaccounts = Api.Socioboard.Repositories.InstagramRepository.getInstagramAccount(objInstagramAccount.InstagramId, _redisCache, dbr);
                    if (Instagramaccounts != null && Instagramaccounts.IsActive == true)
                    {
                        return("This Account is added by some body else.");
                    }
                }
                else
                {
                    return("Issue while fetching instagram userId");
                }

                if (Instagramaccounts == null)
                {
                    int isSaved = dbr.Add <Domain.Socioboard.Models.Instagramaccounts>(objInstagramAccount);
                    if (isSaved == 1)
                    {
                        List <Domain.Socioboard.Models.Instagramaccounts> lstinsAcc = dbr.Find <Domain.Socioboard.Models.Instagramaccounts>(t => t.InstagramId.Equals(objInstagramAccount.InstagramId)).ToList();
                        if (lstinsAcc != null && lstinsAcc.Count() > 0)
                        {
                            isSaved = GroupProfilesRepository.AddGroupProfile(groupId, lstinsAcc.First().InstagramId, lstinsAcc.First().InsUserName, userId, lstinsAcc.First().ProfileUrl, Domain.Socioboard.Enum.SocialProfileType.Instagram, dbr);
                            if (isSaved == 1)
                            {
                                _redisCache.Delete(Domain.Socioboard.Consatants.SocioboardConsts.CacheUserProfileCount + userId);
                                _redisCache.Delete(Domain.Socioboard.Consatants.SocioboardConsts.CacheGroupProfiles + groupId);

                                GetInstagramSelfFeeds(objInstagramAccount.InstagramId, objInstagramAccount.AccessToken, _appSettings);
                                GetInstagramUserDetails(objInstagramAccount.InstagramId, objInstagramAccount.AccessToken, _redisCache, dbr);
                                GetInstagramFollowing(objInstagramAccount.InstagramId, objInstagramAccount.AccessToken, 1, _appSettings);
                                GetInstagramFollower(objInstagramAccount.InstagramId, objInstagramAccount.AccessToken, 1, _appSettings);
                                new Thread(delegate()
                                {
                                    GetInstagramPostLikes(objInstagramAccount.InstagramId, objInstagramAccount.AccessToken, 1, _appSettings);
                                    GetInstagramPostComments(objInstagramAccount.InstagramId, objInstagramAccount.AccessToken, _appSettings);
                                }).Start();

                                return("Added_Successfully");
                            }
                        }
                    }
                }
                else
                {
                    objInstagramAccount.id = Instagramaccounts.id;
                    int isSaved = dbr.Update <Domain.Socioboard.Models.Instagramaccounts>(objInstagramAccount);
                    if (isSaved == 1)
                    {
                        List <Domain.Socioboard.Models.Instagramaccounts> lstinsAcc = dbr.Find <Domain.Socioboard.Models.Instagramaccounts>(t => t.InstagramId.Equals(objInstagramAccount.InstagramId)).ToList();
                        if (lstinsAcc != null && lstinsAcc.Count() > 0)
                        {
                            isSaved = GroupProfilesRepository.AddGroupProfile(groupId, lstinsAcc.First().InstagramId, lstinsAcc.First().InsUserName, userId, lstinsAcc.First().ProfileUrl, Domain.Socioboard.Enum.SocialProfileType.Instagram, dbr);
                            if (isSaved == 1)
                            {
                                _redisCache.Delete(Domain.Socioboard.Consatants.SocioboardConsts.CacheUserProfileCount + userId);
                                _redisCache.Delete(Domain.Socioboard.Consatants.SocioboardConsts.CacheGroupProfiles + groupId);


                                //todo : codes to update feeds
                                GetInstagramSelfFeeds(objInstagramAccount.InstagramId, objInstagramAccount.AccessToken, _appSettings);
                                GetInstagramUserDetails(objInstagramAccount.InstagramId, objInstagramAccount.AccessToken, _redisCache, dbr);
                                GetInstagramFollowing(objInstagramAccount.InstagramId, objInstagramAccount.AccessToken, 1, _appSettings);
                                GetInstagramFollower(objInstagramAccount.InstagramId, objInstagramAccount.AccessToken, 1, _appSettings);
                                new Thread(delegate()
                                {
                                    GetInstagramPostLikes(objInstagramAccount.InstagramId, objInstagramAccount.AccessToken, 1, _appSettings);
                                    GetInstagramPostComments(objInstagramAccount.InstagramId, objInstagramAccount.AccessToken, _appSettings);
                                }).Start();



                                return("Added_Successfully");
                            }
                        }
                    }
                }
            }
            return("issue in access token fetching");

            #endregion
        }
Example #51
0
 /// <summary>
 /// 视频消息预览
 /// </summary>
 /// <param name="token"></param>
 /// <param name="media_id">原视频的MediaId</param>
 /// <param name="title">群发视频标题</param>
 /// <param name="description">群发视频描述</param>
 /// <param name="openid">预览账号的OpenId</param>
 /// <param name="wxname">预览微信账号</param>
 /// <returns></returns>
 public static MassResult MassVideoPreview(this AccessToken token, string media_id, string title, string description, string openid = null, string wxname = null) =>
 Api.Mass.PreviewVideo(token.access_token, media_id, openid, wxname);
Example #52
0
 public AzureDevOpsRepositoryTarget(string url, AccessToken accessToken)
     : base(url, accessToken)
 {
 }
Example #53
0
 /// <summary>
 /// 群发视频消息
 /// </summary>
 /// <param name="token"></param>
 /// <param name="media_id">原视频的MediaId</param>
 /// <param name="title">群发视频标题</param>
 /// <param name="description">群发视频描述</param>
 /// <param name="openid">填写图文消息的接收者,一串OpenID列表,OpenID最少2个,最多10000个</param>
 /// <returns></returns>
 public static MassResult MassVideoByOpenId(this AccessToken token, string media_id, string title, string description, List <string> openid) =>
 Api.Mass.SendVideo(token.access_token, media_id, title, description, openid);
 public LoginResponse(AccessToken accessToken, string refreshToken, bool success = false, string message = null) : base(success, message)
 {
     AccessToken  = accessToken;
     RefreshToken = refreshToken;
 }
Example #55
0
 /// <summary>
 /// 群发视频消息
 /// </summary>
 /// <param name="token"></param>
 /// <param name="media_id">原视频的MediaId</param>
 /// <param name="title">群发视频标题</param>
 /// <param name="description">群发视频描述</param>
 /// <param name="tag_id">群发到的标签的tag_id,参加用户管理中用户分组接口,可不填写tag_id以发送到全部用户</param>
 /// <returns></returns>
 public static MassResult MassVideo(this AccessToken token, string media_id, string title, string description, int tag_id = 0) =>
 Api.Mass.SendVideo(token.access_token, token.MassMessageGetVideoMediaId(media_id, title, description).media_id, tag_id);
Example #56
0
        private async Task <AccessToken> ObtainAccessTokenAsync(string consumerKey, string consumerSecret, RequestToken token, string verifier)
        {
            //https://dev.DoYouBuzz.com/docs/authentication

            _logger.WriteVerbose("ObtainAccessToken");

            var nonce = Guid.NewGuid().ToString("N");

            var authorizationParts = new SortedDictionary <string, string>
            {
                { "oauth_consumer_key", consumerKey },
                { "oauth_nonce", nonce },
                { "oauth_signature_method", "HMAC-SHA1" },
                { "oauth_token", token.Token },
                { "oauth_timestamp", GenerateTimeStamp() },
                { "oauth_verifier", verifier },
                { "oauth_version", "1.0" },
            };

            var parameterBuilder = new StringBuilder();

            foreach (var authorizationKey in authorizationParts)
            {
                parameterBuilder.AppendFormat("{0}={1}&", Uri.EscapeDataString(authorizationKey.Key), Uri.EscapeDataString(authorizationKey.Value));
            }
            parameterBuilder.Length--;
            var parameterString = parameterBuilder.ToString();

            var canonicalRequestBuilder = new StringBuilder();

            canonicalRequestBuilder.Append(HttpMethod.Post.Method);
            canonicalRequestBuilder.Append("&");
            canonicalRequestBuilder.Append(Uri.EscapeDataString(AccessTokenEndpoint));
            canonicalRequestBuilder.Append("&");
            canonicalRequestBuilder.Append(Uri.EscapeDataString(parameterString));

            var signature = ComputeSignature(consumerSecret, token.TokenSecret, canonicalRequestBuilder.ToString());

            authorizationParts.Add("oauth_signature", signature);
            authorizationParts.Remove("oauth_verifier");

            var authorizationHeaderBuilder = new StringBuilder();

            authorizationHeaderBuilder.Append("OAuth ");
            foreach (var authorizationPart in authorizationParts)
            {
                authorizationHeaderBuilder.AppendFormat(
                    "{0}=\"{1}\", ", authorizationPart.Key, Uri.EscapeDataString(authorizationPart.Value));
            }
            authorizationHeaderBuilder.Length = authorizationHeaderBuilder.Length - 2;

            var request = new HttpRequestMessage(HttpMethod.Post, AccessTokenEndpoint);

            request.Headers.Add("Authorization", authorizationHeaderBuilder.ToString());

            var formPairs = new List <KeyValuePair <string, string> >()
            {
                new KeyValuePair <string, string>("oauth_verifier", verifier)
            };

            request.Content = new FormUrlEncodedContent(formPairs);

            var response = await _httpClient.SendAsync(request, Request.CallCancelled);

            if (!response.IsSuccessStatusCode)
            {
                _logger.WriteError("AccessToken request failed with a status code of " + response.StatusCode);
                response.EnsureSuccessStatusCode(); // throw
            }

            var responseText = await response.Content.ReadAsStringAsync();

            var responseParameters = WebHelpers.ParseForm(responseText);

            var accessToken = new AccessToken
            {
                Token       = Uri.UnescapeDataString(responseParameters["oauth_token"]),
                TokenSecret = Uri.UnescapeDataString(responseParameters["oauth_token_secret"]),
                UserId      = "",
            };

            var userInfo = GetUserInfo(consumerKey, consumerSecret, accessToken);

            accessToken.UserId = userInfo.Id.ToString();

            return(accessToken);
        }
Example #57
0
        private async Task <AccessToken> GetUserInfo(string consumerKey, string consumerSecret, AccessToken token)
        {
            _logger.WriteVerbose("ObtainAccessToken");

            var nonce = Guid.NewGuid().ToString("N");

            var authorizationParts = new SortedDictionary <string, string>
            {
                { "oauth_consumer_key", consumerKey },
                { "oauth_nonce", nonce },
                { "oauth_signature_method", "HMAC-SHA1" },
                { "oauth_token", token.Token },
                { "oauth_timestamp", GenerateTimeStamp() },
                { "oauth_version", "1.0" },
            };

            var parameterBuilder = new StringBuilder();

            foreach (var authorizationKey in authorizationParts)
            {
                parameterBuilder.AppendFormat("{0}={1}&", Uri.EscapeDataString(authorizationKey.Key), Uri.EscapeDataString(authorizationKey.Value));
            }
            parameterBuilder.Length--;
            var parameterString = parameterBuilder.ToString();

            var canonicalRequestBuilder = new StringBuilder();

            canonicalRequestBuilder.Append(HttpMethod.Post.Method);
            canonicalRequestBuilder.Append("&");
            canonicalRequestBuilder.Append(Uri.EscapeDataString(UserInfoEndpoint));
            canonicalRequestBuilder.Append("&");
            canonicalRequestBuilder.Append(Uri.EscapeDataString(parameterString));

            var signature = ComputeSignature(consumerSecret, token.TokenSecret, canonicalRequestBuilder.ToString());

            authorizationParts.Add("oauth_signature", signature);
            authorizationParts.Remove("oauth_verifier");

            var authorizationHeaderBuilder = new StringBuilder();

            authorizationHeaderBuilder.Append("OAuth ");
            foreach (var authorizationPart in authorizationParts)
            {
                authorizationHeaderBuilder.AppendFormat("{0}=\"{1}\", ", authorizationPart.Key, Uri.EscapeDataString(authorizationPart.Value));
            }
            authorizationHeaderBuilder.Length = authorizationHeaderBuilder.Length - 2;

            var request = new HttpRequestMessage(HttpMethod.Post, UserInfoEndpoint);

            request.Headers.Add("Authorization", authorizationHeaderBuilder.ToString());

            var response = await _httpClient.SendAsync(request, Request.CallCancelled);

            if (!response.IsSuccessStatusCode)
            {
                _logger.WriteError("AccessToken request failed with a status code of " + response.StatusCode);
                response.EnsureSuccessStatusCode(); // throw
            }

            var responseText = await response.Content.ReadAsStringAsync();

            var document = new XmlDocument();

            document.LoadXml(responseText);

            var json     = JsonConvert.SerializeXmlNode(document, Formatting.None);
            var userInfo = JsonConvert.DeserializeObject <UserInfo>(json);

            return(new AccessToken
            {
                Token = token.Token,
                TokenSecret = token.TokenSecret,
                UserId = userInfo.Id.ToString(),
            });
        }
        protected override UserInformation RetrieveUserInformation(AccessToken accessToken)
        {
            if (accessToken == null)
            {
                throw new ArgumentNullException("accessToken");
            }

            if (string.IsNullOrEmpty(accessToken.PublicToken))
            {
                throw new ArgumentException("accessToken.PublicToken");
            }

            IRestResponse <UserInfoResult> response;

            try
            {
                var restRequest = new RestRequest("/oauth2/v2/userinfo", Method.GET);
                restRequest.AddParameter(AccessTokenKey, accessToken.PublicToken);

                var restClient = RestClientFactory.CreateRestClient("https://www.googleapis.com");

                TraceSource.TraceVerbose("Retrieving user information. Google Endpoint: {0}",
                                         restClient.BuildUri(restRequest).AbsoluteUri);

                response = restClient.Execute <UserInfoResult>(restRequest);
            }
            catch (Exception exception)
            {
                var errorMessage =
                    string.Format("Failed to retrieve any UserInfo data from the Google Api. Error Messages: {0}",
                                  exception.RecursiveErrorMessages());
                TraceSource.TraceError(errorMessage);
                throw new AuthenticationException(errorMessage, exception);
            }

            if (response == null ||
                response.StatusCode != HttpStatusCode.OK)
            {
                var errorMessage = string.Format(
                    "Failed to obtain some UserInfo data from the Google Api OR the the response was not an HTTP Status 200 OK. Response Status: {0}. Response Description: {1}. Error Message: {2}.",
                    response == null ? "-- null response --" : response.StatusCode.ToString(),
                    response == null ? string.Empty : response.StatusDescription,
                    response == null
                        ? string.Empty
                        : response.ErrorException == null
                              ? "--no error exception--"
                              : response.ErrorException.RecursiveErrorMessages());

                TraceSource.TraceError(errorMessage);
                throw new AuthenticationException(errorMessage);
            }

            // Lets check to make sure we have some bare minimum data.
            if (string.IsNullOrEmpty(response.Data.Id))
            {
                const string errorMessage =
                    "We were unable to retrieve the User Id from Google API, the user may have denied the authorization.";
                TraceSource.TraceError(errorMessage);
                throw new AuthenticationException(errorMessage);
            }

            return(new UserInformation
            {
                Id = response.Data.Id,
                Gender = string.IsNullOrEmpty(response.Data.Gender)
                                    ? GenderType.Unknown
                                    : GenderTypeHelpers.ToGenderType(response.Data.Gender),
                Name = response.Data.Name,
                Email = response.Data.Email,
                Locale = response.Data.Locale,
                Picture = response.Data.Picture,
                UserName = response.Data.GivenName
            });
        }
Example #59
0
 /// <summary>
 /// 群发图文消息
 /// </summary>
 /// <param name="token"></param>
 /// <param name="media_id">图文Id</param>
 /// <param name="sendIgnoreReprint">图文消息被判定为转载时,是否继续群发。true为继续群发(转载),false为停止群发。该参数默认为false。</param>
 /// <param name="openid">填写图文消息的接收者,一串OpenID列表,OpenID最少2个,最多10000个</param>
 /// <returns></returns>
 public static MassResult MassNewsByOpenId(this AccessToken token, string media_id, bool sendIgnoreReprint = false, params string[] openid) =>
 token.MassNewsByOpenId(media_id, sendIgnoreReprint, openid.ToList());
Example #60
0
 /// <summary>
 /// 上传图文消息素材
 /// </summary>
 /// <param name="token"></param>
 /// <param name="items">图文列表</param>
 /// <returns></returns>
 public static MediaUpload MassMessageNewsUpload(this AccessToken token, List <Article> items) =>
 Api.Mass.UploadNews(token.access_token, items);