// Copyright (c) Microsoft Open Technologies, Inc. // All Rights Reserved // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // THIS CODE IS PROVIDED *AS IS* BASIS, WITHOUT WARRANTIES OR // CONDITIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED, INCLUDING // WITHOUT LIMITATION ANY IMPLIED WARRANTIES OR CONDITIONS OF // TITLE, FITNESS FOR A PARTICULAR PURPOSE, MERCHANTABLITY OR // NON-INFRINGEMENT. // See the Apache 2 License for the specific language governing // permissions and limitations under the License. using System.Collections.Generic; using System.Linq; namespace Microsoft.AspNet.Identity { /// /// Represents the result of an identity operation /// public class IdentityResult { private static readonly IdentityResult _success = new IdentityResult(true); /// /// Failure constructor that takes error messages /// /// public IdentityResult(params string[] errors) : this((IEnumerable) errors) { } /// /// Failure constructor that takes error messages /// /// public IdentityResult(IEnumerable errors) { if (errors == null || !errors.Any()) { errors = new[] {Resources.DefaultError}; } Succeeded = false; Errors = errors; } private IdentityResult(bool success) { Succeeded = success; Errors = new string[0]; } /// /// True if the operation was successful /// public bool Succeeded { get; private set; } /// /// List of errors /// public IEnumerable Errors { get; private set; } /// /// Static success result /// /// public static IdentityResult Success { get { return _success; } } /// /// Failed helper method /// /// /// public static IdentityResult Failed(params string[] errors) { return new IdentityResult(errors); } } }