-
Notifications
You must be signed in to change notification settings - Fork 4.5k
/
Skillset.cs
122 lines (112 loc) · 3.96 KB
/
Skillset.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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
// <auto-generated>
// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License. See License.txt in the project root for
// license information.
//
// Code generated by Microsoft (R) AutoRest Code Generator.
// Changes may cause incorrect behavior and will be lost if the code is
// regenerated.
// </auto-generated>
namespace Microsoft.Azure.Search.Models
{
using Microsoft.Rest;
using Newtonsoft.Json;
using System.Collections;
using System.Collections.Generic;
using System.Linq;
/// <summary>
/// A list of skills.
/// <see
/// href="https://docs.microsoft.com/azure/search/cognitive-search-tutorial-blob"
/// />
/// </summary>
public partial class Skillset
{
/// <summary>
/// Initializes a new instance of the Skillset class.
/// </summary>
public Skillset()
{
CustomInit();
}
/// <summary>
/// Initializes a new instance of the Skillset class.
/// </summary>
/// <param name="name">The name of the skillset.</param>
/// <param name="description">The description of the skillset.</param>
/// <param name="skills">A list of skills in the skillset.</param>
/// <param name="cognitiveServices">Details about cognitive services to
/// be used when running skills.</param>
/// <param name="eTag">The ETag of the skillset.</param>
public Skillset(string name, string description, IList<Skill> skills, CognitiveServices cognitiveServices = default(CognitiveServices), string eTag = default(string))
{
Name = name;
Description = description;
Skills = skills;
CognitiveServices = cognitiveServices;
ETag = eTag;
CustomInit();
}
/// <summary>
/// An initialization method that performs custom operations like setting defaults
/// </summary>
partial void CustomInit();
/// <summary>
/// Gets or sets the name of the skillset.
/// </summary>
[JsonProperty(PropertyName = "name")]
public string Name { get; set; }
/// <summary>
/// Gets or sets the description of the skillset.
/// </summary>
[JsonProperty(PropertyName = "description")]
public string Description { get; set; }
/// <summary>
/// Gets or sets a list of skills in the skillset.
/// </summary>
[JsonProperty(PropertyName = "skills")]
public IList<Skill> Skills { get; set; }
/// <summary>
/// Gets or sets details about cognitive services to be used when
/// running skills.
/// </summary>
[JsonProperty(PropertyName = "cognitiveServices")]
public CognitiveServices CognitiveServices { get; set; }
/// <summary>
/// Gets or sets the ETag of the skillset.
/// </summary>
[JsonProperty(PropertyName = "@odata.etag")]
public string ETag { get; set; }
/// <summary>
/// Validate the object.
/// </summary>
/// <exception cref="ValidationException">
/// Thrown if validation fails
/// </exception>
public virtual void Validate()
{
if (Name == null)
{
throw new ValidationException(ValidationRules.CannotBeNull, "Name");
}
if (Description == null)
{
throw new ValidationException(ValidationRules.CannotBeNull, "Description");
}
if (Skills == null)
{
throw new ValidationException(ValidationRules.CannotBeNull, "Skills");
}
if (Skills != null)
{
foreach (var element in Skills)
{
if (element != null)
{
element.Validate();
}
}
}
}
}
}