810deb907b
Move all Etherpad's access control from Meteor to a separated [Node application](https://github.com/bigbluebutton/bbb-pads). This new app uses [Etherpad's API](https://etherpad.org/doc/v1.8.4/#index_overview) to create groups and manage session tokens for users to access them. Each group represents one distinct pad at the html5 client. - Removed locked users' access to pads: replaced readOnly pad's access with a new pad's content sharing routine - Pad's access is now controlled by [Etherpad's API](https://etherpad.org/doc/v1.8.4/#index_overview) - Closed captions edited content now reflects at it's live feedback - Improved closed caption's dictation mode live feedback - Moved all Etherpad's API control from Meteor to a separated [app](https://github.com/bigbluebutton/bbb-pads) - Included access control both in akka-apps and bbb-pads
98 lines
2.0 KiB
JavaScript
98 lines
2.0 KiB
JavaScript
import Pads, { PadsUpdates } from '/imports/api/pads';
|
|
import { makeCall } from '/imports/ui/services/api';
|
|
import Auth from '/imports/ui/services/auth';
|
|
import Settings from '/imports/ui/services/settings';
|
|
|
|
const PADS_CONFIG = Meteor.settings.public.pads;
|
|
|
|
const getLang = () => {
|
|
const { locale } = Settings.application;
|
|
return locale ? locale.toLowerCase() : '';
|
|
};
|
|
|
|
const getParams = () => {
|
|
const config = {};
|
|
config.lang = getLang();
|
|
config.rtl = document.documentElement.getAttribute('dir') === 'rtl';
|
|
|
|
const params = Object.keys(config)
|
|
.map((key) => `${key}=${encodeURIComponent(config[key])}`)
|
|
.join('&');
|
|
return params;
|
|
};
|
|
|
|
const getPadId = (externalId) => makeCall('getPadId', externalId);
|
|
|
|
const createGroup = (externalId, model, name) => makeCall('createGroup', externalId, model, name);
|
|
|
|
const hasPad = (externalId) => {
|
|
const pad = Pads.findOne(
|
|
{
|
|
meetingId: Auth.meetingID,
|
|
externalId,
|
|
},
|
|
);
|
|
|
|
return pad !== undefined;
|
|
};
|
|
|
|
const createSession = (externalId) => makeCall('createSession', externalId);
|
|
|
|
const buildPadURL = (padId) => {
|
|
if (padId) {
|
|
const params = getParams();
|
|
const url = Auth.authenticateURL(`${PADS_CONFIG.url}/p/${padId}?${params}`);
|
|
return url;
|
|
}
|
|
|
|
return null;
|
|
};
|
|
|
|
const getRev = (externalId) => {
|
|
const updates = PadsUpdates.findOne(
|
|
{
|
|
meetingId: Auth.meetingID,
|
|
externalId,
|
|
}, { fields: { rev: 1 } },
|
|
);
|
|
|
|
return updates ? updates.rev : 0;
|
|
};
|
|
|
|
const getPadTail = (externalId) => {
|
|
const updates = PadsUpdates.findOne(
|
|
{
|
|
meetingId: Auth.meetingID,
|
|
externalId,
|
|
}, { fields: { tail: 1 } },
|
|
);
|
|
|
|
if (updates && updates.tail) return updates.tail;
|
|
|
|
return '';
|
|
};
|
|
|
|
const getPadContent = (externalId) => {
|
|
const updates = PadsUpdates.findOne(
|
|
{
|
|
meetingId: Auth.meetingID,
|
|
externalId,
|
|
}, { fields: { content: 1 } },
|
|
);
|
|
|
|
if (updates && updates.content) return updates.content;
|
|
|
|
return '';
|
|
};
|
|
|
|
export default {
|
|
getPadId,
|
|
createGroup,
|
|
hasPad,
|
|
createSession,
|
|
buildPadURL,
|
|
getRev,
|
|
getPadTail,
|
|
getPadContent,
|
|
};
|