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

Mỗi giải pháp hội nghị truyền hình mà bạn đã xác định trong manifest của dự án tập lệnh sẽ có một onCreateFunction liên kết. Tiện ích bổ sung gọi hàm này để tạo một cuộc họp bất cứ khi nào người dùng cố gắng chọn giải pháp cuộc họp đó 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 của 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ị của bên thứ ba và tạo một cuộc họp mới bằ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ì 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 tất các bước tiếp theo.
    1. Khởi động tính năng đồng bộ hoá cuộc họp.
    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ề đố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ị truyền hình của bên thứ ba, nhưng thường bao gồm thời gian bắt đầu sự kiện, thời gian kết thúc, bản tóm tắt, danh sách người tham dự và mã nhận dạng.

Khi được gọi, mỗi onCreateFunction bạn xác định sẽ được truyền một đối số chứa mã lịch và mã 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 về sự kiện bằng cách sử dụ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ị vào một sự kiện trước khi sự kiện đó tồn tại. Trong những trường hợp như vậy, Lịch Google sẽ chuyển onCreateFunction một eventId hợp lệ, nhưng các lệnh gọi tiếp theo đến 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ị của bên thứ ba bằng dữ liệu phần 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ị truyền hình 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 tạo các yêu cầu API do hệ thống hội nghị bên thứ ba hỗ trợ. Hãy kiểm tra tài liệu về giải pháp hội nghị của bên thứ ba để xác định những yêu cầu API mà bạn có thể sử dụng để tạo hội nghị.

Trong Apps Script, cách dễ nhất để xử lý việc đưa ra 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 phải xử lý chi tiết uỷ quyền một cách rõ ràng.

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

Khởi động tính năng đồng bộ hoá hội nghị

Sau khi tiện ích bổ sung tạo thành công một cuộc họp trên hệ thống của bên thứ ba, bạn sẽ phải thực hiện một vài bước để bật tính năng đồng bộ hoá để các thay đổi đối với sự kiện trên Lịch Google được phản ánh trong cuộc họp.

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 về cách thiết lập quy trình đồng bộ hoá sau khi tạo hội nghị.

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

Sau đó, bằng cách sử dụng thông tin 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 để chuyển hướng người dùng đến cuộc họp khi cuộc họp bắt đầu.

Khi tạo đố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 URI điểm truy cập và cách kế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ó trong Apps Script.

Xử lý lỗi

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

Khi tạo đối tượng ConferenceData để báo cáo lỗi, bạn không cần đưa bất kỳ thành phần ConferenceData nào vào ngoài đối tượng ConferenceError. ConferenceErrors có thể có một ConferenceErrorType, một thông báo lỗi và trong trường hợp xảy ra vấn đề về việc xác thực, 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 của bên thứ ba.

Ví dụ:

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

Hàm create3rdPartyConference() liên hệ với hệ thống của bên thứ ba để tạo hội nghị truyền hình tại đó, còn hàm getAuthenticationUrl() tạo URL xác thực hệ thống của bên thứ ba. Các lớp này chưa được triển khai đầy đủ tại đây vì chúng phụ thuộc 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 phần Đồ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;
}