/// <summary>
 /// Serializes the object to JSON.
 /// </summary>
 /// <param name="writer">The <see cref="T: Newtonsoft.Json.JsonWriter" /> to write to.</param>
 /// <param name="obj">The object to serialize to JSON.</param>
 internal static void Serialize(JsonWriter writer, SecretValueResourceDescription obj)
 {
     // Required properties are always serialized, optional properties are serialized when not null.
     writer.WriteStartObject();
     writer.WriteProperty(obj.Name, "name", JsonWriterExtensions.WriteStringValue);
     writer.WriteProperty(obj.Properties, "properties", SecretValueResourcePropertiesConverter.Serialize);
     writer.WriteEndObject();
 }
        /// <inheritdoc />
        public Task <SecretValueResourceDescription> AddValueAsync(
            string secretResourceName,
            string secretValueResourceName,
            SecretValueResourceDescription secretValueResourceDescription,
            CancellationToken cancellationToken = default(CancellationToken))
        {
            secretResourceName.ThrowIfNull(nameof(secretResourceName));
            secretValueResourceName.ThrowIfNull(nameof(secretValueResourceName));
            secretValueResourceDescription.ThrowIfNull(nameof(secretValueResourceDescription));
            var requestId = Guid.NewGuid().ToString();
            var url       = "Resources/Secrets/{secretResourceName}/values/{secretValueResourceName}";

            url = url.Replace("{secretResourceName}", secretResourceName);
            url = url.Replace("{secretValueResourceName}", secretValueResourceName);
            var queryParams = new List <string>();

            // Append to queryParams if not null.
            queryParams.Add("api-version=6.4-preview");
            url += "?" + string.Join("&", queryParams);

            string content;

            using (var sw = new StringWriter())
            {
                SecretValueResourceDescriptionConverter.Serialize(new JsonTextWriter(sw), secretValueResourceDescription);
                content = sw.ToString();
            }

            HttpRequestMessage RequestFunc()
            {
                var request = new HttpRequestMessage()
                {
                    Method  = HttpMethod.Put,
                    Content = new StringContent(content, Encoding.UTF8),
                };

                request.Content.Headers.ContentType = System.Net.Http.Headers.MediaTypeHeaderValue.Parse("application/json; charset=utf-8");
                return(request);
            }

            return(this.httpClient.SendAsyncGetResponse(RequestFunc, url, SecretValueResourceDescriptionConverter.Deserialize, requestId, cancellationToken));
        }
示例#3
0
 /// <summary>
 /// Adds the specified value as a new version of the specified secret resource.
 /// </summary>
 /// <remarks>
 /// Creates a new value of the specified secret resource. The name of the value
 /// is typically the version identifier. Once created the value cannot be
 /// changed.
 /// </remarks>
 /// <param name='operations'>
 /// The operations group for this extension method.
 /// </param>
 /// <param name='resourceGroupName'>
 /// Azure resource group name
 /// </param>
 /// <param name='secretResourceName'>
 /// The name of the secret resource.
 /// </param>
 /// <param name='secretValueResourceName'>
 /// The name of the secret resource value which is typically the version
 /// identifier for the value.
 /// </param>
 /// <param name='secretValueResourceDescription'>
 /// Description for creating a value of a secret resource.
 /// </param>
 /// <param name='cancellationToken'>
 /// The cancellation token.
 /// </param>
 public static async Task <SecretValueResourceDescription> CreateAsync(this ISecretValueOperations operations, string resourceGroupName, string secretResourceName, string secretValueResourceName, SecretValueResourceDescription secretValueResourceDescription, CancellationToken cancellationToken = default(CancellationToken))
 {
     using (var _result = await operations.CreateWithHttpMessagesAsync(resourceGroupName, secretResourceName, secretValueResourceName, secretValueResourceDescription, null, cancellationToken).ConfigureAwait(false))
     {
         return(_result.Body);
     }
 }
示例#4
0
 /// <summary>
 /// Adds the specified value as a new version of the specified secret resource.
 /// </summary>
 /// <remarks>
 /// Creates a new value of the specified secret resource. The name of the value
 /// is typically the version identifier. Once created the value cannot be
 /// changed.
 /// </remarks>
 /// <param name='operations'>
 /// The operations group for this extension method.
 /// </param>
 /// <param name='resourceGroupName'>
 /// Azure resource group name
 /// </param>
 /// <param name='secretResourceName'>
 /// The name of the secret resource.
 /// </param>
 /// <param name='secretValueResourceName'>
 /// The name of the secret resource value which is typically the version
 /// identifier for the value.
 /// </param>
 /// <param name='secretValueResourceDescription'>
 /// Description for creating a value of a secret resource.
 /// </param>
 public static SecretValueResourceDescription Create(this ISecretValueOperations operations, string resourceGroupName, string secretResourceName, string secretValueResourceName, SecretValueResourceDescription secretValueResourceDescription)
 {
     return(operations.CreateAsync(resourceGroupName, secretResourceName, secretValueResourceName, secretValueResourceDescription).GetAwaiter().GetResult());
 }