mirror of https://github.com/sualko/cloud_bbb
parent
93154c9556
commit
da6657b2a0
|
@ -1,9 +1,9 @@
|
||||||
import axios from '@nextcloud/axios';
|
import axios from '@nextcloud/axios';
|
||||||
|
|
||||||
export enum ShareType {
|
export enum ShareType {
|
||||||
User = OC.Share.SHARE_TYPE_USER,
|
User = 0, // OC.Share.SHARE_TYPE_USER
|
||||||
Group = OC.Share.SHARE_TYPE_GROUP,
|
Group = 1, // OC.Share.SHARE_TYPE_GROUP
|
||||||
Circle = OC.Share.SHARE_TYPE_CIRCLE
|
Circle = 7, // OC.Share.SHARE_TYPE_CIRCLE
|
||||||
}
|
}
|
||||||
|
|
||||||
export enum Permission { Admin, Moderator, User }
|
export enum Permission { Admin, Moderator, User }
|
||||||
|
|
|
@ -1,23 +1,9 @@
|
||||||
import axios from '@nextcloud/axios';
|
import axios from '@nextcloud/axios';
|
||||||
import { generateOcsUrl, generateUrl } from '@nextcloud/router';
|
import { generateOcsUrl, generateUrl } from '@nextcloud/router';
|
||||||
import { Room } from './Common/Api';
|
import { api } from './Common/Api';
|
||||||
|
|
||||||
declare const OCA: any;
|
declare const OCA: any;
|
||||||
|
|
||||||
class BigBlueButton {
|
|
||||||
public async getRooms(): Promise<Room[]> {
|
|
||||||
const response = await axios.get(OC.generateUrl('/apps/bbb/rooms'));
|
|
||||||
|
|
||||||
return response.data;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$(() => {
|
|
||||||
|
|
||||||
if (!OCA?.Files?.fileActions) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
const mimeTypes = [
|
const mimeTypes = [
|
||||||
'application/pdf',
|
'application/pdf',
|
||||||
'application/vnd.oasis.opendocument.presentation',
|
'application/vnd.oasis.opendocument.presentation',
|
||||||
|
@ -35,14 +21,27 @@ $(() => {
|
||||||
'text/plain',
|
'text/plain',
|
||||||
'text/rtf',
|
'text/rtf',
|
||||||
];
|
];
|
||||||
const bbb = new BigBlueButton();
|
|
||||||
|
|
||||||
bbb.getRooms().then(rooms => {
|
async function createDirectShare(fileId: number): Promise<string> {
|
||||||
rooms.forEach(room => {
|
const url = generateOcsUrl('apps/dav/api/v1', 1) + 'direct';
|
||||||
mimeTypes.forEach(mime => registerFileAction(mime, room.id, room.uid, room.name));
|
const createResponse = await axios.post(url, {
|
||||||
|
fileId,
|
||||||
});
|
});
|
||||||
|
|
||||||
|
return createResponse.data?.ocs?.data?.url;
|
||||||
|
}
|
||||||
|
|
||||||
|
async function share(fileId: number, filename: string, roomUid) {
|
||||||
|
const shareUrl = await createDirectShare(fileId);
|
||||||
|
const joinUrl = generateUrl('/apps/bbb/b/{uid}?u={url}&filename={filename}', {
|
||||||
|
uid: roomUid,
|
||||||
|
url: shareUrl,
|
||||||
|
filename,
|
||||||
});
|
});
|
||||||
|
|
||||||
|
window.open(joinUrl, '_blank', 'noopener,noreferrer');
|
||||||
|
}
|
||||||
|
|
||||||
function registerFileAction(mime, id, uid, name) {
|
function registerFileAction(mime, id, uid, name) {
|
||||||
OCA.Files.fileActions.registerAction({
|
OCA.Files.fileActions.registerAction({
|
||||||
name: 'bbb-' + id,
|
name: 'bbb-' + id,
|
||||||
|
@ -56,23 +55,22 @@ $(() => {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
async function share(fileId: number, filename: string, roomUid) {
|
function addRoomsAsFileAction() {
|
||||||
const shareUrl = await createDirectShare(fileId);
|
if (!OCA?.Files?.fileActions) {
|
||||||
const joinUrl = generateUrl('/apps/bbb/b/{uid}?u={url}&filename={filename}', {
|
console.warn('[BBB] "OCA.Files.fileActions" not available');
|
||||||
uid: roomUid,
|
|
||||||
url: shareUrl,
|
|
||||||
filename,
|
|
||||||
});
|
|
||||||
|
|
||||||
window.open(joinUrl, '_blank', 'noopener,noreferrer');
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
async function createDirectShare(fileId: number): Promise<string> {
|
api.getRooms().then(rooms => {
|
||||||
const url = generateOcsUrl('apps/dav/api/v1', 1) + 'direct';
|
rooms.forEach(room => {
|
||||||
const createResponse = await axios.post(url, {
|
mimeTypes.forEach(mime => registerFileAction(mime, room.id, room.uid, room.name));
|
||||||
fileId,
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
return createResponse.data?.ocs?.data?.url;
|
|
||||||
}
|
}
|
||||||
});
|
|
||||||
|
if (document.readyState === 'complete') {
|
||||||
|
addRoomsAsFileAction();
|
||||||
|
} else {
|
||||||
|
document.addEventListener('DOMContentLoaded', addRoomsAsFileAction);
|
||||||
|
}
|
Loading…
Reference in New Issue