Launching Courses
For your learners to take any of the courses that you've imported, you will have to launch the course through Engine. There are three main steps to launching a course:
- Create a registration in the course for the learner
- Get the launch url for the registration
- Open the launch url in an iframe or a new window
Let's look at each of these steps in more detail below.
To have your learner launch a course, either open a new window to Engine's launch link or open the launch link within an iframe in your application. The launch page will redirect to Engine's player, load up the course, and serve it to your learner. While the course is open, the player will periodically roll the course's progress back up to Engine, and Engine will in turn update your application with the status of the registration. You can read more about the data that is reported to your application here.
Creating a Registration
Note: before you can create a registration, the course your learner needs to take must have already been imported into Engine. If it hasn't, you can refer to the Importing Courses section for more information on how to do that.
Once your course has been imported, you will be able to create a registration through the API by issuing a POST request to the /registrations resource. You will need to provide three required pieces of information in the body of your request:
- courseId: the unique identifier that you specified when you imported your course
- registrationId: a unique for this registration that we're creating
- learner: information about the person taking the course, specifically a unique id, their first name, and their last name.
Please see the Overview page for some more explanation about each of these pieces of information
Getting the Launch Link
Once you have a registration created, you can retrieve the launch link for it with the /registrations/{registrationId}/launchLink endpoint. This returns a url to Engine's launch page with parameters specific to this registration.
When retrieving the launch link, there are a few parameters that you can use to customize the behavior of the launch:
- redirectOnExitUrl: This allows you to specify where the learner will be directed to upon leaving the course. You only need to set it here (versus in your config) if you need this value to be different per-launch. You can read more about the behavior of that setting below.
- tracking: if you pass this in with a value of- false, then Engine will not record any progress from the launch. You might use this in order to give an admin or learner the ability to launch their registration after it has been completed without it affecting the current state.
- forceReview: if you pass this in as- true, then content that supports it will launch in 'review mode'. Engine will still record and updates made during the launch, but the content may behave differently based on this. Often this is used in conjunction with- tracking=false.
- expiry: this is a number of seconds that the launch link is valid. This parameter only takes effect if you are using the Signed Launch Links feature mentioned below.
Signed Launch Links
We generally recommend that customers utilize Engine's ability to create signed, expirable launch links. If the use of signed launch links is enabled, links generated by the API will be signed, and only signed launch links will be accepted by the player. Because of this, your launch links must be generated via the API every time you need one.
Enabling signed launch links will also configure the player to use an expirable token when it reports course progress back to Engine, which will block any attempts to record dubious course progress from third parties, or from stale launches.
In order to enable signed launch links in Engine, use the following configuration settings:
- ApiUseSignedLaunchLinks: enables the feature [default: false]
- ApiTokenSecret: secret used to sign tokens generated by the API. If the string starts with '0x' the remainder will be interpreted as hexadecimal.
- ApiTokenPostbackValidHours: number of hours that the token used to authenticate player postbacks is valid. Remember, this setting can be set on a per-course basis, so you have the power to cater this setting to each course's expected duration, if desired. [default: 24]
In order to cause a launch link to expire, pass expiry as a parameter to either the /preview or /launchLink resources, where the value is the number of seconds till expiration (0 represents no expiration).
Using the Launch Link
Once you have called the API to get the launch link for a particular registration, then you are ready to actually send the learner to the course. Typically customers will do one of two things:
- use the launch url as the source for an iframe within their applications own page
- open a new window/tab with the launch url
Once the launch url is hit in the user's browser, it will redirect to the player page which will load the correct course content for the learner and retrieve any existing bookmark or progress details. At that point, the learner will interact with the course content and the player will record their progress back to Engine.
Redirect on Course Exit
When a learner finishes taking a course, they will typically either close a popup content window, or click an Exit button inside the content or the player. When they do this, Engine's player page will be triggered to redirect to a page of your choosing. Often this is sending the learner back to a summary page showing their status, or a page that will execute some custom logic to refresh a parent page, etc. You can use Engine's token replacement system to pass the ID of the completed registration back to your application's page as a query parameter.
To configure this behavior, you should set a value for RedirectOnExitUrlin your Engine config. The default value is a placeholder page that ships with Engine which is not appropriate for a production environment. 
If you would like to specify this value at course launch time, you can pass a query parameter called redirectOnExitUrl when you call the API to get the launch link. Customers sometimes do this because the redirect url needs to include parameters specific to that learner's launch of the course.
Some customers would rather not redirect the course window after launch at all. For those situations, you can set the value of RedirectOnExitUrl (either as a setting or as as a query param) to noop, which is short for "no operation". This will disable the redirect behavior and leave the player open on exit. If you would like to specify a custom message on this page, then you can specify that message by using a setting value of noop_message=Your custom message here.
Note: the learner may never actually make it back to your redirectOnExitUrl page. Once a learner is finished with their registration, they might just close the their browser. In this case, our content player will use its onbeforeunload handler to fire off a final state save, but the browser closing will mean the leanrer won't ever hit your exit page.
As a result, your integration cannot rely on learners making it back to that page. this limitation is the primary reason that we stress using the registration postback feature to get registration results reliably.
Preview Launches
If you need to open a course outside of the context of an individual learner, you can generate a preview link with the API at /courses/{courseId}/preview. You can treat that link the same way that you would treat a traditional launch link, and use it in an iframe or a new window.
This functionality can be used to serve a couple of different purposes in your application. If you want to provide your content administrators with a way to audit a newly-imported course for any typos or misbehavior, then a preview launch works perfectly. You can also use it as a way for someone browsing courses to get a quick peek at the course contents, or as a way to preview any changes to the course's settings.