/
ResponseStatus.cs
74 lines (64 loc) · 2.22 KB
/
ResponseStatus.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
//Copyright (c) ServiceStack, Inc. All Rights Reserved.
//License: https://raw.github.com/ServiceStack/ServiceStack/master/license.txt
using System.Collections.Generic;
using System.Runtime.Serialization;
namespace ServiceStack;
/// <summary>
/// Common ResponseStatus class that should be present on all response DTO's
/// </summary>
[DataContract]
public class ResponseStatus : IMeta
{
/// <summary>
/// Initializes a new instance of the <see cref="ResponseStatus"/> class.
///
/// A response status without an errorcode == success
/// </summary>
public ResponseStatus() { }
/// <summary>
/// Initializes a new instance of the <see cref="ResponseStatus"/> class.
/// A response status with an errorcode == failure
/// </summary>
public ResponseStatus(string errorCode)
{
this.ErrorCode = errorCode;
}
/// <summary>
/// Initializes a new instance of the <see cref="ResponseStatus"/> class.
/// A response status with an errorcode == failure
/// </summary>
public ResponseStatus(string errorCode, string message)
: this(errorCode)
{
this.Message = message;
}
/// <summary>
/// Holds the custom ErrorCode enum if provided in ValidationException
/// otherwise will hold the name of the Exception type, e.g. typeof(Exception).Name
///
/// A value of non-null means the service encountered an error while processing the request.
/// </summary>
[DataMember(Order = 1)]
public string ErrorCode { get; set; }
/// <summary>
/// A human friendly error message
/// </summary>
[DataMember(Order = 2)]
public string Message { get; set; }
/// <summary>
/// The Server StackTrace when DebugMode is enabled
/// </summary>
[DataMember(Order = 3)]
public string StackTrace { get; set; }
/// <summary>
/// For multiple detailed validation errors.
/// Can hold a specific error message for each named field.
/// </summary>
[DataMember(Order = 4)]
public List<ResponseError> Errors { get; set; }
/// <summary>
/// For additional custom metadata about the error
/// </summary>
[DataMember(Order = 5)]
public Dictionary<string, string> Meta { get; set; }
}