Tạo hội nghị truyền hình của bên thứ ba

Mỗi giải pháp hội nghị mà bạn đã xác định trong tệp kê khai của dự án tập lệnh đều có một onCreateFunction liên kết. Tiện ích bổ sung gọi hàm này để tạo hội nghị bất cứ khi nào người dùng cố gắng chọn giải pháp hội nghị làm một sự kiện.

Bạn phải triển khai từng onCreateFunction được mô tả trong tệp kê khai tiện ích bổ sung. Nhìn chung, các hàm này phải thực hiện những việc sau:

  1. Truy xuất mọi thông tin sự kiện trên Lịch Google, chẳng hạn như mã sự kiện hoặc danh sách người tham dự mà hệ thống hội nghị truyền hình bên thứ ba có thể cần để tạo hội nghị.
  2. Kết nối với dịch vụ hội nghị truyền hình của bên thứ ba và tạo một hội nghị mới ở đó bằng cách sử dụng thông tin sự kiện trên Lịch Google.
  3. Nếu yêu cầu tạo hội nghị truyền hình không thành công vì một lý do nào đó, hãy sử dụng thông tin lỗi để tạo và trả về đối tượng ConferenceData chứa ConferenceError. Nếu không, hãy hoàn thành các bước tiếp theo.
    1. Bắt đầu tính năng đồng bộ hoá hội nghị truyền hình.
    2. Sử dụng thông tin do dịch vụ hội nghị truyền hình của bên thứ ba trả về để tạo và trả về một đối tượng ConferenceData mới.

Truy xuất thông tin sự kiện

Để tạo hội nghị của bên thứ ba, bạn cần có một số thông tin nhất định về sự kiện tương ứng trên Lịch Google. Thông tin chính xác về sự kiện cần thiết sẽ khác nhau giữa các hệ thống hội nghị của bên thứ ba khác nhau, nhưng thông tin thường bao gồm thời gian bắt đầu, thời gian kết thúc, thông tin tóm tắt, danh sách người tham dự và mã sự kiện.

Khi được gọi, mỗi onCreateFunction mà bạn xác định sẽ được truyền một đối số chứa mã lịch và sự kiện. Bạn có thể sử dụng các mã nhận dạng này để truy xuất toàn bộ thông tin sự kiện bằng dịch vụ nâng cao của Lịch Google.

Lịch Google có thể thêm thông tin chi tiết về hội nghị truyền hình vào một sự kiện trước khi sự kiện đó diễn ra. Trong những trường hợp như vậy, Lịch Google sẽ truyền cho onCreateFunction một eventId hợp lệ, nhưng các lệnh gọi tiếp theo tới Calendar.Events.get() có thể dẫn đến phản hồi lỗi cho biết sự kiện không tồn tại. Trong những trường hợp này, tốt nhất bạn nên tạo hội nghị bên thứ ba bằng cách sử dụng dữ liệu giữ chỗ; dữ liệu này sẽ được thay thế vào lần tiếp theo sự kiện đồng bộ hoá.

Tạo hội nghị của bên thứ ba

Sau khi truy xuất dữ liệu sự kiện cần thiết, onCreateFunction phải kết nối với hệ thống hội nghị truyền hình của bên thứ ba để tạo hội nghị truyền hình. Thông thường, việc này được thực hiện bằng cách đưa ra các yêu cầu API mà hệ thống hội nghị truyền hình bên thứ ba hỗ trợ. Hãy xem tài liệu của giải pháp hội nghị truyền hình của bên thứ ba để xác định những yêu cầu API mà bạn có thể dùng để tạo hội nghị truyền hình.

Trong Apps Script, cách dễ nhất để xử lý việc gửi các yêu cầu API bên ngoài là sử dụng thư viện nguồn mở OAuth2 cho Apps Script hoặc OAuth1 cho Apps Script. Bạn cũng có thể kết nối với các API bên ngoài bằng dịch vụ UrlFetch, nhưng điều này yêu cầu bạn xử lý thông tin uỷ quyền một cách rõ ràng.

Sau khi yêu cầu tạo hội nghị truyền hình, bạn có thể cần phải thực hiện thêm yêu cầu để truy xuất thông tin chi tiết về hội nghị mới.

Bắt đầu quy trình đồng bộ hoá hội nghị

Khi tiện ích bổ sung đã tạo thành công một hội nghị trên hệ thống của bên thứ ba, bạn cần thực hiện một vài bước để bật đồng bộ hóa nhằm phản ánh những thay đổi đối với sự kiện Lịch Google trong hội nghị.

Xem bài viết Các thay đổi về cách đồng bộ hoá Lịch để biết thông tin chi tiết về cách thiết lập tính năng đồng bộ hoá sau khi tạo hội nghị truyền hình.

Xây dựng phản hồi dữ liệu hội nghị truyền hình

Khi sử dụng thông tin về hội nghị truyền hình do dịch vụ bên thứ ba trả về, onCreateFunction phải tạo và trả về đối tượng ConferenceData; phần Dữ liệu hội nghị mô tả nội dung của đối tượng này. Lịch Google sử dụng thông tin này để hướng người dùng đến hội nghị khi hội nghị bắt đầu.

Khi xây dựng đối tượng ConferenceData, hãy lưu ý rằng có một số giới hạn về độ dài trường, định dạng của URI điểm truy cập và các tổ hợp điểm truy cập được phép. Ví dụ: có thể có tối đa một điểm truy cập VIDEO trong một ConferenceData. Những giới hạn này giống với các giới hạn được mô tả trong Sự kiện API Lịch cho trường conferenceData tương ứng, mặc dù không phải tất cả các trường sự kiện API được mô tả đều có sẵn trong Apps Script.

Lỗi xử lý

Trong một số trường hợp, quá trình tạo hội nghị không thể hoàn tất do hệ thống hội nghị truyền hình bên thứ ba trả về lỗi. Trong những trường hợp này, tiện ích bổ sung của bạn sẽ xử lý mạnh mẽ điều kiện lỗi bằng cách tạo và trả về đối tượng ConferenceData chứa thông tin chi tiết ConferenceError để Lịch Google có thể hoạt động cho phù hợp.

Khi tạo đối tượng ConferenceData để báo cáo lỗi, bạn không cần thêm bất kỳ thành phần ConferenceData nào ngoài đối tượng ConferenceError. ConferenceErrors có thể có ConferenceErrorType, một thông báo lỗi và trong trường hợp xác thực sẽ đưa ra một URL cho phép người dùng đăng nhập vào hệ thống hội nghị truyền hình bên thứ ba.

Ví dụ:

Sau đây là ví dụ về onCreateFunction (xin lưu ý rằng tên của hàm có thể là bất kỳ tên nào; bạn chỉ cần xác định hàm đó trong tệp kê khai dự án bổ sung).

Hàm create3rdPartyConference() liên hệ với hệ thống bên thứ ba để tạo hội nghị tại đó và hàm getAuthenticationUrl() tạo URL xác thực hệ thống của bên thứ ba. Các tính năng này không được triển khai đầy đủ tại đây vì phụ thuộc rất nhiều vào thông tin chi tiết về hệ thống của bên thứ ba.

Hàm initializeSyncing() không xuất hiện ở đây; hàm này xử lý mọi công việc sơ bộ cần thiết để đồng bộ hoá. Xem bài viết Đồng bộ hoá các thay đổi đối với lịch để biết thông tin chi tiết.

/**
 *  Creates a conference, then builds and returns a ConferenceData object
 *  with the corresponding conference information. This method is called
 *  when a user selects a conference solution defined by the add-on that
 *  uses this function as its 'onCreateFunction' in the add-on manifest.
 *
 *  @param {Object} arg The default argument passed to a 'onCreateFunction';
 *      it carries information about the Google Calendar event.
 *  @return {ConferenceData}
 */
function createConference(arg) {
  const eventData = arg.eventData;
  const calendarId = eventData.calendarId;
  const eventId = eventData.eventId;

  // Retrieve the Calendar event information using the Calendar
  // Advanced service.
  var calendarEvent;
  try {
    calendarEvent = Calendar.Events.get(calendarId, eventId);
  } catch (err) {
    // The calendar event does not exist just yet; just proceed with the
    // given event ID and allow the event details to sync later.
    console.log(err);
    calendarEvent = {
      id: eventId,
    };
  }

  // Create a conference on the third-party service and return the
  // conference data or errors in a custom JSON object.
  var conferenceInfo = create3rdPartyConference(calendarEvent);

  // Build and return a ConferenceData object, either with conference or
  // error information.
  var dataBuilder = ConferenceDataService.newConferenceDataBuilder();

  if (!conferenceInfo.error) {
    // No error, so build the ConferenceData object from the
    // returned conference info.

    var phoneEntryPoint = ConferenceDataService.newEntryPoint()
        .setEntryPointType(ConferenceDataService.EntryPointType.PHONE)
        .setUri('tel:+' + conferenceInfo.phoneNumber)
        .setPin(conferenceInfo.phonePin);

    var adminEmailParameter = ConferenceDataService.newConferenceParameter()
        .setKey('adminEmail')
        .setValue(conferenceInfo.adminEmail);

    dataBuilder.setConferenceId(conferenceInfo.id)
        .addEntryPoint(phoneEntryPoint)
        .addConferenceParameter(adminEmailParameter)
        .setNotes(conferenceInfo.conferenceLegalNotice);

    if (conferenceInfo.videoUri) {
      var videoEntryPoint = ConferenceDataService.newEntryPoint()
          .setEntryPointType(ConferenceDataService.EntryPointType.VIDEO)
          .setUri(conferenceInfo.videoUri)
          .setPasscode(conferenceInfo.videoPasscode);
      dataBuilder.addEntryPoint(videoEntryPoint);
    }

    // Since the conference creation request succeeded, make sure that
    // syncing has been enabled.
    initializeSyncing(calendarId, eventId, conferenceInfo.id);

  } else if (conferenceInfo.error === 'AUTH') {
    // Authenentication error. Implement a function to build the correct
    // authenication URL for the third-party conferencing system.
    var authenticationUrl = getAuthenticationUrl();
    var error = ConferenceDataService.newConferenceError()
        .setConferenceErrorType(
            ConferenceDataService.ConferenceErrorType.AUTHENTICATION)
        .setAuthenticationUrl(authenticationUrl);
    dataBuilder.setError(error);

  } else {
    // Other error type;
    var error = ConferenceDataService.newConferenceError()
        .setConferenceErrorType(
            ConferenceDataService.ConferenceErrorType.TEMPORARY);
    dataBuilder.setError(error);
  }

  // Don't forget to build the ConferenceData object.
  return dataBuilder.build();
}


/**
 *  Contact the third-party conferencing system to create a conference there,
 *  using the provided calendar event information. Collects and retuns the
 *  conference data returned by the third-party system in a custom JSON object
 *  with the following fields:
 *
 *    data.adminEmail - the conference administrator's email
 *    data.conferenceLegalNotice - the conference legal notice text
 *    data.error - Only present if there was an error during
 *         conference creation. Equal to 'AUTH' if the add-on user needs to
 *         authorize on the third-party system.
 *    data.id - the conference ID
 *    data.phoneNumber - the conference phone entry point phone number
 *    data.phonePin - the conference phone entry point PIN
 *    data.videoPasscode - the conference video entry point passcode
 *    data.videoUri - the conference video entry point URI
 *
 *  The above fields are specific to this example; which conference information
 *  your add-on needs is dependent on the third-party conferencing system
 *  requirements.
 *
 * @param {Object} calendarEvent A Calendar Event resource object returned by
 *     the Google Calendar API.
 * @return {Object}
 */
function create3rdPartyConference(calendarEvent) {
  var data = {};

  // Implementation details dependent on the third-party system API.
  // Typically one or more API calls are made to create the conference and
  // acquire its relevant data, which is then put in to the returned JSON
  // object.

  return data;
}

/**
 *  Return the URL used to authenticate the user with the third-party
 *  conferencing system.
 *
 *  @return {String}
 */
function getAuthenticationUrl() {
  var url;
  // Implementation details dependent on the third-party system.

  return url;
}