當前位置: 首頁>>代碼示例>>C#>>正文


C# Logic.WebServiceResponse類代碼示例

本文整理匯總了C#中MonkeyWrench.DataClasses.Logic.WebServiceResponse的典型用法代碼示例。如果您正苦於以下問題:C# WebServiceResponse類的具體用法?C# WebServiceResponse怎麽用?C# WebServiceResponse使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


WebServiceResponse類屬於MonkeyWrench.DataClasses.Logic命名空間,在下文中一共展示了WebServiceResponse類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: IsLoggedIn

	public static bool IsLoggedIn (WebServiceResponse response)
	{
		if (response == null)
			return false;

		return !string.IsNullOrEmpty (response.UserName);
	}
開發者ID:hackmp,項目名稱:monkeywrench,代碼行數:7,代碼來源:Authentication.cs

示例2: IsInRole

	public static bool IsInRole (WebServiceResponse response, string role)
	{
		if (response.UserRoles == null)
			return false;

		return Array.IndexOf (response.UserRoles, role) >= 0;
	}
開發者ID:rolfbjarne,項目名稱:monkeywrench,代碼行數:7,代碼來源:Authentication.cs

示例3: IsInRole

	public static bool IsInRole (WebServiceResponse response, string role)
	{
		bool result;

		if (response == null) {
			log.Debug ("IsInRole: no response");
			return false;
		}

		if (response.UserRoles == null) {
			log.Debug ("IsInRole: no userroles");
			return false;
		}
		
		result = Array.IndexOf (response.UserRoles, role) >= 0;

		log.DebugFormat ("IsInRole ({0}) => {1} (roles: {2})", role, result, string.Join (";", response.UserRoles));

		return result;
	}
開發者ID:joewstroman,項目名稱:monkeywrench,代碼行數:20,代碼來源:Authentication.cs

示例4: IsInRole

	public static bool IsInRole (WebServiceResponse response, string role)
	{
		bool result;

		if (response == null) {
			MonkeyWrench.Logger.Log (2, "IsInRole: no response");
			return false;
		}

		if (response.UserRoles == null) {
			MonkeyWrench.Logger.Log (2, "IsInRole: no userroles");
			return false;
		}
		
		result = Array.IndexOf (response.UserRoles, role) >= 0;

		MonkeyWrench.Logger.Log (2, "IsInRole ({0}) => {1} (roles: {2})", role, result, string.Join (";", response.UserRoles));

		return result;
	}
開發者ID:hackmp,項目名稱:monkeywrench,代碼行數:20,代碼來源:Authentication.cs

示例5: Authenticate

		/// <summary>
		/// Authenticates the request with the provided user/pass.
		/// If no user/pass is provided, the method returns a response
		/// with no roles.
		/// If a wrong user/pass is provided, the method throws an exception.
		/// </summary>
		/// <param name="db"></param>
		/// <param name="login"></param>
		/// <param name="response"></param>
		public static void Authenticate (HttpContext Context, DB db, WebServiceLogin login, WebServiceResponse response, bool @readonly)
		{
			Authenticate (Context.Request.UserHostAddress, db, login, response, @readonly);
		}
開發者ID:hackmp,項目名稱:monkeywrench,代碼行數:13,代碼來源:Authentication.cs

示例6: Authenticate

		internal void Authenticate (DB db, WebServiceLogin login, WebServiceResponse response, bool @readonly)
		{
			Authentication.Authenticate (Context, db, login, response, @readonly);
		}
開發者ID:joewstroman,項目名稱:monkeywrench,代碼行數:4,代碼來源:WebServices.asmx.cs

示例7: MarkAsDontBuild

		public WebServiceResponse MarkAsDontBuild (WebServiceLogin login, int lane_id)
		{
			WebServiceResponse response = new WebServiceResponse ();

			using (DB db = new DB ()) {
				VerifyUserInRole (db, login, Roles.Administrator);
				using (IDbCommand cmd = db.CreateCommand ()) {
					cmd.CommandText = "UPDATE RevisionWork SET state = 11 WHERE state = 0 AND lane_id = @lane_id;";
					DB.CreateParameter (cmd, "lane_id", lane_id);
					cmd.ExecuteNonQuery ();
				}
			}

			return response;
		}
開發者ID:joewstroman,項目名稱:monkeywrench,代碼行數:15,代碼來源:WebServices.asmx.cs

示例8: AddRelease

		public WebServiceResponse AddRelease (WebServiceLogin login, DBRelease release)
		{
			WebServiceResponse response = new WebServiceResponse ();

			using (DB db = new DB ()) {
				VerifyUserInRole (db, login, Roles.BuildBot);
				release.Save (db);
			}

			return response;
		}
開發者ID:joewstroman,項目名稱:monkeywrench,代碼行數:11,代碼來源:WebServices.asmx.cs

示例9: EditNotification

		public WebServiceResponse EditNotification (WebServiceLogin login, DBNotification notification)
		{
			WebServiceResponse response = new WebServiceResponse ();

			using (DB db = new DB ()) {
				VerifyUserInRole (db, login, Roles.Administrator);
				notification.Save (db);
				Notifications.Restart ();
			}

			return response;
		}
開發者ID:joewstroman,項目名稱:monkeywrench,代碼行數:12,代碼來源:WebServices.asmx.cs

示例10: EditIdentity

		public WebServiceResponse EditIdentity (WebServiceLogin login, DBIrcIdentity irc_identity, DBEmailIdentity email_identity)
		{
			WebServiceResponse response = new WebServiceResponse ();

			using (DB db = new DB ()) {
				VerifyUserInRole (db, login, Roles.Administrator);

				if (irc_identity != null) {
					irc_identity.Save (db);
				}
				if (email_identity != null) {
					email_identity.Save (db);
				}
			}

			return response;
		}
開發者ID:joewstroman,項目名稱:monkeywrench,代碼行數:17,代碼來源:WebServices.asmx.cs

示例11: DeleteAllWorkForHost

		public WebServiceResponse DeleteAllWorkForHost (WebServiceLogin login, int host_id)
		{
			WebServiceResponse response = new WebServiceResponse ();

			try {
				using (DB db = new DB ()) {
					VerifyUserInRole (db, login, Roles.Administrator);
					using (IDbCommand cmd = db.CreateCommand ()) {
						cmd.CommandText = @"
DELETE FROM Work WHERE revisionwork_id IN (SELECT id FROM RevisionWork WHERE host_id = @host_id);
UPDATE RevisionWork SET state = 10, workhost_id = DEFAULT, completed = DEFAULT WHERE host_id = @host_id;
";
						DB.CreateParameter (cmd, "host_id", host_id);
						cmd.ExecuteNonQuery ();
					}
				}
			} catch (Exception ex) {
				response.Exception = new WebServiceException (ex);
			}

			return response;
		}
開發者ID:vargaz,項目名稱:monkeywrench,代碼行數:22,代碼來源:WebServices.asmx.cs

示例12: ClearAllWorkForHost

		public WebServiceResponse ClearAllWorkForHost (WebServiceLogin login, int host_id)
		{
			WebServiceResponse response = new WebServiceResponse ();

			try {
				using (DB db = new DB ()) {
					VerifyUserInRole (db, login, Roles.Administrator);
					using (IDbCommand cmd = db.CreateCommand ()) {
						cmd.CommandText = @"
UPDATE Work SET state = DEFAULT, summary = DEFAULT, starttime = DEFAULT, endtime = DEFAULT, duration = DEFAULT, logfile = DEFAULT, host_id = DEFAULT
WHERE Work.revisionwork_id IN (SELECT RevisionWork.id FROM RevisionWork WHERE RevisionWork.host_id = @host_id);

UPDATE RevisionWork SET state = DEFAULT, lock_expires = DEFAULT, completed = DEFAULT, workhost_id = DEFAULT WHERE host_id = @host_id;
";
						DB.CreateParameter (cmd, "host_id", host_id);
						cmd.ExecuteNonQuery ();
					}
				}
			} catch (Exception ex) {
				response.Exception = new WebServiceException (ex);
			}

			return response;
		}
開發者ID:vargaz,項目名稱:monkeywrench,代碼行數:24,代碼來源:WebServices.asmx.cs

示例13: VerifyUserInRole

		public static void VerifyUserInRole (HttpContext Context, DB db, WebServiceLogin login, string role, bool @readonly)
		{
			WebServiceResponse dummy = new WebServiceResponse ();
			Authenticate (Context, db, login, dummy, @readonly);

			if (!dummy.IsInRole (role)) {
				log.InfoFormat ("The user '{0}' has the roles '{1}', and requested role is: {2}", login.User, dummy.UserRoles == null ? "<null>" : string.Join (",", dummy.UserRoles), role);
				throw new UnauthorizedException ("You don't have the required permissions.");
			}
		}
開發者ID:joewstroman,項目名稱:monkeywrench,代碼行數:10,代碼來源:Authentication.cs

示例14: Authenticate

		/// <summary>
		/// Authenticates the request with the provided user/pass.
		/// If no user/pass is provided, the method returns a response
		/// with no roles.
		/// If a wrong user/pass is provided, the method throws an exception.
		/// </summary>
		/// <param name="db"></param>
		/// <param name="login"></param>
		/// <param name="response"></param>
		public static void Authenticate (HttpContext Context, DB db, WebServiceLogin login, WebServiceResponse response, bool @readonly)
		{
			string ip = Context.Request.UserHostAddress;
			int person_id;
			DBLoginView view = null;

			Console.WriteLine ("WebService.Authenticate (Ip4: {0}, UserHostAddress: {1}, User: {2}, Cookie: {3}, Password: {4}", login == null ? null : login.Ip4, Context.Request.UserHostAddress, login == null ? null : login.User, login == null ? null : login.Cookie, login == null ? null : login.Password);

			// Check if credentials were passed in
			if (login == null || string.IsNullOrEmpty (login.User) || (string.IsNullOrEmpty (login.Password) && string.IsNullOrEmpty (login.Cookie))) {
				Console.WriteLine ("No credentials.");
				return;
			}

			if (@readonly && string.IsNullOrEmpty (login.Password)) {
				// Console.WriteLine ("Readonly authentication needs a password.");
				return;
			}

			if (!string.IsNullOrEmpty (login.Ip4)) {
				ip = login.Ip4;
			} else {
				ip = Context.Request.UserHostAddress;
			}

			if (@readonly) {
				DBLogin result = DBLogin_Extensions.Login (db, login.User, login.Password, ip, @readonly);
				if (result == null) {
					// Console.WriteLine ("Incorrect Login/Password for readonly login");
					return;
				}
				person_id = result.person_id;
			} else {
				if (!string.IsNullOrEmpty (login.Password)) {
					DBLogin result = DBLogin_Extensions.Login (db, login.User, login.Password, ip, @readonly);
					if (result != null)
						view = DBLoginView_Extensions.VerifyLogin (db, login.User, result.cookie, ip);
				} else {
					view = DBLoginView_Extensions.VerifyLogin (db, login.User, login.Cookie, ip);
					Console.WriteLine ("Verifying login, cookie: {0} user: {1} ip: {2}", login.Cookie, login.User, ip);
				}

				if (view == null) {
					Console.WriteLine ("Invalid credentials.");
					return;
				}
				person_id = view.person_id;
			}
			Console.WriteLine ("Valid credentials");

			LoginResponse login_response = response as LoginResponse;
			if (login_response != null) {
				login_response.Cookie = view != null ? view.cookie : null;
				login_response.FullName = view != null ? view.fullname : null;
				login_response.ID = person_id;
			}

			DBPerson person = DBPerson_Extensions.Create (db, person_id);

			Console.WriteLine ("Roles for '{0}': {1}", login.User, person.roles);

			if (!string.IsNullOrEmpty (person.roles))
				response.UserRoles = person.roles.Split (new char [] { ',' }, StringSplitOptions.RemoveEmptyEntries);
		}
開發者ID:rolfbjarne,項目名稱:monkeywrench,代碼行數:73,代碼來源:Authentication.cs

示例15: SetResponse

	private void SetResponse (WebServiceResponse response)
	{
		this.response = response;
		LoadView ();
	}
開發者ID:DavidS,項目名稱:monkeywrench,代碼行數:5,代碼來源:Master.master.cs


注:本文中的MonkeyWrench.DataClasses.Logic.WebServiceResponse類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。