Scheduling a Meeting
BookConf
API Description
This API is used to schedule a meeting.
Precautions
- Call this API after login.
- This API is an asynchronous API. The return value only indicates whether the API is successfully called. The actual service processing result is returned in the corresponding callback function.
- When calling this API, add yourself to the participant list and set yourself as the host.
- The callback function returns details about scheduled meetings. For details, see HwmConfDetail. If only meeting IDs are returned, meeting details fail to be obtained.
Method Definition
1
|
HWM_SDK_AGENT_API hwmsdk::HwmErrCode BookConf(const HwmBookConfParam *param); |
Callback Function
1
|
virtual void OnBookConfResult(hwmsdk::HwmErrCode ret, const char* reason, const HwmConfDetail* confDetail) {}; |
Parameter Description
Parameter |
Mandatory |
Type |
Description |
---|---|---|---|
subject |
Yes |
char[] |
Meeting topic. |
startTime |
Yes |
long long |
UTC timestamp when the meeting starts, in seconds.
NOTE:
The value is the difference between the UTC time and the UTC offset (converted into seconds). For example, if the time zone is UTC+08:00, the value is the UTC timestamp – (8 x 60 x 60). |
duration |
Yes |
int |
Meeting duration, in minutes. The value ranges from 15 to 1,440. |
confType |
No |
Meeting type. The default meeting type is video meeting. |
|
isNeedConfPwd |
No |
bool |
Whether a password is required. By default, no password is required.
NOTE:
This parameter is valid only for meetings with a random ID. |
isRecordOn |
No |
bool |
Whether to enable recording.
NOTE:
This parameter is valid only for cloud recording, not for local recording on clients. |
isAutoRecordOn |
No |
bool |
Whether to enable automatic meeting recording. Disabled by default. If automatic meeting recording is enabled, the meeting can be recorded by default even meeting recording is disabled.
NOTE:
This parameter is valid only for cloud recording, not for local recording on clients. |
timeZone |
Yes |
int |
Time zone code. For details, see Time Zone Table. This parameter is used for sending meeting notifications. |
vmrFlag |
No |
bool |
Whether to use the virtual meeting room. To schedule a meeting with a concurrent meeting ID, set this parameter to false. (This parameter is deprecated.) |
vmrId |
No |
char[] |
Unique cloud meeting room ID. To schedule a meeting with a concurrent meeting ID, set this parameter to an empty string. |
joinConfRestrictionType |
No |
Users who are allowed to join the meeting. By default, everyone is allowed. |
|
isSmsOn |
No |
bool |
Whether to send an SMS notification. To use this function, enable it in the enterprise configuration. Otherwise, this parameter does not take effect. |
isMailOn |
No |
bool |
Whether to send an email notification. |
isEmailCalendarOn |
No |
bool |
Whether to send an email calendar. |
attendees |
Yes |
Participant list. |
|
attendeeLen |
Yes |
unsigned int |
Number of participants. |
vmrConfIdType |
No |
ID type of the cloud meeting room. |
|
guestPwd |
No |
char[] |
Guest password. If this parameter is left blank, the guest password is generated by the server.
NOTE:
This parameter is valid only for meetings with a random ID. |
isOpenWaitingRoom |
No |
bool |
Waiting room status.
NOTE:
The function takes effect only after the waiting room function is enabled. |
allowGuestStartConf |
No |
bool |
Whether to allow guests to join the meeting ahead of the host.
NOTE:
|
allowGuestStartConfTime |
No |
unsigned int |
Time range allowed for guests to join the meeting in advance, in minutes. 0: Guests can join the meeting at any time before the scheduled time. x: Guest can join the meeting x minutes before the scheduled time.
NOTE:
|
concurrentParticipants |
No |
unsigned int |
Maximum number of participants in the meeting. If this parameter is left blank, there is no restriction. |
customInfo |
No |
char[] |
Custom extension information. |
confResType |
No |
Meeting resource type. |
|
defaultSummaryState |
No |
Initial state of whether the cloud recording contains minutes. |
|
autoMuteMode |
No |
Whether soft client guests are automatically muted when they join the meeting. |
|
hardTerminalAutoMuteMode |
No |
Whether hard terminal guests are automatically muted when they join the meeting. |
Enumerated Value |
Description |
---|---|
HWM_AUDIO_AND_DATA |
Voice and data meeting. |
HWM_VIDEO_AND_DATA |
Video and data meeting. |
Enumerated Value |
Description |
---|---|
RESTRICTION_CALL_IN_ALL |
Everyone. |
RESTRICTION_CALL_IN_COMPANY |
Corporate users only. |
RESTRICTION_CALL_IN_INVITED |
Invited users only. |
Parameter |
Mandatory |
Type |
Description |
---|---|---|---|
number |
Yes |
char[] |
Number. If this parameter is set to the SIP number (for example, +99111244216210249) allocated to the account, the Huawei Cloud Meeting app is called. If this parameter is set to a PSTN number (for example, 18700000000), the number is called through the VoIP gateway if the enterprise has enabled PSTN call. This parameter is used for account and password authentication. Either this parameter or thirdUserId must be set. |
thirdUserId |
Yes |
char[] |
Third-party user ID. This parameter is used for app ID authentication. Either this parameter or number must be set. |
name |
Yes |
char[] |
Participant name. |
|
No |
char[] |
Email address used for receiving email notifications. |
sms |
No |
char[] |
Mobile number used for receiving SMS notifications. |
isMute |
No |
bool |
Whether to mute the microphone. |
isAutoInvite |
No |
bool |
Whether to automatically invite participants. |
role |
Yes |
Participant role in the meeting. |
|
isAnonymous |
No |
BOOL |
Whether to join the meeting anonymously. (This parameter is used only for obtaining the participant list.) |
callStatus |
No |
Participant status. (This parameter is used only for obtaining the participant list.) |
|
orgId |
No |
char[] |
Used to identify whether the participant belongs to the current enterprise. (This parameter is used only for obtaining the participant list.) |
Enumerated Value |
Description |
---|---|
HWM_CONF_ROLE_ATTENDEE |
Guest. |
HWM_CONF_ROLE_CHAIRMAN |
Host. |
Enumerated Value |
Description |
---|---|
HWM_VMR_CONF_ID_TYPE_FIXED |
Fixed ID of the cloud meeting room. |
HWM_VMR_CONF_ID_TYPE_RANDOM |
Random ID of the cloud meeting room. |
Type |
Description |
---|---|
HwmErrCode |
If 0 is returned, the operation is successful. If other values are returned, the operation fails. For details about values returned upon failures, see Common Error Codes. |
Parameter |
Type |
Description |
---|---|---|
confListInfo |
HwmConfListInfo |
Meeting details. For details, see Table 3. |
vmrFlag |
bool |
Whether the meeting is held in a cloud meeting room. |
vmrId |
char[] |
Unique cloud meeting room ID. |
isRecordOn |
bool |
Whether recording is supported. |
isAutoRecord |
bool |
Whether to enable automatic meeting recording. |
isGuestFreePwd |
bool |
Whether a guest can join the meeting without the password. |
isMailOn |
bool |
Whether to send email notifications. |
isSmsOn |
bool |
Whether to send SMS notifications. |
isEmailCalenderOn |
bool |
Whether to send calendar notifications. |
joinConfRestrictionType |
HwmJoinConfPermissionType |
Participants who are allowed to join the meeting. For details, see Table 3. |
attendees |
HwmAttendeeInfo* |
Participant list. For details about the fields, see Scheduling a Meeting. |
attendeeLen |
unsigned int |
Number of participants. |
confServerType |
HwmConfServerType |
Meeting server type. 1: RTC. 0: MCU. |
isOpenWaitingRoom |
bool |
Whether to enable the waiting room. |
Sample Code
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 |
/** * Schedule a meeting. */ int CdemoBookConfDlg::OnBnClickedBookConf() { hwmsdkagent::HwmBookConfParam data = {0}; strncpy_s(data.subject, GetConfSubject().c_str(), HWM_MAX_SUBJECT_LEN); // UTF-8 string data.confType = hwmsdkagent::HwmConfMediaType::HWM_VIDEO_AND_DATA; data.isNeedConfPwd = true; data.isAutoRecordOn = true; data.isRecordOn = true; data.startTime = 1598398920; // UTC timestamp, in seconds. If the obtained time is the local time, the time needs to be converted to the UTC time. data.duration = 30; // Meeting duration, in minutes data.timeZone = 56; // Time zone. The value 56 indicates GMT+08:00. data.joinConfRestrictionType = hwmsdkagent::HwmJoinConfPermissionType::RESTRICTION_CALL_IN_ALL; std::vector<hwmsdkagent::HwmAttendeeInfo> attendeeList; // Participants to invite hwmsdkagent::HwmAttendeeInfo attendeeInfo = { 0 }; strncpy_s(attendeeInfo.name, GetAttName().c_str(), HWM_MAX_USER_NAME_LEN); strncpy_s(attendeeInfo.number, GetAttNumber().c_str(), HWM_MAX_NUMBER_LEN); strncpy_s(attendeeInfo.email, GetAttEmail().c_str(), HWM_MAX_EMAIL_LEN); strncpy_s(attendeeInfo.sms, GetAttSms().c_str(), HWM_MAX_PHONE_NUM_LEN); strncpy_s(attendeeInfo.thirdUserId, GetAttUserId().c_str(), HWM_MAX_USER_ID_LEN); attendeeInfo.isMute = true; attendeeInfo.isAutoInvite = true; attendeeList.push_back(attendeeInfo); data.attendees = attendeeList.data(); data.attendeeLen = attendeeList.size(); data.isSmsOn = true; data.isMailOn = true; data.isEmailCalendarOn = true; return hwmsdkagent::BookConf(&data); } |
Feedback
Was this page helpful?
Provide feedbackThank you very much for your feedback. We will continue working to improve the documentation.See the reply and handling status in My Cloud VOC.
For any further questions, feel free to contact us through the chatbot.
Chatbot