Skip to content

Builder Modes

Stephan edited this page Feb 19, 2016 · 3 revisions

The Models Builder can be used in different modes:

  • PureLive models
  • Dll models
  • AppData models
  • API models

The mode is indicated by the Umbraco.ModelsBuilder.ModelsMode key in the appSettings section of the web.config file.

Pure Live models

Corresponds to the PureLive setting value.

With PureLive models, models are generated and compiled on the fly, in memory, at runtime. They are available in views exclusively. This is for people who exclusively use the Umbraco back-end, and probably do not write custom code such as controllers anyway. Whenever a content type is modified, models are updated without restarting Umbraco (in the same way .cshtml views are recompiled).

If the ~/App_Data/Models directory contains any non-generated CSharp files (ie *.cs but not *.generated.cs), the Models Builder parses these files for instructions, and includes them in the compilation (see documentation for configuring and extending models).

Generation can fail for various reasons, in which case Umbraco will run without models (and front-end views probably fail to render). Umbraco's log file should contain all details about what prevented the generation, but it is probably faster to check the Models Builder dashboard, which should report the last error that was encountered, if any.

The Models Builder maintains some files in ~/App_Data/Models:

  • models.generated.cs contains the generated models code
  • all.generated.cs contains the compiled code (models merged with non-generated files)
  • models.hash contains a hash code of the content types
  • models.err contains the last generation error infos, if any

The models.hash file is used when Umbraco restarts, to figure out whether models have changed and need to be re-generated. Otherwise, the local models.generated.cs file is reused.

Dll Models

Corresponds to the Dll and LiveDll setting values.

With Dll models, models are generated in the ~/App_Data/Models directory, then compiled into a Dll that is copied into ~/bin, thus restarting the application. Models must be generated explicitely from the dashboard or the content type editor.

If the ~/App_Data/Models directory contains any non-generated CSharp files (ie *.cs but not *.generated.cs), the Models Builder parses these files for instructions, and includes them in the compilation (see documentation for configuring and extending models).

Because models are in a Dll, they become visible to custom code, controllers, etc. and can even be referenced in Visual Studio to benefit from Intellisense.

Generation can fail for various reasons, in which case Umbraco will run without models (and front-end views probably fail to render). Umbraco's log file should contain all details about what prevented the generation, but it is probably faster to check the Models Builder dashboard, which should report the last error that was encountered, if any.

LiveDll models work much in the same way, except that generation takes place automatically whenever content types change. Which means that Umbraco will restart anytime a content type is modified, which is not very efficient. You probably do not want to use LiveDll models.

AppData Models

Corresponds to the AppData and LiveAppData setting values.

With AppData models, models are generated in the ~/App_Data/Models directory, and that is all. It is then up to you to decide how to compile the models (eg by including them in a Visual Studio solution).

If the ~/App_Data/Models directory contains any non-generated CSharp files (ie *.cs but not *.generated.cs), the Models Builder parses these files for instructions (see documentation for configuring and extending models).

Generation can fail for various reasons, in which case... no models are generated. Umbraco's log file should contain all details about what prevented the generation, but it is probably faster to check the Models Builder dashboard, which should report the last error that was encountered, if any.

LiveAppData models work much in the same way, except that generation takes place automatically whenever content types change. Because generation does not cause any compilation, it does not cause Umbraco to restart, either.

API models

With API models, the Models Builder does not generate models into the Umbraco website, but exposes an API that allows external tools to retrieve models. The Models Builder source code contains a sample console tool that connects to the website and retrieve models. In addition, a Visual Studio extension is available, which enables models generation straight from Visual Studio.

In both cases the API must be enabled, see Install And Configure.

Although it is possible to enable the API while still generating models into the Umbraco website, this probably does not make much sense. Therefore, you will want to set the Umbraco.ModelsBuilder.ModelsMode to Nothing (or remove it entirely). Do not disable the Models Builder entirely, though, as that would also disable the models factory (ie, models would be ignored).

When the API is enabled and the Visual Studio extension is installed:

  • Go to Visual Studio Tools | Options | Umbraco | ModelsBuilder Options and configure the url to your website (eg http://www.example.com), and a logon and password for an Umbraco user that has permission to access the developer section.
  • Create a folder in your solution -- pick your own name. Within that folder, create a CSharp file -- again, pick your own name. The file can contain code, or just be empty. Edit the properties of the file and set the Custom tool value to UmbracoModelsBuilder. Save the file, or right-click and Run Custom Tool. New files should appear underneath the file.

These new files are the generated models. They are automatically added to the Visual Studio project and will be compiled alongside the rest of your project. Anytime you need to refresh the models, simply run the custom tool.

If there are some non-generated CSharp files (ie *.cs but not *.generated.cs) in the folder, the Models Builder will parse them for instructions (see documentation for configuring and extending models) and Visual Studio will compile them too.

In order for Visual Studio to compile the project successfully, it needs to reference the Models Builder Dll, so you probably want to install the Models Builder NuGet package in the project.