summaryrefslogtreecommitdiff
path: root/src/StardewModdingAPI.Web/Framework/CommaDelimitedModelBinder.cs
diff options
context:
space:
mode:
authorJesse Plamondon-Willard <github@jplamondonw.com>2017-09-22 01:57:18 -0400
committerJesse Plamondon-Willard <github@jplamondonw.com>2017-09-22 01:57:18 -0400
commit86e55596786f8d65854a75632512750b6e09faae (patch)
tree27f082b50b70f3d3b020855f9ac8b3b1cc5430f6 /src/StardewModdingAPI.Web/Framework/CommaDelimitedModelBinder.cs
parentef60b8d32abf7c8613749766155d80139e33b9d1 (diff)
downloadSMAPI-86e55596786f8d65854a75632512750b6e09faae.tar.gz
SMAPI-86e55596786f8d65854a75632512750b6e09faae.tar.bz2
SMAPI-86e55596786f8d65854a75632512750b6e09faae.zip
switch mod update endpoint to GET with comma-delimited mod keys (#336)
Diffstat (limited to 'src/StardewModdingAPI.Web/Framework/CommaDelimitedModelBinder.cs')
-rw-r--r--src/StardewModdingAPI.Web/Framework/CommaDelimitedModelBinder.cs58
1 files changed, 58 insertions, 0 deletions
diff --git a/src/StardewModdingAPI.Web/Framework/CommaDelimitedModelBinder.cs b/src/StardewModdingAPI.Web/Framework/CommaDelimitedModelBinder.cs
new file mode 100644
index 00000000..119b18e6
--- /dev/null
+++ b/src/StardewModdingAPI.Web/Framework/CommaDelimitedModelBinder.cs
@@ -0,0 +1,58 @@
+using System;
+using System.ComponentModel;
+using System.Reflection;
+using System.Threading.Tasks;
+using Microsoft.AspNetCore.Mvc.ModelBinding;
+
+namespace StardewModdingAPI.Web.Framework
+{
+ /// <summary>Maps comma-delimited values to an <see cref="System.Collections.Generic.IEnumerable{T}"/> parameter.</summary>
+ /// <remarks>Derived from <a href="https://stackoverflow.com/a/43655986/262123" />.</remarks>
+ public class CommaDelimitedModelBinder : IModelBinder
+ {
+ /*********
+ ** Public methods
+ *********/
+ /// <summary>Attempts to bind a model.</summary>
+ /// <param name="bindingContext">The model binding context.</param>
+ public Task BindModelAsync(ModelBindingContext bindingContext)
+ {
+ // validate
+ if (bindingContext == null)
+ throw new ArgumentNullException(nameof(bindingContext));
+
+ // extract values
+ string modelName = bindingContext.ModelName;
+ ValueProviderResult valueProviderResult = bindingContext.ValueProvider.GetValue(modelName);
+ string[] values = valueProviderResult
+ .ToString()
+ .Split(new[] { ',' }, StringSplitOptions.RemoveEmptyEntries);
+ Type elementType = bindingContext.ModelType.GetTypeInfo().GenericTypeArguments[0];
+ if (values.Length == 0)
+ {
+ bindingContext.Result = ModelBindingResult.Success(Array.CreateInstance(elementType, 0));
+ return Task.CompletedTask;
+ }
+
+ // map values
+ TypeConverter converter = TypeDescriptor.GetConverter(elementType);
+ Array typedArray = Array.CreateInstance(elementType, values.Length);
+ try
+ {
+ for (int i = 0; i < values.Length; ++i)
+ {
+ string value = values[i];
+ object convertedValue = converter.ConvertFromString(value);
+ typedArray.SetValue(convertedValue, i);
+ }
+ }
+ catch (Exception exception)
+ {
+ bindingContext.ModelState.TryAddModelError(modelName, exception, bindingContext.ModelMetadata);
+ }
+
+ bindingContext.Result = ModelBindingResult.Success(typedArray);
+ return Task.CompletedTask;
+ }
+ }
+}