This project is a proof of concept to show you how to programmatically use a template to supply metadata like Name, Tags, Category etc for the recording of a Kaltura Meeting.
https://kaltura-meetings-example-entry.herokuapp.com/
http://www.kaltura.com/tiny/vvxmy
- Nodejs
- Kaltura VPaaS account. Once you've opened an account, send an email to [email protected] to activate Meetings.
- Copy env.template to .env and fill in your information
- run npm install
- npm run dev for developement
- npm start for production
To start a meeting, the code from kaltura-nodejs-template was copied into this project, and you can refer to Kaltura Meetings Integration Guide for a comprehensive guide to the Meetings API.
//create room aka resource
let room = await createRoom(adminKs, "Room Topic");
The room is created in createRoom.js
Take note of the custom_rec_auto_start:1
parameter being used to automatically start recordings when the meeting starts. You can learn about other parameters for Kaltura Meetings at Kaltura Meetings Integration Guide
Next, a mediaEntry is created as the template. Almost all meta data from this template will be applied to the recording.
//create mediaEntry as template
let media = await addMedia(adminKs, "The name");
In this example, only the name field is being assigned, however almost all metadata will be applied from the template, like Tags, Category, etc, you can take a look at mediaEntry.add for a full list of meta data available.
Next, an event is created starting now, and going 3 hours into the future.
//create schedule event
let now = Math.floor(Date.now() / 1000);
let end = now + 10800;
let event = await scheduleEvent(adminKs, "Event Topic", now, end, media.id);
And media.id
is passed into the event creation in scheduleEvent.js which is a wrapper for the scheduleEvent.add API call.
async function scheduleEvent(adminKs, topicName, start, end, templateEntryId) {
const client = await KalturaClientFactory.getClient(adminKs);
let scheduleEvent = new kaltura.objects.RecordScheduleEvent();
scheduleEvent.startDate = start;
scheduleEvent.endDate = end;
scheduleEvent.summary = topicName;
scheduleEvent.recurrenceType = kaltura.enums.ScheduleEventRecurrenceType.NONE;
scheduleEvent.templateEntryId = templateEntryId
// *** https://developer.kaltura.com/console/service/scheduleEvent/action/add
return kaltura.services.scheduleEvent.add(scheduleEvent)
While it is not required to schedule an event in order to host a Kaltura Meeting, the only way to apply a template to a recording is via scheduleEvent.add
and since this event is schedule to start now, effectively, this technique can be used for adhoc, on-the-fly meetings as well.
As you see, the id
of the mediaEntry
that was created previously is passed into scheduleEvent
and used as the templateEntryId
Now in index.js
the room
, mediaEntry
template and event
have been created, next:
//associate room with event
await scheduleEventResource(adminKs, event.id, room.id);
let adminRoom = await joinRoom(event.id, null,
true,
"Admin Name",
"Admin Last Name",
"[email protected]");
The room is associated with the event via scheduleEventResource and finally, a url for the admin to join the event is created and passed to index.ejs
res.render('index', {
adminUrl:adminRoom
});
At this point, the user would start a meeting, record it, stop the recording and finally, the recording would be available in your KMC with the metadata from your template, in this case its name would be "The name"
Thank you for helping Kaltura grow! If you'd like to contribute please follow these steps:
- Use the repository issues tracker to report bugs or feature requests
- Read Contributing Code to the Kaltura Platform
- Sign the Kaltura Contributor License Agreement
- Join the Kaltura Community Forums to ask questions or start discussions
- Read the Code of conduct and be patient and respectful
You can learn more about Kaltura and start a free trial at: http://corp.kaltura.com
Contact us via Twitter @Kaltura or email: [email protected]
We'd love to hear from you!
All code in this project is released under the AGPLv3 license unless a different license for a particular library is specified in the applicable library path.
Copyright © Kaltura Inc. All rights reserved.
Authors and contributors: See GitHub contributors list.