Jak powiązać model z dynamicznie tworzoną klasą nancyfx

przede wszystkim dziękuję za każdego, kto chce spojrzeć na mój problem. Jestem całkiem nowy w Nancyfx i mam problemy z próbą powiązania ładunku JSON z dynamicznie tworzoną klasą. Klasę stworzyłem dynamicznie, postępując zgodnie z kodem w tym poście -Dynamicznie utwórz klasę w C #

To jest mój blok kodu, który tworzy klasę dynamiczną, co, przyznaję, jest zasadniczo wycinaniem i wklejaniem kodu podanego przezdanijels

 public static Type CompileResultType(List<Metadata> metadata)
    {            
        TypeBuilder tb = GetTypeBuilder();
        ConstructorBuilder constructor = tb.DefineDefaultConstructor(MethodAttributes.Public | MethodAttributes.SpecialName | MethodAttributes.RTSpecialName);

        foreach (var field in metadata)
        {
            if(field.datatype == "String")
            {
               Type datatype = Type.GetType("System.String");
               CreateProperty(tb, field.columnname, datatype);
            }
            if (field.datatype == "int")
            {
                Type datatype = Type.GetType("System.Int32");
                CreateProperty(tb, field.columnname, datatype);
            }
            if(field.datatype == "datetime")
            {
                Type datatype = Type.GetType("System.DateTime");
                CreateProperty(tb, field.columnname, datatype);
            }

        }

        Type objectType = tb.CreateType();

        return objectType;

    }


    private static TypeBuilder GetTypeBuilder()
    {
        var typeSignature = "MyDynamicType";
        var an = new AssemblyName(typeSignature);
        AssemblyBuilder assemblyBuilder = AppDomain.CurrentDomain.DefineDynamicAssembly(an, AssemblyBuilderAccess.Run);
        ModuleBuilder moduleBuilder = assemblyBuilder.DefineDynamicModule("MainModule");

        TypeBuilder tb;

        tb = moduleBuilder.DefineType(typeSignature, TypeAttributes.Public | TypeAttributes.Class | TypeAttributes.AutoClass | TypeAttributes.AnsiClass | TypeAttributes.BeforeFieldInit | TypeAttributes.AutoLayout, null);

        return tb;

    }

    private static void CreateProperty(TypeBuilder tb, string propertyName, Type propertyType)
    {
        FieldBuilder fieldBuilder = tb.DefineField(propertyName, propertyType, FieldAttributes.Public); //changed field attributes from private to public

        PropertyBuilder propertyBuilder = tb.DefineProperty(propertyName, System.Reflection.PropertyAttributes.None, propertyType, null);

        MethodBuilder getPropMethdBldr = tb.DefineMethod("get_" + propertyName, MethodAttributes.Public | MethodAttributes.SpecialName | MethodAttributes.HideBySig, propertyType, Type.EmptyTypes); //changed get_ to get

        ILGenerator getIl = getPropMethdBldr.GetILGenerator();

        getIl.Emit(OpCodes.Ldarg_0);
        getIl.Emit(OpCodes.Ldfld, fieldBuilder);
        getIl.Emit(OpCodes.Ret);

        MethodBuilder setPropMthdBldr = tb.DefineMethod("set_" + propertyName, MethodAttributes.Public | MethodAttributes.SpecialName | MethodAttributes.HideBySig, null, new[] { propertyType }); //changed set_to set

        ILGenerator setIl = setPropMthdBldr.GetILGenerator();
        Label modifyProperty = setIl.DefineLabel();
        Label exitSet = setIl.DefineLabel();

        setIl.MarkLabel(modifyProperty);
        setIl.Emit(OpCodes.Ldarg_0);
        setIl.Emit(OpCodes.Ldarg_1);
        setIl.Emit(OpCodes.Stfld, fieldBuilder);

        setIl.Emit(OpCodes.Nop);
        setIl.MarkLabel(exitSet);
        setIl.Emit(OpCodes.Ret);

        propertyBuilder.SetGetMethod(getPropMethdBldr);
        propertyBuilder.SetGetMethod(setPropMthdBldr);
    }

//List<Metadata> metadata is a Dictionary

Wiążę to wtedy

  var myType = CompileResultType(metadata);
  var myObject = Activator.CreateInstance(myType);
  var b = this.BindTo(myObject);

Nie mogę mieć normalnej klasy modelu dla Nancy, ponieważ będę miał zbyt wiele modeli tylko do zbierania danych.

//usual model class
public Class PayloadModel
{
   public string firstName {get; set;}
   public string lastName {get; set;}
}

Powodem, dla którego muszę tworzyć klasę dynamicznie, jest to, że ładunek JSON, który otrzymuję, różni się w zależności od posiadanego pola 1 do 30. Kolejnym powodem jest to, że chciałbym zachować go jak najbardziej elastycznym. a posiadanie powyższej klasy oznacza, że ​​jestem przywiązany do wszystkiego, co jest w tej klasie. Wszelkie porady lub wskazówki będą bardzo pomocne!

questionAnswers(1)

yourAnswerToTheQuestion