Skip to content

Latest commit

 

History

History
137 lines (86 loc) · 7.33 KB

readme.md

File metadata and controls

137 lines (86 loc) · 7.33 KB

Meetabout

Meetabout is a web app that facilitates virtual meetings between strangers to discuss shared interests. So, if two people decide to meet to talk about X, Meetabout  leverages the easy-to-use Virtual Meeting Room API to host the meeting on the Kaltura platform.

Getting Started

Things to Know

Meetabout is a sample application not intended to run in a production environment in its current state.

Live Demo:

https://meetabout.herokuapp.com/

Prerequisites

  1. Nodejs
  2. MongoDB
  3. Kaltura VPaaS account. Once you've opened an account, send an email to [email protected] to activate Meetings.

Install and Run

  1. Clone the Meetabout Github Repo
  2. Run npm install
  3. Copy .env.template to .env and populate the following required fields (other fields in the file are not required to run this app):
SESSION_SECRET= #Key used for encrypting session cookies 
SERVER_HOST_URL=http://localhost:3000 
MONGO_URI= #mongodb+srv:// 
KALTURA_SERVICE_URL=https://www.kaltura.com 
KALTURA_ADMIN_SECRET= #obtained from https://kmc.kaltura.com/index.php/kmcng/settings/integrationSettings 
KALTURA_PARTNER_ID=#obtained from https://kmc.kaltura.com/index.php/kmcng/settings/integrationSettings 
KALTURA_USER_ID=#set it to the Kaltura user designated as admin. This is usually the email address you used to create your Kaltura account 
  1. Run the app: npm start

Logging In

Meetabout requires a logged-in user to work. Any attempt to execute the app will force a modal login window to appear. The default login method uses passportjs local strategy, which is completely insecure and therefore should only run on your local machine. Of course this approach does make it very easy to get up and running quickly.

Note: If you want to run Meetabout as a production app, comment out router.post('/', in routes/auth_local.js and implement other authentication strategies. For example, the GitHub, LinkedIn, Microsoft and Google OAuth strategies are implemented in routes/auth_<x> and you can uncomment those routes from app.js. You would also need to create OAuth credentials for those services and supply the keys in .env.

Once logged in, you can begin using the app!

Adding a Topic

Begin by creating a topic to have a meeting about! Enter a topic into "More Topics" and press "Add New Topic".

addtopic

Finding a Meeting

Click on the "Find Meetings" button and you will see a list of all the topics you subscribed to. Choose any topic, and then click the "Meet About: [topic]" button to open the virtual meeting room in a new window.

addtopic

A Meeting!

newrow_room

Setting Up a Meeting: Beneath the Hood

A Kaltura virtual meeting room is created and joined through a series of API calls, described in detail in the integration guide. The Virtual Room Manager App is another helpful tool to understand its usage.

Now, let's walk through the Meetings API, as it relates to Meetabout.

To create a new meeting, we are routed to /routes/meetings.js which calls the createRoom function in /lib/createroom.js:

 createRoom(topicName, function (kalturaResponse) {

kaltura.services.session.start creates a Kaltura Admin Session which is needed to create the virtual room:

// Create the virtual room
let scheduleResource = new kaltura.objects.LocationScheduleResource();
scheduleResource.name = topicName;
scheduleResource.tags = "vcprovider:newrow";

kaltura.services.scheduleResource.add(scheduleResource)
.execute(client)

Notice that the topicName from Meetabout is passed as the topic of the Virtual Room.

The call to kaltura.services.scheduleResource.add(scheduleResource) creates a resource, which is Kaltura's terminology for a virtual room. The resource has an ID which is saved to the Mongo Meeting Model in /routes/meetings.js

createRoom(topicName, function (kalturaResponse) {
      new Meeting({
        topic: topicId,
        user1: uid1,
        user2: uid2,
        kalturaResourceId: kalturaResponse.id
      }).save(function (err, doc) {

The virtual meeting room has now been created and is ready to be used!

Joining the Virtual Meeting Room

Some preparation is needed to join the resource or virtual meeting room. The room needs to know your identity and your user type. Kaltura can designate meeting users as either admins or viewers, where the admins have special privileges. However, in Meetabout, both users are treated as equals and both will be made admins.

In order to identify a user to the room, we need to create a Kaltura Session with some metadata related to the Virtual Meeting Room API, and this is kicked off from /routes/meetings.js right after .save from above by calling:

joinRoom(kalturaResponse.id, user.name, user.email, function (joinLink) {

This then calls /lib/joinroom.js to create a Kaltura Session and authenticates the user that clicked the "Join Meeting" button.

The URL scheme for the room follows the convention for virtual meeting rooms and is created in /lib/joinroom.js:

let roomUrl = "https://" + partnerId + ".kaf.kaltura.com/virtualEvent/launch?ks=" + result;

The ks is a string representing the Kaltura Session for the user for this meeting room. And the partnerId is your Kaltura VPaaS account's partner ID.

And that is it! The URL is ready to use to join the room! It is passed back to the meeting webpage and into the href of the "Join Meeting" button!
And btw, you can also embed this link in an iframe, so in your own app, the room can be embedded inside your application (and in future time we can

Email Setup

Note: this step is unrelated to the usage of the Kaltura Virtual Room API

A production app would use an SMTP server at a company, or an SMTP service. For testing purposes, you can sign up for a free account at ethereal and fill out the following fields in .env:

SMTP_HOST=smtp.ethereal.email
SMTP_USER=
SMTP_PASS=
SMTP_PORT=587