Skip to content

Tutorial 02 04 Configuring Self Hosting

mattl91 edited this page Oct 18, 2022 · 15 revisions

Harmony Core Logo

Configuring Self Hosting

To run an instance of your web service you will need to generate a "self-hosting" application.

VIDEO: Creating a Basic Solution

The term self-hosting refers to the fact that in .NET Core environments, web applications are typically hosted within a custom application that you also write. In most cases, this will be a simple console application. Even if you ultimately plan to host your services in a web server such as Internet Information Server (IIS), you will still need to generate a self-hosting application, and that application will in turn be hosted and managed by IIS.

Of course, you are not expected to implement the functionality of a web server yourself. That functionality is provided by the ASP.NET Core environment in the form of a web server called Kestrel. You simply write an application that uses Kestrel to host an instance of your web site and/or services.

The Harmony Core solution templates already provide a project for creating a self-hosting console application. The project is called Services.Host, but by default it doesn't contain any code. This is because the code that will be needed in the self-hosting application will depend on the types of endpoints and other options that you select by configuring the various options in the regen batch file. Several options cause additional code to be generated into the self-hosting program.

Generating a Self-Hosting Program

To generate the required self-hosting code into the Services.Host project you must enable an option in the regen batch file.

  1. Edit regen.bat and scroll down to the section where all the code generation options are defined.

  2. Locate and remove the comment from the ENABLE_SELF_HOST_GENERATION option, like this:

    set ENABLE_SELF_HOST_GENERATION=YES
    

Generating Harmony Core Sample Data

In addition to generating a self-hosting application, if you are working with the Harmony Core sample data you will need to generate additional code that causes the sample data files to be created and loaded each time your application starts, and deleted when your application stops.

This mechanism is designed to ensure that you will have consistent test data each time you start the service, which can be especially important if you intend to incorporate unit testing within your environment.

This functionality is unlocked by enabling another option:

  1. Locate and remove the comment from the ENABLE_CREATE_TEST_FILES option, like this:

    set ENABLE_CREATE_TEST_FILES=-define ENABLE_CREATE_TEST_FILES
    

VERY IMPORTANT: Do not enable this option unless you are working with the Harmony Core Sample Data and wish to create and delete your data files each time your services start and stop. If you enable this option in a production environment it will CAUSE YOUR DATA FILES TO BE DELETED!

Generating Custom Sample Data

Skip this section if you are working through the Creating a Basic Solution tutorial.

If you are working with your own repository and data files, it is still possible to use the auto-create / auto-delete mechanism to create your own data files as the service starts and ends. To do this you must:

  1. Provide a sequential file containing the data to be loaded. The file must be in the same location and have the same file name as the actual data file, but with a .txt file extension.

  2. Provide an XDL file for the data file, again in the same location, with the same name, but with a file extension of .xdl.

Setting Logical Names for Data File Access

Skip this section if you are working through the Creating a Basic Solution tutorial.

By default, the generated self-hosting code detects any logical names that are used to access your data files, based on the file specifications present in your repository, and sets those logical names to point to the included SampleData folder each time your service starts. This means that the easiest way to get up and running with your own data is to drop a copy of your data files into the SampleData folder.

In most cases, however, you are likely to want to access your data files from their current location in your environment. To do so you will need to do two things:

  • Prevent the self-hosting code from setting environment variables during service startup.
  • Provide appropriate values for the environment variables another way.

Preventing Startup from Setting Environment Variables

Skip this section if you are working through the Creating a Basic Solution tutorial.

  1. To prevent the startup code setting data access environment variables to point to the SampleData folder, enable the DO_NOT_SET_FILE_LOGICALS option, like this:

    set DO_NOT_SET_FILE_LOGICALS=-define DO_NOT_SET_FILE_LOGICALS
    

Customizing Environment Variables

Skip this section if you are working through the Creating a Basic Solution tutorial.

If you suppress the automatic setting of environment variables, you will need to ensure that your services are able to access your data files by causing those environment variables to be set some other way. Exactly how to do this depends on your exact requirements. You will find several options by reviewing:

Generating the Updated Code

  1. Save your changes to the regen.bat file.

  2. If you don't already have a command prompt open in the solution folder, use the Tools > Command Prompt (x64) menu option to open a Windows command prompt, and type the following command:

    cd ..
    
  3. Type the following command to regenerate your code:

    regen
    

As the batch file executes, you will see various messages confirming which source files are being generated. Look for the word DONE to indicate that all code generation tasks completed successfully.

What Changed

Enabling the 'ENABLE_SELF_HOST_GENERATION' option causes two additional source files to be generated into the Services.Host folder:

Services.Host\SelfHost.dbl
Services.Host\SelfHostEnvironment.dbl

Adding the Code to the Visual Studio Projects

The next step is to add the new source files that were just generated to the Visual Studio project:

  1. Right-click on the Services.Host project and select Add > Existing Item.

  2. Select the two new source files and click the Add button.

Building the Code

The entire solution should now be in a buildable and runnable state, although your web service does not have any usable endpoints yet!

  1. Build the project by selecting Build > Rebuild Solution from the Visual Studio menu.

  2. Check the Output window, you should see something like this:

    1>------ Rebuild All started: Project: Repository, Configuration: Debug Any CPU ------
    2>------ Rebuild All started: Project: Services.Models, Configuration: Debug Any CPU ------
    3>------ Rebuild All started: Project: Services.Controllers, Configuration: Debug Any CPU ------
    4>------ Rebuild All started: Project: Services.Isolated, Configuration: Debug Any CPU ------
    5>------ Rebuild All started: Project: Services, Configuration: Debug Any CPU ------
    6>------ Rebuild All started: Project: Services.Host, Configuration: Debug Any CPU ------
    ========== Rebuild All: 6 succeeded, 0 failed, 0 skipped ==========
    

Running the Code

  1. In Visual Studio Solution Explorer, right-click on the Services.Host project then select Set as Startup Project.

The name of the project file should now be displayed in bold.

  1. Press F5 (start debugging) to start the self-hosting application.

You should see a console window appear with text similar to this:

Hosting environment: Development
Content root path: D:\MyApi\Services.Host\bin\Debug\net6.0\
Now listening on: http://localhost:8085
Now listening on: https://localhost:8086
Application started. Press Ctrl+C to shut down.
  1. Look in the SampleData folder, you should find that the five ISAM files have been created and loaded with data. These data files will be deleted again when the hosting program closes.

Interacting with the Service

Your web service currently has very limited functionality, because you have not yet enabled the options to create any data-centric endpoints. But there is SOME functionality present. Your service should currently expose:

  • An OData Service Document that lists the OData entities that the service knows about.
  • An OData Metadata document that defines the operations and data types exposed by the service.
  • API documentation based on Swagger UI, although your service currently has no endpoints to document!

Viewing the Service Home Page

Solutions based on the harmonycore template include a static HTML home page that includes links to the resources.

  1. Open a web browser and go to the URL https://localhost:8086.

You should see that page, which looks like this:

Harmony Core Logo

Viewing the OData Service Document

  1. Click on the OData Entities link.

You should see something like this:

Harmony Core Logo

This lists the data types that the service knows about; but we haven't yet implemented any operations for any of those types, so the information is not currently useful to us.

If you see something that looks more like this:

{"@odata.context":"https://localhost:8086/odata/v1/$metadata","value":[{"name":"Customers","kind":"EntitySet","url":"Customers"},{"name":"Items","kind":"EntitySet","url":"Items"},{"name":"Orders","kind":"EntitySet","url":"Orders"},{"name":"OrderItems","kind":"EntitySet","url":"OrderItems"},{"name":"Vendors","kind":"EntitySet","url":"Vendors"}]}

It's the same thing, but your browser doesn't know how to format JSON data. If your browser supports extensions, check its app store for an extension that formats JSON data.

Viewing the OData Metadata Document

  1. Click on the OData Metadata (XML) link.

You should see something like this:

Harmony Core Logo

This XML document currently defines the data types that are going to be exposed by the service, but again, there is not yet any information about service endpoints because none have been created yet.

Viewing the API Documentation

  1. Click on the API Documentation link.

You should see the API documentation home page that looks something like this:

Base API Documentation

Notice that this lists metadata and schemas, but no operations for endpoints. This is because the API documentation for Harmony Core services is generated at runtime based on the web service endpoints exposed by the service, and this service does not currently expose any endpoints.

You will learn more about API Documentation once you have added some useful endpoints to your web service.

Stop the Service

  1. Either switch focus back to Visual Studio and type Shift + F5 (stop debugging), or switch focus to the console window of the self-hosting application and type Ctrl + C.

  2. Check the SampleData folder, you should find that the five ISAM files have been deleted.


Next topic: Entity Collection Endpoints


Clone this wiki locally