This disclosure relates generally to recording meetings between individuals and storing recordings for subsequent playback.
Depending on the size of the enterprise, the various employees and contractors of a company may engage in any of a number of meetings on a day-to-day basis. Recordings of one or more meetings may be made to, for example, document what was discussed at the meetings and whether any decisions were made. Some recordings of meetings may be stored securely and made available for subsequent review. But if a recording is not initiated for a meeting, information may be lost.
Techniques are disclosed herein to prevent information loss by recording meetings. In various embodiments, a computer system enables individuals attending a meeting to retroactively decide to retain a recording of the meeting for subsequent playback such that the recording includes portions of the meeting that occurred before the decision to retain the recording was made. In some embodiments, one or more of the individuals decide to retain a recording of the meeting while the meeting is ongoing. In other embodiments, one or more individuals decide to retain a recording of the meeting after the meeting has concluded. In these embodiments, the computer system records all of the meeting in case one of more individuals attending the meeting decide that a recording of the meeting should be retained for future playback. However, merely automatically recording the entirety of all meetings regardless of whether the individuals attending a given meeting have indicated their decision that a recording of the given meeting should be retained may (1) result in using resources to store recordings of meetings that are not interesting or important enough to warrant retention and (2) potentially have privacy or security implications because some individuals may object to being recorded or may decide that some topics discussed at the meeting should not be recorded (e.g., privileged communications between clients and attorneys). The techniques disclosed herein, though, relate to recording a meeting and, based on having received a recording confirmation command from one or more of the individuals, retaining a recording of the meeting for future playback without the individuals deciding at the outset of the meeting that a recording ought to be made.
This disclosure includes references to “one embodiment” or “an embodiment.” The appearances of the phrases “in one embodiment” or “in an embodiment” do not necessarily refer to the same embodiment. Particular features, structures, or characteristics may be combined in any suitable manner consistent with this disclosure.
Within this disclosure, different entities (which may variously be referred to as “units,” “circuits,” other components, etc.) may be described or claimed as “configured” to perform one or more tasks or operations. This formulation—[entity] configured to [perform one or more tasks]—is used herein to refer to structure (i.e., something physical, such as an electronic circuit). More specifically, this formulation is used to indicate that this structure is arranged to perform the one or more tasks during operation. A structure can be said to be “configured to” perform some task even if the structure is not currently being operated. A “computer system configured to initiate a recording” is intended to cover, for example, a computer system has circuitry that performs this function during operation, even if the computer system in question is not currently being used (e.g., a power supply is not connected to it). Thus, an entity described or recited as “configured to” perform some task refers to something physical, such as a device, circuit, memory storing program instructions executable to implement the task, etc. This phrase is not used herein to refer to something intangible. Thus, the “configured to” construct is not used herein to refer to a software entity such as an application programming interface (API).
The term “configured to” is not intended to mean “configurable to.” An unprogrammed FPGA, for example, would not be considered to be “configured to” perform some specific function, although it may be “configurable to” perform that function and may be “configured to” perform the function after programming.
Reciting in the appended claims that a structure is “configured to” perform one or more tasks is expressly intended not to invoke 35 U.S.C. § 112(f) for that claim element. Accordingly, none of the claims in this application as filed are intended to be interpreted as having means-plus-function elements. Should Applicant wish to invoke Section 112(f) during prosecution, it will recite claim elements using the “means for” [performing a function] construct.
As used herein, the terms “first,” “second,” etc. are used as labels for nouns that they precede, and do not imply any type of ordering (e.g., spatial, temporal, logical, etc.) unless specifically stated. For example, references to “first” and “second” individuals would not imply an ordering between the two unless otherwise stated.
As used herein, the term “based on” is used to describe one or more factors that affect a determination. This term does not foreclose the possibility that additional factors may affect a determination. That is, a determination may be solely based on specified factors or based on the specified factors as well as other, unspecified factors. Consider the phrase “determine A based on B.” This phrase specifies that B is a factor is used to determine A or that affects the determination of A. This phrase does not foreclose that the determination of A may also be based on some other factor, such as C. This phrase is also intended to cover an embodiment in which A is determined based solely on B. As used herein, the phrase “based on” is thus synonymous with the phrase “based at least in part on.”
As used herein, the word “module” refers to structure that stores or executes a set of operations. A module refers to hardware that implements the set of operations, or a memory storing the set of instructions such that, when executed by one or more processors of a computer system, cause the computer system to perform the set of operations. A module may thus include an application-specific integrated circuit implementing the instructions, a memory storing the instructions and one or more processors executing said instructions, or a combination of both.
This disclosure describes techniques for recording a meeting and storing recordings for future playback. Embodiments for a meeting, a recording of the meeting, and the computer system on which the recording of the meeting is stored are described in reference to
Referring now to
Meeting 100 occurs between a plurality of individuals 102. In various embodiments, meeting 100 may be an in-person meeting between individuals 102, a telephonic meeting between individuals 102, an online meeting between individuals 102 (e.g., occurring over VOIP, occurring over a video conferencing service such as Skype®, Google®, or Facebook®), or a combination. The plurality of individuals 102 may be physically in the same location (e.g., in a conference room), may be in different, remote locations (e.g., at the individuals' 102 various offices), or a combination where some individuals 102 are in the same location but others are remote (e.g., a group of individuals 102 are meeting in a conference room in California with other individuals calling into the meeting from Texas and British Columbia). Meeting 100, for example, may be an in-person meeting (e.g., taking place in an office, conference room, etc.) where an individual 102X is presenting information to other individuals including individuals 102Y and 102Z as shown in
Individuals 102 are any of a number of people who are attending meeting 100 (either in-person or remotely). At meeting 100, the individuals 102 make a number of statements 106. In various embodiments, statement 106 is a vocalization by an individual 102 (e.g., spoken in an in-person meeting, spoken on in a telephonic meeting), but statement 106 may be any of a number of communications from an individual 102 including but not limited to vocalizations, written messages, sign language, electronic messages, etc. As part of attending meeting 100, individuals 102 (including individuals 102 physically present at meeting 100 and remotely-located individuals 102) may access meeting software (e.g., discussed herein in reference to meeting module 200 on
In various embodiments, individuals 102, for example, may be employees and contractors working for the same enterprise. Among the plurality of individuals 102, there may be a number of key individuals 102. In various embodiments, who qualifies as a “key individual” may vary. In some embodiments, computer system 120 obtains information about the one or more enterprises associated with meeting 100 and designates, based on a hierarchy of the one or more individuals 102 attending meeting 100, the individuals 102 in the highest levels the entities (e.g., higher ranking employees, officers, directors, owners) as key individuals. In various embodiments, the schedule includes information indicating that the presence of certain individuals 102 is required at meeting 100, and these individuals 102 are designated as key individuals 102. In some embodiments, the organizer of meeting 100 is designated as a key individual 102. In some embodiments, the organizer of meeting 100 can manually designated one or more individuals 102 attending meeting 100 as key individuals 102.
In embodiments where the plurality of individuals 102 arrive at a decision at meeting 100, in some embodiments one or more of these key individuals 102 must agree to the decision for the decision to be implemented. For example, in a meeting 100 among a director of engineering and her direct reports discussing the design of a widget and whether to build a prototype, it may be the case that the director must agree to the design of the widget before the prototype is built. In the embodiment depicted in
Recording device 104 is any of a number of devices that are configured to record meeting 100. In various embodiments, recording device 104 includes a microphone and records the audio of meeting 100. In such embodiments, recording device 104 may comprise a dedicated recording device 104 or a general-purpose device such as a laptop or cellular phone used as a recording device 104. In various embodiments, recording device 104 relays signals based on the audio of the meeting to software (e.g., running on a computer, server, or plurality of servers) that packages the signals into a recording. In various embodiments, there may be a plurality of recording devices 104 that work together to create the recording of meeting 100 (e.g., by using multiple microphones that are mixed together in the recorded meeting 240 of meeting 100 retained for subsequent playback, by using multiple general-purpose devices running recording software whose signals are mixed together in the recorded meeting 240 of meeting 100 retained for subsequent playback). Recording device 104 may include a user interface configured to receive commands from individuals 102 that includes by is not limited to physical buttons, a touch screen and a graphical user interface, a pointing device, or a combination.
In addition to recording audio, in various embodiments recording device 104 may record images or video of meeting 100 (e.g., with one or more cameras filming ones of the individuals 102, one or more conference rooms in which meeting 100 is occurring, etc.) and may record images or video of material presented at meeting 100 (e.g., a recording the material an individual 102 is sharing from his or her computer, a presentation one or more individuals 102 is giving to other individuals 102 in meeting 100). In various embodiments, recording device 104 may also record indications of electronic files viewed, revised, or generated during the meeting (e.g., a spreadsheet, text document, presentation, etc.) using one or more computing devices 108. In such embodiments, these indications may include links to the electronic files (e.g., links to the document on a server or cloud of servers) or the electronic files themselves. In some embodiments where individuals 102 can make statements 106 (e.g., written statements to the general audience of meeting 100, private messages between individuals 102 attending meeting 100) through a chat feature in meeting software, recording device 104 may also record any or all statements 106 made using such a chat features. Accordingly, in various embodiments, recording device 104 includes one or more devices (e.g., microphones, cameras, computer screen capturing software) configured to record one or more of audio information associated with meeting 100, visual information associated with meeting 100, and electronic transmission information associated with meeting 100.
Computing devices 108 include one or more electronics devices configured to access and/or edit one of more files during meeting 100 in various embodiments. In various embodiments, computing devices 108 include personal computers 108A (e.g., a laptop computer, a tablet computer, a desktop computer) and/or mobile devices 108B (e.g., a smartphone, a wearable computer). In various embodiments, computing device 108 are associated with ones of the plurality of individuals 102 (e.g., an individual 102 is logged-in to a particular computing device 108, an individual 102 has been assigned a particular computing device 108).
Meeting information 110 includes the various information captured by the one or more recording devices 104 of at least a portion of meeting 100. In various embodiments, meeting information 110 includes audio information (e.g., vocally-spoken statements 106 from individuals 102). In some of such embodiments, meeting information 110 includes visual information (e.g., images, video, electronic messages, presentations given at meeting 100). In various embodiments, meeting information 110 includes information indicative of accesses and/or revisions to one of more files made by one of more of the individuals 102 using one of more computing device 108 during meeting 100. In various embodiments, meeting information 110 is encrypted (e.g., by recording device 104, computing device 108) before being sent to computer system 120.
Recording confirmation command 112 may be any message used by one of more individuals 102 to indicate the one of more individuals' 102 assent to retaining a recording of the meeting 100 for subsequent playback. Recording confirmation command 112 may be verbal, non-verbal (e.g., a gesture, a sign), visual, electronic, or a combination. In various embodiments, recording confirmation command 112 is captured by a microphone or camera (e.g., a microphone or camera of recording device 104). In other embodiments, recording confirmation command 112 is entered via a user interface (e.g., of a computing device 108 or recording device 104). As used herein, a particular individual's 102 “assent” to retain a recording is an indication that the particular individual 102 has approved retaining a recording of the meeting 100. Assent may be given (or denied) for retaining a recording of a particular meeting 100, may be given using generalized rules (e.g., individual 102Z generally assents to recording all meetings between herself and her direct reports), or may be given by a delegate (e.g., a person, software) appointed by individual 102. In various embodiments, recording confirmation command 112 is received during meeting 100. In other embodiments, recording confirmation command 112 is received after meeting 100 has ended. In various embodiments, recording confirmation command 112 is encrypted (e.g., by recording device 104, computing device 108) before being sent to computer system 120. Recording confirmation command 112 is discussed in further detail in reference to
In the embodiment depicted in
Computer system 120 is configured to receive meeting information 110 (e.g., with communications module 126) from one or more recording devices 104. Computer system 120 is further configured to receive recording confirmation command 112 (e.g., with communications module 126) from one or more recording device 104 and/or computing device 108. In various embodiments where meeting information 110 and/or recording confirmation command 112 are encrypted, computer system 120 is configured to decrypt the encrypted meeting information 110 and/or recording confirmation command 112. As discussed herein, computer system 120 is configured to store recorded meeting information 110 in long-term storage 130 (e.g., as recorded meetings 240 discussed herein). Computer system 120 is configured to access a schedule (e.g., with scheduling module 124) including information indicating a plurality of meetings 100 that are scheduled to occur and detect, using the schedule, the start of a particular meeting 100. Computer system 120 is configured to initiate a recording of the particular meeting 100, receive one or more recording confirmation commands 112 (e.g., with communications module 126) and, after determining that the particular meeting has ended and based on having received a recording confirmation command 112, cause the recording of the particular meeting 100 to be retained in long-term storage 130 for subsequent playback. In various embodiments, if a recording confirmation command 112 has not been received (e.g., received during the meeting 100, received within a period of time after meeting 100) computer system 120 is configured to delete the recording of the particular meeting 100.
Accordingly, the embodiments depicted in
Referring now to
Controller module 122 causes computer system 120 to perform the operations discussed herein, including coordinating the operations performed with scheduling module 124, communications module 126, and long-term storage 130. For example, controller module 122 is configured to receive meeting information 110 and recording confirmation command 112 (with communications module 126) and retain the received meeting information 110 as recorded meeting 240 (in long-term storage 130). In various embodiments, controller module 122 also interfaces with short-term storage 230 and creates and maintains meeting metadata 250. In various embodiments, controller module 122 includes meeting module 200, identification module 210, and security module 220.
In various embodiments, meeting module 200 facilitates making determinations about meeting 100 and assembling meeting information 110 into a recorded meeting 240 as discussed herein. In various embodiments, meeting module 200 includes recording module 202. As discussed herein, in various embodiments, meeting module 200 records various determinations about meeting 100 as meeting metadata 250.
In various embodiments, meeting module 200 detects the start of meeting 100 and determines that meeting 100 has ended. In some of such embodiments, detecting the start of meeting 100 is based on receiving a meeting start command from one of the computing devices 108. Further, in some embodiments detecting the start of meeting 100 includes accessing the schedule (e.g., with scheduling module 124) to determine a location of a particular meeting 100 (or a plurality of locations for meetings 100 occurring in multiple places), the scheduled start time of the particular meeting 100, and the plurality of individuals 102 indicated as participating in the particular meeting 100. In such embodiments, meeting module 200 monitors one or more recording devices 104 associated with the location(s) beginning at a start time of meeting 100 to detect one or more voices of the plurality of individuals 102. As discussed herein, in some embodiments, identification module 210 is used to identify the particular individuals 102 whose voices are detected by the one or more recording device 104. However, in other embodiments, meeting module 200 merely detects sounds at the location(s) that are above a certain volume and similar to human voices (e.g., within the frequency range of human voices). In other embodiments, detecting the start of meeting 100 includes checking a schedule (e.g., with scheduling module 124) to identify the scheduled start time of a particular meeting 100 (e.g., 12:00 GMT) and the location(s) where the meeting is scheduled to occur, checking the current time, and determining that the scheduled start time is the current time.
Similarly, in some embodiments, determining that meeting 100 has ended is based on receiving a meeting stop command from one of the computing devices 108. Further, in some embodiments determining that meeting 100 has ended includes accessing the schedule (e.g., with scheduling module 124) to determine a location of a particular meeting 100 (or a plurality of locations for meetings 100 occurring in multiple places), the scheduled end time of meeting 100, and the plurality of individuals 102 indicated as participating in the particular meeting 100. In such embodiments, meeting module 200 monitors one or more recording devices 104 associated with the location(s) to determine that the voices of the plurality of individuals 102 are no longer detected detected. As discussed herein, in some embodiments, identification module 210 is used to identify the particular individuals 102 whose voices were previously detected by the one or more recording device 104, and meeting module 200 determines that the voices of the particular individuals 102 are no longer detected. However, in other embodiments, meeting module 200 merely determines that sounds similar to human voices (e.g., within the frequency range of human voices) above a certain volume are no longer detected. In other embodiments, determining that meeting 100 has ended includes checking a schedule (e.g., with scheduling module 124) to identify the scheduled end time of a particular meeting 100 (e.g., 12:00 GMT) and the location(s) where the meeting is scheduled to occur, checking the current time, and determining that the scheduled end time is the current time.
In various embodiments, meeting module 230 is configured to implement the “meeting software” used by some or all of the individuals 102 attending meeting 100. As used herein, “meeting software” refers to software running on a computer system (e.g., computer system 120) locally on a computing device 108 associated with an individual 102 and/or remotely on a server or group of servers that facilitates meeting 100 including identifying individuals 102 and allowing individuals 102 to exchange audio, video, and/or electronic message information between one another. For example, individual 102X may give a presentation by accessing meeting software and sharing their screen and individual 102Y and individual 102Z may attend the meeting and watch individual 102X's presentation using meeting software that receives the information individual 102X is sharing from their screen. In various embodiments, meeting module 230 runs the meeting software and remotely displays meeting information on computers associated with the various individuals 102. In various embodiments, the meeting software may include modules that implement portions of the tasks performed by recording device 104 discussed herein.
Identification module 210 is configured to determine the identities of the various individuals 102 attending meeting 100. In various embodiments, identification module 210 is configured to determine the identities of individuals 102 by one or more of requesting that the various individual 102 identify themselves, analyzing audio and recognizing the various voices of individuals 102, and analyzing video or images and recognizing the images of the face or other body parts of the individuals 102. In some of such embodiments, identification module 210 is configured to request that the various individual 102 identify themselves by requesting that the individuals 102 present a credential associated with themselves (e.g., user login and password, biometric identification, voiceprint identification) and/or a credential associated with a computing device 108 associated with individual 102 or another device associated with the individual 102 (e.g., a changing number generated by a security token device, a code or token stored on an identification badge). In various embodiments, identification module 210 requests that individuals 102 identify themselves before joining meeting 100 (e.g., by requiring individuals 102 to log in to meeting software before joining meeting 100, by requesting the individual 102 speak his or her name before joining meeting 100, by requiring a roll call of individuals 102 attending meeting 100 before meeting 100 begins).
In other embodiments, identification module 210 is configured to identify individuals 102 based on their voice and/or image. In embodiments where identification module 210 identifies individuals 102 by voice, identification module 210 may be configured to store voice prints 212 associated with the various individuals' 102 profiles such that when a voice of an individual 102 in meeting information 110 is compared to the individual's voice print 210, the identification module 210 is able to determine the individual's 102 identity. Similarly, in embodiments where identification module 210 identifies individuals 102 by image, identification module 210 may be configured to store one or more reference images 214 associated with the various individuals' 102 profiles such that when an image of an individual 102 in meeting information 110 is compared to the individual's reference image 214, the identification module 210 is able to determine the individual's 102 identity.
Security module 220 is configured to perform various security operations for computer system 120. In various embodiments, such security operations include but are not limited to decrypting received meeting information 110 and/or recording confirmation command 112 and encrypting stored recorded meetings 240 and/or meeting metadata 250. In various embodiments, security module 220 restricts access to recorded meetings 240, meeting metadata 250, and/or schedule to authorized entities using any of a number of security techniques including cryptography, storing restricted information on physically separate media, restricting a given entity's access to long-term storage 130 or short-term storage 230 to certain memory locations associated with that given entity, or a combination. Accordingly, in some embodiments in which the schedule includes information indicating that a first plurality of meetings 100 that are associated with a first entity are scheduled to occur, and information indicating that a second plurality of meetings that are associated with a second entity are scheduled to occur, the security module 220 restricts access by the first entity to recorded meetings 240 and meeting metadata 250 associated with the first entity and prevents the second entity from accessing the recorded meetings 240 and meeting metadata 250 associated with the first entity. Likewise, security module 220 restricts access by the second entity to recorded meetings 240 and meeting metadata 250 associated with the second entity and prevents the first entity from accessing the recorded meetings 240 and meeting metadata 250 associated with the second entity. This may be accomplished, for example, by encrypting the recorded meetings 240 and meeting metadata 250 associated with the first entity such that only the first entity has the ability to decrypt the recorded meetings 240 and meeting metadata 250 associated with it.
Scheduling module 124 access a schedule that includes information about one or more meetings 100. In various embodiments, the schedule includes information indicating a plurality of meetings that are scheduled to occur. In some of such embodiments, the schedule includes additional information about meetings 100 that are scheduled to occur including but not limited to the scheduled start time of the meetings 100, the scheduled end time of the meetings 100, the location(s) of the meetings 100, the individuals 102 who have been invited to the meetings 100, whether the presence of certain individuals 102 is required, the individuals 102 who have indicated they will attend the meetings 100, the individuals 102 who have indicated they will not attend the meetings 100, contact information for the individuals 102 have who been invited to the meetings 100, and one or more hyperlinks that are usable to access meeting software associated with the meetings 100. In various embodiments, the schedule includes information about meetings 100 that are associated with more than one entity (e.g., more than one enterprise, more than one division within a single enterprise), and in such embodiments the schedule includes information indicating that a first plurality of meetings 100 are associated with a first entity, that a second plurality of meetings 100 are associated with a second entity, etc.
Communications module 126 receives messages sent to computer system 120 and sends messages from computer system 120 to facilitate communication. Communications module 126 is configured to receive meeting information 110, receive recording confirmation command 112, send challenge message 332, receive response to challenge message 334, and provide access to recorded meetings 240. Communications module 126 may include any of a number of wired (e.g., ethernet, USB, etc.) or wireless (e.g., cellular radio, WiFi) communications devices and protocols. In various embodiments, computer system 120 sends and receives communication from local area networks and wide area networks (e.g., the Internet). In various embodiments, communications module 126 is configured to receive input from recording devices 104. In such embodiments, communications module 126 may include one or more audio jacks and/or one or more video jacks. Such audio and/or video jacks may be analog (e.g., a headphone jack) or digital (e.g., an HDMI port). In various embodiments, communications module 126 is configured to receive messages from computer systems associated with various individuals 102 communicating with computer system 120 over a network. For example, communications module 126 may receive messages from meeting software during the meeting including audio information or visual information generated by one or more individuals 102 during meeting 100.
Long-term storage 130 is usable to store program instructions executable by computer system 120 to perform various operations described herein as well as recorded meetings 230 and meeting metadata 250. Short-term storage 230 is usable to store recorded meetings 230 and meeting metadata 250 (not shown). Long-term storage 130 and short-term storage 230 may be implemented using different physical memory media, such as hard disk storage, floppy disk storage, removable disk storage, flash memory, random access memory (RAM—SRAM, EDO RAM, SDRAM, DDR SDRAM, RAMBUS RAM, etc.), read only memory (PROM, EEPROM, etc.), and so on. As used herein, “long-term storage” and “short-term storage” are relative terms used to refer to the amount of time information is retained in each. For example, in various embodiments information in long-term storage is retained for a long period of time (e.g., years), and information in short-term storage is retained for a shorter duration (e.g., hours, days, weeks, months) before being deleted. In various embodiments, information in long-term storage is stored for an indefinite period of time (i.e., when the information is stored in long-term storage, the date for its eventual deletion is not predetermined) and information in short-term storage is stored for a predetermined period of time (e.g., information in short-term storage is deleted after two weeks, one month, two months, etc.).
In various embodiments, short-term storage 230 is implemented using a temporary buffer. In such embodiments, prior to receiving recording confirmation command 112 associated with a particular meeting, the recorded meeting 240 for the particular meeting 100 is stored in the temporary buffer. In such embodiments, causing the recorded meeting 240 for the particular meeting 100 to be retained (i.e., in long-term storage 130) includes storing, in a file to be retained for subsequent playback, portions of the particular meeting 100 occurring from the time of the recording confirmation command 112 was received to an end of the particular meeting 100; and causing contents of the temporary buffer to be associated with the file. In some of such embodiments, the temporary buffer has a maximum size and is configured to discard portions of the recorded meeting 240 for the particular meeting 100 when the amount stored in the temporary buffer exceeds the maximum size. Accordingly, in some embodiments, at the time that recording confirmation command 112 is received, a portion of the recorded meeting 240 for the particular meeting 100 has been discarded from the temporary buffer. The maximum size of the temporary buffer may be a particular period of time (e.g., 15 minutes, 30 minutes) or a particular amount of memory (e.g., a 1 gigabyte). The maximum size of the temporary buffer may be dependent in part on the specifications of computer system 120 (e.g., the amount of available memory in short-term storage 230). In other embodiments, the maximum size of the temporary buffer may be dependent in part on a license purchased by the enterprise with which meeting 100 is associated. Thus, for example, a standard licensee enterprise may have a smaller maximum size (e.g., 30 minutes), a premium licensee enterprise may have a larger maximum size (e.g., 60 minutes), and super premium licensee may have an unlimited maximum size.
The recorded meetings 240 stored in long-term storage 130 are retained for subsequent playback. Computer system 120 may make the recorded meetings 240 available for playback in any of a number of ways. For example, communications module 126 may stream the recorded meetings 240 to users (e.g., individuals 102) via a graphical user interface. Additionally, communications module 126 may send a complete copy of recorded meeting 240 to a computing device 108.
Recorded meetings 240 includes meeting information 110 that has been captured (e.g., by recording devices 104) for a given meeting 100 and received by computer system 120. A given recorded meeting 240 may include audio information (e.g., vocally-spoken statements 106 from individuals 102), visual information (e.g., images, video, electronic messages, presentations given at meeting 100, display information from at least one of the computing devices 108 associated with ones of the plurality of individuals 102 attending meeting 100), information indicative of accesses and/or revisions to one of more files made by one of more of the individuals 102 using one of more computing device 108 during meeting 100, or a combination. Recorded meetings 240 may be stored in short-term storage 230, where they will eventually be deleted according to a data retention policy as discussed herein. Recorded meetings 240 may be stored in long-term storage 130, where they are retained for subsequent playback as discussed herein.
In various embodiments, recorded meeting 240 includes several streams of information synched together. Recorded meeting 240 may include a timeline that may be used to correlate various information recorded by recording devices 104 together. Thus, in various embodiments, visual (e.g., recorded with a camera, recorded with a computer screen recorder) information is synced to the audio (e.g., recorded with a microphone) information such that a video of an individual 102 speaking is synced to the audible sounds of the individual's 102 voice) and/or a video of the information an individual 102 shared using his or her computer is synced to audio of the individual 102 speaking about the shared information. In embodiments, multiple sources of audio and/or video may be mixed together in recorded meeting 240. In some embodiments, for example, the audio from individual 102X may be recorded with a first recording device 104 (e.g. a microphone worn by individual 102X) and individuals 102Y and 102Z may be recorded with a second recording device 104 (e.g., a microphone on the table). These different audio sources may be mixed together into a single audio track, or they may be kept on separate tracks and synced up when the recorded meeting 240 is played back. Additionally, recorded meeting 240 may include visual information from multiple camera angles recorded in separate video feeds that may be played back separately or simultaneously. Electronic information such as visual signals showing information an individual 102 is sharing from a computer or a record of chat information may also be recorded separately synced to the other audio and/or visual information in recorded meeting 240.
Meeting metadata 250 includes information about the various recorded meetings 230. In various embodiments, meeting metadata 250 includes, for a given meeting 100, the start time of the meeting 100, the end time of the meeting 100, the duration of the meeting 100, the location of the meeting 100, indications of the plurality of individuals (e.g., names, titles, position, etc.), an indication of the recording confirmation command(s) 112 received for the meeting, or a combination. The indication of the recording confirmation command(s) 112 may include when the recording confirmation command 112 was received, the individual 102 (or individuals 102) whose assent was indicated by the recording confirmation command 112, and the manner in which the recording confirmation command 112 was received (e.g., via a spoken command, via a graphical user interface, etc.), or a combination.
In various embodiments, a blockchain-based shared ledger is used to store meeting metadata 250 and coordinate the various recorded meetings 240 stored in long-term storage 130. In these embodiments, a copy of the shared ledger is stored on computer system 120 as well as the computer systems (e.g., computing devices 108) used to access recorded meetings 240. In such embodiments, the shared ledger is used to facilitate and restrict accesses to the various recorded meetings 240. In such embodiments, access to a given stored recorded meeting 240 is conditioned on whether a recording confirmation command 112 has been received for the given recorded meeting 240. Because computer system 120, the computer system (e.g., a computing device 108) being used by an individual attempting to access a given recorded meeting 240, and computer systems (e.g., computing devices 108) associated with other individuals all have copies of the same shared ledger, the shared ledger may provide additional assurance that users are not given access to a given recorded meeting 240 for which a recording confirmation command 112 has not been received. For example, if an individual attempting to access a given recorded meeting 240 has fraudulently modified his or her copy of the shared ledger to indicate that a recording confirmation comment 112 has been received for the given recorded meeting 240 in order to gain access, the shared ledger on computer system 120 and the other user's computing systems would be usable to identify the fraudulent change and the computer system 120 could deny access to the given recorded meeting 240.
In various embodiments, for each given recorded meeting 240, the shared ledger includes meeting metadata 250 indicative of the individuals 100 who attended the given meeting 100, and information indicative of whether ones of the individuals 102 who attended the given meeting 100 have assented to access to the given recorded meeting 240 (e.g., via a recording confirmation command 112). When an additional meeting 100 is recorded as discussed herein, computer system 120 adds to the shared ledger metadata 250 indicative of the plurality of individuals 102 who attended the additional meeting 100, and information indicative of ones of the plurality of individuals 102 that have assented to access to the recorded meeting 240. Later, when a user seeks to access the additional recorded meeting 240, computer system 120 determines, based on the shared ledger, whether to grant access to the recorded meeting 240.
Further, the shared ledger may also be used to determine whether to accept a proposed change to a recorded meeting 240. Such a proposed change may include removing portions of a recorded meeting 240 (e.g., removing audio and/or visual information associated with an individual 102 making rude, abusive or offensive statements, removing audio tracks with loud background noise, and removing audio and/or visual information with poor quality (e.g., a low bitrate, poor connection during meeting 100, etc.)) or adding a portion to recorded meeting 240 (e.g., by adding visual information corresponding to a slide presentation given at meeting 100). Individuals 102 who attend the meeting 100 for which a change has been proposed may indicate their assent (or not) to the change, and such assent (or not) may be noted in the shared ledger. If the shared ledger indicates sufficient assent to the change (e.g., majority rules, unanimous assent, etc.), computer system 120 makes the change to recorded meeting 240.
A computer system 120, as shown in
Referring now to
In various embodiments, recording confirmation command 112 is sent by (or on the behalf of) particular individual(s) 102 indicating that the particular individual(s) 102 assents to retaining the recorded meeting 240. Recording confirmation command 112 may be communicated to computer system 120 in any of a number of ways. In some embodiments, recording confirmation command 112 is a direct verbal command to record meeting 100 (e.g., “Start recording of meeting”) given by an individual 102 and received via a recording device 104. In other embodiments, recording confirmation command 112 is not a direct command but is intuited by computer system 120 based on words spoken by individuals 102. For example, individual 102X may make an important statement and individual 102Y may say something like “Are we recording this?” or “Is this meeting being recorded?”, and computer system 120 interprets individual 102Y's statement as a command to retain the recorded meeting 240 for subsequent playback. In other embodiment, recording confirmation command 112 is a gesture given by an individual 102 (e.g., waving a hand back and forth three times). In still other embodiments, recording confirmation command 112 is an electronic command received via a graphical user interface (e.g., a graphical user interface of meeting software). In some embodiments, only certain individuals 102 are empowered to give recording confirmation command 112. For example, in some embodiments, only the individual 102 who organized meeting 100 is empowered to give recording confirmation command 112. In other embodiments, only a high-ranking individual 102 (e.g., key individual 102Z) is empowered to give recording confirmation command 112.
Referring now to
Referring now to
Referring now to
Challenge message 332 may be issued in any of a number of ways including but not limited to a pop-up on meeting software facilitating meeting 100, an audio message played during meeting 100 (e.g., via a speaker coupled to recording device 104 or a computing device 108), an email, or a message sent to one or more computing device 108. As discussed above, challenge message 332 may inquire as to how much of meeting 100 should be retained for subsequent playback. Additionally or alternatively, challenge message 332 may ask that individuals 102 other than the individual(s) 102 who sent the recording confirmation command 112 also assent to retaining a recorded meeting 240 for meeting 100 (e.g., asking for the assent of a majority of individuals 102, asking for the unanimous assent from all individuals 102). Challenge message 332 may also ask what kind of meeting information 110 should be retained for future playback (e.g., audio only, video and audio, audio and information indicating files access or modified during meeting 100). Challenge message 332 may also ask whether access to the recorded meeting 240 should be restricted (e.g., to only the individuals 102 attending meeting 100, only to users with a high enough security clearance level, etc.). Further, in embodiments where recording confirmation command 112 is not a direct command but is intuited by computer system 120 based on words spoken by individuals 102, challenge message 332 may confirm whether the individuals 102 would like to record meeting 100 (e.g., in response to individual 102Y stating “Are we recording this?”, challenge message 332 may be an audio message “Would you like to start recording this meeting?”).
Response to challenge message 334 may similarly given in any of a number of ways including but not limited to interaction with a graphical user interface on meeting software facilitating meeting 100, spoken responses by individuals 102, gestures given by individuals 102, an email, or a message sent with one or more computing devices 108. Response to challenge message 334 may include any of a number of commands in response to challenge message 332 as well as unsolicited commands (e.g., a command to retain only a portion of meeting 100, a command to restrict access to recorded meeting 240, etc.).
Accordingly, in various embodiments recording confirmation command 112 is received during meeting 100. In other embodiments, recording confirmation command 112 is received after meeting 100. In embodiments, all of the meeting 100 from start point 302 and end point 306 is retained for future playback. In other embodiments, only portions of the meeting 100 are retained for future playback. Further, in embodiments where a recording confirmation command 112 is not received within a period of time, recorded meeting 240 is deleted.
For example, individuals 102X, 102Y, and 102Z schedule a meeting 100 to occur at a particular time. For this meeting 100, each of individuals 102X, 102Y, and 102Z will attend in person at the same location (e.g., Meeting Room 1). An individual 102 (or a person assisting an individual 102) enters information about the meeting (e.g., invited individuals 102, location(s) of meeting, start time, end time) into a schedule (e.g., with meeting software) maintained by scheduling module 124. Individuals 102 are affiliated with an entity, Meeting Corp., that has numerous meetings scheduled at various times and in various locations. Scheduling module 124 accesses the schedule and determines that meeting 100 between individuals 102X, 102Y, and 102Z has begun (e.g., by determining that meeting 100 was scheduled to start at the current time, by detecting voices at with a recording device 104 in Meeting Room 1, etc.). As the meeting 100 is in progress, computer system 120 initiates a recording (e.g., with recording module 202) of the meeting, and receives meeting information 110 from at least one recording device 104 in Meeting Room 1. As discussed herein, prior to receiving a recording confirmation command 112, computer system 120 may store the recorded meeting 240 in short-term storage 230. While the meeting 100 is being recorded, the computer system 120 receives a recording confirmation command 112 from individual 102X (e.g., via a verbal command, via a command entered into a graphical user interface in meeting software running on a computing device 108, etc.). The meeting 100 continues until the individuals 102 end the meeting. As discussed herein, computer system 120 determines that the meeting 100 has ended (e.g., none of the voices of individuals 102X, 102Y, and 102Z are detected at Meeting Room 1 anymore). Having determined that the meeting 100 has ended and having received a recording confirmation command 112, computer system 120 causes the recording of the particular meeting 100 to be retained by the computer system 120 (e.g., in long-term storage 130) for subsequent playback.
Referring now to
For example, individuals 102 associated with Meeting Corp. routinely engage in meetings 100, resulting in a plurality of recorded meetings 240. A computer system 120 stores this plurality of recorded meetings 240 associated with Meeting Corp. Computer system 120 also maintains a blockchain-based shared ledger associated with recorded meetings 240. The shared ledger stores metadata 250 associated with the recorded meetings 240. In this embodiment, the shared ledger stores information indicative of the individuals 102 who attended each recorded meeting 240 (e.g., names, employee numbers) and information indicative of whether the individuals 102 who attended each meeting 100 have assented to access to the particular recorded meeting 240 (e.g., whether individual 102X who attended Meeting X on Mar. 10, 2018 has assented to access to the recording of Meeting 123). Computer system 120 initiates a recording (e.g., with recording module 202) of a meeting 100 (e.g., Meeting Y) between a plurality of individuals 102X, 102Y, and 102Z including audio of the meeting 100. Computer system 120 stores the recording (e.g., a recorded meeting 240) of Meeting Y. Computer system 120 also adds metadata 250 indicative of the fact that individuals 102X, 102Y, and 102Z attended Meeting Y to the shared ledger. Computer system 120 receives a recording confirmation command 112 from individual 102X which indicates individual 102X's assent to access of the recording of Meeting Y, and computer system 120 adds metadata 120 indicative of individual 102X's assent to the shared ledger. Then, based on the shared ledger, computer system 120 determines whether to give access to the recording of Meeting Y. For example, in embodiments where assent from only one individual 102 is necessary to permit access to recorded meeting 240, access to Meeting Y is granted because the shared ledger indicates that individual 102X has assented. However, in embodiments where assent from a majority of all individuals 102 is necessary to permit access to a recorded meeting 240, access to the recording of Meeting Y will not be granted because individuals 102Y and/or 102Z have not indicated their assent to access.
Turning now to
Processor subsystem 660 may include one or more processors or processing units. In various embodiments of computer system 600, multiple instances of processor subsystem 660 may be coupled to interconnect 660. In various embodiments, processor subsystem 660 (or each processor unit within 660) may contain a cache or other form of on-board memory.
System memory 620 is usable to store program instructions executable by processor subsystem 660 to cause system 600 perform various operations described herein. System memory 620 may be implemented using different physical memory media, such as hard disk storage, floppy disk storage, removable disk storage, flash memory, random access memory (RAM—SRAM, EDO RAM, SDRAM, DDR SDRAM, RAMBUS RAM, etc.), read only memory (PROM, EEPROM, etc.), and so on. Memory in computer system 600 is not limited to primary storage such as memory 620. Rather, computer system 600 may also include other forms of storage such as cache memory in processor subsystem 660 and secondary storage on I/O Devices 650 (e.g., a hard drive, storage array, etc.). In some embodiments, these other forms of storage may also store program instructions executable by processor subsystem 660.
I/O interfaces 640 may be any of various types of interfaces configured to couple to and communicate with other devices, according to various embodiments. In one embodiment, I/O interface 640 is a bridge chip (e.g., Southbridge) from a front-side to one or more back-side buses. I/O interfaces 640 may be coupled to one or more I/O devices 650 via one or more corresponding buses or other interfaces. Examples of I/O devices 650 include storage devices (hard drive, optical drive, removable flash drive, storage array, SAN, or their associated controller), network interface devices (e.g., to a local or wide-area network), or other devices (e.g., graphics, user interface devices, etc.). In one embodiment, computer system 600 is coupled to a network via a network interface device 650 (e.g., configured to communicate over WiFi, Bluetooth, Ethernet, etc.).
Although specific embodiments have been described above, these embodiments are not intended to limit the scope of the present disclosure, even where only a single embodiment is described with respect to a particular feature. Examples of features provided in the disclosure are intended to be illustrative rather than restrictive unless stated otherwise. The above description is intended to cover such alternatives, modifications, and equivalents as would be apparent to a person skilled in the art having the benefit of this disclosure.
The scope of the present disclosure includes any feature or combination of features disclosed herein (either explicitly or implicitly), or any generalization thereof, whether or not it mitigates any or all of the problems addressed herein. Accordingly, new claims may be formulated during prosecution of this application (or an application claiming priority thereto) to any such combination of features. In particular, with reference to the appended claims, features from dependent claims may be combined with those of the independent claims and features from respective independent claims may be combined in any appropriate manner and not merely in the specific combinations enumerated in the appended claims.