There are a number of conference tools presently available for enabling people to conduct live meetings, conferences, presentations, or other types of gatherings via the Internet, the public switched telephone network (PSTN), or other voice and/or data networks. In these cases, participants typically use a telephone, computer, or other communication device that connects to a conference system or server. The meetings include an audio component and/or a visual component, such as, a shared presentation, video, whiteboard, or other multimedia, text, graphics, etc. These types of convenient conference solutions have become an indispensable form of communication for many businesses and individuals.
Typically, such conference calls involve an organizer initially scheduling a conference call and sending invitations to the desired participants. Each invited participant can be provided a subject of the conference, a call-in telephone number, a time and date for the conference call, an access code in the form of a pass code and, perhaps, a list of other participants. An invited participant is then required to call the call-in number at the particular time and date, enter a pass code and subsequently be connected to the scheduled conference call.
Conference calling enables multiple parties to conveniently meet and conduct business without the expense, both time and money, incurred by traveling to a particular location. However, while existing conference, meeting, grouping or other types of gathering systems offer many advantages, there remain significant areas for new and improved ideas for allowing users with to easily and efficiently identify their conference session preferences in conjunction with their day to day calendar.
A system, in accord with a first aspect of this disclosure, includes at least one processor and one or more computer readable media. The computer readable media include instructions which, when executed by the at least one processor, cause the at least one processor to cause to be displayed, to a first user for a first conference event, a first user interface including a first selectable option for the first user to be automatically connected to the first conference event. The instructions also cause the at least one processor to record, in response to a first user selection of the first selectable option, a first authorization to automatically connect the first user to the first conference event. The instructions further cause the at least one processor to automatically initiate, in response to the recorded first authorization and at a time associated with the first conference event, a first telecommunications session with the first user, thereby connecting the first user to the first conference event.
A method, in accord with a second aspect of this disclosure, includes receiving a conference organization request identifying time of a first conference event and a plurality of attendees including a first attendee. The method further includes delivering, to a first device associated with the first attendee identified in the conference organization request, a meeting invite with embedded control signals that, when executed by the first device, cause the first device to display a first user interface including the time of the first conference event, a first selectable option indicating accepting or declining the meeting invite, and a second selectable option indicating whether to automatically establish connection between a system hosting the first conference event and one or more devices associated with the first attendee. In addition, the method includes receiving, from the first device, a first response to the displayed first user interface, the first response including a user selection of the first selectable option accepting the meeting invite, and a user selection of the second selectable option to automatically establish a connection between the system hosting the first conference event and the one or more devices associated with the first attendee. Furthermore, the method includes setting a connection trigger condition corresponding to the first attendee and the first conference event, the connection trigger condition specifying a trigger time, set based on the time of the first conference event, to automatically establish a connection between the system hosting the first conference event and the one or more devices associated with the first attendee. The method also involves determining that the connection trigger condition has been met, automatically causing a first connection to be established between the system hosting the first conference event and a second device of the one or more devices associated with the first attendee, and causing the first attendee to be admitted into the first conference event.
A system, in accord with a third aspect of this disclosure, includes means for receiving a conference organization request identifying time of a first conference event and a plurality of attendees including a first attendee, and means for delivering, to a first device associated with the first attendee identified in the conference organization request, a meeting invite with embedded control signals that, when executed by the first device, cause the first device to display a first user interface means including the time of the first conference event, a first selectable option indicating accepting or declining the meeting invite, and a second selectable option indicating whether to automatically establish connection between a means for hosting the first conference event and one or more devices associated with the first attendee. The system further includes means for receiving, from the first device, a first response to the displayed first user interface means, the first response including a user selection of the first selectable option accepting the meeting invite, and a user selection of the second selectable option to automatically establish a connection between the means for hosting the first conference event and the one or more devices associated with the first attendee. In addition, the system includes means for setting a connection trigger condition corresponding to the first attendee and the first conference event, the connection trigger condition specifying a trigger time, set based on the time of the first conference event, to automatically establish a connection between the means for hosting the first conference event and the one or more devices associated with the first attendee. Furthermore, the system includes means for automatically causing, in response to determining that the connection trigger condition has been met, a first connection to be established between the means for hosting the first conference event and a second device of the one or more devices associated with the first attendee and means for causing the first attendee to be admitted into the first conference event.
This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used to limit the scope of the claimed subject matter. Furthermore, the claimed subject matter is not limited to implementations that solve any or all disadvantages noted in any part of this disclosure.
The drawing figures depict one or more implementations in accord with the present teachings, by way of example only, not by way of limitation. In the figures, like reference numerals refer to the same or similar elements. Furthermore, it should be understood that the drawings are not necessarily to scale.
In the following detailed description, numerous specific details are set forth by way of examples in order to provide a thorough understanding of the relevant teachings. However, it should be apparent that the present teachings may be practiced without such details. In other instances, well known methods, procedures, components, and/or circuitry have been described at a relatively high-level, without detail, in order to avoid unnecessarily obscuring aspects of the present teachings.
The following implementations introduce a method and system for automatically joining a scheduled conference event, where a user may be offered options for enabling the automatic connection to the conference at various stages or instances prior to the scheduled meeting. Traditionally, conference scheduling has included a series of steps where users can: (1) schedule a meeting; (2) generate an invitation to send to participant(s); (3) receive an invitation; (4) RSVP for the meeting; (5) connect to the meeting; and (6) communicate with fellow participants and/or present audio or video in real-time, during the conference.
However, there are many technical problems associated with this process. For example, participants can fail to recall they have an upcoming meeting, incorrectly recall the time or date the meeting has been scheduled, or they may be away from a device that would facilitate their access to the meeting. In some other cases, a user may set an alarm on a personal device to remind them of the conference, but at the time of the alarm they may be away from the device generating the alarm, have inadvertently muted the alarm, or be unable to recall which event the alarm was associated with. In addition, if the meeting has been rescheduled to a different time, the alarm may not be updated, and result in that user missing the meeting. Even in cases where the user remembers the scheduled meeting in a timely manner, they may encounter situations where they are away from the office or from the device that would facilitate their access to any conference login information, thereby delay their attempts to join the call. If the user is in a location where there is no internet, they may be unable to enter the correct access code and number.
As will be discussed below, the disclosed implementations offer a powerful set of technical solutions by which a user can ensure a timely and ready automatic connection to meetings at particular instances leading up to the meeting. The option will be provided to the user in a manner that maximizes convenience and efficiency. For example, the option to be automatically connected to a meeting can be presented to a user as he or she is scheduling the meeting, during their review of the invitation or while RSVP-ing, and/or while viewing reminders, calendar updates or previews, or other items associated with meeting preparation, information, or notifications. By offering users the option to auto-join a conference during one or more workflow instances leading up to the meeting, a user can make better decisions for their day-to-day schedule, as well as easily modify their connection preferences for each meeting that appears on their calendar.
These solutions provide a wide array of advantageous technical effects. By opting to auto join a meeting, a user can be contacted directly at a preferred device(s) and/or via a preferred application(s), without being prompted to enter access codes, pin numbers, website passwords, or other such login credentials, and participate in the conference event with little effort. Furthermore, by providing individual event opportunities to select the auto join feature, a user can customize the manner in which they connect to each particular meeting on their calendar, per their preference, at first view—as they receive invitations or as they create an invitation. For example, a user may auto-connect to some meetings, and manually connect to other meetings. In addition, the auto-connect settings or configuration may be adjusted for each conference event that occurs. As will be discussed below, users can also opt to auto-record upcoming meetings (or meetings in progress), providing the benefit of access to meeting history and information, as well as the added advantage of ‘attending’ meetings that overlap in time by subsequent playback of the missed portions or conferences.
For purposes of this application, a conference event (“conference”) or a meeting can refer to a real time, or near-real time, telecommunication session involving two or more participants. Thus, a meeting can encompass an event, activity, gathering, assembly, class, conference, convention, summit, get-together, congregation, reunion, or the like that may be prescheduled. Examples can include a conference call, a World Wide Web (Web) based conference, a videoconference, and/or a multi-party instant messaging (IM) or chat session. As will be discussed below, when a scheduled conference arises, the participants who have opted to be automatically joined to said conference will be contacted and then joined into the conference, and/or can receive a notification via a selected communication channel that provides a link to access the meeting.
In addition, the term scheduled meeting or scheduled conference as used throughout this application refers to a communication session that has been scheduled for a particular date/time. It should be understood that the disclosed implementations may also be applicable to meetings that have not yet been scheduled. For example, as a user is creating the meeting, or if a general meeting notice is communicated and the time/date is to be announced or determined at a later time (TBA/TBD), or before a meeting has been finalized.
Furthermore, while the terms “call” or “calls” will be used in the description, the described systems and methods are also applicable to session-based telecommunications in general and are not limited to voice calls. It will also be appreciated that the systems and methods are not limited to sessions and are applicable to messaging-based or packet-based communications. Thus, conference calls can include exchange of as any combination of voice data, video data, text data, image data (e.g., presentation data), file data, or any other types of data.
As noted above, the option to automatically connect to a scheduled meeting or conference event can be configured to occur at various workflow instances of a meeting lifecycle and can have an effect on both the connection process as well as aspects of the meeting itself. A meeting lifecycle includes the time during the meeting, as well as the time prior to the meeting and the time after the meeting. The workflow instances for a meeting therefore include any step, event, action, or communication associated with the meeting, and can include but is not limited to creation of the meeting, receipt of a meeting invite, communications between invitees of the meeting, meeting documents shared with invitees, agenda or calendar notifications related to the meeting, meeting updates, and so forth. Furthermore, the following implementations may refer to the concept of “first view”, which refers to an instance in which a participant first engages with information for the meeting; for example, while creating the meeting or when receiving the invite.
For purposes of this application, usage of the terms “automatically connect”, “automatically join”, “auto-connect”, or “auto-join” refer to the capability of a system to automatically initiate and establish a connection between a system hosting the conference event and one or more devices associated with the attendee when a predetermined date and time occurs and/or specified conditions are met. For example, if the auto-connect feature is enabled, the system can be configured to begin placing outgoing telephone calls via a telephony system to a participant that has opted to be auto-connected to the meeting. As another example, the system may be configured to generate and/or transmit notifications on the date and around the time of the conference via a direct link the meeting to participants that have authorized auto-connect functionality.
Furthermore, references to a communication application, a scheduling application, an organizer application, or simply “application” may be understood to refer to any software applications configured to provide a means of scheduling, viewing, modifying, joining a meeting, and/or communicating or transmitting or receiving data associated with the meeting. This can include any type of electronic calendar or electronic scheduling system that is capable of tracking a user's meetings or appointments. Some such programs can include Skype®, Microsoft Teams®, Microsoft Outlook®, GoToMeeting®, WebEx®, Zoom®, Join.Me®, GoogleHangouts®, AnyMeeting® and other applications that can provide conferencing tools and/or facilitate communication or collaboration online. These are non-limiting examples, and any other communication-related application may benefit from the disclosed implementations. Specific references to a software application by name throughout this description should not therefore be understood to limit the use of the proposed systems and methods. It should further be understood that in some implementations, the application used to enable an auto-connection function may differ from the application used to schedule the meeting, while in other implementations, they may be the same.
In order to better introduce the technical solutions offered by the disclosed systems and methods,
In this example, the first user 110 is presented with an initial selectable option 190 to auto join a meeting they are currently creating and the second user 120, third user 130, and fourth user 140 are also presented with their own selectable options 192 as they view their respective invitations to the meeting. In other words, during their first viewing of information (“first instance”) associated with the conference, each potential attendee is able to easily select if they prefer to be auto joined to the meeting. By displaying this option during the first viewing of the meeting information, when a user is most likely to give their most attention and time to the details of the conference, a user can create and/or respond to an invite, consider the logistics of the meeting, and make a measured, thoughtful choice as to whether they prefer to be auto joined this particular event.
As shown in
Referring now to
It can be seen that the benefits this type of technical solution, whereby one is given the option to auto join the conference while initially viewing information for the conference, itself can significantly simplify the connection process for each invitee. The user is no longer required to expend time or attention in following additional steps to be connected to the call, nor are they required to modify their overall connection preferences (applicable to all conferences), for example via a generalized or indiscriminate settings menu in order to facilitate their connection to one particular meeting. As will be discussed below, the option to auto join can be provided during one or all instances in which information associated with each individual conference is communicated to a user, without affecting a user's connection preferences for other meetings.
Referring now to
The scheduler user interface 300 includes a plurality of fields 310 for receiving meeting-related input, including but not limited to a title field 312, a location field 314, a start field 316, an end field 318, a meeting details field 320, and an invitees field 322. In different implementations, the application can be configured to present additional or other options to a user. As one example, a selectable option 390 is included by which a user may request to be auto-joined to this meeting. In
While the selectable option 390 is positioned beneath the end field 318 and meeting details field 320 in
Another technical conferencing management solution is shown in
In different implementations, a conference organization request can also be sent to an invitee with details for a scheduled meeting (meeting invitation). This invitation can identify time of a first conference event and a plurality of attendees including a first attendee. For example, a remote system can be configured to deliver to a web browser application executing on the user's device as identified in the conference organization request a meeting invite. This meeting invite can include embedded control signals that, when executed by the user's device, cause the device to display a first user interface. In different implementations, the first user interface can include the time of the first conference event, a first selectable option indicating accepting or declining the meeting invite, and/or a second selectable option indicating whether to automatically establish connection between a system hosting the first conference event and one or more devices associated with the first attendee.
For purposes of clarity, one example of a meeting invitation is depicted in
A selectable option 590 is included by which a user may request to be auto-joined to this meeting. In
Thus, in different implementations, the remote system can be configured to receive, from the user's device, a response to the displayed first user interface. The response can include a user selection of the first selectable option accepting the meeting invite, and a user selection of the second selectable option to automatically establish a connection between the system hosting the conference event and one or more devices associated with the user. This can command the remote system to set a connection trigger condition corresponding to the user and the conference event. The connection trigger condition can specify a trigger time, set based on the time of the conference event, to automatically establish a connection between the system hosting the conference event and the one or more devices associated with the user. Once the remote system determines that the connection trigger condition has been met, it can automatically cause a connection to be established between the system hosting the conference event and the same or other device associated with the user, causing the user to be admitted into the first conference event.
Furthermore, as described above with respect to
In different implementations, a user may continue to receive information for various meetings and events on a collaboration, calendar, or agenda component of a conferencing application. Referring to
The calendar panel 602 in this example includes a first indicator 610 for a first meeting, a second indicator 620 for a second meeting, and a third indicator 630 for a third meeting. Each indicator can be configured to display or present information specific to one event or activity. In
With respect to the first indicator 610, it can be seen that the first meeting (“Design Crit”) is already in progress, and an auto join option is not offered—instead a first selectable option 612 indicates only a straightforward “Join” function that may remain available throughout the duration of an ongoing meeting. In addition, a user can opt to initiate a recording of the in-progress meeting from their calendar (see a selectable record option 614), without necessarily joining the meeting or having to access further interfaces or settings.
A later meeting is represented by the second indicator 620 (“PM Roadmap Planning Part 2”) that has an upcoming start time. For purposes of illustration, the second indicator 620 can be understood to represent a second instance or second viewing of information for a specific meeting that has been presented to a user. In this case, the user is being shown various details for the second meeting via the second indicator 620, including their previously submitted preference to be auto-joined to this meeting, as reflected by a second selectable option 622 being switched “ON”. It should be understood that they can review and modify their previous selection to Auto-Join the meeting via the second selectable option 622 via the second indicator 620 (e.g., turn the option to “OFF” via the second selectable option 622). Furthermore, a first selectable auto-record option 624 is also shown, by which a user can request the system to automatically record the conference, as discussed herein.
In addition, the third indicator 630 is directed to a third meeting (“Brown Bag: Marketing Design”) occurring on a later date. This indicator can similarly be understood to represent a second instance or second viewing by the user of information for a specific meeting. In this case, the user is shown various details for the second meeting, including their preference to not be auto joined to this meeting, as reflected by a third selectable option 632 being switched “OFF”. As noted above, they can review and modify their selection to Auto-Join the meeting via the third selectable option 632 (e.g., turn the option to “ON” via the third selectable option 632). A second selectable auto-record option 634 is also shown, by which a user can request the system to automatically record the conference.
Thus, it can be seen that across different implementations, meeting information may be conveyed in many other formats and over a plurality of instances. As a few non-limiting examples, reminders or other types of notifications for a particular meeting may be sent to a user, updates to the meeting may occur and require the meeting information to be re-sent, meeting-related pop-up windows or ‘toasts’ can appear on user devices, chat messages related to the meeting may be communicated between participants, emails discussing the upcoming meeting may be sent, or SMS messages with meeting information can be generated.
Each instance can include information that provides a user with details or a message associated with a specific or particular conference event. Thus, a user may receive one, two, three, or multiple instances over the course of the pre-meeting workflow, where each instance that occurs is in some way related to the upcoming scheduled meeting. These notifications or indicators can also occur once the scheduled meeting has begun, for example, via a reminder email to the user that has failed to connect to the meeting on time.
In different implementations, the technical solution(s) offered by the auto-join feature and/or auto-record feature are configured to be presented as a recurring or repeated option, during any one of the pre-meeting instances in which any information associated with a specific meeting is communicated or conveyed to a user. A further example of this mechanism is shown in
The first notification interface 700 can be understood to represent an additional instance (e.g., second instance) of information for the third meeting 710 being presented to a user. In this case, the user is shown various details for the third meeting, including their preference to be auto joined to this meeting, as reflected by a fourth selectable option 790 being switched “ON”.
In
In addition, the first notification interface 700 of
As noted above, in different implementations, the system may include provisions for adjusting, modifying, customizing, or otherwise specifying their preferred auto-connection settings. One example of this is illustrated in
As a first example, a user may be able to request that, going forward, the user should be auto-connected to all upcoming meetings (see selectable option 890). In other words, each meeting or event that is accepted by the user (e.g., an RSVP status of “yes”, or “maybe”) will be automatically updated as an auto-connect meeting for this user. While the illustration in
In a second example, in some implementations, the system can be configured to receive input from a user specifying the time that they should be connected to the conference. In other words, the user interface may provide a means by which a user can input at what point in the meeting they wish to begin their telecommunications session. In
In some cases, the user may wish to identify a condition that should occur before they are automatically joined to the meeting. In
As a third example, in different implementations, the system can be configured to receive input from a user specifying the communication medium by which they should be connected to the conference (via telecommunications session). In other words, the user interface may provide a means by which a user can input which method the system should use when initiating the connection. In
While the second category 850 of
In a fourth example, in some implementations, the system can be configured to receive input from a user specifying additional preferences associated with the auto-connection. In
In other implementations, there are a variety of device configurations that are made available during a telecommunications session. For example, a user may wish to pre-specify that their camera be on (or off) at the start of the call (see third sub-option 866), and/or that their microphone be on (or off) at the start of the call (see fourth sub-option 868). While the third category 860 shown in
Furthermore, in some cases, a user may be successfully auto-connected to a conference, but then unexpectedly or inadvertently lose their connection to the telecommunication session. For example, there may be issues with their internet connection, the device battery may be exhausted, the call may drop in areas with less coverage, or other such issues can often occur. In such situations, it is likely that the user will wish to be re-connected, and may not have ready or easy access to the conference calling information or required credentials. In order to address this type of scenario, the system can offer the user the option of automatically attempting to re-establish a connection between the user and the continuing telecommunications session. In some implementations, the user may be able to specify how many times the system should attempt to automatically re-connect them, how long to wait between attempts, and/or whether one or more different PCPs should be used. For example, the user may wish to have the system attempt connection with another PCP if the previous PCP is blocked or appears to be out of service. Thus, users can feel confident that they will be re-connected to meetings that are important to them, regardless of their current device status, signal strength, or physical location.
In order to further the reader's understanding of the proposed systems, a schematic flow diagram depicting one implementation of the system is illustrated in
If, on the other hand, the meeting and authorization remain current, the system can determine, with reference to a calendar for example, whether the current time matches the time specified or otherwise designated by the user in a fourth step 910. If the auto-connect event is not to be triggered yet, the process can return to the start (first step 902) to continue receiving updated information for the first conference event. However, if the auto-connect is triggered, the flow diagram continues in
In a sixth step 922 the system can determine whether the user opted to decline the call; if so, the system will no longer proceed with attempts to automatically contact the user, as shown by a second terminus 924. In a seventh step 926, the system evaluates whether any input has been received corresponding to a request for the snooze option. If the snooze option has been triggered, the system can delay for a pre-specified snooze duration in a ‘holding pattern’ step 928, after which the system will attempt to re-connect the user with the conference via initiation of a telecommunications session in an eighth step 932. If the snooze option has not been triggered, the system will ascertain whether the connection was successful in a ninth step 934. If the user has been successfully connected to the conference, the system will continue to monitor the connection. As noted above with respect to
Returning to the ninth step 934, if the connection attempt was unsuccessful, the system will ascertain whether the user preferences permit or authorize additional attempts in an eleventh step 940. If the user has directed that no additional attempts be made, the system will no longer proceed with attempts to automatically contact the user, as shown by a fourth terminus 942. If there is authorization—or a lack of prohibition—to reattempt connecting the user, the system can again access user preferences to determine whether the next attempt should be at the same PCP, or a different PCP, in a twelfth step 944. If the same PCP is designated for contact, the system again attempts to connect the user at the same PCP in a thirteenth step 948. If an alternate PCP is designated for contact, the next attempt will be to the alternate PCP in a fourteenth step 946. As noted above with respect to
Through the application of such a system, users can be automatically brought into a meeting by establishing a telecommunications session with the user to the meeting. Users can identify their preferences for various aspects and steps leading to the connection, or the system can implement default settings. For example, in some implementations, a system first calls the user on their VoIP client. If the user cannot be reached at the VoIP client, the system then proceeds to attempt a connection on the user's phone line. When multiple users have opted to be auto-connected, they will all be brought into the meeting automatically by the system. In some implementations, users can also receive a notification in their email and/or a chat message stream if the system is unable to reach the user. The system can retry connecting the user, depending on the user settings. These settings can specify how and when the connection should occur, as well as device configurations such as audio and visual modes, auto presentation of a deck (slides) for the meeting, joining or inviting other participants, or choosing a room.
A third step 1030 includes receiving, from the first device, a first response to the displayed first user interface. The first response includes a user selection of the first selectable option accepting the meeting invite, and a user selection of the second selectable option to automatically establish a connection between the system hosting the first conference event and the one or more devices associated with the first attendee. A fourth step 1040 involves setting a connection trigger condition corresponding to the first attendee and the first conference event. The connection trigger condition specifies a trigger time, set based on the time of the first conference event, to automatically establish a connection between the system hosting the first conference event and the one or more devices associated with the first attendee.
In a fifth step 1050, the method includes determining that the connection trigger condition has been met, automatically causing a first connection to be established between the system hosting the first conference event and a second device of the one or more devices associated with the first attendee. Finally in a sixth step 1060, the method includes causing the first attendee to be admitted into the first conference event.
In other implementations, the method can include additional or alternate steps. For example, the method may further include determining an interruption of the first connection between the first attendee and the first conference event has occurred prior to a conclusion of the first conference event, and then automatically causing, in response to determining that an interruption has occurred, a second connection with a third device of the one or more devices in order to re-connect the first attendee to the first conference event. In some implementations, the trigger time can correspond to a scheduled start time of the conference event, while in other implementations the trigger time can correspond to a pre-established time prior to a scheduled start time of the conference event. In one implementation, the first device and the second device can refer to the same device, and in another implementation the second device can differ from the first device.
As another example, the method may involve delivering, to the first device, an options interface with embedded control signals that, when executed by the first device, cause the first device to display a second user interface including a third selectable option indicating whether to automatically establish connections between one or more systems hosting one or more conference events and one or more devices associated with the first attendee for all future conference events occurring over a specified duration. The method can also include receiving, from the first device, a second response to the displayed second user interface, the second response including a user selection of the third selectable option, and setting an extended connection trigger condition corresponding to the first attendee and all conference events occurring over the specified duration. The method further includes automatically causing, in response to determining that a second conference event occurs during the specified duration, a second connection to be established between a system hosting the second conference event and a third device of the one or more devices associated with the first attendee.
In another example, the method can include causing a third device associated with a second attendee to display a second user interface including a third selectable option indicating whether to automatically establish connection between a system hosting a second conference event and one or more devices associated with the second attendee. Furthermore, the method may include receiving, from the third device, a second response to the displayed second user interface, the second response including a user selection of the third selectable option to automatically establish a connection between the system hosting the second conference event and the one or more devices associated with the second attendee. In addition, the method includes automatically initiating a second connection between the system hosting the second conference event and a fourth device of the one or more devices associated with the second attendee, and receiving, from the fourth device, a first input corresponding to a request to delay connection to the second conference event by a specified duration. The method can also include automatically causing, in response to determining that the specified duration has passed, a second connection to be established between the system hosting the second conference event and a fifth device of the one or more devices associated with the second attendee. In different implementations, the second user interface comprises a virtual invitation for the second conference event, a notification for the second conference event, an e-mail regarding the second conference event, or an instant message related to the second conference event.
Furthermore, in some implementations, the method may involve causing a third device associated with a second attendee to display a second user interface including a third selectable option indicating whether to automatically establish connection between a system hosting a second conference event and one or more devices associated with the second attendee. The method may also include receiving, from the third device, a second response to the displayed second user interface, the second response including a user selection of the third selectable option to automatically establish a connection between the system hosting the second conference event and the one or more devices associated with the second attendee. In addition, the method can involve automatically initiating a second connection between the system hosting the second conference event and a fourth device of the one or more devices associated with the second attendee, and determining the second attendee failed to connect to the second conference event via the fourth device. The method can further include automatically causing, in response to determining that the second attendee failed to connect to the second conference event, a third connection to be established between the system hosting the second conference event and a fifth device of the one or more devices associated with the second attendee.
As a general matter, an example system for management of conference calls can include a conference server (which in some implementations can include more than one server). The server can be located in multiple geographic areas. In addition, the conference server can be connected, often through a firewall, to a wide area network (WAN), such as the Internet. The WAN can be coupled to and accessed through either a wired connection or a wireless local area network (WLAN) that can feature a wireless access point that operates, for example, in accordance with one of the IEEE 802.11 specifications.
In some implementations, the conference server can also be connected to a public switched telephone network (PSTN) via direct inward dialing (DID) trunks or primary rate interface (PRI) trunks. The conference server can also communicate, often through a relay, with a public land mobile network (PLMN), which can also be referred to as a wireless wide area network (WWAN) or a cellular network. In some cases, the PLMN can be configured to be interconnected with or integrated into the PSTN.
In addition, the system can include a number of electronic devices, such as mobile devices and stationary devices. These can include for example, a cellular phone, a smartphone, a tablet, a netbook, a laptop, a PDA (personal digital assistant), or any other device enabled for wireless communication. A mobile device can be equipped for cellular communications through the PLMN, for communications over WAN (accessed, for example, through WLAN by connecting via Wi-Fi to wireless access points) or it can be a dual-mode device capable of both cellular and WAN/WLAN communications. Cellular communications through the PLMN can include voice communications and data communications, and mobile device can support either or both these communication channels.
A mobile device can also include one or more radio transceivers and associated processing hardware and software to enable wireless communications with PLMN, and/or a WLAN via a wireless access point. In different implementations, the PLMN and a mobile device may be configured to operate in compliance with any one or more of a number of wireless protocols, including GSM, GPRS, CDMA, EDGE, UMTS, EvDO, HSPA, 3GPP, LTE, or a variety of others. In addition, a mobile device can roam within PLMN and across PLMNs, in a known manner, as its user moves. In some instances, a dual-mode mobile device and/or the conference server may be configured to facilitate roaming between PLMN and wireless access points, and are thus capable of seamlessly transferring sessions (such as voice calls) from a connection with the cellular interface of a dual-mode device (i.e., mobile device) to a WLAN interface of the dual-mode device, and vice versa.
There may also be a relay that serves to direct communications received over PLMN from a device to the conference server. The relay can also direct communications from the conference server to the mobile device via PLMN. Furthermore, in another implementation, a telephone set (such as a conventional landline telephone) can communicate with the conference server through PSTN.
In different implementations, the conference server can be implemented on one or more servers having suitable communications interfaces for connecting to and communicating with other system components. The conference server can include one or more processors, a memory, and a data interface. The processor(s) can be a single or multiple microprocessors, field programmable gate arrays (FPGAs), or digital signal processors (DSPs) capable of executing particular sets of instructions. Computer-readable instructions can be stored on a tangible non-transitory computer-readable medium, such as a flexible disk, a hard disk, a CD-ROM (compact disk-read only memory), and MO (magneto-optical), a DVD-ROM (digital versatile disk-read only memory), a DVD RAM (digital versatile disk-random access memory), or a semiconductor memory.
In some implementations, a memory stores user-profile or account information and user preferences for one or more users. The user-profile information can include, for example, a user's name, email address, location data, place of employment, home address, or the like. In addition, the user-profile information can include device information for one or more electronic devices (e.g., one or more mobile or computing devices and/or one or more telephone sets) associated with a user. Device information can include device's phone number (e.g., a cellular phone number or a landline number), a personal identification number (PIN), an IP address, if available, and so forth. In some embodiments, some or all of the user-profile information, including device information, can be retrieved, by the conference server, from the electronic devices. For example, if user-information for a particular electronic device includes device information only for one device associated with the user, and the device information includes only the IP address of the device, the conference server can use the IP information to communicate with the electronic device, for example, via WAN. The conference server can then retrieve from the electronic device additional device information for the device itself (e.g., a cellphone number associated with the device) and/or device information for other electronic devices associated with the same user (e.g., a landline number of the user's telephone set).
In one implementation, the conference server implements the switching to connect session legs and provides the conversion between, for example, a circuit-switched call and a VoIP call, or to connect legs of other media sessions. In some embodiments, in the context of voice calls, the conference server provides a number of additional functions including an automated attendant, interactive voice responses, call forwarding, conference call, or other such features. It can also implement certain usage restrictions on enterprise users, such as blocking international calls or toll free calls. In many embodiments, Session Initiation Protocol (SIP) can be used to set-up, manage, and terminate media sessions for voice calls. Other protocols can also be employed by the conference server, such as Web Services, Computer Telephony Integration (CTI) protocol, Session Initiation Protocol for Instant Messaging and Presence Leveraging Extensions (SIMPLE), and various custom Application Programming Interfaces (APIs).
The use of the disclosed systems and methods can enable users to review information for a conference at multiple points prior to the meeting time, and be presented an option to be auto joined to said conference during this review. In other words, in conjunction with their viewing of information for said conference, a user can readily opt to be automatically connected to the conference at a time specified for the conference. For example, as a user creates a meeting and its corresponding invitation, while a user views an invitation for the meeting, when a user RSVPs (or changes their RSVP) for the meeting, during any meeting notifications, meeting indicators, meeting “toasts” or pop-up messages, e-mail communications from the system or other users about the meeting, meeting preparation communications, or meeting objects can provide instances in which a user can be presented with an option to auto-join the meeting, making the process highly convenient and relevant. The ability to deliberately select this option for individual meetings at a time of their choosing, offers a wide range of benefits to users. This feature substantially reduces the time needed to prepare for user participation in the meeting, and the aggravation of being auto-joined to all meetings because of a setting that was modified previously for another meeting or forgetting to change one's general settings to auto-join scan various items. Furthermore, users are offered a straightforward means by which to implement their preferences for participating in a meeting, and the ability to easily change one's mind about the means of connecting to the meeting at multiple opportunities leading up to the meeting.
For the sake of simplicity of description, details are not provided herein for performing various connection processes and the configuration of different telecommunication components. Implementations of the present disclosure can make use of any of the features, systems, components, devices, and methods described in U.S. Patent Publication Number 2009/0319916 to Gudipaty et al., published Dec. 24, 2009 and entitled “Techniques to auto-attend multimedia conference events,”; U.S. Patent Publication Number 2012/0275349 to Boyer et al., published Nov. 1, 2012 and entitled “Conference call monitoring with automatic reconnect”; U.S. Patent Publication Number 2017/0302718 to Ananthanarayanan et al., published Oct. 19, 2017 and entitled “Dynamic recording of online conference”; U.S. Patent Publication Number 2013/0144603 to Lord et al., published Jun. 6, 2013 and entitled “Enhanced voice conferencing with history”; U.S. Patent Publication Number 2011/0267419 to Quinn et al., published Nov. 3, 2011 and entitled “Accelerated instant replay for co-present and distributed meetings”; U.S. Patent Publication Number 2011/0249954 to Meek et al., published Oct. 13, 2011 and entitled “Capturing presentations in online conferences”; U.S. Patent Publication Number 2014/0362979 to Kaplan et al., published Dec. 11, 2014 and entitled “Catching up with an ongoing conference call”; U.S. Patent Publication Number 2010/0246448 to Krantz et al., published Sep. 30, 2010 and entitled “Automatic utilization of resources in a realtime conference”; U.S. Patent Publication Number 20120297229 to Desai et al., published on Nov. 22, 2012 and entitled “Auto-connect in a peer-to-peer network”; and U.S. Patent Publication Number 2016/0373490 to Sedar et al., published on Dec. 22, 2016 and entitled “Automatic equipment configuration for meetings” as well as each of their disclosed methods and systems for the management of meetings, connection to and recording of conferences, and so forth, the disclosures of each of which are herein incorporated by reference in their entirety.
The detailed examples of systems, devices, and techniques described in connection with
In some examples, a hardware module may be implemented mechanically, electronically, or with any suitable combination thereof. For example, a hardware module may include dedicated circuitry or logic that is configured to perform certain operations. For example, a hardware module may include a special-purpose processor, such as a field-programmable gate array (FPGA) or an Application Specific Integrated Circuit (ASIC). A hardware module may also include programmable logic or circuitry that is temporarily configured by software to perform certain operations, and may include a portion of machine-readable medium data and/or instructions for such configuration. For example, a hardware module may include software encompassed within a programmable processor configured to execute a set of software instructions. It will be appreciated that the decision to implement a hardware module mechanically, in dedicated and permanently configured circuitry, or in temporarily configured circuitry (for example, configured by software) may be driven by cost, time, support, and engineering considerations.
Accordingly, the phrase “hardware module” should be understood to encompass a tangible entity capable of performing certain operations and may be configured or arranged in a certain physical manner, be that an entity that is physically constructed, permanently configured (for example, hardwired), and/or temporarily configured (for example, programmed) to operate in a certain manner or to perform certain operations described herein. As used herein, “hardware-implemented module” refers to a hardware module. Considering examples in which hardware modules are temporarily configured (for example, programmed), each of the hardware modules need not be configured or instantiated at any one instance in time. For example, where a hardware module includes a programmable processor configured by software to become a special-purpose processor, the programmable processor may be configured as respectively different special-purpose processors (for example, including different hardware modules) at different times. Software may accordingly configure a particular processor or processors, for example, to constitute a particular hardware module at one instance of time and to constitute a different hardware module at a different instance of time. A hardware module implemented using one or more processors may be referred to as being “processor implemented” or “computer implemented.”
Hardware modules can provide information to, and receive information from, other hardware modules. Accordingly, the described hardware modules may be regarded as being communicatively coupled. Where multiple hardware modules exist contemporaneously, communications may be achieved through signal transmission (for example, over appropriate circuits and buses) between or among two or more of the hardware modules. In implementations in which multiple hardware modules are configured or instantiated at different times, communications between such hardware modules may be achieved, for example, through the storage and retrieval of information in memory devices to which the multiple hardware modules have access. For example, one hardware module may perform an operation and store the output in a memory device, and another hardware module may then access the memory device to retrieve and process the stored output.
In some examples, at least some of the operations of a method may be performed by one or more processors or processor-implemented modules. Moreover, the one or more processors may also operate to support performance of the relevant operations in a “cloud computing” environment or as a “software as a service” (SaaS). For example, at least some of the operations may be performed by, and/or among, multiple computers (as examples of machines including processors), with these operations being accessible via a network (for example, the Internet) and/or via one or more software interfaces (for example, an application program interface (API)). The performance of certain of the operations may be distributed among the processors, not only residing within a single machine, but deployed across a number of machines. Processors or processor-implemented modules may be located in a single geographic location (for example, within a home or office environment, or a server farm), or may be distributed across multiple geographic locations.
The example software architecture 1102 may be conceptualized as layers, each providing various functionality. For example, the software architecture 1102 may include layers and components such as an operating system (OS) 1114, libraries 1116, frameworks 1118, applications 1120, and a presentation layer 1144. Operationally, the applications 1120 and/or other components within the layers may invoke API calls 1124 to other layers and receive corresponding results 1126. The layers illustrated are representative in nature and other software architectures may include additional or different layers. For example, some mobile or special purpose operating systems may not provide the frameworks/middleware 1118.
The OS 1114 may manage hardware resources and provide common services. The OS 1114 may include, for example, a kernel 1128, services 1130, and drivers 1132. The kernel 1128 may act as an abstraction layer between the hardware layer 1104 and other software layers. For example, the kernel 1128 may be responsible for memory management, processor management (for example, scheduling), component management, networking, security settings, and so on. The services 1130 may provide other common services for the other software layers. The drivers 1132 may be responsible for controlling or interfacing with the underlying hardware layer 1104. For instance, the drivers 1132 may include display drivers, camera drivers, memory/storage drivers, peripheral device drivers (for example, via Universal Serial Bus (USB)), network and/or wireless communication drivers, audio drivers, and so forth depending on the hardware and/or software configuration.
The libraries 1116 may provide a common infrastructure that may be used by the applications 1120 and/or other components and/or layers. The libraries 1116 typically provide functionality for use by other software modules to perform tasks, rather than rather than interacting directly with the OS 1114. The libraries 1116 may include system libraries 1134 (for example, C standard library) that may provide functions such as memory allocation, string manipulation, file operations. In addition, the libraries 1116 may include API libraries 1136 such as media libraries (for example, supporting presentation and manipulation of image, sound, and/or video data formats), graphics libraries (for example, an OpenGL library for rendering 2D and 3D graphics on a display), database libraries (for example, SQLite or other relational database functions), and web libraries (for example, WebKit that may provide web browsing functionality). The libraries 1116 may also include a wide variety of other libraries 1138 to provide many functions for applications 1120 and other software modules.
The frameworks 1118 (also sometimes referred to as middleware) provide a higher-level common infrastructure that may be used by the applications 1120 and/or other software modules. For example, the frameworks 1118 may provide various graphic user interface (GUI) functions, high-level resource management, or high-level location services. The frameworks 1118 may provide a broad spectrum of other APIs for applications 1120 and/or other software modules.
The applications 1120 include built-in applications 1140 and/or third-party applications 1142. Examples of built-in applications 1140 may include, but are not limited to, a contacts application, a browser application, a location application, a media application, a messaging application, and/or a game application. Third-party applications 1142 may include any applications developed by an entity other than the vendor of the particular platform. The applications 1120 may use functions available via OS 1114, libraries 1116, frameworks 1118, and presentation layer 1144 to create user interfaces to interact with users.
Some software architectures use virtual machines, as illustrated by a virtual machine 1148. The virtual machine 1148 provides an execution environment where applications/modules can execute as if they were executing on a hardware machine (such as the machine 1000 of
The machine 1200 may include processors 1210, memory 1230, and I/O components 1250, which may be communicatively coupled via, for example, a bus 1202. The bus 1202 may include multiple buses coupling various elements of machine 1200 via various bus technologies and protocols. In an example, the processors 1210 (including, for example, a central processing unit (CPU), a graphics processing unit (GPU), a digital signal processor (DSP), an ASIC, or a suitable combination thereof) may include one or more processors 1212a to 1212n that may execute the instructions 1216 and process data. In some examples, one or more processors 1210 may execute instructions provided or identified by one or more other processors 1210. The term “processor” includes a multi-core processor including cores that may execute instructions contemporaneously. Although
The memory/storage 1230 may include a main memory 1232, a static memory 1234, or other memory, and a storage unit 1236, both accessible to the processors 1210 such as via the bus 1202. The storage unit 1236 and memory 1232, 1234 store instructions 1216 embodying any one or more of the functions described herein. The memory/storage 1230 may also store temporary, intermediate, and/or long-term data for processors 1210. The instructions 1216 may also reside, completely or partially, within the memory 1232, 1234, within the storage unit 1236, within at least one of the processors 1210 (for example, within a command buffer or cache memory), within memory at least one of I/O components 1250, or any suitable combination thereof, during execution thereof. Accordingly, the memory 1232, 1234, the storage unit 1236, memory in processors 1210, and memory in I/O components 1250 are examples of machine-readable media.
As used herein, “machine-readable medium” refers to a device able to temporarily or permanently store instructions and data that cause machine 1200 to operate in a specific fashion. The term “machine-readable medium,” as used herein, does not encompass transitory electrical or electromagnetic signals per se (such as on a carrier wave propagating through a medium); the term “machine-readable medium” may therefore be considered tangible and non-transitory. Non-limiting examples of a non-transitory, tangible machine-readable medium may include, but are not limited to, nonvolatile memory (such as flash memory or read-only memory (ROM)), volatile memory (such as a static random-access memory (RAM) or a dynamic RAM), buffer memory, cache memory, optical storage media, magnetic storage media and devices, network-accessible or cloud storage, other types of storage, and/or any suitable combination thereof. The term “machine-readable medium” applies to a single medium, or combination of multiple media, used to store instructions (for example, instructions 1216) for execution by a machine 1200 such that the instructions, when executed by one or more processors 1210 of the machine 1200, cause the machine 1200 to perform and one or more of the features described herein. Accordingly, a “machine-readable medium” may refer to a single storage device, as well as “cloud-based” storage systems or storage networks that include multiple storage apparatus or devices.
The I/O components 1250 may include a wide variety of hardware components adapted to receive input, provide output, produce output, transmit information, exchange information, capture measurements, and so on. The specific I/O components 1250 included in a particular machine will depend on the type and/or function of the machine. For example, mobile devices such as mobile phones may include a touch input device, whereas a headless server or IoT device may not include such a touch input device. The particular examples of I/O components illustrated in
In some examples, the I/O components 1250 may include biometric components 1256 and/or position components 1262, among a wide array of other environmental sensor components. The biometric components 1256 may include, for example, components to detect body expressions (for example, facial expressions, vocal expressions, hand or body gestures, or eye tracking), measure biosignals (for example, heart rate or brain waves), and identify a person (for example, via voice-, retina-, and/or facial-based identification). The position components 1262 may include, for example, location sensors (for example, a Global Position System (GPS) receiver), altitude sensors (for example, an air pressure sensor from which altitude may be derived), and/or orientation sensors (for example, magnetometers).
The I/O components 1250 may include communication components 1264, implementing a wide variety of technologies operable to couple the machine 1200 to network(s) 1270 and/or device(s) 1280 via respective communicative couplings 1272 and 1282. The communication components 1264 may include one or more network interface components or other suitable devices to interface with the network(s) 1270. The communication components 1264 may include, for example, components adapted to provide wired communication, wireless communication, cellular communication, Near Field Communication (NFC), Bluetooth communication, Wi-Fi, and/or communication via other modalities. The device(s) 1280 may include other machines or various peripheral devices (for example, coupled via USB).
In some examples, the communication components 1264 may detect identifiers or include components adapted to detect identifiers. For example, the communication components 1264 may include Radio Frequency Identification (RFID) tag readers, NFC detectors, optical sensors (for example, one- or multi-dimensional bar codes, or other optical codes), and/or acoustic detectors (for example, microphones to identify tagged audio signals). In some examples, location information may be determined based on information from the communication components 1262, such as, but not limited to, geo-location via Internet Protocol (IP) address, location via Wi-Fi, cellular, NFC, Bluetooth, or other wireless station identification and/or signal triangulation.
Furthermore, implementations of the present disclosure can make use of any of the features, systems, components, devices, and methods described in U.S. Pat. No. 8,660,978 to Hinckley et al., issued Feb. 25, 2014 and titled “Detecting and Responding to Unintentional Contact with a Computing Device,” the disclosure of which is herein incorporated by reference in its entirety.
While various implementations have been described, the description is intended to be exemplary, rather than limiting, and it is understood that many more implementations and implementations are possible that are within the scope of the implementations. Although many possible combinations of features are shown in the accompanying figures and discussed in this detailed description, many other combinations of the disclosed features are possible. Any feature of any implementation may be used in combination with or substituted for any other feature or element in any other implementation unless specifically restricted. Therefore, it will be understood that any of the features shown and/or discussed in the present disclosure may be implemented together in any suitable combination. Accordingly, the implementations are not to be restricted except in light of the attached claims and their equivalents. Also, various modifications and changes may be made within the scope of the attached claims.
While the foregoing has described what are considered to be the best mode and/or other examples, it is understood that various modifications may be made therein and that the subject matter disclosed herein may be implemented in various forms and examples, and that the teachings may be applied in numerous applications, only some of which have been described herein. It is intended by the following claims to claim any and all applications, modifications and variations that fall within the true scope of the present teachings.
Unless otherwise stated, all measurements, values, ratings, positions, magnitudes, sizes, and other specifications that are set forth in this specification, including in the claims that follow, are approximate, not exact. They are intended to have a reasonable range that is consistent with the functions to which they relate and with what is customary in the art to which they pertain.
The scope of protection is limited solely by the claims that now follow. That scope is intended and should be interpreted to be as broad as is consistent with the ordinary meaning of the language that is used in the claims when interpreted in light of this specification and the prosecution history that follows and to encompass all structural and functional equivalents. Notwithstanding, none of the claims are intended to embrace subject matter that fails to satisfy the requirement of Sections 101, 102, or 103 of the Patent Act, nor should they be interpreted in such a way. Any unintended embracement of such subject matter is hereby disclaimed.
Except as stated immediately above, nothing that has been stated or illustrated is intended or should be interpreted to cause a dedication of any component, step, feature, object, benefit, advantage, or equivalent to the public, regardless of whether it is or is not recited in the claims.
It will be understood that the terms and expressions used herein have the ordinary meaning as is accorded to such terms and expressions with respect to their corresponding respective areas of inquiry and study except where specific meanings have otherwise been set forth herein. Relational terms such as first and second and the like may be used solely to distinguish one entity or action from another without necessarily requiring or implying any actual such relationship or order between such entities or actions. The terms “comprises,” “comprising,” or any other variation thereof, are intended to cover a non-exclusive inclusion, such that a process, method, article, or apparatus that comprises a list of elements does not include only those elements but may include other elements not expressly listed or inherent to such process, method, article, or apparatus. An element proceeded by “a” or “an” does not, without further constraints, preclude the existence of additional identical elements in the process, method, article, or apparatus that comprises the element.
The Abstract of the Disclosure is provided to allow the reader to quickly ascertain the nature of the technical disclosure. It is submitted with the understanding that it will not be used to interpret or limit the scope or meaning of the claims. In addition, in the foregoing Detailed Description, it can be seen that various features are grouped together in various examples for the purpose of streamlining the disclosure. This method of disclosure is not to be interpreted as reflecting an intention that the claims require more features than are expressly recited in each claim. Rather, as the following claims reflect, inventive subject matter lies in less than all features of a single disclosed example. Thus the following claims are hereby incorporated into the Detailed Description, with each claim standing on its own as a separately claimed subject matter.