WO2023075425A1 - 외부 전자 장치를 제어하는 어플리케이션을 결정하는 전자 장치 및 그 동작 방법 - Google Patents

외부 전자 장치를 제어하는 어플리케이션을 결정하는 전자 장치 및 그 동작 방법 Download PDF

Info

Publication number
WO2023075425A1
WO2023075425A1 PCT/KR2022/016499 KR2022016499W WO2023075425A1 WO 2023075425 A1 WO2023075425 A1 WO 2023075425A1 KR 2022016499 W KR2022016499 W KR 2022016499W WO 2023075425 A1 WO2023075425 A1 WO 2023075425A1
Authority
WO
WIPO (PCT)
Prior art keywords
electronic device
application
external electronic
various embodiments
information
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Ceased
Application number
PCT/KR2022/016499
Other languages
English (en)
French (fr)
Inventor
김남진
박성미
신무현
조상훈
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Samsung Electronics Co Ltd
Original Assignee
Samsung Electronics Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Priority claimed from KR1020210162312A external-priority patent/KR20230060405A/ko
Application filed by Samsung Electronics Co Ltd filed Critical Samsung Electronics Co Ltd
Priority to EP22887621.5A priority Critical patent/EP4362430B1/en
Priority to US17/975,143 priority patent/US12445820B2/en
Publication of WO2023075425A1 publication Critical patent/WO2023075425A1/ko
Anticipated expiration legal-status Critical
Ceased legal-status Critical Current

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/28Data switching networks characterised by path configuration, e.g. LAN [Local Area Networks] or WAN [Wide Area Networks]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/12Protocols specially adapted for proprietary or special-purpose networking environments, e.g. medical networks, sensor networks, networks in vehicles or remote metering networks
    • H04L67/125Protocols specially adapted for proprietary or special-purpose networking environments, e.g. medical networks, sensor networks, networks in vehicles or remote metering networks involving control of end-device applications over a network
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/60Scheduling or organising the servicing of application requests, e.g. requests for application data transmissions using the analysis and optimisation of the required network resources
    • H04L67/61Scheduling or organising the servicing of application requests, e.g. requests for application data transmissions using the analysis and optimisation of the required network resources taking into account QoS or priority requirements
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/40Network security protocols
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W8/00Network data management

Definitions

  • the present disclosure relates to an electronic device that determines an application capable of controlling an external electronic device and an operating method thereof.
  • the Internet of Things refers to a technology that connects to the Internet by embedding sensors and communication functions in various objects.
  • IoT is an artificial intelligence technology that allows objects connected to the Internet to exchange data, analyze themselves, provide learned information to users, or allow users to control them remotely.
  • Objects can be various embedded systems such as home appliances, mobile equipment, or wearable devices. Things connected to the IoT must be connected to the Internet with unique IPs that can distinguish themselves, and sensors can be embedded to acquire data from the external environment.
  • IoT is also highly applicable for the purpose of controlling various electronic devices in the home. Users can control electronic devices such as TVs, washing machines, air conditioners, etc. to perform specialized services in the home IoT environment, and can easily share information about them.
  • the user may first select an application for connecting and controlling the electronic device to the cloud and connect and control the electronic device using the corresponding application.
  • the electronic device can be controlled by linking with Cloud to Cloud, and in order to link with Cloud to Cloud, different Interfaces between manufacturers' clouds must be matched, and access to the corresponding cloud may need to be granted through a separate authentication process.
  • an aspect of the present disclosure provides an electronic device that determines an application capable of registering an external electronic device in the cloud and grants administrator authority to control the external electronic device to applications of other manufacturers/platforms.
  • an electronic device includes communication circuitry and at least one processor coupled to the communication circuitry.
  • the at least one processor determines a first application for controlling the external electronic device based on onboarding information of the external electronic device, and determines the external electronic device corresponding to the first application.
  • Register in a first server determine a second application for controlling the external electronic device independently of the first application based on the onboarding information of the external electronic device, and set to execute the second application.
  • an electronic device includes communication circuitry and at least one processor coupled to the communication circuitry.
  • the at least one processor obtains onboarding information of an external electronic device, receives priority information about an application that can be executed in the electronic device from a server, and An application for controlling an external electronic device may be determined based on the boarding information and the priority information for the application, and the application may be set to be executed.
  • the electronic device may efficiently determine an application capable of registering the external electronic device to the cloud based on the characteristics and priorities of the external electronic device.
  • an electronic device may grant administrator authority for controlling an external electronic device to applications of other manufacturers/platforms.
  • FIG. 1 is a block diagram of an electronic device in a network environment according to an embodiment of the present disclosure
  • FIG. 2 is a block diagram illustrating a program according to an embodiment of the present disclosure
  • FIG. 3 is a diagram illustrating an example of an IoT environment according to an embodiment of the present disclosure
  • FIG. 4 is a diagram illustrating another example of an IoT environment according to an embodiment of the present disclosure.
  • FIG. 5 is a diagram illustrating another example of an IoT environment according to an embodiment of the present disclosure.
  • 6a, 6b, and 6c are flowcharts for describing an operation of an electronic device according to embodiments of the present disclosure
  • FIG. 7 is a diagram for explaining operations of an electronic device and a server according to an embodiment of the present disclosure.
  • FIG. 8 is a flowchart illustrating a process of triggering execution of a second application in a first application and updating administrator rights in the second application according to an embodiment of the present disclosure
  • FIG. 9 is a flowchart illustrating a process of granting administrator authority to a second application by a first application according to an embodiment of the present disclosure
  • FIG. 10 is a diagram illustrating an example of a user interface allowing administrator authority to be added to a second application after onboarding through a first application according to an embodiment of the present disclosure
  • FIG. 11 is a diagram illustrating an example of a user interface for adding a second application according to whether or not a first application is installed and app priority after QR recognition in a camera according to an embodiment of the present disclosure
  • FIG. 12 is a diagram for explaining a method of operating an electronic device according to an embodiment of the present disclosure.
  • FIG. 13 is a diagram for explaining a method of operating an electronic device according to an embodiment of the present disclosure.
  • FIG. 14 is a diagram for explaining an operating method of an electronic device according to an embodiment of the present disclosure.
  • FIG. 1 is a block diagram of an electronic device in a network environment according to an embodiment of the present disclosure.
  • an electronic device 101 communicates with an electronic device 102 through a first network 198 (eg, a short-range wireless communication network) or through a second network 199. It may communicate with at least one of the electronic device 104 or the server 108 through (eg, a long-distance wireless communication network). According to one embodiment, the electronic device 101 may communicate with the electronic device 104 through the server 108 .
  • the electronic device 101 includes a processor 120, a memory 130, an input module 150, an audio output module 155, a display module 160, an audio module 170, a sensor module ( 176), interface 177, connection terminal 178, haptic module 179, camera module 180, power management module 188, battery 189, communication module 190, subscriber identification module 196 , or the antenna module 197 may be included.
  • at least one of these components eg, the connection terminal 178) may be omitted or one or more other components may be added.
  • some of these components eg, sensor module 176, camera module 180, or antenna module 197) are integrated into a single component (eg, display module 160). It can be.
  • the processor 120 for example, executes software (eg, the program 140) to cause at least one other component (eg, hardware or software component) of the electronic device 101 connected to the processor 120. It can control and perform various data processing or calculations. According to one embodiment, as at least part of data processing or operation, the processor 120 transfers instructions or data received from other components (e.g., sensor module 176 or communication module 190) to volatile memory 132. , processing commands or data stored in the volatile memory 132 , and storing resultant data in the non-volatile memory 134 .
  • software eg, the program 140
  • the processor 120 transfers instructions or data received from other components (e.g., sensor module 176 or communication module 190) to volatile memory 132. , processing commands or data stored in the volatile memory 132 , and storing resultant data in the non-volatile memory 134 .
  • the processor 120 may include a main processor 121 (eg, a central processing unit or an application processor) or a secondary processor 123 (eg, a graphic processing unit, a neural network processing unit ( NPU: neural processing unit (NPU), image signal processor, sensor hub processor, or communication processor).
  • a main processor 121 eg, a central processing unit or an application processor
  • a secondary processor 123 eg, a graphic processing unit, a neural network processing unit ( NPU: neural processing unit (NPU), image signal processor, sensor hub processor, or communication processor.
  • NPU neural network processing unit
  • the secondary processor 123 may be implemented separately from or as part of the main processor 121 .
  • the secondary processor 123 may, for example, take the place of the main processor 121 while the main processor 121 is in an inactive (eg, sleep) state, or the main processor 121 is active (eg, running an application). ) state, together with the main processor 121, at least one of the components of the electronic device 101 (eg, the display module 160, the sensor module 176, or the communication module 190) It is possible to control at least some of the related functions or states.
  • the auxiliary processor 123 eg, image signal processor or communication processor
  • the auxiliary processor 123 may include a hardware structure specialized for processing an artificial intelligence model.
  • AI models can be created through machine learning. Such learning may be performed, for example, in the electronic device 101 itself where the artificial intelligence model is performed, or may be performed through a separate server (eg, the server 108).
  • the learning algorithm may include, for example, supervised learning, unsupervised learning, semi-supervised learning or reinforcement learning, but in the above example Not limited.
  • the artificial intelligence model may include a plurality of artificial neural network layers.
  • Artificial neural networks include deep neural networks (DNNs), convolutional neural networks (CNNs), recurrent neural networks (RNNs), restricted boltzmann machines (RBMs), deep belief networks (DBNs), bidirectional recurrent deep neural networks (BRDNNs), It may be one of deep Q-networks or a combination of two or more of the foregoing, but is not limited to the foregoing examples.
  • the artificial intelligence model may include, in addition or alternatively, software structures in addition to hardware structures.
  • the memory 130 may store various data used by at least one component (eg, the processor 120 or the sensor module 176) of the electronic device 101 .
  • the data may include, for example, input data or output data for software (eg, program 140) and commands related thereto.
  • the memory 130 may include volatile memory 132 or non-volatile memory 134 .
  • the program 140 may be stored as software in the memory 130 and may include, for example, an operating system 142 , middleware 144 , or an application 146 .
  • the input module 150 may receive a command or data to be used by a component (eg, the processor 120) of the electronic device 101 from the outside of the electronic device 101 (eg, a user).
  • the input module 150 may include, for example, a microphone, a mouse, a keyboard, a key (eg, a button), or a digital pen (eg, a stylus pen).
  • the sound output module 155 may output sound signals to the outside of the electronic device 101 .
  • the sound output module 155 may include, for example, a speaker or a receiver.
  • the speaker can be used for general purposes such as multimedia playback or recording playback.
  • a receiver may be used to receive an incoming call. According to one embodiment, the receiver may be implemented separately from the speaker or as part of it.
  • the display module 160 may visually provide information to the outside of the electronic device 101 (eg, a user).
  • the display module 160 may include, for example, a display, a hologram device, or a projector and a control circuit for controlling the device.
  • the display module 160 may include a touch sensor set to detect a touch or a pressure sensor set to measure the intensity of force generated by the touch.
  • the audio module 170 may convert sound into an electrical signal or vice versa. According to one embodiment, the audio module 170 acquires sound through the input module 150, the sound output module 155, or an external electronic device connected directly or wirelessly to the electronic device 101 (eg: Sound may be output through the electronic device 102 (eg, a speaker or a headphone).
  • the audio module 170 acquires sound through the input module 150, the sound output module 155, or an external electronic device connected directly or wirelessly to the electronic device 101 (eg: Sound may be output through the electronic device 102 (eg, a speaker or a headphone).
  • the sensor module 176 detects an operating state (eg, power or temperature) of the electronic device 101 or an external environmental state (eg, a user state), and generates an electrical signal or data value corresponding to the detected state. can do.
  • the sensor module 176 may include, for example, a gesture sensor, a gyro sensor, an air pressure sensor, a magnetic sensor, an acceleration sensor, a grip sensor, a proximity sensor, a color sensor, an IR (infrared) sensor, a bio sensor, It may include a temperature sensor, humidity sensor, or light sensor.
  • the interface 177 may support one or more designated protocols that may be used to directly or wirelessly connect the electronic device 101 to an external electronic device (eg, the electronic device 102).
  • the interface 177 may include, for example, a high definition multimedia interface (HDMI), a universal serial bus (USB) interface, an SD card interface, or an audio interface.
  • HDMI high definition multimedia interface
  • USB universal serial bus
  • SD card interface Secure Digital Card interface
  • audio interface audio interface
  • connection terminal 178 may include a connector through which the electronic device 101 may be physically connected to an external electronic device (eg, the electronic device 102).
  • the connection terminal 178 may include, for example, an HDMI connector, a USB connector, an SD card connector, or an audio connector (eg, a headphone connector).
  • the haptic module 179 may convert electrical signals into mechanical stimuli (eg, vibration or motion) or electrical stimuli that a user may perceive through tactile or kinesthetic senses.
  • the haptic module 179 may include, for example, a motor, a piezoelectric element, or an electrical stimulation device.
  • the camera module 180 may capture still images and moving images. According to one embodiment, the camera module 180 may include one or more lenses, image sensors, image signal processors, or flashes.
  • the power management module 188 may manage power supplied to the electronic device 101 .
  • the power management module 188 may be implemented as at least part of a power management integrated circuit (PMIC), for example.
  • PMIC power management integrated circuit
  • the battery 189 may supply power to at least one component of the electronic device 101 .
  • the battery 189 may include, for example, a non-rechargeable primary cell, a rechargeable secondary cell, or a fuel cell.
  • the communication module 190 is a direct (eg, wired) communication channel or a wireless communication channel between the electronic device 101 and an external electronic device (eg, the electronic device 102, the electronic device 104, or the server 108). Establishment and communication through the established communication channel may be supported.
  • the communication module 190 may include one or more communication processors that operate independently of the processor 120 (eg, an application processor) and support direct (eg, wired) communication or wireless communication.
  • the communication module 190 is a wireless communication module 192 (eg, a cellular communication module, a short-range wireless communication module, or a global navigation satellite system (GNSS) communication module) or a wired communication module 194 (eg, : a local area network (LAN) communication module or a power line communication module).
  • a wireless communication module 192 eg, a cellular communication module, a short-range wireless communication module, or a global navigation satellite system (GNSS) communication module
  • GNSS global navigation satellite system
  • wired communication module 194 eg, : a local area network (LAN) communication module or a power line communication module.
  • a corresponding communication module is a first network 198 (eg, a short-range communication network such as Bluetooth TM , wireless fidelity (Wi-Fi) direct, or infrared data association (IrDA)) or a second network 199 ( Example: It may communicate with the external electronic device 104 through a legacy cellular network, a 5G network, a next-generation communication network, the Internet, or a telecommunications network such as a computer network (eg, a LAN or a WAN).
  • a computer network eg, a LAN or a WAN
  • These various types of communication modules may be integrated as one component (eg, a single chip) or implemented as a plurality of separate components (eg, multiple chips).
  • the wireless communication module 192 uses subscriber information (eg, International Mobile Subscriber Identifier (IMSI)) stored in the subscriber identification module 196 within a communication network such as the first network 198 or the second network 199.
  • subscriber information eg, International Mobile Subscriber Identifier (IMSI)
  • IMSI International Mobile Subscriber Identifier
  • the electronic device 101 may be identified or authenticated.
  • the wireless communication module 192 may support a 5G network after a 4G network and a next-generation communication technology, for example, NR access technology (new radio access technology).
  • NR access technologies include high-speed transmission of high-capacity data (enhanced mobile broadband (eMBB)), minimization of terminal power and access of multiple terminals (massive machine type communications (mMTC)), or high reliability and low latency (ultra-reliable and low latency (URLLC)).
  • eMBB enhanced mobile broadband
  • mMTC massive machine type communications
  • URLLC ultra-reliable and low latency
  • -latency communications can be supported.
  • the wireless communication module 192 may support a high frequency band (eg, mmWave band) to achieve a high data rate, for example.
  • the wireless communication module 192 uses various technologies for securing performance in a high frequency band, such as beamforming, massive multiple-input and multiple-output (MIMO), and full-dimensional multiplexing. Technologies such as input/output (FD-MIMO: full dimensional MIMO), array antenna, analog beam-forming, or large scale antenna may be supported.
  • the wireless communication module 192 may support various requirements defined for the electronic device 101, an external electronic device (eg, the electronic device 104), or a network system (eg, the second network 199).
  • the wireless communication module 192 is a peak data rate for eMBB realization (eg, 20 Gbps or more), a loss coverage for mMTC realization (eg, 164 dB or less), or a U-plane latency for URLLC realization (eg, Example: downlink (DL) and uplink (UL) each of 0.5 ms or less, or round trip 1 ms or less) may be supported.
  • eMBB peak data rate for eMBB realization
  • a loss coverage for mMTC realization eg, 164 dB or less
  • U-plane latency for URLLC realization eg, Example: downlink (DL) and uplink (UL) each of 0.5 ms or less, or round trip 1 ms or less
  • the antenna module 197 may transmit or receive signals or power to the outside (eg, an external electronic device).
  • the antenna module 197 may include an antenna including a radiator formed of a conductor or a conductive pattern formed on a substrate (eg, PCB).
  • the antenna module 197 may include a plurality of antennas (eg, an array antenna). In this case, at least one antenna suitable for a communication method used in a communication network such as the first network 198 or the second network 199 is selected from the plurality of antennas by the communication module 190, for example. can be chosen A signal or power may be transmitted or received between the communication module 190 and an external electronic device through the selected at least one antenna.
  • other components eg, a radio frequency integrated circuit (RFIC) may be additionally formed as a part of the antenna module 197 in addition to the radiator.
  • RFIC radio frequency integrated circuit
  • the antenna module 197 may form a mmWave antenna module.
  • the mmWave antenna module includes a printed circuit board, an RFIC disposed on or adjacent to a first surface (eg, a lower surface) of the printed circuit board and capable of supporting a designated high frequency band (eg, mmWave band); and a plurality of antennas (eg, array antennas) disposed on or adjacent to a second surface (eg, a top surface or a side surface) of the printed circuit board and capable of transmitting or receiving signals of the designated high frequency band. can do.
  • peripheral devices eg, a bus, general purpose input and output (GPIO), serial peripheral interface (SPI), or mobile industry processor interface (MIPI)
  • signal e.g. commands or data
  • commands or data may be transmitted or received between the electronic device 101 and the external electronic device 104 through the server 108 connected to the second network 199 .
  • Each of the external electronic devices 102 or 104 may be the same as or different from the electronic device 101 .
  • all or part of operations executed in the electronic device 101 may be executed in one or more external electronic devices among the external electronic devices 102 , 104 , or 108 .
  • the electronic device 101 when the electronic device 101 needs to perform a certain function or service automatically or in response to a request from a user or another device, the electronic device 101 instead of executing the function or service by itself.
  • one or more external electronic devices may be requested to perform the function or at least part of the service.
  • One or more external electronic devices receiving the request may execute at least a part of the requested function or service or an additional function or service related to the request, and deliver the execution result to the electronic device 101 .
  • the electronic device 101 may provide the result as at least part of a response to the request as it is or additionally processed.
  • cloud computing distributed computing, mobile edge computing (MEC), or client-server computing technology may be used.
  • the electronic device 101 may provide an ultra-low latency service using, for example, distributed computing or mobile edge computing.
  • the external electronic device 104 may include an internet of things (IoT) device.
  • Server 108 may be an intelligent server using machine learning and/or neural networks. According to one embodiment, the external electronic device 104 or server 108 may be included in the second network 199 .
  • the electronic device 101 may be applied to intelligent services (eg, smart home, smart city, smart car, or health care) based on 5G communication technology and IoT-related technology.
  • Electronic devices may be devices of various types.
  • the electronic device may include, for example, a portable communication device (eg, a smart phone), a computer device, a portable multimedia device, a portable medical device, a camera, a wearable device, or a home appliance.
  • a portable communication device eg, a smart phone
  • a computer device e.g., a smart phone
  • a portable multimedia device e.g., a portable medical device
  • a camera e.g., a portable medical device
  • a camera e.g., a portable medical device
  • a camera e.g., a portable medical device
  • a camera e.g., a camera
  • a wearable device e.g., a smart bracelet
  • first, second, or first or secondary may simply be used to distinguish a given component from other corresponding components, and may be used to refer to a given component in another aspect (eg, importance or order) is not limited.
  • a (e.g., first) component is said to be “coupled” or “connected” to another (e.g., second) component, with or without the terms “functionally” or “communicatively.”
  • the certain component may be connected to the other component directly (eg by wire), wirelessly, or through a third component.
  • module used in various embodiments of this document may include a unit implemented in hardware, software, or firmware, and is interchangeable with terms such as, for example, logic, logical blocks, parts, or circuits.
  • a module may be an integrally constructed component or a minimal unit of components or a portion thereof that performs one or more functions.
  • the module may be implemented in the form of an application-specific integrated circuit (ASIC).
  • ASIC application-specific integrated circuit
  • a storage medium eg, internal memory 136 or external memory 138
  • a machine eg, electronic device 101
  • a processor eg, the processor 120
  • a device eg, the electronic device 101
  • the one or more instructions may include code generated by a compiler or code executable by an interpreter.
  • the device-readable storage medium may be provided in the form of a non-transitory storage medium.
  • the storage medium is a tangible device and does not contain a signal (e.g. electromagnetic wave), and this term refers to the case where data is stored semi-permanently in the storage medium. It does not discriminate when it is temporarily stored.
  • a signal e.g. electromagnetic wave
  • the method according to various embodiments disclosed in this document may be included and provided in a computer program product.
  • Computer program products may be traded between sellers and buyers as commodities.
  • a computer program product is distributed in the form of a device-readable storage medium (eg compact disc read only memory (CD-ROM)), or through an application store (eg Play Store TM ) or on two user devices ( It can be distributed (eg downloaded or uploaded) online, directly between smart phones.
  • a device-readable storage medium eg compact disc read only memory (CD-ROM)
  • an application store eg Play Store TM
  • It can be distributed (eg downloaded or uploaded) online, directly between smart phones.
  • at least part of the computer program product may be temporarily stored or temporarily created in a device-readable storage medium such as a manufacturer's server, an application store server, or a relay server's memory.
  • each component (eg, module or program) of the above-described components may include a single object or a plurality of entities, and some of the plurality of entities may be separately disposed in other components. there is.
  • one or more components or operations among the aforementioned corresponding components may be omitted, or one or more other components or operations may be added.
  • a plurality of components eg modules or programs
  • the integrated component may perform one or more functions of each of the plurality of components identically or similarly to those performed by a corresponding component of the plurality of components prior to the integration. .
  • the actions performed by a module, program, or other component are executed sequentially, in parallel, iteratively, or heuristically, or one or more of the actions are executed in a different order, or omitted. or one or more other actions may be added.
  • FIG. 2 is a block diagram illustrating a program according to one embodiment of the present disclosure.
  • the program 140 is an operating system (OS) 142, middleware 144, or an application executable in the operating system 142 for controlling one or more resources of the electronic device 101 ( 146) may be included.
  • the operating system 142 may include, for example, Android TM , iOS TM , Windows TM , Symbian TM , Tizen TM , or Bada TM .
  • At least some of the programs 140 are, for example, preloaded in the electronic device 101 at the time of manufacture, or when used by a user, an external electronic device (eg, the electronic device 102 or 104), or a server ( 108)) can be downloaded or updated.
  • the operating system 142 may control management (eg, allocation or reclamation) of one or more system resources (eg, process, memory, or power) of the electronic device 101 .
  • Operating system 142 may additionally or alternatively include other hardware devices of electronic device 101 , such as input module 150 , sound output module 155 , display module 160 , audio module 170 . , sensor module 176, interface 177, haptic module 179, camera module 180, power management module 188, battery 189, communication module 190, subscriber identification module 196, or It may include one or more driver programs for driving the antenna module 197.
  • the middleware 144 may provide various functions to the application 146 so that the function or information provided from one or more resources of the electronic device 101 may be used by the application 146 .
  • the middleware 144 includes, for example, the application manager 201, the window manager 203, the multimedia manager 205, the resource manager 207, the power manager 209, the database manager 211, and the package manager 213. ), connectivity manager 215, notification manager 217, location manager 219, graphics manager 221, security manager 223, call manager 225, or voice recognition manager 227. can
  • the application manager 201 may manage the life cycle of the application 146 , for example.
  • the window manager 203 may manage one or more GUI resources used in a screen, for example.
  • the multimedia manager 205 identifies, for example, one or more formats necessary for reproducing media files, and encodes or decodes a corresponding media file among the media files using a codec suitable for the selected format. can be done
  • the resource manager 207 may manage a source code of the application 146 or a memory space of the memory 130 .
  • the power manager 209 may manage, for example, the capacity, temperature, or power of the battery 189, and determine or provide related information necessary for the operation of the electronic device 101 by using corresponding information among them. . According to an embodiment, the power manager 209 may interoperate with a basic input/output system (BIOS) (not shown) of the electronic device 101 .
  • BIOS basic input/output system
  • the database manager 211 may create, search, or change a database to be used by the application 146, for example.
  • the package manager 213 may manage installation or update of applications distributed in the form of package files, for example.
  • the connectivity manager 215 may manage, for example, a wireless connection or a direct connection between the electronic device 101 and an external electronic device.
  • the notification manager 217 may provide a function for notifying a user of occurrence of a designated event (eg, an incoming call, message, or alarm), for example.
  • the location manager 219 may manage location information of the electronic device 101, for example.
  • the graphic manager 221 may manage, for example, one or more graphic effects to be provided to a user or a user interface related thereto.
  • Security manager 223 may provide system security or user authentication, for example.
  • the telephony manager 225 may manage, for example, a voice call function or a video call function provided by the electronic device 101 .
  • the voice recognition manager 227 transmits, for example, the user's voice data to the server 108, and at least partially based on the voice data, a command corresponding to a function to be performed in the electronic device 101; Alternatively, text data converted at least partially based on the voice data may be received from the server 108 .
  • the middleware 244 may dynamically delete some existing components or add new components.
  • at least part of the middleware 144 may be included as part of the operating system 142 or may be implemented as separate software different from the operating system 142 .
  • the application 146 includes, for example, a home 251, a dialer 253, an SMS/MMS 255, an instant message (IM) 257, a browser 259, a camera 261, and an alarm 263. , Contacts (265), Voice Recognition (267), Email (269), Calendar (271), Media Player (273), Albums (275), Watch (277), Health (279) (e.g. exercise or blood sugar) measurement of biometric information) or environmental information 281 (eg, measurement of atmospheric pressure, humidity, or temperature information). According to an embodiment, the application 146 may further include an information exchange application (not shown) capable of supporting information exchange between the electronic device 101 and an external electronic device.
  • an information exchange application not shown
  • the information exchange application may include, for example, a notification relay application configured to transmit designated information (eg, a call, message, or alarm) to an external electronic device, or a device management application configured to manage an external electronic device.
  • the notification relay application for example, transmits notification information corresponding to a designated event (eg, mail reception) generated in another application (eg, the email application 269) of the electronic device 101 to an external electronic device.
  • the notification relay application may receive notification information from an external electronic device and provide the notification information to the user of the electronic device 101 .
  • the device management application is, for example, a power source (eg, turn-on or turn-off) of an external electronic device that communicates with the electronic device 101 or some component thereof (eg, a display module or a camera module of the external electronic device). ) or functions (eg brightness, resolution, or focus).
  • the device management application may additionally or alternatively support installation, deletion, or update of an application operating in an external electronic device.
  • FIG 3 is a diagram illustrating an example of an IoT environment according to an embodiment of the present disclosure.
  • the IoT environment 300 may include an electronic device 310, a cloud 320, and cloud-connected devices 330.
  • the IoT environment 300 connects the cloud-connected devices 330, such as home appliances, to various types of communication networks and relays and controls them in the cloud 320 and a local server. can mean a platform.
  • the IoT environment 300 includes Bluetooth (BT), Bluetooth low energy (BLE), WIFI, peer-to-peer network (P2P), and universal plug and play. Device discovery and control can be provided while supporting various communication protocols such as universal plug and play (UPnP), CLOUD, or ultra-wideband (UWB).
  • BT Bluetooth
  • BLE Bluetooth low energy
  • WIFI wireless fidelity
  • P2P peer-to-peer network
  • UWB ultra-wideband
  • the IoT environment 300 may be implemented as an open platform to connect not only sensors and products of a specific brand, but also products of other brands. According to various embodiments, the IoT environment 300 may be implemented as a closed platform so that a sensor of a specific brand is connected to a product.
  • the electronic device 310 (eg, the electronic device 101 of FIG. 1) includes an application 315 executable by an operating system (eg, the operating system 142 of FIG. 1). ) (eg, the application 146 of FIG. 1) may be installed.
  • the application 315 may be preloaded on the electronic device 310 during manufacturing, or may be an external electronic device (eg, the electronic device 102 or 104 of FIG. 1 , or the server of FIG. 1 ( 108)) can be downloaded or updated.
  • the application 315 may check the status of the cloud-connected devices 330 registered to a server in the cloud 320 and control the cloud-connected devices 330 .
  • the application 315 controls the cloud-connected devices 330 registered to the server in the cloud 320 to automatically operate at a predetermined time, or the cloud-connected devices 330 You can receive notifications from
  • the application 315 may control and manage smart home appliances or the Internet of Things (IoT) through the electronic device 310 and may be connected to peripheral devices by wire or wirelessly.
  • the cloud-connected devices 330 may include at least one of a TV, a speaker, a refrigerator, a kimchi refrigerator, a wine cellar, a washing machine, a dryer, an air dresser, an oven, a dishwasher, a cooktop, a robot vacuum cleaner, an air conditioner, and an air purifier. may contain one.
  • FIG. 4 is a diagram illustrating another example of an IoT environment according to an embodiment of the present disclosure.
  • the IoT environment 400 includes the electronic device 410, a first cloud 420, and cloud-connected devices 430 (eg, the cloud-connected devices of FIG. 3 ( 330)), a hub 440, a second cloud 460, and/or a third cloud 470.
  • the IoT environment 400 may provide an environment substantially the same as or similar to the IoT environment 300 described in FIG. 3 .
  • the electronic device 410 eg, the electronic device 101 of FIG. 1
  • includes an application eg, an operating system 142 of FIG. 1
  • an operating system. 415) eg, application 146 of FIG. 1
  • the application 415 may refer to a client application that registers the cloud-connected devices 430 to the first cloud 420 and remotely controls the registered devices. According to various embodiments, the application 415 may check the status of the cloud-connected devices 430 registered to a server in the first cloud 420 and control the cloud-connected devices 430. there is. According to various embodiments, the application 415 controls the cloud-connected devices 430 registered to the server in the first cloud 420 to automatically operate at a predetermined time, or the cloud-connected devices ( 430). According to various embodiments, the application 415 may control and manage smart home appliances or the Internet of Things (IoT) through the electronic device 310 and may be connected to peripheral devices by wire or wirelessly.
  • IoT Internet of Things
  • a device capable of connecting to the first cloud 420 may be a hub-connected 440, a direct-connected 450, or a cloud-connected ( 424 and 428 may be connected to the first cloud 420 .
  • the first cloud 420 may include a server that manages or controls the electronic device 410 and the cloud-connected devices 430 .
  • the server in the first cloud 420 stores information transmitted and received between the electronic device 410 and the cloud-connected devices 430 or stores information between the electronic device 410 and the cloud-connected devices 430. It may relay communication between devices 430 and support communication between the electronic device 410 and the cloud-connected devices 430 .
  • the first cloud 420 may implement an application programming interface (API) 422 that is a language or message format used for communication between an operating system and an application program.
  • API application programming interface
  • the first cloud 420 may be connected to the cloud-connected devices 430 through the hub 440 .
  • the hub 440 may connect the first cloud 420 and the cloud-connected devices 430 through a communication function such as ZigBee, Zwave, LAN, or Matter.
  • the hub 440 may refer to a device (eg, a gateway) relaying communication between the first cloud 420 and the cloud-connected devices 430 .
  • the hub 440 may be a device implemented in the first cloud 420 or implemented as a separate device (eg, an external server).
  • the first cloud 420 may be connected to the cloud-connected devices 430 through a direct connection 450 without using the hub 440 .
  • at least one of the cloud-connected devices 430 may be connected to the first cloud 420 by directly connecting to a Wi-Fi AP.
  • the first cloud 420 may be connected to the cloud connector 424 using an API 422 and communicate with the second cloud 460 .
  • an operator providing services in the first cloud 420 may be different from an operator providing services in the second cloud 460 .
  • the cloud connector 424 may relay communication between different clouds (eg, the first cloud 420 and the second cloud 460 ).
  • the cloud connector 424 may be a hardware device or a software module implemented in the first cloud 420 .
  • the cloud connector 424 may be a hardware device or software module implemented outside the first cloud 420 .
  • the cloud connector 424 may be a separate server implemented outside the first cloud 420 .
  • the first cloud 420 is connected to the automation function 426 using the API 422, and the automation function 426, when a condition set by the user in the application 415 is satisfied, provides the user with
  • Each of the cloud-connected devices 430 connected to the first cloud 420 may be controlled to perform a defined operation without a command (or input).
  • the automation function 426 may be a hardware device or a software module implemented in the first cloud 420 .
  • the automation function 426 may be a hardware device or software module implemented outside the first cloud 420 .
  • the automation function 426 may be a separate server implemented outside the first cloud 420 .
  • the application 415 may determine the time (eg, specific time, specific time period, always, or day of the week, etc.), device status, member location (eg, , Check whether or not you are in the initially set place), place conditions, or weather conditions can be set.
  • the automation function 426 when a condition set in the application 415 is satisfied, performs an operation for the cloud-connected devices 430 connected to the first cloud 420 without a user command (or input). It can be controlled to perform functions such as device control, smartphone notification, voice message play through the speaker, change in the status of a place, or mode execution.
  • the first cloud 420 may be connected to the cloud connector 428 using an API 422 and communicate with the third cloud 470 .
  • an operator providing services in the first cloud 420 may be different from an operator providing services in the third cloud 470 .
  • the cloud connector 428 may relay communication between different clouds (eg, the first cloud 420 and the third cloud 470 ).
  • the cloud connector 428 may be a hardware device or a software module implemented in the first cloud 420 .
  • the cloud connector 428 may be a hardware device or software module implemented outside the first cloud 420 .
  • the cloud connector 428 may be a separate server implemented outside the first cloud 420 .
  • the cloud-connected devices 430 connected in the form can be onboarded (or registered) to the first cloud 420 through the application 415 .
  • onboarding may be a process of registering at least one electronic device to the first cloud 420 through the application 415 .
  • FIG. 5 is a diagram illustrating another example of an IoT environment according to an embodiment of the present disclosure.
  • an IoT environment 500 may include an electronic device 510, a server 520, a workspace 530, and/or a database (DB) 540.
  • the IoT environment 500 may provide an environment substantially the same as or similar to the IoT environment 300 described in FIG. 3 or the IoT environment 400 described in FIG. 4 .
  • the electronic device 510 eg, the electronic device 101 of FIG. 1
  • the application 515 executable by an operating system (eg, the operating system 142 of FIG. 1 ). ) (eg, the application 146 of FIG. 1) may be installed.
  • the electronic device 510 may include a camera application 511 , a near device scanner (NDS) 513 , and/or an application 515 .
  • the camera app 511 may recognize (or check) a QR code of at least one external electronic device to be onboarded.
  • the camera app 511 may parse a QR code to allow a user to check (or determine) whether to onboard at least one external electronic device.
  • the application 515 may refer to a client application that registers at least one external electronic device with the server 520 in the cloud and remotely controls the registered device.
  • the application 515 may check the status of at least one external electronic device registered to the server 520 in the cloud and control the at least one external electronic device.
  • the peripheral device scanner 513 may scan at least one external electronic device in the background as a nearby device scanner service module.
  • the peripheral device scanner 513 may detect (or detect) at least one external electronic device capable of onboarding.
  • the peripheral device scanner 513 may provide a function of determining the priority of an application for performing (or controlling) onboarding and executing the application.
  • the electronic device 510 may obtain onboarding information on at least one external electronic device by using the camera app 511 and/or the peripheral device scanner 513 .
  • the onboarding information for at least one external electronic device may include a vendor ID of the at least one external electronic device and an ID of the at least one external electronic device registered in the workspace 530. (productid).
  • the electronic device 510 may transmit onboarding information on at least one external electronic device to the server 520 .
  • the electronic device 510 may store and use information about priorities of applications for performing (or controlling) onboarding.
  • the information about the priority of applications may include information about the priority for granting manager authority to manufacturers/platforms different from the electronic device (or external electronic device).
  • the electronic device 510 may provide onboarding information for at least one external electronic device to a manufacturer ID (vendorid) of the at least one external electronic device and at least one registered in the workspace 530.
  • An application type to control at least one external electronic device may be determined based on a productid (ID) of the external electronic device.
  • the electronic device 510 determines a vendor ID (vendorid) of at least one external electronic device, a productid (ID) of at least one external electronic device registered in the workspace 530, and an application priority.
  • An application type to control at least one external electronic device may be determined based on the related information.
  • the application priority is the type of operating system (mobile OS) installed on the electronic device 510 (eg, Galaxy, Non-Galaxy, Android, or iOS) and the application installed on the electronic device 510. It may be determined based on information about (eg, whether SmartThings App is installed or not, or whether Google Home App is installed).
  • the electronic device 510 may pre-store an application list capable of onboarding at least one external electronic device or receive the application list from the server 520 .
  • the electronic device 510 may automatically recommend an application for onboarding or display a list of possible applications according to the application list.
  • the workspace 530 may also be called a developer workspace, and a developer of each product may transmit information about the product type, characteristics, and/or device number to the server 520.
  • a 3 rd party manufacturer uses its own product (or at least one external electronic device) in the workspace 530 to display the type, characteristics, and/or unique number of the device. It is possible to transmit related information to the server 520.
  • the database 540 may receive onboarding information on at least one external electronic device from the server 520 and store it.
  • the database 540 includes application type information (partner name), manufacturer ID (vendorid) of at least one external electronic device, and ID (productid) of at least one external electronic device registered in the workspace 530. ), and information about an application link according to an application type may be stored.
  • the database 540 may provide stored information to the server 520 according to a request of the server 520 .
  • information stored in the database 540 may be provided to the electronic device 510 through the server 520 .
  • the present disclosure determines an application capable of onboarding (or registering) an external electronic device based on a priority, and grants administrator authority to control the external electronic device to applications of other manufacturers/platforms. Suggest how to do it.
  • the present disclosure obtains onboarding information of an external electronic device through QR code recognition or nearby device scanning and determines (or selects) an application based on priority. there is.
  • an application of another manufacturer/platform may control the external electronic device. You can add admin privileges.
  • an application of a manufacturer of an external electronic device may directly grant administrator authority to an application of another manufacturer/platform.
  • an application of another manufacturer/platform may directly update administrator privileges for an external electronic device after an application of another manufacturer/platform is executed.
  • an application of a manufacturer of an external electronic device may directly provide administrator authority to a user located in a specific location through an invitation function.
  • an application of a manufacturer of an external electronic device may be referred to as a “first application” and an application of another manufacturer/platform may be referred to as a “second application”.
  • 6A to 6C are flowcharts for explaining an operation of an electronic device according to an embodiment of the present disclosure.
  • the system includes an IoT device 610, an electronic device 620, a server 630, a first application 640, a second application 650, and/or a third application 660. ) may be included.
  • the IoT device 610 is one of the electronic device 102 or 104 of FIG. 2 , the cloud-connected devices 330 of FIG. 3 , or the cloud-connected devices 430 of FIG. 4 . Either one can be implemented.
  • the electronic device 620 may include a camera app 620-1 (eg, the camera app 511 of FIG. 5 ) and/or a peripheral scanner 620-2 (eg, the camera app 511 of FIG. 5 ). Peripheral device scanner 513 of FIG. 5).
  • the server 630 may refer to a server for onboarding (or registering) the IoT device 610 in order to control the IoT device 610 through the electronic device 620 .
  • the server 630 may correspond to each of the first application 640 , the second application 650 , and the third application 660 .
  • the server 630 is illustrated as one server, but the technical spirit of the present disclosure is not limited thereto, and the server 630 includes a first application 640, a second application 650, and It may include three independent servers corresponding to each of the third applications 660 .
  • each of the first application 640, the second application 650, and the third application 660 communicates with each of the corresponding three servers to support onboarding of the IoT device 610.
  • each of the first application 640, the second application 650, and the third application 660 may be independently managed by different product manufacturers or server operators.
  • each of the first application 640, the second application 650, and the third application 660 may communicate with each other through corresponding server-to-server communication or a cloud connection.
  • the user 600 may execute the camera app 620-1 (operation 601).
  • the camera app 620-1 may scan a QR code image for the IoT device 610 based on a user command (operation 603).
  • the IoT device 610 may provide QR code information to the camera app 620-1 (operation 605), and the camera app 620-1 may parse the QR code ( 607 action).
  • the camera app 620-1 may display a user consent popup (Operation 609).
  • the camera app 620-1 transmits a commissioning payload to the peripheral device scanner 620. -2) (Operation 613).
  • the peripheral scanner 620-2 when the user 600 drives the peripheral scanner 620-2, the peripheral scanner 620-2 performs device discovery on the IoT device 610 using short-range communication. may be performed (action 615). According to various embodiments, the peripheral device scanner 620-2 may perform device discovery for the IoT device 610 using short-range communication such as BLE scanning, WiFi, Bluetooth, or UWB (Operation 615). According to various embodiments, the peripheral device scanner 620-2 may display a popup for at least one discovered (or discovered) external electronic device (Operation 617).
  • the peripheral device scanner 620-2 detects the IoT device 610 and/or at least one A device to be commissioned may be determined based on onboarding information (eg, vendorid and/or productid) of the external electronic device (Operation 621).
  • the peripheral device scanner 620-2 may, in operation 613, obtain onboarding information of the IoT device 610 (eg, based on the commissioning payload received from the camera app 620-1 and the device discovery result). For example, vendorid and/or productid) may be obtained.
  • the peripheral device scanner 620-2 may transmit a request for an application to be commissioned to the server 630 (operation 623).
  • the application request to be commissioned may include device information about the IoT device 610 (eg, matter device: Phlips Hue), manufacturer ID of the IoT device 610 (eg, vendorid: 0x0010), and a unique ID (eg, productid: 0x0011) given to the IoT device 610.
  • the server 630 may transmit a response message including a priority app list to the peripheral device scanner 620-2 (Operation 625).
  • the priority app list may include priority information about applications, scheme information about each application, or package information.
  • the peripheral device scanner 620-2 may check package exit for the first application 640 (Operation 627).
  • the peripheral device scanner 620-2 may execute the first application 640 (Operation 629).
  • the peripheral device scanner 620-2 may transmit a request for an application to be commissioned to the server 630 (operation 631).
  • the application request to be commissioned may include device information about the IoT device 610 (eg, matter device: Phlips Hue), manufacturer ID of the IoT device 610 (eg, vendorid: 0x0010), and a unique ID (eg, productid: 0x0011) given to the IoT device 610.
  • the server 630 may transmit a response message including a priority app list to the peripheral device scanner 620-2 (Operation 633).
  • the priority app list may include priority information about applications, scheme information about each application, or package information.
  • the peripheral device scanner 620-2 may check package exit for the first application 640 (Operation 635).
  • the peripheral device scanner 620-2 may check package exit for the second application 650 (Operation 637).
  • the peripheral device scanner 620-2 may execute the second application 650 (Operation 639).
  • the peripheral device scanner 620-2 may transmit a request for an application to be commissioned to the server 630 (operation 641).
  • the application request to be commissioned may include device information about device information about the IoT device 610 (eg, matter device: Phlips Hue), manufacturer ID of the IoT device 610 (eg, vendorid : 0x0010), and a unique ID (eg, productid: 0x0011) given to the IoT device 610.
  • the server 630 may transmit a response message including a priority app list to the peripheral device scanner 620-2 (Operation 643).
  • the priority app list may include priority information about applications, scheme information about each application, or package information.
  • the peripheral device scanner 620-2 may check package exit for the first application 640 (Operation 645).
  • the peripheral device scanner 620-2 may check package exit for the third application 660 (Operation 647).
  • the peripheral device scanner 620-2 may execute the third application 660 (Operation 649).
  • FIG. 7 is a diagram for explaining operations of an electronic device and a server according to an embodiment of the present disclosure.
  • the system includes the electronic device 710, an external electronic device 720, an AP 730, and the server 740.
  • the electronic device 710 includes the electronic device 101 of FIG. 1 , the electronic device 310 of FIG. 3 , the electronic device 410 of FIG. 4 , and the electronic device 510 of FIG. 5 . ), or the electronic device 610 of FIGS. 6A to 6C.
  • the external electronic device 720 is the electronic device 102 or 104 of FIG. 1 , the cloud-connected devices 330 of FIG. 3 or the cloud-connected devices 430 of FIG. 4 , respectively.
  • the server 740 is the server 108 of FIG. 1, the cloud 320 of FIG. 3, the cloud 420, 460, 470 of FIG. 4, the server 520 of FIG. 5, or It may be implemented as the server 630 of FIGS. 6A to 6C.
  • the electronic device 710 may scan an external electronic device 720 located nearby (Operation 701). According to various embodiments, the external electronic device 720 may receive device information about the electronic device 710 (Operation 702). According to various embodiments, the electronic device 710 may receive device information about the external electronic device 720. According to various embodiments, the electronic device 710 may transmit the device model type selected by the user to be onboarded to the server 740 (Operation 703). According to various embodiments, the server 740 may store or update registered device information 741 . According to various embodiments, the registered device information 741 may include at least one of serial, model code, location, or wifi information for each of the at least one external electronic device. there is.
  • the server 740 may select an onboarding configuration type based on the model type 743 (Operation 704).
  • the onboarding setting type may refer to a user interface (UI) type displayed to a user when onboarding (or registering) at least one external electronic device to a cloud (or server).
  • the onboarding configuration type may include "Configuration Type 1", “Configuration Type 2", “Configuration Type 3", "Easy Configuration Type 1", or "Easy Configuration Type 2".
  • “setting type 1” may be a UI type that requires user input for device type and device model name.
  • "Easy setting type 1" is a UI type in which user input information is removed as much as possible, and may be a UI type that requires only user input for a device type.
  • the electronic device 710 may transfer the device model type to be onboarded to the external electronic device 720 (Operation 705).
  • the electronic device 710 may transmit Wi-Fi information (eg, SSID, passphrase) of the AP 730 to the external electronic device 720 (Operation 706).
  • the external electronic device 720 may be connected to the cloud through the AP 730 using the received wi-fi information (operation 707).
  • the external electronic device 720 may communicate with the server 740 through a network connection through the AP 730 (Operation 708).
  • the external electronic device 720 may communicate with the server 740 so that a serial and model code for the external electronic device 720 is registered in the server 740. Yes (708).
  • the server 740 may register a serial and model code of the external electronic device 720 in the registered device information 741 .
  • the electronic device 710 receives registered device information 741 including a serial and model code of the external electronic device 720 from the server 740 and save it (act 709).
  • FIG. 8 is a flowchart illustrating a process of triggering the execution of a second application in a first application and updating administrator rights in the second application according to an embodiment of the present disclosure.
  • the system may include a first application 810 , an external electronic device 820 , a server 830 , and/or a second application 840 .
  • the first application 810 may perform the same or substantially the same function as the application 515 of FIG. 5 or the first application 640 of FIGS. 6A to 6C.
  • the first application 810 may include the electronic device 101 of FIG. 1 , the electronic device 310 of FIG. 3 , the electronic device 410 of FIG. 4 , and the electronic device 510 of FIG. 5 . ), the electronic device 620 of FIGS. 6A to 6C, or the electronic device 710 of FIG. 7.
  • the external electronic device 820 is the electronic device 102 or 104 of FIG. 1, the cloud-connected devices 330 of FIG. 3, the cloud-connected devices 430 of FIG. 4, or It may be implemented as the external electronic device 720 of FIG. 7 .
  • the server 830 may be the server 108 of FIG. 1, the cloud 320 of FIG. 3, the clouds 420, 460, 470 of FIG. 4, the server 520 of FIG. 5, or the cloud 320 of FIG. It may perform the same or substantially the same function as the server 630 of FIGS. 6a to 6c.
  • the second application 840 may perform the same or substantially the same function as the second application 650 or the third application 660 of FIGS. 6A to 6C .
  • the first application 810 provides (or displays) a multi-admin additional message to the user 800 to allow a plurality of applications to have control authority over the external electronic device 820.
  • the user 800 may display a confirmation message indicating acceptance of the multi-admin addition message on the first application 810 (Operation 802).
  • the first application 810 may request a commissioning application from the server 830 based on onboarding information (vendorid, productid) of the external electronic device 820 (operation 803). ).
  • the server 830 may transmit a request response scheme to the first application 810 (Operation 804).
  • the external electronic device 820 when the external electronic device 820 is onboarded (or registered) to the server 830 corresponding to the first application 810, the external electronic device 820 performs device-to-device (D2D) It can be controlled not to perform a connection.
  • the external electronic device 820 in order for the external electronic device 820 to be additionally onboarded (or registered) to a server corresponding to the second application 840, the external electronic device 820 may be controlled to perform D2D connection again. .
  • the external electronic device 820 in order for the external electronic device 820 to be additionally onboarded (or registered) to a server corresponding to the second application 840, the external electronic device 820 performs a D2D connection to the first application 810.
  • a D2D connection command (eg, open pairing window) to the external electronic device 820 (Operation 805).
  • the external electronic device 820 may change a device state so that D2D connection can be performed.
  • the external electronic device 820 may switch to a pairing mode in which D2D connection may be performed.
  • the external electronic device 820 checks that a multi-admin for controlling the external electronic device 820 can be set, and executes the second application 840. You can run pairing mode.
  • the first application 810 may trigger the second application 840 to be executed (Operation 806).
  • the second application 840 may acquire manager authority for the external electronic device 820 or directly update manager authority for the external electronic device 820 .
  • the external electronic device 820 is first onboarded (or registered) to the server 830 through the first application 810, and second administrator rights (2nd admin) are granted to the external electronic device 820.
  • a pairing mode may be executed so that the external electronic device 820 may be onboarded (or registered) to another server.
  • the external electronic device 820 requests vendorid, productid, and/or onboarding app information (eg, information on the first application 810) from the server 830, and receives the information Based on the second application 840 can be executed.
  • FIG. 9 is a flowchart illustrating a process of granting an administrator authority to another application by an application according to an embodiment of the present disclosure.
  • the system includes an application 910, an external electronic device 920, a first server 930, and/or a second server 940.
  • the application 910 may perform the same or substantially the same function as the application 515 of FIG. 5 or the first application 640 of FIGS. 6A to 6C.
  • the application 910 may include the electronic device 101 of FIG. 1 , the electronic device 310 of FIG. 3 , the electronic device 410 of FIG. 4 , the electronic device 510 of FIG. 5 , It may be implemented by being installed in the electronic device 610 of FIGS. 6A to 6C or the electronic device 710 of FIG. 7 .
  • the external electronic device 920 is the electronic device 102 or 104 of FIG. 1, the cloud-connected devices 330 of FIG. 3, the cloud-connected devices 430 of FIG. 4, or It may be implemented as the external electronic device 720 of FIG. 7 .
  • the first server 930 includes the server 108 of FIG. 1, the cloud 320 of FIG. 3, the clouds 420, 460, and 470 of FIG. 4, the server 520 of FIG. Alternatively, it may perform the same or substantially the same function as the server 630 of FIGS. 6A to 6C.
  • the second server 940 may mean a server corresponding to the second application 650 or the third application 660 of FIGS. 6A to 6C.
  • the application 910 provides (or displays) a multi-admin additional message to the user 900 to allow a plurality of applications to have control authority over the external electronic device 920 ( Operation 901), the user 900 may display a confirmation message indicating acceptance of the multi-admin addition message on the application 910 (operation 902).
  • the external electronic device 920 when the external electronic device 920 is onboarded (or registered) to the first server 930, the external electronic device 920 may be controlled not to perform D2D connection thereafter. According to various embodiments, in order for the external electronic device 920 to be additionally onboarded (or registered) to the second server 940, the external electronic device 920 may be controlled to perform D2D connection again. According to various embodiments, in order for the external electronic device 920 to be additionally onboarded (or registered) to the second server 940, the application 910 may use a D2D connection command ( For example, an open pairing window may be transmitted to the external electronic device 920 (Operation 903).
  • a D2D connection command For example, an open pairing window may be transmitted to the external electronic device 920 (Operation 903).
  • the external electronic device 920 may change a device state so that D2D connection can be performed. According to various embodiments, upon receiving a D2D connection command (eg, open pairing window), the external electronic device 920 may switch to a pairing mode in which a D2D connection can be performed. According to various embodiments, the external electronic device 920 confirms that a multi-admin for controlling the external electronic device 920 can be set, and the external electronic device 920 determines that the second server 940 may launch pairing mode to be onboarded (or registered).
  • a D2D connection command eg, open pairing window
  • the application 910 may request Operation CSR (OpCSR) information from the external electronic device 920 (Operation 904) and receive OpCSR information from the external electronic device 920 (Operation 905).
  • the application 910 may issue an operational certificate (Op Cert) (eg, POST/cert) to the first server 930 (Operation 906).
  • Op Cert Operation CSR
  • POST/cert operational certificate
  • Operation CSR is as follows.
  • an example of an operational certificate is as follows.
  • the first server 930 may issue an operational certificate (Op Cert) (eg, POST/cert) to the second server 940 (Operation 907).
  • the second server 940 may return an operational certificate (Op Cert) to the first server 930 (Operation 908).
  • the first server 930 may return an operational certificate (Op Cert) to the application 910 (Operation 909).
  • the application 910 may set credentials with the external electronic device 920 (operation 910-1) and set access control lists (ACLs) (operation 911). ).
  • the application 910 may transmit a completion message to the external electronic device 920 (Operation 912).
  • the application 910 may directly grant administrator authority for the external electronic device 920 to other applications corresponding to the second server 940 .
  • the application 910 controls the external electronic device 920 to execute a pairing mode in order to set (or update) the second administrator authority (2nd admin) in the external electronic device 920 (or command) can.
  • the application 910 may request certificates from the first server 930 based on the vendor ID (vendorid) of the external electronic device 920 .
  • the first server 930 may request a certificate of an application mapped to a vendor ID (vendorid) of the external electronic device 920 .
  • the application 910 receives the certificate of the application mapped to the vendor ID (vendorid) of the external electronic device 920, and sets second administrator authority (2nd admin) for the external electronic device 920 (or update).
  • the external electronic device 920 in the case of an external electronic device 920 connected to a hub (eg, the hub 440 of FIG. 4 ), the user 900 through an application 910 (eg, invite a member) If the location is shared as a function), the external electronic device 920 may be controlled by directly controlling the hub. According to various embodiments, in the case of an external electronic device 920 that is not connected to a hub, the external electronic device 920 may be controlled through a corresponding application only when an application to which administrator authority is added is connected.
  • the application 910 can manage a plurality of electronic devices as one group and simultaneously control one group.
  • the application 910 may provide location information and/or the same Group ID to a plurality of electronic devices set (or invited) as a group.
  • the application 910 may share a group ID to update the administrator authority of the external electronic device 920 included in the group.
  • the application 910 transmits a group invitation message to the external electronic device 920, and when the external electronic device 920 accepts the group invitation, the application 910 receives a message from the first server 930.
  • a Group ID of the external electronic device 920 may be acquired.
  • the application 910 may transmit a pairing command to the external electronic device 920 and update the Group ID of the external electronic device 920 .
  • FIG. 10 is a diagram illustrating an example of a user interface allowing administrator authority to be added to a second application after onboarding through a first application according to an embodiment of the present disclosure.
  • an electronic device eg, the electronic device 101 of FIG. 1 , the electronic device 310 of FIG. 3 , the electronic device 410 of FIG. 4 , and the electronic device 510 of FIG. 5
  • the electronic device 610 of FIGS. 6A to 6C, the electronic device 710 of FIG. 7, the electronic device 820 of FIG. 8, or the electronic device 920 of FIG. 9 is a camera included in the electronic device.
  • the camera module 180 of FIG. 1 or the camera app 511 of FIG. 5 may recognize a QR code of an external electronic device (eg, a door open sensor).
  • the electronic device determines that a recognized external electronic device is a first application (eg, the application 515 of FIG. 5 , the first application 640 of FIGS. 6A to 6C , or the first application 640 of FIGS. Provides a user interface (e.g., "Click here to add this device to SmartThings") to be onboarded (or registered) to the server via application 810, or first application 910 in FIG. Can (1010).
  • the electronic device may provide a user interface for starting an onboarding (or registration) procedure of an external electronic device (eg, a door open sensor) (1020).
  • an electronic device may include a hub (eg, the hub 440 of FIG.
  • an external electronic device eg, a door open sensor
  • an external electronic device eg, a door open sensor
  • the electronic device may provide a user interface for setting information on a location (eg, a living room) (1030).
  • the electronic device may proceed with an onboarding (or registration) procedure of an external electronic device (eg, a door open sensor) (1040).
  • the electronic device completes onboarding (or registration) for an external electronic device (eg, a door open sensor) through a first application, and then activates an external electronic device (eg, an air purifier).
  • a second application eg, the second application 650 of FIGS. 6A to 6C , the third application 660 , the second application 840 of FIG.
  • a user interface capable of adding administrator privileges may be provided (1050).
  • the electronic device may provide a user interface for automatically or manually guiding the user to a second application capable of additional onboarding of an external electronic device (eg, an air purifier).
  • an external electronic device eg, an air purifier
  • FIG. 11 is a diagram illustrating an example of a user interface for adding a second application according to whether or not a first application is installed and app priorities after recognizing a QR in a camera according to an embodiment of the present disclosure.
  • an electronic device eg, the electronic device 101 of FIG. 1 , the electronic device 310 of FIG. 3 , the electronic device 410 of FIG. 4 , and the electronic device 510 of FIG. 5 )
  • the electronic device 610 of FIGS. 6A to 6C, the electronic device 710 of FIG. 7, the electronic device 820 of FIG. 8, or the electronic device 920 of FIG. 9 is a camera included in the electronic device.
  • the camera module 180 of FIG. 1 or the camera app 511 of FIG. 5 may recognize a QR code of an external electronic device (eg, a door open sensor).
  • the electronic device may perform a first application (eg, application 515 of FIG.
  • a user interface may be provided to onboard (or register) an external electronic device (eg, a door open sensor) through the first application 910 of FIG. 9 ( 1110 ).
  • the electronic device may provide a different user interface depending on whether the first application is installed in the electronic device (1110).
  • the electronic device onboards (or registers) an external electronic device eg, a door open sensor
  • a user interface capable of onboarding (or registering) an external electronic device eg, a door open sensor
  • the electronic device onboards (or registers) an external electronic device eg, a door open sensor
  • the electronic device onboards (or registers) an external electronic device eg, a door open sensor
  • a user interface for onboarding (or registering) eg, a door open sensor
  • FIG. 12 is a diagram for explaining an operating method of an electronic device according to an embodiment of the present disclosure.
  • an electronic device eg, the electronic device 101 of FIG. 1 , the electronic device 310 of FIG. 3 , the electronic device 410 of FIG. 4 , and the electronic device 510 of FIG. 5 )
  • the electronic device 610 of FIGS. 6A to 6C the electronic device 710 of FIG. 7, the electronic device 820 of FIG. 8, or the electronic device 920 of FIG.
  • a first application for controlling an external electronic device may be determined based on onboarding information (operation S1210).
  • the electronic device may register the external electronic device with the first server corresponding to the first application (operation S1220).
  • the electronic device may determine a second application for controlling the external electronic device independently of the first application based on the onboarding information of the external electronic device and execute the second application (operation S1230). .
  • the electronic device may register the external electronic device with the second server corresponding to the second application.
  • the electronic device may grant multi-administration authority to the second application in response to a user input so that the second application can control the external electronic device.
  • the onboarding information of the external electronic device may include a manufacturer ID (vendorid) of the external electronic device and a unique ID (productid) given to the external electronic device.
  • an electronic device may select a first application based on the onboarding information of an external electronic device, information about an operating system installed in the electronic device, and/or information about applications installed in the electronic device. can decide
  • the electronic device may receive a certificate mapped to the manufacturer ID of the external electronic device from the first server and determine the second application based on the certificate.
  • the electronic device receives priority information about applications that can be executed in the electronic device from the first server, and the onboarding information of the external electronic device and the priority information about the applications are received. Based on this, the second application may be determined. According to various embodiments, the electronic device obtains the onboarding information of the external electronic device based on a camera recognizing a QR code of the external electronic device and information based on the QR code and detection information on the external electronic device It may further include a peripheral device scanner.
  • FIG. 13 is a diagram for explaining an operating method of an electronic device according to an embodiment of the present disclosure.
  • an electronic device eg, the electronic device 101 of FIG. 1 , the electronic device 310 of FIG. 3 , the electronic device 410 of FIG. 4 , and the electronic device 510 of FIG. 5
  • the electronic device 610 of FIGS. 6A to 6C may be obtained (operation S1310).
  • the electronic device may receive priority information about applications that can be executed in the electronic device from the server (operation S1320).
  • the electronic device may determine an application for controlling the external electronic device based on the onboarding information of the external electronic device and the priority information for the application, and execute the application (S1330 movement).
  • FIG. 14 is a diagram for explaining an operating method of an electronic device according to an embodiment of the present disclosure.
  • an electronic device eg, the electronic device 101 of FIG. 1 , the electronic device 310 of FIG. 3 , the electronic device 410 of FIG. 4 , and the electronic device 510 of FIG. 5
  • the electronic device 610 of FIGS. 6A to 6C the electronic device 710 of FIG. 7, the electronic device 820 of FIG. 8, or the electronic device 920 of FIG. (onboarding) information
  • the electronic device 610 of FIGS. 6A to 6C the electronic device 710 of FIG. 7, the electronic device 820 of FIG. 8, or the electronic device 920 of FIG. (onboarding) information
  • the electronic device may check whether the first application is installed in the electronic device (Operation S1420).
  • the electronic device executes the first application, and based on the onboarding information of the external electronic device, the external electronic device independently of the first application.
  • a second application to control the electronic device may be determined (operation S1430).
  • the second application to control the external electronic device independently of the first application may be determined based on at least one of a vendor ID (vendorid) of the external electronic device and a unique ID (productid) given to the external electronic device.
  • the electronic device may transmit onboarding information of the external electronic device to the server and control the external electronic device from the server.
  • a list of existing applications may be received (operation S1440).
  • the electronic device may determine a second application to control the external electronic device based on the application list (Operation S1450).
  • an electronic device eg, the electronic device 101 of FIG. 1 , the electronic device 310 of FIG. 3 , the electronic device 410 of FIG. 4 , the electronic device 510 of FIG. 5 )
  • the electronic device 610 of FIGS. 6A to 6C, the electronic device 710 of FIG. 7, the electronic device 820 of FIG. 8, or the electronic device 920 of FIG. 9 is a communication module (eg , communication module 190 of FIG. 1) and at least one processor coupled to the communication module (eg, processor 120 of FIG. 1).
  • at least one processor may be connected to an external electronic device (eg, the electronic devices 102 and 104 of FIG. 1, the cloud-connected devices 330 of FIG.
  • a first application for controlling the device eg, the application 515 of FIG. 5, the first application 640 of FIGS. 6A to 6C, the first application 810 of FIG. 8, or the application of FIG. 9 ( 910), and sets the external electronic device to a first server corresponding to the first application (eg, the server 630 of FIGS. 6A to 6C , the server 740 of FIG. 7 , the server of FIG. 8 ( 830), and the first server 930 of FIG. 9).
  • a first server corresponding to the first application eg, the server 630 of FIGS. 6A to 6C , the server 740 of FIG. 7 , the server of FIG. 8 ( 830), and the first server 930 of FIG. 9).
  • At least one processor may use a second application (eg, the first application of FIGS. 6A to 6C ) to control the external electronic device independently of the first application based on the onboarding information of the external electronic device.
  • the second application 650 or the second application 840 of FIG. 8 may be determined and controlled to execute the second application.
  • at least one processor may control the external electronic device to be registered with the second server corresponding to the second application.
  • at least one processor may be configured to grant multi-administration authority to the second application in response to a user input so that the second application can control the external electronic device.
  • the onboarding information of the external electronic device may include a manufacturer ID (vendorid) of the external electronic device and a unique ID (productid) given to the external electronic device.
  • the at least one processor executes a first application based on onboarding information of an external electronic device, information about an operating system installed in the electronic device, and information about applications installed in the electronic device. can decide According to various embodiments, at least one processor may receive a certificate mapped to the manufacturer ID of the external electronic device from the first server, and determine a second application based on the received certificate. According to various embodiments, at least one processor receives priority information about applications that can be executed in the electronic device from the first server, and based on the onboarding information of the external electronic device and the priority information about the applications, provides priority information. 2 applications can be determined.
  • an electronic device may include a camera for recognizing a QR code of an external electronic device, and a peripheral device for obtaining onboarding information of an external electronic device based on information based on the QR code and detection information on the external electronic device. It may further include a scanner.
  • At least one processor may obtain onboarding information of an external electronic device and receive priority information about applications that may be executed in the electronic device from a server. According to various embodiments, at least one processor may determine and/or execute an application for controlling an external electronic device based on the onboarding information of the external electronic device and the priority information for the application.
  • At least one processor may obtain onboarding information of an external electronic device and determine whether a first application is installed in the electronic device. According to various embodiments, at least one processor, when the first application is installed in the electronic device, executes the first application and controls the external electronic device independently of the first application based on onboarding information of the external electronic device. A second application may be determined. According to various embodiments of the present disclosure, when the first application is not installed in the electronic device, the at least one processor receives an application list capable of controlling the external electronic device from the server, and the external electronic device is configured based on the received application list. A second application to control may be determined. According to various embodiments, at least one processor may be configured to grant multi-administration authority to the second application in response to a user input so that the second application can control the external electronic device.

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Computer Security & Cryptography (AREA)
  • Databases & Information Systems (AREA)
  • Health & Medical Sciences (AREA)
  • Computing Systems (AREA)
  • General Health & Medical Sciences (AREA)
  • Medical Informatics (AREA)
  • Telephonic Communication Services (AREA)

Abstract

본 개시의 일 실시 예에 따르면, 전자 장치는, 통신 회로 및 상기 통신 회로에 연결된 적어도 하나의 프로세서를 포함한다. 상기 적어도 하나의 프로세서는, 외부 전자 장치의 온보딩 (onboarding) 정보에 기반하여 상기 외부 전자 장치를 제어하기 위한 제 1 어플리케이션 (application)을 결정하고, 상기 외부 전자 장치를 상기 제 1 어플리케이션에 대응하는 제 1 서버에 등록하고, 상기 외부 전자 장치의 상기 온보딩 정보에 기반하여 상기 제 1 어플리케이션과 독립적으로 상기 외부 전자 장치를 제어하기 위한 제 2 어플리케이션을 결정하고, 상기 제 2 어플리케이션을 실행하도록 설정된다.

Description

외부 전자 장치를 제어하는 어플리케이션을 결정하는 전자 장치 및 그 동작 방법
본 개시는 외부 전자 장치를 제어할 수 있는 어플리케이션을 결정하는 전자 장치 및 그 동작 방법에 관한 것이다.
사물 인터넷 (IoT, Internet of Things)은 각종 사물에 센서와 통신 기능을 내장하여 인터넷에 연결하는 기술을 의미한다.
IoT는 인터넷으로 연결된 사물들이 데이터를 주고받아 스스로 분석하고 학습한 정보를 사용자에게 제공하거나 사용자가 이를 원격 조정할 수 있는 인공지능 기술이다. 사물이란 가전제품, 모바일 장비, 또는 웨어러블 디바이스 등 다양한 임베디드 시스템이 될 수 있다. IoT 에 연결되는 사물들은 자신을 구별할 수 있는 유일한 IP를 가지고 인터넷으로 연결되어야 하며, 외부 환경으로부터의 데이터 취득을 위해 센서를 내장할 수 있다.
IoT는 가정 내에서 다양한 전자 장치를 제어하기 위한 목적으로도 활용성이 높다. 사용자는 가정 내 사물 인터넷 환경에서 TV, 세탁기, 또는 에어컨 등과 같은 전자 장치들이 각각 특화된 서비스를 수행하도록 제어할 수 있으며, 이에 대한 정보를 쉽게 공유할 수 있다.
상기 정보는 본 개시의 이해를 돕기 위한 배경 정보로서 만 제공된다. 상기 내용 중 어느 것이 본 개시와 관련하여 선행 기술로 적용될 수 있는지 여부에 대해 결정된 바가 없으며 어떠한 주장도 없다.
사용자는 전자 장치를 클라우드에 연결 및 제어하기 위한 어플리케이션을 먼저 선택하고 해당 어플리케이션을 이용하여 전자 장치를 연결 및 제어할 수 있다. 사용자가 다른 제조사에서 제공하는 어플리케이션으로 해당 전자 장치를 연결 및 제어하기 위해서는 클라우드 투 클라우드 (Cloud to Cloud)로 연동하여 전자 장치를 제어할 수 있으며 클라우드 투 클라우드 (Cloud to Cloud)로 연동 하기 위해 서로 다른 제조사 클라우드 간 인터페이스 (interface)를 맞춰야 하며 별도의 인증 과정을 통해 해당 클라우드의 접근 권한을 부여 받아야 할 수 있다.
본 개시의 측면들은 적어도 위에서 언급된 문제 및/또는 단점을 해결하고 적어도 아래에 설명된 이점을 제공하는 것이다. 따라서, 본 개시의 측면은 외부 전자 장치를 클라우드에 등록할 수 있는 어플리케이션을 결정하고, 다른 제조사/플랫폼의 어플리케이션에도 외부 전자 장치를 제어할 수 있는 관리자 권한을 부여하는 전자 장치를 제공한다.
본 개시의 실시 예들은 상술한 해결 수단들로 제한되는 것은 아니며, 언급되지 아니한 해결 수단들은 본 명세서 및 첨부된 도면으로부터 본 발명이 속하는 기술분야에서 통상의 지식을 가진 자에게 명확하게 이해될 수 있을 것이다.
본 개시의 일 측면에 따라, 전자 장치는, 통신 회로 및 상기 통신 회로에 연결된 적어도 하나의 프로세서를 포함한다. 상기 적어도 하나의 프로세서는, 외부 전자 장치의 온보딩 (onboarding) 정보에 기반하여 상기 외부 전자 장치를 제어하기 위한 제 1 어플리케이션 (application)을 결정하고, 상기 외부 전자 장치를 상기 제 1 어플리케이션에 대응하는 제 1 서버에 등록하고, 상기 외부 전자 장치의 상기 온보딩 정보에 기반하여 상기 제 1 어플리케이션과 독립적으로 상기 외부 전자 장치를 제어하기 위한 제 2 어플리케이션을 결정하고, 상기 제 2 어플리케이션을 실행하도록 설정될 수 있다.
본 개시의 다른 측면에 따라, 전자 장치는, 통신 회로 및 상기 통신 회로에 연결된 적어도 하나의 프로세서를 포함한다. 상기 적어도 하나의 프로세서는, 외부 전자 장치의 온보딩 (onboarding) 정보를 획득하고, 상기 전자 장치에서 실행할 수 있는 어플리케이션 (application)에 대한 우선순위 정보를 서버로부터 수신하고, 상기 외부 전자 장치의 상기 온보딩 정보 및 상기 어플리케이션에 대한 상기 우선순위 정보에 기반하여 외부 전자 장치를 제어하기 위한 어플리케이션 (application)을 결정하고, 상기 어플리케이션을 실행하도록 설정될 수 있다.
다양한 실시 예들에 따르면, 전자 장치는 외부 전자 장치의 특성 및 우선순위에 기반하여 외부 전자 장치를 클라우드에 등록할 수 있는 어플리케이션을 효율적으로 결정할 수 있다.
다양한 실시 예들에 따르면, 전자 장치는 다른 제조사/플랫폼의 어플리케이션에도 외부 전자 장치를 제어할 수 있는 관리자 권한을 부여할 수 있다.
본 개시의 다른 측면들, 이점 및 두드러진 특징은 첨부 도면과 함께 본 발명의 다양한 실시 예들을 개시하는 다음의 상세한 설명으로부터 당업자에게 명백해질 것이다.
본 개시의 어떤 실시 예들의 상기 및 다른 측면들, 특징 및 이점은 첨부 도면과 함께 기술된 다음의 설명으로부터 더욱 명백해질 것이며, 여기서:
도 1은 본 개시의 일 실시 예에 따른 네트워크 환경 내의 전자 장치의 블록도이다;
도 2는 본 개시의 일 실시 예에 따른 프로그램을 예시하는 블록도이다;
도 3은 본 개시의 일 실시 예에 따른 IoT 환경의 일 예시를 나타내는 도면이다;
도 4는 본 개시의 일 실시 예에 따른 IoT 환경의 다른 예시를 나타내는 도면이다;
도 5는 본 개시의 일 실시 예에 따른 IoT 환경의 또 다른 예시를 나타내는 도면이다;
도 6a, 6b, 및 도 6c는 본 개시의 실시 예들에 따른 전자 장치의 동작을 설명하기 위한 흐름도이다;
도 7은 본 개시의 일 실시 예에 따른 전자 장치 및 서버의 동작을 설명하기 위한 도면이다;
도 8은 본 개시의 일 실시 예에 따른 제 1 어플리케이션에서 제 2 어플리케이션의 실행을 트리거하고, 제 2 어플리케이션에서 관리자 권한을 업데이트하는 과정을 설명하기 위한 흐름도이다;
도 9는 본 개시의 일 실시 예에 따른 제 1 어플리케이션이 제 2 어플리케이션에 대한 관리자 권한을 부여하는 과정을 설명하기 위한 흐름도이다;
도 10은 본 개시의 일 실시 예에 따른 제 1 어플리케이션을 통한 온보딩 후 제 2 어플리케이션에 관리자 권한을 추가할 수 있도록 하는 사용자 인터페이스의 예시를 나타내는 도면이다;
도 11은 본 개시의 일 실시 예에 따른 카메라에서 QR 인식 후 제 1 어플리케이션의 설치 유무 및 앱 우선순위에 따라 제 2 어플리케이션을 추가하는 사용자 인터페이스의 예시를 나타내는 도면이다;
도 12는 본 개시의 일 실시 예에 따른 전자 장치의 동작 방법을 설명하기 위한 도면이다;
도 13은 본 개시의 일 실시 예에 따른 전자 장치의 동작 방법을 설명하기 위한 도면이다;
도 14는 본 개시의 일 실시 예에 따른 전자 장치의 동작 방법을 설명하기 위한 도면이다.
도면 전체에 걸쳐, 동일한 참조 번호는 동일하거나 유사한 요소, 특징 및 구조를 묘사하는 데 사용된다는 점에 유의해야 한다.
도 1은 본 개시의 일 실시예에 따른 네트워크 환경 내의 전자 장치의 블록도이다.
도 1을 참조하면, 네트워크 환경(100)에서 전자 장치(101)는 제 1 네트워크(198)(예: 근거리 무선 통신 네트워크)를 통하여 전자 장치(102)와 통신하거나, 또는 제 2 네트워크(199)(예: 원거리 무선 통신 네트워크)를 통하여 전자 장치(104) 또는 서버(108) 중 적어도 하나와 통신할 수 있다. 일실시예에 따르면, 전자 장치(101)는 서버(108)를 통하여 전자 장치(104)와 통신할 수 있다. 일실시예에 따르면, 전자 장치(101)는 프로세서(120), 메모리(130), 입력 모듈(150), 음향 출력 모듈(155), 디스플레이 모듈(160), 오디오 모듈(170), 센서 모듈(176), 인터페이스(177), 연결 단자(178), 햅틱 모듈(179), 카메라 모듈(180), 전력 관리 모듈(188), 배터리(189), 통신 모듈(190), 가입자 식별 모듈(196), 또는 안테나 모듈(197)을 포함할 수 있다. 어떤 실시예에서는, 전자 장치(101)에는, 이 구성요소들 중 적어도 하나(예: 연결 단자(178))가 생략되거나, 하나 이상의 다른 구성요소가 추가될 수 있다. 어떤 실시예에서는, 이 구성요소들 중 일부들(예: 센서 모듈(176), 카메라 모듈(180), 또는 안테나 모듈(197))은 하나의 구성요소(예: 디스플레이 모듈(160))로 통합될 수 있다.
프로세서(120)는, 예를 들면, 소프트웨어(예: 프로그램(140))를 실행하여 프로세서(120)에 연결된 전자 장치(101)의 적어도 하나의 다른 구성요소(예: 하드웨어 또는 소프트웨어 구성요소)를 제어할 수 있고, 다양한 데이터 처리 또는 연산을 수행할 수 있다. 일실시예에 따르면, 데이터 처리 또는 연산의 적어도 일부로서, 프로세서(120)는 다른 구성요소(예: 센서 모듈(176) 또는 통신 모듈(190))로부터 수신된 명령 또는 데이터를 휘발성 메모리(132)에 저장하고, 휘발성 메모리(132)에 저장된 명령 또는 데이터를 처리하고, 결과 데이터를 비휘발성 메모리(134)에 저장할 수 있다. 일실시예에 따르면, 프로세서(120)는 메인 프로세서(121)(예: 중앙 처리 장치 또는 어플리케이션 프로세서) 또는 이와는 독립적으로 또는 함께 운영 가능한 보조 프로세서(123)(예: 그래픽 처리 장치, 신경망 처리 장치(NPU: neural processing unit), 이미지 시그널 프로세서, 센서 허브 프로세서, 또는 커뮤니케이션 프로세서)를 포함할 수 있다. 예를 들어, 전자 장치(101)가 메인 프로세서(121) 및 보조 프로세서(123)를 포함하는 경우, 보조 프로세서(123)는 메인 프로세서(121)보다 저전력을 사용하거나, 지정된 기능에 특화되도록 설정될 수 있다. 보조 프로세서(123)는 메인 프로세서(121)와 별개로, 또는 그 일부로서 구현될 수 있다.
보조 프로세서(123)는, 예를 들면, 메인 프로세서(121)가 인액티브(예: 슬립) 상태에 있는 동안 메인 프로세서(121)를 대신하여, 또는 메인 프로세서(121)가 액티브(예: 어플리케이션 실행) 상태에 있는 동안 메인 프로세서(121)와 함께, 전자 장치(101)의 구성요소들 중 적어도 하나의 구성요소(예: 디스플레이 모듈(160), 센서 모듈(176), 또는 통신 모듈(190))와 관련된 기능 또는 상태들의 적어도 일부를 제어할 수 있다. 일실시예에 따르면, 보조 프로세서(123)(예: 이미지 시그널 프로세서 또는 커뮤니케이션 프로세서)는 기능적으로 관련 있는 다른 구성요소(예: 카메라 모듈(180) 또는 통신 모듈(190))의 일부로서 구현될 수 있다. 일실시예에 따르면, 보조 프로세서(123)(예: 신경망 처리 장치)는 인공지능 모델의 처리에 특화된 하드웨어 구조를 포함할 수 있다. 인공지능 모델은 기계 학습을 통해 생성될 수 있다. 이러한 학습은, 예를 들어, 인공지능 모델이 수행되는 전자 장치(101) 자체에서 수행될 수 있고, 별도의 서버(예: 서버(108))를 통해 수행될 수도 있다. 학습 알고리즘은, 예를 들어, 지도형 학습(supervised learning), 비지도형 학습(unsupervised learning), 준지도형 학습(semi-supervised learning) 또는 강화 학습(reinforcement learning)을 포함할 수 있으나, 전술한 예에 한정되지 않는다. 인공지능 모델은, 복수의 인공 신경망 레이어들을 포함할 수 있다. 인공 신경망은 심층 신경망(DNN: deep neural network), CNN(convolutional neural network), RNN(recurrent neural network), RBM(restricted boltzmann machine), DBN(deep belief network), BRDNN(bidirectional recurrent deep neural network), 심층 Q-네트워크(deep Q-networks) 또는 상기 중 둘 이상의 조합 중 하나일 수 있으나, 전술한 예에 한정되지 않는다. 인공지능 모델은 하드웨어 구조 이외에, 추가적으로 또는 대체적으로, 소프트웨어 구조를 포함할 수 있다.
메모리(130)는, 전자 장치(101)의 적어도 하나의 구성요소(예: 프로세서(120) 또는 센서 모듈(176))에 의해 사용되는 다양한 데이터를 저장할 수 있다. 데이터는, 예를 들어, 소프트웨어(예: 프로그램(140)) 및, 이와 관련된 명령에 대한 입력 데이터 또는 출력 데이터를 포함할 수 있다. 메모리(130)는, 휘발성 메모리(132) 또는 비휘발성 메모리(134)를 포함할 수 있다.
프로그램(140)은 메모리(130)에 소프트웨어로서 저장될 수 있으며, 예를 들면, 운영 체제(142), 미들 웨어(144) 또는 어플리케이션(146)을 포함할 수 있다.
입력 모듈(150)은, 전자 장치(101)의 구성요소(예: 프로세서(120))에 사용될 명령 또는 데이터를 전자 장치(101)의 외부(예: 사용자)로부터 수신할 수 있다. 입력 모듈(150)은, 예를 들면, 마이크, 마우스, 키보드, 키(예: 버튼), 또는 디지털 펜(예: 스타일러스 펜)을 포함할 수 있다.
음향 출력 모듈(155)은 음향 신호를 전자 장치(101)의 외부로 출력할 수 있다. 음향 출력 모듈(155)은, 예를 들면, 스피커 또는 리시버를 포함할 수 있다. 스피커는 멀티미디어 재생 또는 녹음 재생과 같이 일반적인 용도로 사용될 수 있다. 리시버는 착신 전화를 수신하기 위해 사용될 수 있다. 일실시예에 따르면, 리시버는 스피커와 별개로, 또는 그 일부로서 구현될 수 있다.
디스플레이 모듈(160)은 전자 장치(101)의 외부(예: 사용자)로 정보를 시각적으로 제공할 수 있다. 디스플레이 모듈(160)은, 예를 들면, 디스플레이, 홀로그램 장치, 또는 프로젝터 및 해당 장치를 제어하기 위한 제어 회로를 포함할 수 있다. 일실시예에 따르면, 디스플레이 모듈(160)은 터치를 감지하도록 설정된 터치 센서, 또는 상기 터치에 의해 발생되는 힘의 세기를 측정하도록 설정된 압력 센서를 포함할 수 있다.
오디오 모듈(170)은 소리를 전기 신호로 변환시키거나, 반대로 전기 신호를 소리로 변환시킬 수 있다. 일실시예에 따르면, 오디오 모듈(170)은, 입력 모듈(150)을 통해 소리를 획득하거나, 음향 출력 모듈(155), 또는 전자 장치(101)와 직접 또는 무선으로 연결된 외부 전자 장치(예: 전자 장치(102))(예: 스피커 또는 헤드폰)를 통해 소리를 출력할 수 있다.
센서 모듈(176)은 전자 장치(101)의 작동 상태(예: 전력 또는 온도), 또는 외부의 환경 상태(예: 사용자 상태)를 감지하고, 감지된 상태에 대응하는 전기 신호 또는 데이터 값을 생성할 수 있다. 일실시예에 따르면, 센서 모듈(176)은, 예를 들면, 제스처 센서, 자이로 센서, 기압 센서, 마그네틱 센서, 가속도 센서, 그립 센서, 근접 센서, 컬러 센서, IR(infrared) 센서, 생체 센서, 온도 센서, 습도 센서, 또는 조도 센서를 포함할 수 있다.
인터페이스(177)는 전자 장치(101)가 외부 전자 장치(예: 전자 장치(102))와 직접 또는 무선으로 연결되기 위해 사용될 수 있는 하나 이상의 지정된 프로토콜들을 지원할 수 있다. 일실시예에 따르면, 인터페이스(177)는, 예를 들면, HDMI(high definition multimedia interface), USB(universal serial bus) 인터페이스, SD카드 인터페이스, 또는 오디오 인터페이스를 포함할 수 있다.
연결 단자(178)는, 그를 통해서 전자 장치(101)가 외부 전자 장치(예: 전자 장치(102))와 물리적으로 연결될 수 있는 커넥터를 포함할 수 있다. 일실시예에 따르면, 연결 단자(178)는, 예를 들면, HDMI 커넥터, USB 커넥터, SD 카드 커넥터, 또는 오디오 커넥터(예: 헤드폰 커넥터)를 포함할 수 있다.
햅틱 모듈(179)은 전기적 신호를 사용자가 촉각 또는 운동 감각을 통해서 인지할 수 있는 기계적인 자극(예: 진동 또는 움직임) 또는 전기적인 자극으로 변환할 수 있다. 일실시예에 따르면, 햅틱 모듈(179)은, 예를 들면, 모터, 압전 소자, 또는 전기 자극 장치를 포함할 수 있다.
카메라 모듈(180)은 정지 영상 및 동영상을 촬영할 수 있다. 일실시예에 따르면, 카메라 모듈(180)은 하나 이상의 렌즈들, 이미지 센서들, 이미지 시그널 프로세서들, 또는 플래시들을 포함할 수 있다.
전력 관리 모듈(188)은 전자 장치(101)에 공급되는 전력을 관리할 수 있다. 일실시예에 따르면, 전력 관리 모듈(188)은, 예를 들면, PMIC(power management integrated circuit)의 적어도 일부로서 구현될 수 있다.
배터리(189)는 전자 장치(101)의 적어도 하나의 구성요소에 전력을 공급할 수 있다. 일실시예에 따르면, 배터리(189)는, 예를 들면, 재충전 불가능한 1차 전지, 재충전 가능한 2차 전지 또는 연료 전지를 포함할 수 있다.
통신 모듈(190)은 전자 장치(101)와 외부 전자 장치(예: 전자 장치(102), 전자 장치(104), 또는 서버(108)) 간의 직접(예: 유선) 통신 채널 또는 무선 통신 채널의 수립, 및 수립된 통신 채널을 통한 통신 수행을 지원할 수 있다. 통신 모듈(190)은 프로세서(120)(예: 어플리케이션 프로세서)와 독립적으로 운영되고, 직접(예: 유선) 통신 또는 무선 통신을 지원하는 하나 이상의 커뮤니케이션 프로세서를 포함할 수 있다. 일실시예에 따르면, 통신 모듈(190)은 무선 통신 모듈(192)(예: 셀룰러 통신 모듈, 근거리 무선 통신 모듈, 또는 GNSS(global navigation satellite system) 통신 모듈) 또는 유선 통신 모듈(194)(예: LAN(local area network) 통신 모듈, 또는 전력선 통신 모듈)을 포함할 수 있다. 이들 통신 모듈 중 해당하는 통신 모듈은 제 1 네트워크(198)(예: 블루투스TM, Wi-Fi(wireless fidelity) direct 또는 IrDA(infrared data association)와 같은 근거리 통신 네트워크) 또는 제 2 네트워크(199)(예: 레거시 셀룰러 네트워크, 5G 네트워크, 차세대 통신 네트워크, 인터넷, 또는 컴퓨터 네트워크(예: LAN 또는 WAN)와 같은 원거리 통신 네트워크)를 통하여 외부의 전자 장치(104)와 통신할 수 있다. 이런 여러 종류의 통신 모듈들은 하나의 구성요소(예: 단일 칩)로 통합되거나, 또는 서로 별도의 복수의 구성요소들(예: 복수 칩들)로 구현될 수 있다. 무선 통신 모듈(192)은 가입자 식별 모듈(196)에 저장된 가입자 정보(예: 국제 모바일 가입자 식별자(IMSI))를 이용하여 제 1 네트워크(198) 또는 제 2 네트워크(199)와 같은 통신 네트워크 내에서 전자 장치(101)를 확인 또는 인증할 수 있다.
무선 통신 모듈(192)은 4G 네트워크 이후의 5G 네트워크 및 차세대 통신 기술, 예를 들어, NR 접속 기술(new radio access technology)을 지원할 수 있다. NR 접속 기술은 고용량 데이터의 고속 전송(eMBB(enhanced mobile broadband)), 단말 전력 최소화와 다수 단말의 접속(mMTC(massive machine type communications)), 또는 고신뢰도와 저지연(URLLC(ultra-reliable and low-latency communications))을 지원할 수 있다. 무선 통신 모듈(192)은, 예를 들어, 높은 데이터 전송률 달성을 위해, 고주파 대역(예: mmWave 대역)을 지원할 수 있다. 무선 통신 모듈(192)은 고주파 대역에서의 성능 확보를 위한 다양한 기술들, 예를 들어, 빔포밍(beamforming), 거대 배열 다중 입출력(massive MIMO(multiple-input and multiple-output)), 전차원 다중입출력(FD-MIMO: full dimensional MIMO), 어레이 안테나(array antenna), 아날로그 빔형성(analog beam-forming), 또는 대규모 안테나(large scale antenna)와 같은 기술들을 지원할 수 있다. 무선 통신 모듈(192)은 전자 장치(101), 외부 전자 장치(예: 전자 장치(104)) 또는 네트워크 시스템(예: 제 2 네트워크(199))에 규정되는 다양한 요구사항을 지원할 수 있다. 일실시예에 따르면, 무선 통신 모듈(192)은 eMBB 실현을 위한 Peak data rate(예: 20Gbps 이상), mMTC 실현을 위한 손실 Coverage(예: 164dB 이하), 또는 URLLC 실현을 위한 U-plane latency(예: 다운링크(DL) 및 업링크(UL) 각각 0.5ms 이하, 또는 라운드 트립 1ms 이하)를 지원할 수 있다.
안테나 모듈(197)은 신호 또는 전력을 외부(예: 외부의 전자 장치)로 송신하거나 외부로부터 수신할 수 있다. 일실시예에 따르면, 안테나 모듈(197)은 서브스트레이트(예: PCB) 위에 형성된 도전체 또는 도전성 패턴으로 이루어진 방사체를 포함하는 안테나를 포함할 수 있다. 일실시예에 따르면, 안테나 모듈(197)은 복수의 안테나들(예: 어레이 안테나)을 포함할 수 있다. 이런 경우, 제 1 네트워크(198) 또는 제 2 네트워크(199)와 같은 통신 네트워크에서 사용되는 통신 방식에 적합한 적어도 하나의 안테나가, 예를 들면, 통신 모듈(190)에 의하여 상기 복수의 안테나들로부터 선택될 수 있다. 신호 또는 전력은 상기 선택된 적어도 하나의 안테나를 통하여 통신 모듈(190)과 외부의 전자 장치 간에 송신되거나 수신될 수 있다. 어떤 실시예에 따르면, 방사체 이외에 다른 부품(예: RFIC(radio frequency integrated circuit))이 추가로 안테나 모듈(197)의 일부로 형성될 수 있다.
다양한 실시예에 따르면, 안테나 모듈(197)은 mmWave 안테나 모듈을 형성할 수 있다. 일실시예에 따르면, mmWave 안테나 모듈은 인쇄 회로 기판, 상기 인쇄 회로 기판의 제 1 면(예: 아래 면)에 또는 그에 인접하여 배치되고 지정된 고주파 대역(예: mmWave 대역)을 지원할 수 있는 RFIC, 및 상기 인쇄 회로 기판의 제 2 면(예: 윗 면 또는 측 면)에 또는 그에 인접하여 배치되고 상기 지정된 고주파 대역의 신호를 송신 또는 수신할 수 있는 복수의 안테나들(예: 어레이 안테나)을 포함할 수 있다.
상기 구성요소들 중 적어도 일부는 주변 기기들간 통신 방식(예: 버스, GPIO(general purpose input and output), SPI(serial peripheral interface), 또는 MIPI(mobile industry processor interface))을 통해 서로 연결되고 신호(예: 명령 또는 데이터)를 상호간에 교환할 수 있다.
일실시예에 따르면, 명령 또는 데이터는 제 2 네트워크(199)에 연결된 서버(108)를 통해서 전자 장치(101)와 외부의 전자 장치(104)간에 송신 또는 수신될 수 있다. 외부의 전자 장치(102, 또는 104) 각각은 전자 장치(101)와 동일한 또는 다른 종류의 장치일 수 있다. 일실시예에 따르면, 전자 장치(101)에서 실행되는 동작들의 전부 또는 일부는 외부의 전자 장치들(102, 104, 또는 108) 중 하나 이상의 외부의 전자 장치들에서 실행될 수 있다. 예를 들면, 전자 장치(101)가 어떤 기능이나 서비스를 자동으로, 또는 사용자 또는 다른 장치로부터의 요청에 반응하여 수행해야 할 경우에, 전자 장치(101)는 기능 또는 서비스를 자체적으로 실행시키는 대신에 또는 추가적으로, 하나 이상의 외부의 전자 장치들에게 그 기능 또는 그 서비스의 적어도 일부를 수행하라고 요청할 수 있다. 상기 요청을 수신한 하나 이상의 외부의 전자 장치들은 요청된 기능 또는 서비스의 적어도 일부, 또는 상기 요청과 관련된 추가 기능 또는 서비스를 실행하고, 그 실행의 결과를 전자 장치(101)로 전달할 수 있다. 전자 장치(101)는 상기 결과를, 그대로 또는 추가적으로 처리하여, 상기 요청에 대한 응답의 적어도 일부로서 제공할 수 있다. 이를 위하여, 예를 들면, 클라우드 컴퓨팅, 분산 컴퓨팅, 모바일 에지 컴퓨팅(MEC: mobile edge computing), 또는 클라이언트-서버 컴퓨팅 기술이 이용될 수 있다. 전자 장치(101)는, 예를 들어, 분산 컴퓨팅 또는 모바일 에지 컴퓨팅을 이용하여 초저지연 서비스를 제공할 수 있다. 다른 실시예에 있어서, 외부의 전자 장치(104)는 IoT(internet of things) 기기를 포함할 수 있다. 서버(108)는 기계 학습 및/또는 신경망을 이용한 지능형 서버일 수 있다. 일실시예에 따르면, 외부의 전자 장치(104) 또는 서버(108)는 제 2 네트워크(199) 내에 포함될 수 있다. 전자 장치(101)는 5G 통신 기술 및 IoT 관련 기술을 기반으로 지능형 서비스(예: 스마트 홈, 스마트 시티, 스마트 카, 또는 헬스 케어)에 적용될 수 있다.
본 문서에 개시된 다양한 실시예들에 따른 전자 장치는 다양한 형태의 장치가 될 수 있다. 전자 장치는, 예를 들면, 휴대용 통신 장치(예: 스마트폰), 컴퓨터 장치, 휴대용 멀티미디어 장치, 휴대용 의료 기기, 카메라, 웨어러블 장치, 또는 가전 장치를 포함할 수 있다. 본 문서의 실시예에 따른 전자 장치는 전술한 기기들에 한정되지 않는다.
본 문서의 다양한 실시예들 및 이에 사용된 용어들은 본 문서에 기재된 기술적 특징들을 특정한 실시예들로 한정하려는 것이 아니며, 해당 실시예의 다양한 변경, 균등물, 또는 대체물을 포함하는 것으로 이해되어야 한다. 도면의 설명과 관련하여, 유사한 또는 관련된 구성요소에 대해서는 유사한 참조 부호가 사용될 수 있다. 아이템에 대응하는 명사의 단수 형은 관련된 문맥상 명백하게 다르게 지시하지 않는 한, 상기 아이템 한 개 또는 복수 개를 포함할 수 있다. 본 문서에서, "A 또는 B", "A 및 B 중 적어도 하나", "A 또는 B 중 적어도 하나", "A, B 또는 C", "A, B 및 C 중 적어도 하나", 및 "A, B, 또는 C 중 적어도 하나"와 같은 문구들 각각은 그 문구들 중 해당하는 문구에 함께 나열된 항목들 중 어느 하나, 또는 그들의 모든 가능한 조합을 포함할 수 있다. "제 1", "제 2", 또는 "첫째" 또는 "둘째"와 같은 용어들은 단순히 해당 구성요소를 다른 해당 구성요소와 구분하기 위해 사용될 수 있으며, 해당 구성요소들을 다른 측면(예: 중요성 또는 순서)에서 한정하지 않는다. 어떤(예: 제 1) 구성요소가 다른(예: 제 2) 구성요소에, "기능적으로" 또는 "통신적으로"라는 용어와 함께 또는 이런 용어 없이, "커플드" 또는 "커넥티드"라고 언급된 경우, 그것은 상기 어떤 구성요소가 상기 다른 구성요소에 직접적으로(예: 유선으로), 무선으로, 또는 제 3 구성요소를 통하여 연결될 수 있다는 것을 의미한다.
본 문서의 다양한 실시예들에서 사용된 용어 "모듈"은 하드웨어, 소프트웨어 또는 펌웨어로 구현된 유닛을 포함할 수 있으며, 예를 들면, 로직, 논리 블록, 부품, 또는 회로와 같은 용어와 상호 호환적으로 사용될 수 있다. 모듈은, 일체로 구성된 부품 또는 하나 또는 그 이상의 기능을 수행하는, 상기 부품의 최소 단위 또는 그 일부가 될 수 있다. 예를 들면, 일실시예에 따르면, 모듈은 ASIC(application-specific integrated circuit)의 형태로 구현될 수 있다.
본 문서의 다양한 실시예들은 기기(machine)(예: 전자 장치(101)) 의해 읽을 수 있는 저장 매체(storage medium)(예: 내장 메모리(136) 또는 외장 메모리(138))에 저장된 하나 이상의 명령어들을 포함하는 소프트웨어(예: 프로그램(140))로서 구현될 수 있다. 예를 들면, 기기(예: 전자 장치(101))의 프로세서(예: 프로세서(120))는, 저장 매체로부터 저장된 하나 이상의 명령어들 중 적어도 하나의 명령을 호출하고, 그것을 실행할 수 있다. 이것은 기기가 상기 호출된 적어도 하나의 명령어에 따라 적어도 하나의 기능을 수행하도록 운영되는 것을 가능하게 한다. 상기 하나 이상의 명령어들은 컴파일러에 의해 생성된 코드 또는 인터프리터에 의해 실행될 수 있는 코드를 포함할 수 있다. 기기로 읽을 수 있는 저장 매체는, 비일시적(non-transitory) 저장 매체의 형태로 제공될 수 있다. 여기서, '비일시적'은 저장 매체가 실재(tangible)하는 장치이고, 신호(signal)(예: 전자기파)를 포함하지 않는다는 것을 의미할 뿐이며, 이 용어는 데이터가 저장 매체에 반영구적으로 저장되는 경우와 임시적으로 저장되는 경우를 구분하지 않는다.
일실시예에 따르면, 본 문서에 개시된 다양한 실시예들에 따른 방법은 컴퓨터 프로그램 제품(computer program product)에 포함되어 제공될 수 있다. 컴퓨터 프로그램 제품은 상품으로서 판매자 및 구매자 간에 거래될 수 있다. 컴퓨터 프로그램 제품은 기기로 읽을 수 있는 저장 매체(예: compact disc read only memory(CD-ROM))의 형태로 배포되거나, 또는 어플리케이션 스토어(예: 플레이 스토어TM)를 통해 또는 두 개의 사용자 장치들(예: 스마트 폰들) 간에 직접, 온라인으로 배포(예: 다운로드 또는 업로드)될 수 있다. 온라인 배포의 경우에, 컴퓨터 프로그램 제품의 적어도 일부는 제조사의 서버, 어플리케이션 스토어의 서버, 또는 중계 서버의 메모리와 같은 기기로 읽을 수 있는 저장 매체에 적어도 일시 저장되거나, 임시적으로 생성될 수 있다.
다양한 실시예들에 따르면, 상기 기술한 구성요소들의 각각의 구성요소(예: 모듈 또는 프로그램)는 단수 또는 복수의 개체를 포함할 수 있으며, 복수의 개체 중 일부는 다른 구성요소에 분리 배치될 수도 있다. 다양한 실시예들에 따르면, 전술한 해당 구성요소들 중 하나 이상의 구성요소들 또는 동작들이 생략되거나, 또는 하나 이상의 다른 구성요소들 또는 동작들이 추가될 수 있다. 대체적으로 또는 추가적으로, 복수의 구성요소들(예: 모듈 또는 프로그램)은 하나의 구성요소로 통합될 수 있다. 이런 경우, 통합된 구성요소는 상기 복수의 구성요소들 각각의 구성요소의 하나 이상의 기능들을 상기 통합 이전에 상기 복수의 구성요소들 중 해당 구성요소에 의해 수행되는 것과 동일 또는 유사하게 수행할 수 있다. 다양한 실시예들에 따르면, 모듈, 프로그램 또는 다른 구성요소에 의해 수행되는 동작들은 순차적으로, 병렬적으로, 반복적으로, 또는 휴리스틱하게 실행되거나, 상기 동작들 중 하나 이상이 다른 순서로 실행되거나, 생략되거나, 또는 하나 이상의 다른 동작들이 추가될 수 있다.
도 2은 본 개시의 일 실시예에 따른 프로그램을 예시하는 블록도이다.
도 2를 참조하면, 프로그램(140)은 전자 장치(101)의 하나 이상의 리소스들을 제어하기 위한 운영 체제(OS)(142), 미들웨어(144), 또는 상기 운영 체제(142)에서 실행 가능한 어플리케이션(146)을 포함할 수 있다. 운영 체제(142)는, 예를 들면, AndroidTM, iOSTM, WindowsTM, SymbianTM, TizenTM, 또는 BadaTM를 포함할 수 있다. 프로그램(140) 중 적어도 일부 프로그램은, 예를 들면, 제조 시에 전자 장치(101)에 프리로드되거나, 또는 사용자에 의해 사용 시 외부 전자 장치(예: 전자 장치(102 또는 104), 또는 서버(108))로부터 다운로드되거나 갱신 될 수 있다.
운영 체제(142)는 전자 장치(101)의 하나 이상의 시스템 리소스들(예: 프로세스, 메모리, 또는 전원)의 관리(예: 할당 또는 회수)를 제어할 수 있다. 운영 체제(142)는, 추가적으로 또는 대체적으로, 전자 장치(101)의 다른 하드웨어 디바이스, 예를 들면, 입력 모듈(150), 음향 출력 모듈(155), 디스플레이 모듈(160), 오디오 모듈(170), 센서 모듈(176), 인터페이스(177), 햅틱 모듈(179), 카메라 모듈(180), 전력 관리 모듈(188), 배터리(189), 통신 모듈(190), 가입자 식별 모듈(196), 또는 안테나 모듈(197)을 구동하기 위한 하나 이상의 드라이버 프로그램들을 포함할 수 있다.
미들웨어(144)는 전자 장치(101)의 하나 이상의 리소스들로부터 제공되는 기능 또는 정보가 어플리케이션(146)에 의해 사용될 수 있도록 다양한 기능들을 어플리케이션(146)으로 제공할 수 있다. 미들웨어(144)는, 예를 들면, 어플리케이션 매니저(201), 윈도우 매니저(203), 멀티미디어 매니저(205), 리소스 매니저(207), 파워 매니저(209), 데이터베이스 매니저(211), 패키지 매니저(213), 커넥티비티 매니저(215), 노티피케이션 매니저(217), 로케이션 매니저(219), 그래픽 매니저(221), 시큐리티 매니저(223), 통화 매니저(225), 또는 음성 인식 매니저(227)를 포함할 수 있다.
어플리케이션 매니저(201)는, 예를 들면, 어플리케이션(146)의 생명 주기를 관리할 수 있다. 윈도우 매니저(203)는, 예를 들면, 화면에서 사용되는 하나 이상의 GUI 자원들을 관리할 수 있다. 멀티미디어 매니저(205)는, 예를 들면, 미디어 파일들의 재생에 필요한 하나 이상의 포맷들을 파악하고, 그 중 선택된 해당하는 포맷에 맞는 코덱을 이용하여 상기 미디어 파일들 중 해당하는 미디어 파일의 인코딩 또는 디코딩을 수행할 수 있다. 리소스 매니저(207)는, 예를 들면, 어플리케이션(146)의 소스 코드 또는 메모리(130)의 메모리의 공간을 관리할 수 있다. 파워 매니저(209)는, 예를 들면, 배터리(189)의 용량, 온도 또는 전원을 관리하고, 이 중 해당 정보를 이용하여 전자 장치(101)의 동작에 필요한 관련 정보를 결정 또는 제공할 수 있다. 일실시예에 따르면, 파워 매니저(209)는 전자 장치(101)의 바이오스(BIOS: basic input/output system)(미도시)와 연동할 수 있다.
데이터베이스 매니저(211)는, 예를 들면, 어플리케이션(146)에 의해 사용될 데이터베이스를 생성, 검색, 또는 변경할 수 있다. 패키지 매니저(213)는, 예를 들면, 패키지 파일의 형태로 배포되는 어플리케이션의 설치 또는 갱신을 관리할 수 있다. 커넥티비티 매니저(215)는, 예를 들면, 전자 장치(101)와 외부 전자 장치 간의 무선 연결 또는 직접 연결을 관리할 수 있다. 노티피케이션 매니저(217)는, 예를 들면, 지정된 이벤트(예: 착신 통화, 메시지, 또는 알람)의 발생을 사용자에게 알리기 위한 기능을 제공할 수 있다. 로케이션 매니저(219)는, 예를 들면, 전자 장치(101)의 위치 정보를 관리할 수 있다. 그래픽 매니저(221)는, 예를 들면, 사용자에게 제공될 하나 이상의 그래픽 효과들 또는 이와 관련된 사용자 인터페이스를 관리할 수 있다.
시큐리티 매니저(223)는, 예를 들면, 시스템 보안 또는 사용자 인증을 제공할 수 있다. 통화(telephony) 매니저(225)는, 예를 들면, 전자 장치(101)에 의해 제공되는 음성 통화 기능 또는 영상 통화 기능을 관리할 수 있다. 음성 인식 매니저(227)는, 예를 들면, 사용자의 음성 데이터를 서버(108)로 전송하고, 그 음성 데이터에 적어도 일부 기반하여 전자 장치(101)에서 수행될 기능에 대응하는 명령어(command), 또는 그 음성 데이터에 적어도 일부 기반하여 변환된 문자 데이터를 서버(108)로부터 수신할 수 있다. 일 실시예에 따르면, 미들웨어(244)는 동적으로 기존의 구성요소를 일부 삭제하거나 새로운 구성요소들을 추가할 수 있다. 일 실시예에 따르면, 미들웨어(144)의 적어도 일부는 운영 체제(142)의 일부로 포함되거나, 또는 운영 체제(142)와는 다른 별도의 소프트웨어로 구현될 수 있다.
어플리케이션(146)은, 예를 들면, 홈(251), 다이얼러(253), SMS/MMS(255), IM(instant message)(257), 브라우저(259), 카메라(261), 알람(263), 컨택트(265), 음성 인식(267), 이메일(269), 달력(271), 미디어 플레이어(273), 앨범(275), 와치(277), 헬스(279)(예: 운동량 또는 혈당과 같은 생체 정보를 측정), 또는 환경 정보(281)(예: 기압, 습도, 또는 온도 정보 측정) 어플리케이션을 포함할 수 있다. 일실시예에 따르면, 어플리케이션(146)은 전자 장치(101)와 외부 전자 장치 사이의 정보 교환을 지원할 수 있는 정보 교환 어플리케이션(미도시)을 더 포함할 수 있다. 정보 교환 어플리케이션은, 예를 들면, 외부 전자 장치로 지정된 정보 (예: 통화, 메시지, 또는 알람)를 전달하도록 설정된 노티피케이션 릴레이 어플리케이션, 또는 외부 전자 장치를 관리하도록 설정된 장치 관리 어플리케이션을 포함할 수 있다. 노티피케이션 릴레이 어플리케이션은, 예를 들면, 전자 장치(101)의 다른 어플리케이션(예: 이메일 어플리케이션(269))에서 발생된 지정된 이벤트(예: 메일 수신)에 대응하는 알림 정보를 외부 전자 장치로 전달할 수 있다. 추가적으로 또는 대체적으로, 노티피케이션 릴레이 어플리케이션은 외부 전자 장치로부터 알림 정보를 수신하여 전자 장치(101)의 사용자에게 제공할 수 있다.
장치 관리 어플리케이션은, 예를 들면, 전자 장치(101)와 통신하는 외부 전자 장치 또는 그 일부 구성 요소(예: 외부 전자장치의 디스플레이 모듈 또는 카메라 모듈)의 전원(예: 턴-온 또는 턴-오프) 또는 기능(예: 밝기, 해상도, 또는 포커스)을 제어할 수 있다. 장치 관리 어플리케이션은, 추가적으로 또는 대체적으로, 외부 전자 장치에서 동작하는 어플리케이션의 설치, 삭제, 또는 갱신을 지원할 수 있다.
도 3은 본 개시의 일 실시 예에 따른 IoT 환경의 일 예시를 나타내는 도면이다.
도 3을 참조하면, 상기 IoT 환경 (300)은 전자 장치 (310), 클라우드 (320), 및 클라우드-연결 장치들 (330)을 포함할 수 있다. 다양한 실시 예들에 따라, 상기 IoT 환경 (300)은 가전제품과 같은 상기 클라우드-연결 장치들 (330)을 다양한 종류의 통신 네트워크로 연결하고 상기 클라우드 (320) 및 로컬 서버에서 중계 및 제어하는 방식의 플랫폼을 의미할 수 있다. 다양한 실시 예들에 따라, 상기 IoT 환경 (300)은 블루투스 (bluetooth; BT), 블루투스 저에너지 (bluetooth low energy; BLE), WIFI, 피어 투 피어 네트워크 (peer-to-peer network; P2P), 범용 플러그 앤 플레이 (universal plug and play; UPnP), CLOUD, 또는 초광대역 (ultra-wideband; UWB)와 같은 다양한 통신 프로토콜을 지원하면서 장치 검색 및 제어를 제공할 수 있다. 다양한 실시 예들에 따라, 상기 IoT 환경 (300)은 특정 브랜드의 센서와 제품 뿐만 아니라, 다른 브랜드의 제품도 연결할 수 있도록 오픈 플랫폼으로 구현될 수 있다. 다양한 실시 예들에 따라, 상기 IoT 환경 (300)은 특정 브랜드의 센서와 제품 간 연결되도록 폐쇄형 플랫폼으로 구현될 수 있다.
다양한 실시 예들에 따라, 상기 전자 장치 (310) (예를 들어, 도 1의 전자 장치 (101))에는 운영 체제 (예를 들어, 도 1의 운영 체제 (142))에 의해 실행 가능한 어플리케이션 (315) (예를 들어, 도 1의 어플리케이션 (146))이 설치될 수 있다. 다양한 실시 예들에 따라, 어플리케이션 (315)은 제조 시에 상기 전자 장치 (310)에 프리로드되거나, 외부 전자 장치 (예를 들어, 도 1의 전자 장치 (102 또는 104), 또는 도 1의 서버 (108))로부터 다운로드되거나 갱신될 수 있다. 다양한 실시 예들에 따라, 어플리케이션 (315)은 상기 클라우드 (320) 내 서버에 등록된 상기 클라우드-연결 장치들 (330)의 상태를 확인하고 상기 클라우드-연결 장치들 (330)을 제어할 수 있다. 다양한 실시 예들에 따라, 어플리케이션 (315)은 상기 클라우드 (320) 내 서버에 등록된 상기 클라우드-연결 장치들 (330)을 정해진 시간에 자동으로 동작하도록 제어하거나, 상기 클라우드-연결 장치들 (330)로부터 알림을 제공 받을 수 있다. 다양한 실시 예들에 따라, 어플리케이션 (315)은 상기 전자 장치 (310)을 통해 스마트 가전, 또는 사물 인터넷 (IoT)을 제어 및 관리하고, 주변 기기와 유선 또는 무선으로 연결될 수 있다. 예를 들면, 상기 클라우드-연결 장치들 (330)은 TV, 스피커, 냉장고, 김치냉장고, 와인셀러, 세탁기, 건조기, 에어드레서, 오븐, 식기세척기, 쿡탑, 로봇 청소기, 에어컨, 및 공기청정기 중 적어도 하나를 포함할 수 있다.
도 4는 본 개시의 일 실시 예에 따른 IoT 환경의 다른 예시를 나타내는 도면이다.
도 4를 참조하면, 상기 IoT 환경 (400)은 상기 전자 장치 (410), 제 1 클라우드 (420), 클라우드-연결 장치들 (430) (예를 들어, 도 3의 상기 클라우드-연결 장치들 (330)), 허브 (440), 제 2 클라우드 (460), 및/또는 제 3 클라우드 (470)를 포함할 수 있다. 다양한 실시 예들에 따라, 상기 IoT 환경 (400)은 도 3에서 설명한 상기 IoT 환경 (300)과 실질적으로 동일하거나 유사한 환경을 제공할 수 있다. 다양한 실시 예들에 따라, 상기 전자 장치 (410) (예를 들어, 도 1의 상기 전자 장치 (101))에는 운영 체제 (예를 들어, 도 1의 운영 체제 (142))에 의해 실행 가능한 어플리케이션 (415) (예를 들어, 도 1의 어플리케이션 (146))이 설치될 수 있다. 다양한 실시 예들에 따라, 어플리케이션 (415)은 상기 클라우드-연결 장치들 (430)을 상기 제 1 클라우드 (420)에 등록하고 등록된 기기를 원격으로 제어하는 클라이언트 어플리케이션을 의미할 수 있다. 다양한 실시 예들에 따라, 어플리케이션 (415)은 상기 제 1 클라우드 (420) 내 서버에 등록된 상기 클라우드-연결 장치들 (430)의 상태를 확인하고 상기 클라우드-연결 장치들 (430)을 제어할 수 있다. 다양한 실시 예들에 따라, 어플리케이션 (415)은 상기 제 1 클라우드 (420) 내 서버에 등록된 상기 클라우드-연결 장치들 (430)을 정해진 시간에 자동으로 동작하도록 제어하거나, 상기 클라우드-연결 장치들 (430)로부터 알림을 받을 수 있다. 다양한 실시 예들에 따라, 어플리케이션 (415)은 상기 전자 장치 (310)을 통해 스마트 가전, 또는 사물 인터넷 (IoT)을 제어 및 관리하고, 주변 기기와 유선 또는 무선으로 연결될 수 있다.
다양한 실시 예들에 따라, 상기 제 1 클라우드 (420)에 연결할 수 있는 장치는 허브 연결 (Hub-connected) (440), 직접 연결 (Direct-connected) (450), 또는 클라우드 연결 (Cloud-connected) (424, 428)의 형태로 상기 제 1 클라우드 (420)에 연결될 수 있다. 다양한 실시 예들에 따라, 상기 제 1 클라우드 (420)은 상기 전자 장치 (410) 및 상기 클라우드-연결 장치들 (430)을 관리 또는 제어하는 서버를 포함할 수 있다. 다양한 실시 예들에 따라, 상기 제 1 클라우드 (420) 내 서버는 상기 전자 장치 (410) 및 상기 클라우드-연결 장치들 (430) 간 송수신하는 정보를 저장하거나 상기 전자 장치 (410) 및 상기 클라우드-연결 장치들 (430) 간 통신을 중계하고, 상기 전자 장치 (410) 및 상기 클라우드-연결 장치들 (430)의 통신을 지원할 수 있다. 다양한 실시 예들에 따라, 상기 제 1 클라우드 (420)은 운영체제와 응용프로그램 사이의 통신에 사용되는 언어나 메시지 형식인 응용 프로그래밍 인터페이스 (application programming interface; API) (422)를 구현할 수 있다. 다양한 실시 예들에 따라, 상기 제 1 클라우드 (420)은 상기 허브 (440)을 통해 상기 클라우드-연결 장치들 (430)과 연결될 수 있다. 다양한 실시 예들에 따라, 상기 허브 (440)은 ZigBee, Zwave, LAN, 또는 Matter와 같은 통신 기능을 통해 상기 제 1 클라우드 (420)과 상기 클라우드-연결 장치들 (430)을 연결할 수 있다. 다양한 실시 예들에 따라, 상기 허브 (440)은 상기 제 1 클라우드 (420)과 상기 클라우드-연결 장치들 (430) 간 통신을 중계하는 장치 (예를 들어, 게이트웨이)를 의미할 수 있다. 다양한 실시 예들에 따라, 상기 허브 (440)은 상기 제 1 클라우드 (420) 내에 구현된 장치이거나 별도의 장치 (예를 들어, 외부 서버)로 구현될 수 있다.
다양한 실시 예들에 따라, 상기 제 1 클라우드 (420)은 상기 허브 (440)을 이용하지 않고 직접 연결 (450)을 통해 상기 클라우드-연결 장치들 (430)과 연결될 수 있다. 다양한 실시 예들에 따라, 상기 클라우드-연결 장치들 (430) 중에서 적어도 하나는 Wi-Fi AP에 직접 연결하여 상기 제 1 클라우드 (420)에 연결될 수 있다.
다양한 실시 예들에 따라, 상기 제 1 클라우드 (420)은 API (422)를 이용하여 클라우드 커넥터 (424)와 연결되고, 상기 제 2 클라우드 (460)과 통신할 수 있다. 다양한 실시 예들에 따라, 상기 제 1 클라우드 (420)에서 서비스를 제공하는 사업자는 상기 제 2 클라우드 (460)에서 서비스를 제공하는 사업자와 상이할 수 있다. 다양한 실시 예들에 따라, 클라우드 커넥터 (424)는 서로 다른 클라우드 (예를 들어, 상기 제 1 클라우드 (420)과 상기 제 2 클라우드 (460)) 간 통신을 중계할 수 있다. 다양한 실시 예들에 따라, 클라우드 커넥터 (424)는 상기 제 1 클라우드 (420) 내에 구현된 하드웨어 장치 또는 소프트웨어 모듈일 수 있다. 다양한 실시 예들에 따라, 클라우드 커넥터 (424)는 상기 제 1 클라우드 (420) 외부에 구현되는 하드웨어 장치 또는 소프트웨어 모듈일 수 있다. 다양한 실시 예들에 따라, 클라우드 커넥터 (424)는 상기 제 1 클라우드 (420) 외부에 구현되는 별도의 서버일 수 있다.
다양한 실시 예들에 따라, 상기 제 1 클라우드 (420)은 API (422)를 이용하여 자동화 기능 (426)과 연결되고, 자동화 기능 (426)은 사용자가 어플리케이션 (415)에서 설정한 조건이 충족되면 사용자 명령 (또는 입력) 없이 상기 제 1 클라우드 (420)에 연결된 상기 클라우드-연결 장치들 (430) 각각이 정의된 동작을 수행하도록 제어할 수 있다. 다양한 실시 예들에 따라, 자동화 기능 (426)은 상기 제 1 클라우드 (420) 내에 구현된 하드웨어 장치 또는 소프트웨어 모듈일 수 있다. 다양한 실시 예들에 따라, 자동화 기능 (426)은 상기 제 1 클라우드 (420) 외부에 구현되는 하드웨어 장치 또는 소프트웨어 모듈일 수 있다. 다양한 실시 예들에 따라, 자동화 기능 (426)은 상기 제 1 클라우드 (420) 외부에 구현되는 별도의 서버일 수 있다. 다양한 실시 예들에 따라, 다양한 실시 예들에 따라, 사용자 입력에 응답하여 어플리케이션 (415)은 시간 (예를 들어, 특정 시간, 특정 시간대, 항상, 또는 요일 등), 장치 상태, 멤버 위치 (예를 들어, 처음에 설정 한 장소에 있는지 유무 확인), 장소 상태, 또는 날씨 등의 다양한 조건을 설정할 수 있다. 다양한 실시 예들에 따라, 어플리케이션 (415)에서 설정된 조건이 충족되면, 자동화 기능 (426)은 사용자 명령 (또는 입력) 없이 상기 제 1 클라우드 (420)에 연결된 상기 클라우드-연결 장치들 (430)에 대한 장치 제어, 스마트폰 알림, 스피커에서 메시지 음성 재생, 장소의 상태 변경, 또는 모드 실행의 기능이 수행되도록 제어할 수 있다.
다양한 실시 예들에 따라, 상기 제 1 클라우드 (420)은 API (422)를 이용하여 클라우드 커넥터 (428)와 연결되고, 상기 제 3 클라우드 (470)과 통신할 수 있다. 다양한 실시 예들에 따라, 상기 제 1 클라우드 (420)에서 서비스를 제공하는 사업자는 상기 제 3 클라우드 (470)에서 서비스를 제공하는 사업자와 상이할 수 있다. 다양한 실시 예들에 따라, 클라우드 커넥터 (428)는 서로 다른 클라우드 (예를 들어, 상기 제 1 클라우드 (420)과 상기 제 3 클라우드 (470)) 간 통신을 중계할 수 있다. 다양한 실시 예들에 따라, 클라우드 커넥터 (428)는 상기 제 1 클라우드 (420) 내에 구현된 하드웨어 장치 또는 소프트웨어 모듈일 수 있다. 다양한 실시 예들에 따라, 클라우드 커넥터 (428)는 상기 제 1 클라우드 (420) 외부에 구현되는 하드웨어 장치 또는 소프트웨어 모듈일 수 있다. 다양한 실시 예들에 따라, 클라우드 커넥터 (428)는 상기 제 1 클라우드 (420) 외부에 구현되는 별도의 서버일 수 있다.
다양한 실시 예들에 따라, 상기 제 1 클라우드 (420)에 허브 연결 (Hub-connected) (440), 직접 연결 (Direct-connected) (450), 또는 클라우드 연결 (Cloud-connected) (424, 428)의 형태로 연결된 상기 클라우드-연결 장치들 (430)은 인증이 완료되면 어플리케이션 (415)을 통해 상기 제 1 클라우드 (420)에 온보딩 (onboarding) (또는 등록)될 수 있다. 다양한 실시 예들에 따라, 온보딩 (onboarding)은 어플리케이션 (415)을 통해 적어도 하나의 전자 장치를 상기 제 1 클라우드 (420)에 등록하는 과정일 수 있다.
도 5는 본 개시의 일 실시 예에 따른 IoT 환경의 또 다른 예시를 나타내는 도면이다.
도 5를 참조하면, IoT 환경 (500)은 전자 장치 (510), 서버 (520), 워크스페이스 (workspace) (530), 및/또는 데이터베이스 (database, DB) (540)를 포함할 수 있다. 다양한 실시 예들에 따라, IoT 환경 (500)은 도 3에서 설명한 상기 IoT 환경 (300) 또는 도 4에서 설명한 상기 IoT 환경 (400)과 실질적으로 동일하거나 유사한 환경을 제공할 수 있다. 다양한 실시 예들에 따라, 전자 장치 (510) (예를 들어, 도 1의 상기 전자 장치 (101))에는 운영 체제 (예를 들어, 도 1의 운영 체제 (142))에 의해 실행 가능한 어플리케이션 (515) (예를 들어, 도 1의 어플리케이션 (146))이 설치될 수 있다.
다양한 실시 예들에 따라, 전자 장치 (510)는 카메라 앱 (camera application) (511), 주변 기기 스캐너 (nearby device scanner, NDS) (513), 및/또는 어플리케이션 (515)을 포함할 수 있다. 다양한 실시 예들에 따라, 카메라 앱 (511)은 온보딩 (onboarding)하려는 적어도 하나의 외부 전자 장치의 QR 코드 (code)를 인식 (또는 확인)할 수 있다. 다양한 실시 예들에 따라, 카메라 앱 (511)은 QR 코드 (code)를 파싱 (parsing)하여 사용자가 적어도 하나의 외부 전자 장치를 온보딩 (onboarding)할지 여부를 확인 (또는 결정)하도록 할 수 있다. 다양한 실시 예들에 따라, 어플리케이션 (515)은 적어도 하나의 외부 전자 장치를 클라우드 내 서버 (520)에 등록하고 등록된 기기를 원격으로 제어하는 클라이언트 어플리케이션을 의미할 수 있다. 다양한 실시 예들에 따라, 어플리케이션 (515)은 클라우드 내 서버 (520)에 등록된 적어도 하나의 외부 전자 장치의 상태를 확인하고 적어도 하나의 외부 전자 장치를 제어할 수 있다. 다양한 실시 예들에 따라, 주변 기기 스캐너 (513)는 주변 기기 스캐너 서비스 모듈 (nearby device scanner service module)로서 백그라운드 (background)에서 적어도 하나의 외부 전자 장치를 스캐닝 (scanning)할 수 있다. 다양한 실시 예들에 따라, 주변 기기 스캐너 (513)는 온보딩 (onboarding) 가능한 적어도 하나의 외부 전자 장치를 감지 (또는 검출)할 수 있다. 다양한 실시 예들에 따라, 주변 기기 스캐너 (513)는 온보딩 (onboarding)을 수행 (또는 제어)하기 위한 어플리케이션의 우선순위를 결정하고, 어플리케이션을 실행하는 기능을 제공할 수 있다. 다양한 실시 예들에 따라, 전자 장치 (510)는 카메라 앱 (511) 및/또는 주변 기기 스캐너 (513)를 이용하여 적어도 하나의 외부 전자 장치에 대한 온보딩 (onboarding) 정보를 획득할 수 있다. 다양한 실시 예들에 따라, 적어도 하나의 외부 전자 장치에 대한 온보딩 (onboarding) 정보는 적어도 하나의 외부 전자 장치의 제조사 ID (vendorid) 및 워크스페이스 (530)에 등록된 적어도 하나의 외부 전자 장치의 ID (productid)를 포함할 수 있다. 다양한 실시 예들에 따라, 전자 장치 (510)는 적어도 하나의 외부 전자 장치에 대한 온보딩 (onboarding) 정보를 서버 (520)로 전송할 수 있다. 다양한 실시 예들에 따라, 전자 장치 (510)는 온보딩 (onboarding)을 수행 (또는 제어)하기 위한 어플리케이션의 우선순위에 대한 정보를 저장하고 사용할 수 있다. 다양한 실시 예들에 따라, 어플리케이션의 우선순위에 대한 정보는 전자 장치 (또는 외부 전자 장치)와 다른 제조사/플랫폼에 관리자 권한을 부여하는 우선 순위에 관한 정보를 포함할 수 있다.
다양한 실시 예들에 따라, 전자 장치 (510)는 적어도 하나의 외부 전자 장치에 대한 온보딩 (onboarding) 정보는 적어도 하나의 외부 전자 장치의 제조사 ID (vendorid) 및 워크스페이스 (530)에 등록된 적어도 하나의 외부 전자 장치의 ID (productid)에 기반하여 적어도 하나의 외부 전자 장치를 제어할 어플리케이션 타입을 결정할 수 있다. 다양한 실시 예들에 따라, 전자 장치 (510)는 적어도 하나의 외부 전자 장치의 제조사 ID (vendorid), 워크스페이스 (530)에 등록된 적어도 하나의 외부 전자 장치의 ID (productid), 및 어플리케이션 우선순위에 관한 정보에 기반하여 적어도 하나의 외부 전자 장치를 제어할 어플리케이션 타입을 결정할 수 있다. 다양한 실시 예들에 따라, 어플리케이션 우선순위는 전자 장치 (510)에 설치된 운영 시스템 (mobile OS)의 종류 (예를 들어, Galaxy, Non-Galaxy, Android, 또는 iOS) 및 전자 장치 (510)에 설치된 어플리케이션에 관한 정보 (예를 들어, SmartThings App 설치 유무, 또는 Google Home App 설치 유무)에 기반하여 결정될 수 있다. 다양한 실시 예들에 따라, 전자 장치 (510)는 적어도 하나의 외부 전자 장치를 온보딩 (onboarding) 가능한 어플리케이션 리스트를 미리 저장하거나, 서버 (520)로부터 어플리케이션 리스트를 수신할 수 있다. 다양한 실시 예들에 따라, 전자 장치 (510)는 어플리케이션 리스트에 따라 온보딩 (onboarding)을 위한 어플리케이션을 자동으로 추천하거나, 가능한 어플리케이션 리스트를 표시할 수 있다.
다양한 실시 예들에 따라, 워크스페이스 (530)는 developer workspace로도 불릴 수 있으며, 각 제품의 개발자가 제품의 종류, 특징, 및/또는 기기의 고유 번호에 관한 정보를 서버 (520)에 전송할 수 있다. 다양한 실시 예들에 따라, 타사 제조업체 (3rd party manufacturer)는 워크스페이스 (530)에 자신의 제품 (또는 적어도 하나의 외부 전자 장치)을 이용하여 제품의 종류, 특징, 및/또는 기기의 고유 번호에 관한 정보를 서버 (520)에 전송할 수 있다. 다양한 실시 예들에 따라, 데이터베이스 (540)는 서버 (520)로부터 적어도 하나의 외부 전자 장치에 대한 온보딩 (onboarding) 정보를 수신하고 이를 저장할 수 있다. 다양한 실시 예들에 따라, 데이터베이스 (540)는 어플리케이션 타입 정보 (partner name), 적어도 하나의 외부 전자 장치의 제조사 ID (vendorid), 워크스페이스 (530)에 등록된 적어도 하나의 외부 전자 장치의 ID (productid), 및 어플리케이션 타입에 따른 어플리케이션 링크 (app link)에 관한 정보 중에서 적어도 하나를 저장할 수 있다. 다양한 실시 예들에 따라, 데이터베이스 (540)는 서버 (520)의 요청에 따라 저장한 정보를 서버 (520)로 제공할 수 있다. 다양한 실시 예들에 따라, 데이터베이스 (540)에 저장된 정보는 서버 (520)를 통해 전자 장치 (510)로 제공될 수 있다.
다양한 실시 예들에 따라, 본 개시는 외부 전자 장치를 온보딩 (또는 등록)할 수 있는 어플리케이션을 우선 순위 기반으로 결정하고, 다른 제조사/플랫폼의 어플리케이션에도 외부 전자 장치를 제어할 수 있는 관리자 권한을 부여하는 방법을 제안한다. 다양한 실시 예들에 따라, 본 개시는 QR 코드 인식 또는 주변 기기 스캐닝 (nearby device scanning)를 통해 외부 전자 장치의 온보딩 (onboarding) 정보를 획득하고 우선 순위 기반에 따라 어플리케이션을 결정 (또는 선택)할 수 있다.
다양한 실시 예들에 따라, 외부 전자 장치를 온보딩 (또는 등록)하는 최초 어플리케이션이 외부 전자 장치 (또는 전자 장치)의 제조사의 어플리케이션인 경우, 다른 제조사/플랫폼의 어플리케이션에 외부 전자 장치를 제어할 수 있는 관리자 권한을 추가할 수 있다. 다양한 실시 예들에 따라, 외부 전자 장치 (또는 전자 장치)의 제조사의 어플리케이션은 다른 제조사/플랫폼의 어플리케이션으로 관리자 권한을 직접 부여할 수 있다. 다양한 실시 예들에 따라, 다른 제조사/플랫폼의 어플리케이션 실행 후 다른 제조사/플랫폼의 어플리케이션이 외부 전자 장치에 대한 관리자 권한을 직접 업데이트할 수 있다. 다양한 실시 예들에 따라, 외부 전자 장치 (또는 전자 장치)의 제조사의 어플리케이션은 초대 기능을 통해 특정 위치에 위치하는 사용자에게 관리자 권한을 직접 제공할 수 있다.
본 개시에서 설명의 편의를 위해 외부 전자 장치 (또는 전자 장치)의 제조사의 어플리케이션은 "제 1 어플리케이션"으로 지칭될 수 있고, 다른 제조사/플랫폼의 어플리케이션은 "제 2 어플리케이션"으로 지칭될 수도 있다.
도 6a 내지 도 6c는 본 개시의 일 실시 예에 따른 전자 장치의 동작을 설명하기 위한 흐름도이다.
도 6a 내지 도 6c를 참조하면, 시스템은 IoT 기기 (610), 전자 장치 (620), 서버 (630), 제 1 어플리케이션 (640), 제 2 어플리케이션 (650), 및/또는 제 3 어플리케이션 (660)을 포함할 수 있다. 다양한 실시 예들에 따라, IoT 기기 (610)는 도 2의 전자 장치 (102 또는 104), 도 3의 상기 클라우드-연결 장치들 (330), 또는 도 4의 상기 클라우드-연결 장치들 (430) 중 어느 하나로 구현될 수 있다.
다양한 실시 예들에 따라, 전자 장치 (620)는 카메라 앱 (620-1) (예를 들어, 도 5의 카메라 앱 (511)), 및/또는 주변 기기 스캐너 (620-2) (예를 들어, 도 5의 주변 기기 스캐너 (513))를 포함할 수 있다. 다양한 실시 예들에 따라, 서버 (630)는 전자 장치 (620)를 통해 IoT 기기 (610)를 제어하기 위해 IoT 기기 (610)를 온보딩 (또는 등록)하기 위한 서버를 의미할 수 있다. 다양한 실시 예들에 따라, 서버 (630)는 제 1 어플리케이션 (640), 제 2 어플리케이션 (650), 및 제 3 어플리케이션 (660) 각각에 대응될 수 있다. 설명의 편의를 위해, 서버 (630)는 하나의 서버로 도시되어 있으나, 본 개시의 기술적 사상은 이에 제한되지 않고, 서버 (630)는 제 1 어플리케이션 (640), 제 2 어플리케이션 (650), 및 제 3 어플리케이션 (660) 각각에 대응되는 독립적인 3개의 서버들을 포함할 수 있다. 다양한 실시 예들에 따라, 제 1 어플리케이션 (640), 제 2 어플리케이션 (650), 및 제 3 어플리케이션 (660) 각각은 대응되는 3개의 서버들 각각과 통신하여 IoT 기기 (610)에 대한 온보딩을 지원할 수 있다. 다양한 실시 예들에 따라, 제 1 어플리케이션 (640), 제 2 어플리케이션 (650), 및 제 3 어플리케이션 (660) 각각은 서로 다른 제품 제조사 또는 서버 운영자에 의해 독립적으로 관리될 수 있다. 다양한 실시 예들에 따라, 제 1 어플리케이션 (640), 제 2 어플리케이션 (650), 및 제 3 어플리케이션 (660) 각각은 대응되는 서버 간 통신 또는 클라우드 연결을 통해 서로 통신할 수 있다.
도 6a를 참조하면, 사용자 (600)가 카메라 앱 (620-1)을 구동하는 경우 사용자 (600)는 카메라 앱 (620-1)을 실행할 수 있다 (601 동작). 다양한 실시 예들에 따라, 카메라 앱 (620-1)은 사용자 명령에 기반하여 IoT 기기 (610)에 대한 QR 코드 이미지를 스캐닝할 수 있다 (603 동작). 다양한 실시 예들에 따라, IoT 기기 (610)는 QR 코드 정보를 카메라 앱 (620-1)으로 제공하고 (605 동작), 카메라 앱 (620-1)은 QR 코드를 파싱 (parsing)할 수 있다 (607 동작). 다양한 실시 예들에 따라, 카메라 앱 (620-1)은 사용자 동의 팝업 (popup)을 표시할 수 있다 (609 동작). 다양한 실시 예들에 따라, 사용자 (600)가 카메라 앱 (620-1)을 통해 팝업을 클릭하면 (611 동작), 카메라 앱 (620-1)은 커미셔닝 페이로드 (commissioning payload)를 주변 기기 스캐너 (620-2)로 전송할 수 있다 (613 동작).
다양한 실시 예들에 따라, 사용자 (600)가 주변 기기 스캐너 (620-2)를 구동하는 경우 주변 기기 스캐너 (620-2)는 근거리 통신을 이용하여 IoT 기기 (610)에 대한 장치 디스커버리 (discovery)를 수행할 수 있다 (615 동작). 다양한 실시 예들에 따라, 주변 기기 스캐너 (620-2)는 BLE 스캐닝, WiFi, Bluetooth, 또는 UWB와 같은 근거리 통신을 이용하여 IoT 기기 (610)에 대한 장치 디스커버리를 수행할 수 있다 (615 동작). 다양한 실시 예들에 따라, 주변 기기 스캐너 (620-2)는 디스커버리 (또는 발견)된 적어도 하나의 외부 전자 장치에 대한 팝업을 표시할 수 있다 (617 동작). 다양한 실시 예들에 따라, 사용자 (600)가 주변 기기 스캐너 (620-2)를 통해 팝업을 클릭하면 (619 동작), 주변 기기 스캐너 (620-2)는 IoT 기기 (610) 및/또는 적어도 하나의 외부 전자 장치의 온보딩 정보 (예를 들어, vendorid, 및/또는 productid)에 기반하여 커미셔닝할 장치를 결정할 수 있다 (621 동작). 다양한 실시 예들에 따라, 주변 기기 스캐너 (620-2)는 613 동작에서 카메라 앱 (620-1)으로부터 수신한 커미셔닝 페이로드 및 장치 디스커버리 결과에 기반하여 IoT 기기 (610)의 온보딩 정보 (예를 들어, vendorid, 및/또는 productid)를 획득할 수 있다.
도 6b의 case 1을 참조하면, 주변 기기 스캐너 (620-2)는 서버 (630)로 커미셔닝할 어플리케이션 요청을 전송할 수 있다 (623 동작). 다양한 실시 예들에 따라, 커미셔닝할 어플리케이션 요청은 IoT 기기 (610)에 관한 장치 정보 (예를 들어, matter device: Phlips Hue), IoT 기기 (610)의 제조사 ID (예를 들어, vendorid: 0x0010), 및 IoT 기기 (610)에게 부여되는 고유 ID (예를 들어, productid: 0x0011) 중에서 적어도 하나를 포함할 수 있다. 다양한 실시 예들에 따라, 서버 (630)는 주변 기기 스캐너 (620-2)로 우선순위 앱 리스트를 포함하는 응답 메시지를 전송할 수 있다 (625 동작). 다양한 실시 예들에 따라, 우선순위 앱 리스트는 어플리케이션에 대한 우선순위 정보, 각 어플리케이션에 대한 정보 scheme 정보, 또는 package 정보를 포함할 수 있다. 다양한 실시 예들에 따라, 주변 기기 스캐너 (620-2)는 제 1 어플리케이션 (640)에 대한 패키지 종료를 확인 (check package exit)할 수 있다 (627 동작). 다양한 실시 예들에 따라, 주변 기기 스캐너 (620-2)는 제 1 어플리케이션 (640)을 실행할 수 있다 (629 동작).
도 6b의 case 2를 참조하면, 주변 기기 스캐너 (620-2)는 서버 (630)로 커미셔닝할 어플리케이션 요청을 전송할 수 있다 (631 동작). 다양한 실시 예들에 따라, 커미셔닝할 어플리케이션 요청은 IoT 기기 (610)에 관한 장치 정보 (예를 들어, matter device: Phlips Hue), IoT 기기 (610)의 제조사 ID (예를 들어, vendorid: 0x0010), 및 IoT 기기 (610)에게 부여되는 고유 ID (예를 들어, productid: 0x0011) 중에서 적어도 하나를 포함할 수 있다. 다양한 실시 예들에 따라, 서버 (630)는 주변 기기 스캐너 (620-2)로 우선순위 앱 리스트를 포함하는 응답 메시지를 전송할 수 있다 (633 동작). 다양한 실시 예들에 따라, 우선순위 앱 리스트는 어플리케이션에 대한 우선순위 정보, 각 어플리케이션에 대한 정보 scheme 정보, 또는 package 정보를 포함할 수 있다. 다양한 실시 예들에 따라, 주변 기기 스캐너 (620-2)는 제 1 어플리케이션 (640)에 대한 패키지 종료를 확인 (check package exit)할 수 있다 (635 동작). 다양한 실시 예들에 따라, 주변 기기 스캐너 (620-2)는 제 2 어플리케이션 (650)에 대한 패키지 종료를 확인 (check package exit)할 수 있다 (637 동작). 다양한 실시 예들에 따라, 주변 기기 스캐너 (620-2)는 제 2 어플리케이션 (650)을 실행할 수 있다 (639 동작).
도 6c를 참조하면, 주변 기기 스캐너 (620-2)는 서버 (630)로 커미셔닝할 어플리케이션 요청을 전송할 수 있다 (641 동작). 다양한 실시 예들에 따라, 커미셔닝할 어플리케이션 요청은 IoT 기기 (610)에 관한 장치 정보에 관한 장치 정보 (예를 들어, matter device: Phlips Hue), IoT 기기 (610)의 제조사 ID (예를 들어, vendorid: 0x0010), 및 IoT 기기 (610)에게 부여되는 고유 ID (예를 들어, productid: 0x0011) 중에서 적어도 하나를 포함할 수 있다. 다양한 실시 예들에 따라, 서버 (630)는 주변 기기 스캐너 (620-2)로 우선순위 앱 리스트를 포함하는 응답 메시지를 전송할 수 있다 (643 동작). 다양한 실시 예들에 따라, 우선순위 앱 리스트는 어플리케이션에 대한 우선순위 정보, 각 어플리케이션에 대한 정보 scheme 정보, 또는 package 정보를 포함할 수 있다. 다양한 실시 예들에 따라, 주변 기기 스캐너 (620-2)는 제 1 어플리케이션 (640)에 대한 패키지 종료를 확인 (check package exit)할 수 있다 (645 동작). 다양한 실시 예들에 따라, 주변 기기 스캐너 (620-2)는 제 3 어플리케이션 (660)에 대한 패키지 종료를 확인 (check package exit)할 수 있다 (647 동작). 다양한 실시 예들에 따라, 주변 기기 스캐너 (620-2)는 제 3 어플리케이션 (660)을 실행할 수 있다 (649 동작).
도 7은 본 개시의 일 실시 예에 따른 전자 장치 및 서버의 동작을 설명하기 위한 도면이다.
도 7을 참조하면, 시스템은 상기 전자 장치 (710), 외부 전자 장치 (720), AP (730), 및 상기 서버 (740)을 포함한다. 다양한 실시 예들에 따라, 상기 전자 장치 (710)은 도 1의 상기 전자 장치 (101), 도 3의 상기 전자 장치 (310), 도 4의 상기 전자 장치 (410), 도 5의 전자 장치 (510), 또는 도 6a 내지 도 6c의 전자 장치 (610)로 구현될 수 있다. 다양한 실시 예들에 따라, 외부 전자 장치 (720)는 도 1의 전자 장치 (102, 104), 도 3의 상기 클라우드-연결 장치들 (330) 또는 도 4의 상기 클라우드-연결 장치들 (430) 각각으로 구현될 수 있다. 다양한 실시 예들에 따라, 상기 서버 (740)은 도 1의 서버 (108), 도 3의 상기 클라우드 (320), 도 4의 클라우드 (420, 460, 470), 도 5의 서버 (520), 또는 도 6a 내지 도 6c의 서버 (630)로 구현될 수 있다.
다양한 실시 예들에 따라, 상기 전자 장치 (710)은 주변에 위치하는 외부 전자 장치 (720)를 스캔할 수 있다 (701 동작). 다양한 실시 예들에 따라, 외부 전자 장치 (720)는 상기 전자 장치 (710)에 대한 기기 정보를 수신할 수 있다 (702 동작). 다양한 실시 예들에 따라, 상기 전자 장치 (710)은 외부 전자 장치 (720)에 대한 기기 정보를 수신할 수 있다. 다양한 실시 예들에 따라, 상기 전자 장치 (710)은 사용자가 선택한 온보딩 (onboarding)하려는 기기 모델 타입을 상기 서버 (740)로 전달할 수 있다 (703 동작). 다양한 실시 예들에 따라, 상기 서버 (740)은 등록된 기기 정보 (741)를 저장하거나 업데이트할 수 있다. 다양한 실시 예들에 따라, 등록된 기기 정보 (741)는 적어도 하나의 외부 전자 장치 각각에 대한 시리얼 (serial), 모델 코드 (model code), 위치 (location), 또는 wifi 정보 중에서 적어도 하나를 포함할 수 있다. 다양한 실시 예들에 따라, 상기 서버 (740)은 모델 타입 (743)에 기반하여 온보딩 설정 타입을 선택할 수 있다 (704 동작). 다양한 실시 예들에 따라, 온보딩 설정 타입은 적어도 하나의 외부 전자 장치를 클라우드 (또는 서버)에 온보딩 (또는 등록) 시 사용자에게 디스플레이되는 UI (user interface) 타입을 의미할 수 있다. 다양한 실시 예들에 따라, 온보딩 설정 타입은 "설정 타입 1", "설정 타입 2", "설정 타입 3", "쉬운 설정 타입 1", 또는 "쉬운 설정 타입 2"를 포함할 수 있다. 예를 들어, "설정 타입 1"은 기기 타입 및 기기 모델명에 대한 사용자 입력을 요구하는 UI 타입일 수 있다. 예를 들어, "쉬운 설정 타입 1"은 사용자에게 입력 받는 내용을 최대한 삭제한 UI 타입이며, 기기 타입에 대한 사용자 입력만을 요구하는 UI 타입일 수 있다.
다양한 실시 예들에 따라, 상기 전자 장치 (710)은 온보딩하려는 기기 모델 타입을 외부 전자 장치 (720)로 전달할 수 있다 (705 동작). 다양한 실시 예들에 따라, 상기 전자 장치 (710)은 AP (730)의 wi-fi 정보 (예를 들어, SSID, passphrase)를 외부 전자 장치 (720)로 전달할 수 있다 (706 동작). 다양한 실시 예들에 따라, 외부 전자 장치 (720)는 수신한 wi-fi 정보를 이용하여 AP (730)를 통해 클라우드에 연결될 수 있다 (707 동작). 다양한 실시 예들에 따라, 외부 전자 장치 (720)는 AP (730)를 통해 네트워크 연결되어 상기 서버 (740)과 통신할 수 있다 (708 동작). 다양한 실시 예들에 따라, 외부 전자 장치 (720)는 외부 전자 장치 (720)에 대한 시리얼 (serial) 및 모델 코드 (model code)가 상기 서버 (740)에 등록되도록 상기 서버 (740)과 통신할 수 있다 (708). 다양한 실시 예들에 따라, 상기 서버 (740)은 등록된 기기 정보 (741)에 외부 전자 장치 (720)에 대한 시리얼 (serial) 및 모델 코드 (model code)를 등록할 수 있다. 다양한 실시 예들에 따라, 상기 전자 장치 (710)은 외부 전자 장치 (720)에 대한 시리얼 (serial) 및 모델 코드 (model code)를 포함하는 등록된 기기 정보 (741)를 상기 서버 (740)로부터 수신하고 이를 저장할 수 있다 (709 동작).
도 8은 본 개시의 일 실시 예에 따른 제 1 어플리케이션에서 제 2 어플리케이션의 실행을 트리거하고, 제 2 어플리케이션에서 관리자 권한을 업데이트하는 과정을 설명하기 위한 흐름도이다.
도 8을 참조하면, 시스템은 제 1 어플리케이션 (810), 외부 전자 장치 (820), 서버 (830), 및/또는 제 2 어플리케이션 (840)을 포함할 수 있다. 다양한 실시 예들에 따라, 제 1 어플리케이션 (810)은 도 5의 어플리케이션 (515), 또는 도 6a 내지 도 6c의 제 1 어플리케이션 (640)과 동일하거나 실질적으로 동일한 기능을 수행할 수 있다. 다양한 실시 예들에 따라, 제 1 어플리케이션 (810)은 도 1의 상기 전자 장치 (101), 도 3의 상기 전자 장치 (310), 도 4의 상기 전자 장치 (410), 도 5의 전자 장치 (510), 도 6a 내지 도 6c의 전자 장치 (620), 또는 도 7의 상기 전자 장치 (710)내에 설치되어 구현될 수 있다. 다양한 실시 예들에 따라, 외부 전자 장치 (820)는 도 1의 전자 장치 (102, 104), 도 3의 상기 클라우드-연결 장치들 (330), 도 4의 상기 클라우드-연결 장치들 (430) 또는 도 7의 외부 전자 장치 (720)로 구현될 수 있다. 다양한 실시 예들에 따라, 서버 (830)는 도 1의 서버 (108), 도 3의 상기 클라우드 (320), 도 4의 클라우드 (420, 460, 470), 도 5의 서버 (520), 또는 도 6a 내지 도 6c의 서버 (630)와 동일하거나 실질적으로 동일한 기능을 수행할 수 있다. 다양한 실시 예들에 따라, 제 2 어플리케이션 (840)은 도 6a 내지 도 6c의 제 2 어플리케이션 (650) 또는 제 3 어플리케이션 (660)과 동일하거나 실질적으로 동일한 기능을 수행할 수 있다.
다양한 실시 예들에 따라, 제 1 어플리케이션 (810)은 외부 전자 장치 (820)에 대한 제어 권한을 복수의 어플리케이션들이 갖도록 하는 다중 관리자 (multi-admin) 추가 메시지를 사용자 (800)에게 제공 (또는 디스플레이)하고 (801 동작), 사용자 (800)는 다중 관리자 (multi-admin) 추가 메시지에 대한 승낙을 나타내는 확인 메시지를 제 1 어플리케이션 (810)에 표시할 수 있다 (802 동작). 다양한 실시 예들에 따라, 제 1 어플리케이션 (810)은 외부 전자 장치 (820)에 대한 온보딩 정보 (vendorid, productid)에 기반하여 커미셔닝 앱 (commissioning application)을 서버 (830)로 요청할 수 있다 (803 동작). 다양한 실시 예들에 따라, 서버 (830)는 응답 스킴 요청 (request response scheme)을 제 1 어플리케이션 (810)으로 전송할 수 있다 (804 동작).
다양한 실시 예들에 따라, 외부 전자 장치 (820)가 제 1 어플리케이션 (810)에 대응되는 서버 (830)에 온보딩 (또는 등록)되면 이후 외부 전자 장치 (820)는 D2D(device-to-device) 연결을 수행하지 않도록 제어될 수 있다. 다양한 실시 예들에 따라, 외부 전자 장치 (820)가 제 2 어플리케이션 (840)에 대응하는 서버에 추가적으로 온보딩 (또는 등록)되기 위해 외부 전자 장치 (820)는 다시 D2D 연결을 수행하도록 제어될 수 있다. 다양한 실시 예들에 따라, 외부 전자 장치 (820)가 제 2 어플리케이션 (840)에 대응하는 서버에 추가적으로 온보딩 (또는 등록)되기 위해 외부 전자 장치 (820)가 D2D 연결을 수행하도록 제 1 어플리케이션 (810)은 D2D 연결 커맨드 (예를 들어, open pairing window)를 외부 전자 장치 (820)로 전송할 수 있다 (805 동작). 다양한 실시 예들에 따라, D2D 연결 커맨드 (예를 들어, open pairing window)를 수신한 외부 전자 장치 (820)는 D2D 연결이 수행될 수 있도록 기기 상태를 변경할 수 있다. 다양한 실시 예들에 따라, D2D 연결 커맨드 (예를 들어, open pairing window)를 수신한 외부 전자 장치 (820)는 D2D 연결이 수행될 수 있는 페어링 모드로 전환될 수 있다. 다양한 실시 예들에 따라, 외부 전자 장치 (820)는 외부 전자 장치 (820)에 대한 제어를 위한 다중 관리자 (multi-admin)가 설정될 수 있음을 확인하고, 제 2 어플리케이션 (840)을 실행하기 위한 페어링 모드를 실행할 수 있다.
다양한 실시 예들에 따라, 제 1 어플리케이션 (810)은 제 2 어플리케이션 (840)이 실행되도록 트리거할 수 있다 (806 동작). 다양한 실시 예들에 따라, 제 2 어플리케이션 (840)은 외부 전자 장치 (820)에 대한 관리자 권한을 획득하거나 외부 전자 장치 (820)에 대한 관리자 권한을 직접 업데이트할 수 있다. 다양한 실시 예들에 따라, 외부 전자 장치 (820)는 먼저 제 1 어플리케이션 (810)을 통해 서버 (830)에 온보딩 (또는 등록)되고, 외부 전자 장치 (820)에 두번째 관리자 권한 (2nd admin)이 설정되면 외부 전자 장치 (820)가 다른 서버에도 온보딩 (또는 등록)될 수 있도록 페어링 모드 (paring mode)를 실행할 수 있다. 다양한 실시 예들에 따라, 외부 전자 장치 (820)는 서버 (830)에 vendorid, productid, 및/또는 Onboarding app 정보 (예를 들어, 제 1 어플리케이션 (810)에 대한 정보)를 요청하고, 전달 받은 정보를 기반으로 제 2 어플리케이션 (840)을 실행할 수 있다.
도 9는 본 개시의 일 실시 예에 따른 어플리케이션이 다른 어플리케이션에 대한 관리자 권한을 부여하는 과정을 설명하기 위한 흐름도이다.
도 9를 참조하면, 시스템은 어플리케이션 (910), 외부 전자 장치 (920), 제 1 서버 (930), 및/또는 제 2 서버 (940)를 포함한다. 다양한 실시 예들에 따라, 어플리케이션 (910)은 도 5의 어플리케이션 (515), 또는 도 6a 내지 도 6c의 제 1 어플리케이션 (640)과 동일하거나 실질적으로 동일한 기능을 수행할 수 있다. 다양한 실시 예들에 따라, 어플리케이션 (910)은 도 1의 상기 전자 장치 (101), 도 3의 상기 전자 장치 (310), 도 4의 상기 전자 장치 (410), 도 5의 전자 장치 (510), 도 6a 내지 도 6c의 전자 장치 (610), 또는 도 7의 상기 전자 장치 (710) 내에 설치되어 구현될 수 있다. 다양한 실시 예들에 따라, 외부 전자 장치 (920)는 도 1의 전자 장치 (102, 104), 도 3의 상기 클라우드-연결 장치들 (330), 도 4의 상기 클라우드-연결 장치들 (430) 또는 도 7의 외부 전자 장치 (720)로 구현될 수 있다. 다양한 실시 예들에 따라, 제 1 서버 (930)는 도 1의 서버 (108), 도 3의 상기 클라우드 (320), 도 4의 클라우드 (420, 460, 470), 도 5의 서버 (520), 또는 도 6a 내지 도 6c의 서버 (630)와 동일하거나 실질적으로 동일한 기능을 수행할 수 있다. 다양한 실시 예들에 따라, 제 2 서버 (940)는 도 6a 내지 도 6c의 제 2 어플리케이션 (650) 또는 제 3 어플리케이션 (660)에 대응되는 서버를 의미할 수 있다.
다양한 실시 예들에 따라, 어플리케이션 (910)은 외부 전자 장치 (920)에 대한 제어 권한을 복수의 어플리케이션들이 갖도록 하는 다중 관리자 (multi-admin) 추가 메시지를 사용자 (900)에게 제공 (또는 디스플레이)하고 (901 동작), 사용자 (900)는 다중 관리자 (multi-admin) 추가 메시지에 대한 승낙을 나타내는 확인 메시지를 어플리케이션 (910)에 표시할 수 있다 (902 동작).
다양한 실시 예들에 따라, 외부 전자 장치 (920)가 제 1 서버 (930)에 온보딩 (또는 등록)되면 이후 외부 전자 장치 (920)는 D2D 연결을 수행하지 않도록 제어될 수 있다. 다양한 실시 예들에 따라, 외부 전자 장치 (920)가 제 2 서버 (940)에 추가적으로 온보딩 (또는 등록)되기 위해 외부 전자 장치 (920)는 다시 D2D 연결을 수행하도록 제어될 수 있다. 다양한 실시 예들에 따라, 외부 전자 장치 (920)가 제 2 서버 (940)에 추가적으로 온보딩 (또는 등록)되기 위해 외부 전자 장치 (920)가 D2D 연결을 수행하도록 어플리케이션 (910)은 D2D 연결 커맨드 (예를 들어, open pairing window)를 외부 전자 장치 (920)로 전송할 수 있다 (903 동작). 다양한 실시 예들에 따라, D2D 연결 커맨드 (예를 들어, open pairing window)를 수신한 외부 전자 장치 (920)는 D2D 연결이 수행될 수 있도록 기기 상태를 변경할 수 있다. 다양한 실시 예들에 따라, D2D 연결 커맨드 (예를 들어, open pairing window)를 수신한 외부 전자 장치 (920)는 D2D 연결이 수행될 수 있는 페어링 모드로 전환될 수 있다. 다양한 실시 예들에 따라, 외부 전자 장치 (920)는 외부 전자 장치 (920)에 대한 제어를 위한 다중 관리자 (multi-admin)가 설정될 수 있음을 확인하고, 외부 전자 장치 (920)가 제 2 서버 (940)에 온보딩 (또는 등록)되도록 페어링 모드를 실행할 수 있다.
다양한 실시 예들에 따라, 어플리케이션 (910)은 Operation CSR (OpCSR) 정보를 외부 전자 장치 (920)로 요청하고 (904 동작), 외부 전자 장치 (920)로부터 OpCSR 정보를 수신할 수 있다 (905 동작). 다양한 실시 예들에 따라, 어플리케이션 (910)은 운영 인증서 (Operational certificate, Op Cert) (예를 들어, POST/cert)를 제 1 서버 (930)로 발급할 수 있다 (906 동작).
다양한 실시 예들에 따라, Operation CSR (OpCSR)의 예시는 다음과 같다.
다양한 실시 예들에 따라, 운영 인증서 (Operational certificate, Op Cert)의 예시는 다음과 같다.
다양한 실시 예들에 따라, 제 1 서버 (930)는 운영 인증서 (Operational certificate, Op Cert) (예를 들어, POST/cert)를 제 2 서버 (940)로 발급할 수 있다 (907 동작). 다양한 실시 예들에 따라, 제 2 서버 (940)는 제 1 서버 (930)로 운영 인증서 (Operational certificate, Op Cert)를 리턴할 수 있다 (908 동작). 다양한 실시 예들에 따라, 제 1 서버 (930)는 어플리케이션 (910)으로 운영 인증서 (Operational certificate, Op Cert)를 리턴할 수 있다 (909 동작). 다양한 실시 예들에 따라, 어플리케이션 (910)은 외부 전자 장치 (920)로 크리덴셜 (credential)을 설정하고 (910-1 동작), 액세스 제어 목록 (access control list; ACLs)을 설정할 수 있다 (911 동작). 다양한 실시 예들에 따라, 어플리케이션 (910)은 외부 전자 장치 (920)로 완료 메시지를 전송할 수 있다 (912 동작).
다양한 실시 예들에 따라, 어플리케이션 (910)은 제 2 서버 (940)에 대응되는 다른 어플리케이션으로 외부 전자 장치 (920)에 대한 관리자 권한을 직접 부여할 수 있다. 다양한 실시 예들에 따라, 어플리케이션 (910)은 외부 전자 장치 (920)에 두번째 관리자 권한 (2nd admin)이 설정 (또는 업데이트)되기 위해 외부 전자 장치 (920)가 페어링 모드 (paring mode)를 실행하도록 제어 (또는 명령)할 수 있다. 다양한 실시 예들에 따라, 어플리케이션 (910)은 외부 전자 장치 (920)의 제조사 ID (vendorid)를 기반으로 제 1 서버 (930)에 인증서 (certificates)를 요청할 수 있다. 다양한 실시 예들에 따라, 제 1 서버 (930)는 외부 전자 장치 (920)의 제조사 ID (vendorid)에 매핑된 어플리케이션의 인증서를 요청할 수 있다. 다양한 실시 예들에 따라, 어플리케이션 (910)은 외부 전자 장치 (920)의 제조사 ID (vendorid)에 매핑된 어플리케이션의 인증서를 수신하고, 외부 전자 장치 (920)에 대한 두번째 관리자 권한 (2nd admin)을 설정 (또는 업데이트)할 수 있다.
다양한 실시 예들에 따라, 허브 (예를 들어, 도 4의 상기 허브 (440))에 연결된 외부 전자 장치 (920)의 경우, 사용자 (900)는 어플리케이션 (910)을 통해 (예를 들면, 멤버 초대 기능으로 위치가 공유되면) 허브를 직접 제어하여 외부 전자 장치 (920)를 제어할 수 있다. 다양한 실시 예들에 따라, 허브에 연결되지 않고 외부 전자 장치 (920)의 경우, 외부 전자 장치 (920)는 관리자 권한을 추가한 어플리케이션이 연결되는 경우에만 해당 어플리케이션을 통해 제어될 수 있다.
다양한 실시 예들에 따라, 어플리케이션 (910)은 복수의 전자 장치들을 하나의 그룹으로 관리할 수 있으며, 하나의 그룹을 동시에 제어할 수 있다. 다양한 실시 예들에 따라, 어플리케이션 (910)은 하나의 그룹으로 설정 (또는 초대)된 복수의 전자 장치들로 위치 (location) 정보 및/또는 동일한 Group ID를 제공할 수 있다. 다양한 실시 예들에 따라, 어플리케이션 (910)은 그룹에 포함되는 외부 전자 장치 (920)에 대한 관리자 권한 업데이트를 위해 Group ID를 공유할 수 있다. 다양한 실시 예들에 따라, 어플리케이션 (910)은 외부 전자 장치 (920)로 그룹 초대 메시지를 전송하고, 외부 전자 장치 (920)가 그룹 초대를 수락하는 경우 어플리케이션 (910)은 제 1 서버 (930)로부터 외부 전자 장치 (920)의 Group ID를 획득할 수 있다. 다양한 실시 예들에 따라, 어플리케이션 (910)은 외부 전자 장치 (920)에 페어링 커맨드 (paring command)를 전송하고, 외부 전자 장치 (920)에 대한 Group ID를 업데이트할 수 있다.
도 10은 본 개시의 일 실시 예에 따른 제 1 어플리케이션을 통한 온보딩 후 제 2 어플리케이션에 관리자 권한을 추가할 수 있도록 하는 사용자 인터페이스의 예시를 나타내는 도면이다.
도 10을 참조하면, 전자 장치 (예를 들어, 도 1의 상기 전자 장치 (101), 도 3의 상기 전자 장치 (310), 도 4의 상기 전자 장치 (410), 도 5의 전자 장치 (510), 도 6a 내지 도 6c의 전자 장치 (610), 도 7의 상기 전자 장치 (710), 도 8의 전자 장치 (820), 또는 도 9의 전자 장치 (920))는 전자 장치에 포함된 카메라 (예를 들어, 도 1의 카메라 모듈 (180), 도 5의 카메라 앱 (511))를 통해 외부 전자 장치 (예를 들어, 문열림 센서)의 QR 코드를 인지할 수 있다. 다양한 실시 예들에 따라, 전자 장치는 인지된 외부 전자 장치가 제 1 어플리케이션 (예를 들어, 도 5의 어플리케이션 (515), 또는 도 6a 내지 도 6c의 제 1 어플리케이션 (640), 도 8의 제 1 어플리케이션 (810), 또는 도 9의 제 1 어플리케이션 (910))을 통해 서버에 온보딩 (또는 등록)되도록 사용자 인터페이스 (예를 들어, "SmartThings에 이 디바이스를 추가하려면 여기를 누르세요")를 제공할 수 있다 (1010). 다양한 실시 예들에 따라, 전자 장치는 외부 전자 장치 (예를 들어, 문열림 센서)의 온보딩 (또는 등록) 절차를 시작하는 사용자 인터페이스를 제공할 수 있다 (1020). 다양한 실시 예들에 따라, 전자 장치는 외부 전자 장치 (예를 들어, 문열림 센서)에 연결된 허브 (예를 들어, 도 4의 상기 허브 (440)) 및 외부 전자 장치 (예를 들어, 문열림 센서)의 위치 (예를 들어, 거실)에 관한 정보를 설정하도록 하는 사용자 인터페이스를 제공할 수 있다 (1030). 다양한 실시 예들에 따라, 전자 장치는 외부 전자 장치 (예를 들어, 문열림 센서)의 온보딩 (또는 등록) 절차를 진행할 수 있다 (1040). 다양한 실시 예들에 따라, 전자 장치는 제 1 어플리케이션을 통해 외부 전자 장치 (예를 들어, 문열림 센서)에 대한 온보딩 (또는 등록)을 완료한 후 외부 전자 장치 (예를 들어, 공기청정기)를 제어할 수 있도록 제 2 어플리케이션 (예를 들어, 도 6a 내지 도 6c의 제 2 어플리케이션 (650), 제 3 어플리케이션 (660), 도 8의 제 2 어플리케이션 (840), 또는 도 9의 제 2 서버 (940))에 관리자 권한을 추가할 수 있는 사용자 인터페이스를 제공할 수 있다 (1050). 다양한 실시 예들에 따라, 전자 장치는 외부 전자 장치 (예를 들어, 공기청정기)에 대한 추가 온보딩이 가능한 제 2 어플리케이션을 자동 또는 수동으로 사용자에게 가이드하는 사용자 인터페이스를 제공할 수 있다.
도 11은 본 개시의 일 실시 예에 따른 카메라에서 QR 인식 후 제 1 어플리케이션의 설치 유무 및 앱 우선순위에 따라 제 2 어플리케이션을 추가하는 사용자 인터페이스의 예시를 나타내는 도면이다.
도 11을 참조하면, 전자 장치 (예를 들어, 도 1의 상기 전자 장치 (101), 도 3의 상기 전자 장치 (310), 도 4의 상기 전자 장치 (410), 도 5의 전자 장치 (510), 도 6a 내지 도 6c의 전자 장치 (610), 도 7의 상기 전자 장치 (710), 도 8의 전자 장치 (820), 또는 도 9의 전자 장치 (920))는 전자 장치에 포함된 카메라 (예를 들어, 도 1의 카메라 모듈 (180), 도 5의 카메라 앱 (511))를 통해 외부 전자 장치 (예를 들어, 문열림 센서)의 QR 코드를 인지할 수 있다. 다양한 실시 예들에 따라, 전자 장치는 제 1 어플리케이션 (예를 들어, 도 5의 어플리케이션 (515), 또는 도 6a 내지 도 6c의 제 1 어플리케이션 (640), 도 8의 제 1 어플리케이션 (810), 또는 도 9의 제 1 어플리케이션 (910))을 통해 외부 전자 장치 (예를 들어, 문열림 센서)를 온보딩 (또는 등록)할 수 있도록 사용자 인터페이스를 제공할 수 있다 (1110). 다양한 실시 예들에 따라, 전자 장치는 제 1 어플리케이션이 전자 장치에 설치되었는지 여부에 따라 다른 사용자 인터페이스를 제공할 수 있다 (1110). 다양한 실시 예들에 따라, 제 1 어플리케이션이 전자 장치에 설치되지 않은 경우, 전자 장치는 제 1 어플리케이션에 대한 설치 후 외부 전자 장치 (예를 들어, 문열림 센서)를 온보딩 (또는 등록)하거나 제 1 어플리케이션 설치 없이 제 2 어플리케이션에 외부 전자 장치 (예를 들어, 문열림 센서)를 온보딩 (또는 등록)할 수 있도록 하는 사용자 인터페이스를 제공할 수 있다 (1120). 다양한 실시 예들에 따라, 제 1 어플리케이션이 전자 장치에 설치된 경우, 전자 장치는 제 1 어플리케이션에 외부 전자 장치 (예를 들어, 문열림 센서)를 온보딩 (또는 등록)하거나 제 2 어플리케이션에 외부 전자 장치 (예를 들어, 문열림 센서)를 온보딩 (또는 등록)할 수 있도록 하는 사용자 인터페이스를 제공할 수 있다 (1130).
도 12는 본 개시의 일 실시 예에 따른 전자 장치의 동작 방법을 설명하기 위한 도면이다.
도 12를 참조하면, 전자 장치 (예를 들어, 도 1의 상기 전자 장치 (101), 도 3의 상기 전자 장치 (310), 도 4의 상기 전자 장치 (410), 도 5의 전자 장치 (510), 도 6a 내지 도 6c의 전자 장치 (610), 도 7의 상기 전자 장치 (710), 도 8의 전자 장치 (820), 또는 도 9의 전자 장치 (920))는 외부 전자 장치의 온보딩 (onboarding) 정보에 기반하여 외부 전자 장치를 제어하기 위한 제 1 어플리케이션 (application)을 결정할 수 있다 (S1210 동작). 다양한 실시 예들에 따라, 전자 장치는 외부 전자 장치를 제 1 어플리케이션에 대응하는 제 1 서버에 등록할 수 있다 (S1220 동작). 다양한 실시 예들에 따라, 전자 장치는 외부 전자 장치의 온보딩 정보에 기반하여 제 1 어플리케이션과 독립적으로 외부 전자 장치를 제어하기 위한 제 2 어플리케이션을 결정하고, 제 2 어플리케이션을 실행할 수 있다 (S1230 동작). 다양한 실시 예들에 따라, 전자 장치는 외부 전자 장치를 제 2 어플리케이션에 대응하는 제 2 서버에 등록할 수 있다
다양한 실시 예들에 따라, 전자 장치는, 제 2 어플리케이션이 외부 전자 장치를 제어할 수 있도록 사용자 입력에 응답하여 제 2 어플리케이션에 다중 관리자 (multi administration) 권한을 부여할 수 있다. 다양한 실시 예들에 따라, 외부 전자 장치의 온보딩 정보는, 외부 전자 장치의 제조사 ID (vendorid) 및 상기 외부 전자 장치에게 부여되는 고유 ID (productid)를 포함할 수 있다. 다양한 실시 예들에 따라, 전자 장치는 외부 전자 장치의 상기 온보딩 정보, 전자 장치에 설치된 운영 시스템 (operating system)에 대한 정보, 및/또는 전자 장치에 설치된 어플리케이션에 대한 정보에 기반하여 제 1 어플리케이션을 결정할 수 있다. 다양한 실시 예들에 따라, 전자 장치는 상기 외부 전자 장치의 상기 제조사 ID에 매핑된 인증서를 상기 제 1 서버로부터 수신하고, 상기 인증서에 기반하여 상기 제 2 어플리케이션을 결정할 수 있다. 다양한 실시 예들에 따라, 전자 장치는 상기 전자 장치에서 실행할 수 있는 어플리케이션에 대한 우선순위 정보를 상기 제 1 서버로부터 수신하고, 상기 외부 전자 장치의 상기 온보딩 정보 및 상기 어플리케이션에 대한 상기 우선순위 정보에 기반하여 상기 제 2 어플리케이션을 결정할 수 있다. 다양한 실시 예들에 따라, 전자 장치는 상기 외부 전자 장치의 QR 코드를 인식하는 카메라 및 상기 QR 코드에 기반한 정보 및 상기 외부 전자 장치에 대한 감지 정보에 기반하여 상기 외부 전자 장치의 상기 온보딩 정보를 획득하는 주변 기기 스캐너를 더 포함할 수 있다.
도 13은 본 개시의 일 실시 예에 따른 전자 장치의 동작 방법을 설명하기 위한 도면이다.
도 13을 참조하면, 전자 장치 (예를 들어, 도 1의 상기 전자 장치 (101), 도 3의 상기 전자 장치 (310), 도 4의 상기 전자 장치 (410), 도 5의 전자 장치 (510), 도 6a 내지 도 6c의 전자 장치 (610), 도 7의 상기 전자 장치 (710), 도 8의 전자 장치 (820), 또는 도 9의 전자 장치 (920))는 외부 전자 장치의 온보딩 (onboarding) 정보를 획득할 수 있다 (S1310 동작). 다양한 실시 예들에 따라, 전자 장치는 전자 장치에서 실행할 수 있는 어플리케이션 (application)에 대한 우선순위 정보를 서버로부터 수신할 수 있다 (S1320 동작). 다양한 실시 예들에 따라, 전자 장치는 외부 전자 장치의 온보딩 정보 및 어플리케이션에 대한 상기 우선순위 정보에 기반하여 외부 전자 장치를 제어하기 위한 어플리케이션 (application)을 결정하고, 상기 어플리케이션을 실행할 수 있다 (S1330 동작).
도 14는 본 개시의 일 실시 예에 따른 전자 장치의 동작 방법을 설명하기 위한 도면이다.
도 14를 참조하면, 전자 장치 (예를 들어, 도 1의 상기 전자 장치 (101), 도 3의 상기 전자 장치 (310), 도 4의 상기 전자 장치 (410), 도 5의 전자 장치 (510), 도 6a 내지 도 6c의 전자 장치 (610), 도 7의 상기 전자 장치 (710), 도 8의 전자 장치 (820), 또는 도 9의 전자 장치 (920))는 외부 전자 장치의 온보딩 (onboarding) 정보를 획득할 수 있다 (S1410 동작).
다양한 실시 예들에 따라, 전자 장치는 전자 장치에 제 1 어플리케이션 (application)이 설치되었는지 여부를 확인할 수 있다 (S1420 동작).
다양한 실시 예들에 따라, 전자 장치에 제 1 어플리케이션이 설치된 경우 (S1420 동작-예), 전자 장치는 제 1 어플리케이션을 실행하고 외부 전자 장치의 상기 온보딩 정보에 기반하여 제 1 어플리케이션과 독립적으로 상기 외부 전자 장치를 제어할 제 2 어플리케이션을 결정할 수 있다 (S1430 동작). 다양한 실시 예들에 따라, 제 1 어플리케이션과 독립적으로 외부 전자 장치를 제어할 제 2 어플리케이션은 외부 전자 장치의 제조사 ID (vendorid) 및 외부 전자 장치에게 부여되는 고유 ID (productid) 중에서 적어도 하나에 기반하여 결정될 수 있다.
다양한 실시 예들에 따라, 전자 장치에 제 1 어플리케이션이 설치되지 않은 경우 (S1420 동작-아니오), 전자 장치는 외부 전자 장치의 온보딩 정보를 서버로 전송하고, 서버로부터 상기 외부 전자 장치를 제어할 수 있는 어플리케이션 리스트를 수신할 수 있다 (S1440 동작). 다양한 실시 예들에 따라, 전자 장치는 어플리케이션 리스트에 기반하여 외부 전자 장치를 제어할 제 2 어플리케이션을 결정할 수 있다 (S1450 동작).
다양한 실시 예들에 따라, 전자 장치 (예를 들어, 도 1의 상기 전자 장치 (101), 도 3의 상기 전자 장치 (310), 도 4의 상기 전자 장치 (410), 도 5의 전자 장치 (510), 도 6a 내지 도 6c의 전자 장치 (610), 도 7의 상기 전자 장치 (710), 도 8의 전자 장치 (820), 또는 도 9의 전자 장치 (920))는 통신 모듈 (예를 들어, 도 1의 통신 모듈 (190)) 및 통신 모듈에 연결된 적어도 하나의 프로세서 (예를 들어, 도 1의 프로세서 (120))를 포함한다. 다양한 실시 예들에 따라, 적어도 하나의 프로세서는, 외부 전자 장치 (예를 들어, 도 1의 전자 장치 (102, 104), 도 3의 상기 클라우드-연결 장치들 (330), 도 4의 상기 클라우드-연결 장치들 (430) 또는 도 7의 외부 전자 장치 (720), 도 8의 외부 전자 장치 (820), 또는 도 9의 외부 전자 장치 (920))의 온보딩 (onboarding) 정보에 기반하여 외부 전자 장치를 제어하기 위한 제 1 어플리케이션 (예를 들어, 도 5의 어플리케이션 (515), 도 6a 내지 도 6c의 제 1 어플리케이션 (640), 도 8의 제 1 어플리케이션 (810), 또는 도 9의 어플리케이션 (910))을 결정하고, 외부 전자 장치를 제 1 어플리케이션에 대응하는 제 1 서버 (예를 들어, 도 6a 내지 도 6c의 서버 (630), 도 7의 상기 서버 (740), 도 8의 서버 (830), 도 9의 제 1 서버 (930))에 등록할 수 있다. 다양한 실시 예들에 따라, 적어도 하나의 프로세서는, 외부 전자 장치의 온보딩 정보에 기반하여 제 1 어플리케이션과 독립적으로 외부 전자 장치를 제어하기 위한 제 2 어플리케이션 (예를 들어, 도 6a 내지 도 6c의 제 2 어플리케이션 (650), 또는 도 8의 제 2 어플리케이션 (840))을 결정하고, 제 2 어플리케이션을 실행하도록 제어할 수 있다. 다양한 실시 예들에 따라, 적어도 하나의 프로세서는, 외부 전자 장치를 제 2 어플리케이션에 대응하는 제 2 서버에 등록하도록 제어할 수 있다. 다양한 실시 예들에 따라, 적어도 하나의 프로세서는, 제 2 어플리케이션이 외부 전자 장치를 제어할 수 있도록 사용자 입력에 응답하여 제 2 어플리케이션에 다중 관리자 (multi administration) 권한을 부여하도록 설정할 수 있다. 다양한 실시 예들에 따라, 외부 전자 장치의 온보딩 정보는 외부 전자 장치의 제조사 ID (vendorid) 및 외부 전자 장치에게 부여되는 고유 ID (productid)를 포함할 수 있다.
다양한 실시 예들에 따라, 적어도 하나의 프로세서는, 외부 전자 장치의 온보딩 정보, 전자 장치에 설치된 운영 시스템 (operating system)에 대한 정보, 및 전자 장치에 설치된 어플리케이션에 대한 정보에 기반하여 제 1 어플리케이션을 결정할 수 있다. 다양한 실시 예들에 따라, 적어도 하나의 프로세서는, 외부 전자 장치의 상기 제조사 ID에 매핑된 인증서를 제 1 서버로부터 수신하고, 수신한 인증서에 기반하여 제 2 어플리케이션을 결정할 수 있다. 다양한 실시 예들에 따라, 적어도 하나의 프로세서는, 전자 장치에서 실행할 수 있는 어플리케이션에 대한 우선순위 정보를 제 1 서버로부터 수신하고, 외부 전자 장치의 온보딩 정보 및 어플리케이션에 대한 우선순위 정보에 기반하여 제 2 어플리케이션을 결정할 수 있다. 다양한 실시 예들에 따라, 전자 장치는, 외부 전자 장치의 QR 코드를 인식하는 카메라, 및 QR 코드에 기반한 정보 및 외부 전자 장치에 대한 감지 정보에 기반하여 외부 전자 장치의 온보딩 정보를 획득하는 주변 기기 스캐너를 더 포함할 수 있다.
다양한 실시 예들에 따라, 적어도 하나의 프로세서는, 외부 전자 장치의 온보딩 (onboarding) 정보를 획득하고, 전자 장치에서 실행할 수 있는 어플리케이션 (application)에 대한 우선순위 정보를 서버로부터 수신할 수 있다. 다양한 실시 예들에 따라, 적어도 하나의 프로세서는, 외부 전자 장치의 온보딩 정보 및 어플리케이션에 대한 상기 우선순위 정보에 기반하여 외부 전자 장치를 제어하기 위한 어플리케이션 (application)을 결정 및/또는 실행할 수 있다.
다양한 실시 예들에 따라, 적어도 하나의 프로세서는, 외부 전자 장치의 온보딩 (onboarding) 정보를 획득하고, 전자 장치에 제 1 어플리케이션 (application)이 설치되었는지 여부를 확인할 수 있다. 다양한 실시 예들에 따라, 적어도 하나의 프로세서는, 전자 장치에 제 1 어플리케이션이 설치된 경우, 제 1 어플리케이션을 실행하고 외부 전자 장치의 온보딩 정보에 기반하여 제 1 어플리케이션과 독립적으로 외부 전자 장치를 제어할 제 2 어플리케이션을 결정할 수 있다. 다양한 실시 예들에 따라, 적어도 하나의 프로세서는, 전자 장치에 제 1 어플리케이션이 설치되지 않은 경우, 서버로부터 외부 전자 장치를 제어할 수 있는 어플리케이션 리스트를 수신하고, 수신한 어플리케이션 리스트에 기반하여 외부 전자 장치를 제어할 제 2 어플리케이션을 결정할 수 있다. 다양한 실시 예들에 따라, 적어도 하나의 프로세서는, 제 2 어플리케이션이 외부 전자 장치를 제어할 수 있도록 사용자 입력에 응답하여 제 2 어플리케이션에 다중 관리자 (multi administration) 권한을 부여하도록 설정할 수 있다.

Claims (15)

  1. 전자 장치에 있어서,
    통신 회로; 및
    상기 통신 회로에 연결된 적어도 하나의 프로세서를 포함하고,
    상기 적어도 하나의 프로세서는:
    외부 전자 장치의 온보딩 (onboarding) 정보에 기반하여 상기 외부 전자 장치를 제어하기 위한 제 1 어플리케이션 (application)을 결정하고,
    상기 외부 전자 장치를 상기 제 1 어플리케이션에 대응하는 제 1 서버에 등록하고,
    상기 외부 전자 장치의 상기 온보딩 정보에 기반하여 상기 제 1 어플리케이션과 독립적으로 상기 외부 전자 장치를 제어하기 위한 제 2 어플리케이션을 결정하고, 상기 제 2 어플리케이션을 실행하도록 설정되는, 전자 장치.
  2. 제1항에 있어서, 상기 적어도 하나의 프로세서는,
    상기 외부 전자 장치를 상기 제 2 어플리케이션에 대응하는 제 2 서버에 등록하도록 더 설정되는, 전자 장치.
  3. 제1항에 있어서,
    상기 제 2 어플리케이션이 상기 외부 전자 장치를 제어할 수 있도록 사용자 입력에 응답하여 상기 제 2 어플리케이션에 다중 관리자 (multi administration) 권한을 부여하도록 설정되는, 전자 장치.
  4. 제1항에 있어서,
    상기 외부 전자 장치의 상기 온보딩 정보는 상기 외부 전자 장치의 제조사 ID 및 상기 외부 전자 장치에게 부여되는 고유 ID를 포함하는, 전자 장치.
  5. 제4항에 있어서, 상기 적어도 하나의 프로세서는,
    상기 외부 전자 장치의 상기 온보딩 정보, 상기 전자 장치에 설치된 운영 시스템 (operating system)에 대한 정보, 및 상기 전자 장치에 설치된 어플리케이션에 대한 정보에 기반하여 상기 제 1 어플리케이션을 결정하도록 더 설정되는, 전자 장치.
  6. 제4항에 있어서, 상기 적어도 하나의 프로세서는,
    상기 외부 전자 장치의 상기 제조사 ID에 매핑된 인증서를 상기 제 1 서버로부터 수신하도록 더 설정되고,
    상기 인증서에 더 기반하여 상기 제 2 어플리케이션을 결정하도록 더 설정되는, 전자 장치.
  7. 제4항에 있어서, 상기 적어도 하나의 프로세서는,
    상기 전자 장치에서 실행할 수 있는 어플리케이션에 대한 우선순위 정보를 상기 제 1 서버로부터 수신하도록 더 설정되고,
    상기 외부 전자 장치의 상기 온보딩 정보 및 상기 어플리케이션에 대한 상기 우선순위 정보에 더 기반하여 상기 제 2 어플리케이션을 결정하도록 더 설정되는, 전자 장치.
  8. 제1항에 있어서,
    상기 외부 전자 장치의 QR(quick response) 코드를 인식하도록 설정되는 카메라; 및
    상기 QR 코드에 기반한 정보 및 상기 외부 전자 장치에 대한 감지 정보에 기반하여 상기 외부 전자 장치의 상기 온보딩 정보를 획득하도록 설정되는 주변 기기 스캐너를 더 포함하는, 전자 장치.
  9. 전자 장치에 있어서,
    통신 회로; 및
    상기 통신 회로에 연결된 적어도 하나의 프로세서를 포함하고,
    상기 적어도 하나의 프로세서는:
    외부 전자 장치의 온보딩 (onboarding) 정보를 획득하고,
    상기 전자 장치에서 실행할 수 있는 어플리케이션 (application)에 대한 우선순위 정보를 서버로부터 수신하고,
    상기 외부 전자 장치의 상기 온보딩 정보 및 상기 어플리케이션에 대한 상기 우선순위 정보에 기반하여 외부 전자 장치를 제어하기 위한 어플리케이션 (application)을 결정하고,
    상기 어플리케이션을 실행하도록 설정되는, 전자 장치.
  10. 제9항에 있어서,
    상기 외부 전자 장치의 상기 온보딩 정보는 상기 외부 전자 장치의 제조사 ID 및 상기 외부 전자 장치에게 부여되는 고유 ID를 포함하는, 전자 장치.
  11. 외부 전자 장치를 제어하기 위한 어플리케이션을 결정하는 전자 장치의 동작 방법에 있어서,
    상기 외부 전자 장치의 온보딩 (onboarding) 정보에 기반하여 상기 외부 전자 장치를 제어하기 위한 제 1 어플리케이션 (application)을 결정하는 동작;
    상기 외부 전자 장치를 상기 제 1 어플리케이션에 대응하는 제 1 서버에 등록하는 동작; 및
    상기 외부 전자 장치의 상기 온보딩 정보에 기반하여 상기 제 1 어플리케이션과 독립적으로 상기 외부 전자 장치를 제어하기 위한 제 2 어플리케이션을 결정하고, 상기 제 2 어플리케이션을 실행하는 동작을 포함하는, 방법.
  12. 제11항에 있어서,
    상기 외부 전자 장치를 상기 제 2 어플리케이션에 대응하는 제 2 서버에 등록하는 동작을 더 포함하는, 방법.
  13. 제11항에 있어서,
    상기 제 2 어플리케이션이 상기 외부 전자 장치를 제어할 수 있도록 사용자 입력에 응답하여 상기 제 2 어플리케이션에 다중 관리자 (multi administration) 권한을 부여하는 동작을 더 포함하는, 방법.
  14. 제11항에 있어서,
    상기 외부 전자 장치의 상기 온보딩 정보는 상기 외부 전자 장치의 제조사 ID (vendorid) 및 상기 외부 전자 장치에게 부여되는 고유 ID (productid)를 포함하는, 방법.
  15. 외부 전자 장치를 제어하기 위한 어플리케이션을 결정하는 전자 장치의 동작 방법에 있어서,
    외부 전자 장치의 온보딩 (onboarding) 정보를 획득하는 동작;
    상기 전자 장치에서 실행할 수 있는 어플리케이션 (application)에 대한 우선순위 정보를 서버로부터 수신하는 동작;
    상기 외부 전자 장치의 상기 온보딩 정보 및 상기 어플리케이션에 대한 상기 우선순위 정보에 기반하여 외부 전자 장치를 제어하기 위한 어플리케이션 (application)을 결정하는 동작; 및
    상기 어플리케이션을 실행하는 동작을 포함하는, 방법.
PCT/KR2022/016499 2021-10-27 2022-10-26 외부 전자 장치를 제어하는 어플리케이션을 결정하는 전자 장치 및 그 동작 방법 Ceased WO2023075425A1 (ko)

Priority Applications (2)

Application Number Priority Date Filing Date Title
EP22887621.5A EP4362430B1 (en) 2021-10-27 2022-10-26 Electronic device for determining application which controls external electronic device, and operation method thereof
US17/975,143 US12445820B2 (en) 2021-10-27 2022-10-27 Electronic device for determining application controlling external electronic device and method for operating the same

Applications Claiming Priority (4)

Application Number Priority Date Filing Date Title
KR10-2021-0144688 2021-10-27
KR20210144688 2021-10-27
KR1020210162312A KR20230060405A (ko) 2021-10-27 2021-11-23 외부 전자 장치를 제어하는 어플리케이션을 결정하는 전자 장치 및 그 동작 방법
KR10-2021-0162312 2021-11-23

Related Child Applications (1)

Application Number Title Priority Date Filing Date
US17/975,143 Continuation US12445820B2 (en) 2021-10-27 2022-10-27 Electronic device for determining application controlling external electronic device and method for operating the same

Publications (1)

Publication Number Publication Date
WO2023075425A1 true WO2023075425A1 (ko) 2023-05-04

Family

ID=86158221

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/KR2022/016499 Ceased WO2023075425A1 (ko) 2021-10-27 2022-10-26 외부 전자 장치를 제어하는 어플리케이션을 결정하는 전자 장치 및 그 동작 방법

Country Status (1)

Country Link
WO (1) WO2023075425A1 (ko)

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20140022254A (ko) * 2012-08-13 2014-02-24 삼성전자주식회사 클라우드 서버를 이용하여 단말 장치에서 웹 인텐트 메시지 및 이벤트를 처리하는 방법 및 장치
KR20160086332A (ko) * 2013-11-14 2016-07-19 퀄컴 인코포레이티드 물리적인 iot 디바이스를 식별하는 방법 및 장치
KR20160091663A (ko) * 2015-01-26 2016-08-03 삼성전자주식회사 멀티 플랫폼 기반의 어플리케이션 실행 방법 및 장치
KR20160149922A (ko) * 2015-06-19 2016-12-28 삼성전자주식회사 복수의 운영 체제를 지원하는 전자 장치 제어 방법
US20210075693A1 (en) * 2019-09-06 2021-03-11 Jpmorgan Chase Bank, N.A. Enterprise control plane for data streaming service

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20140022254A (ko) * 2012-08-13 2014-02-24 삼성전자주식회사 클라우드 서버를 이용하여 단말 장치에서 웹 인텐트 메시지 및 이벤트를 처리하는 방법 및 장치
KR20160086332A (ko) * 2013-11-14 2016-07-19 퀄컴 인코포레이티드 물리적인 iot 디바이스를 식별하는 방법 및 장치
KR20160091663A (ko) * 2015-01-26 2016-08-03 삼성전자주식회사 멀티 플랫폼 기반의 어플리케이션 실행 방법 및 장치
KR20160149922A (ko) * 2015-06-19 2016-12-28 삼성전자주식회사 복수의 운영 체제를 지원하는 전자 장치 제어 방법
US20210075693A1 (en) * 2019-09-06 2021-03-11 Jpmorgan Chase Bank, N.A. Enterprise control plane for data streaming service

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
See also references of EP4362430A4 *

Similar Documents

Publication Publication Date Title
WO2019221451A1 (en) Method and an electronic device connecting plurality of electronic devices to server through hub
WO2021075786A1 (en) Electronic device and method of processing pop-up window using multi-window thereof
WO2022030893A1 (ko) 오디오 공유를 지원하는 전자 장치
WO2022102960A1 (en) Electronic device for managing task relating to processing of audio signal, and operation method therefor
WO2021177640A1 (ko) 외부 전자 장치의 어플리케이션을 제어하는 방법 및 이를 지원하는 전자 장치
WO2023013839A1 (ko) 외부 전자 장치의 성능 정보에 기반하여 인터페이스의 동작 모드를 설정하는 전자 장치 및 전자 장치의 동작 방법
WO2022149763A1 (ko) 요청된 기능을 수행하는 외부 전자 장치를 관리하기 위한 전자 장치 및 그 작동 방법
WO2022065845A1 (ko) 입력 데이터 처리 방법 및 이를 지원하는 전자 장치
WO2022025692A1 (ko) 입력 기반 스트리밍 제어 방법 및 이를 위한 전자 장치
WO2022030860A1 (ko) Iot 환경에서 타겟 전자 장치를 제어하기 위한 전자 장치 및 그에 관한 방법
WO2022071665A1 (ko) 네트워크 환경에서 통화 대기 기능을 동기화하기 위한 전자 장치 및 그에 관한 방법
KR20230060405A (ko) 외부 전자 장치를 제어하는 어플리케이션을 결정하는 전자 장치 및 그 동작 방법
WO2023075425A1 (ko) 외부 전자 장치를 제어하는 어플리케이션을 결정하는 전자 장치 및 그 동작 방법
WO2024085728A1 (ko) 전자 장치 및 전자 장치에서 외부 전자 장치의 데이터를 업로드하는 방법
WO2023054905A1 (ko) 외부 전자 장치의 데이터를 활용하는 방법 및 전자 장치
WO2024039235A1 (ko) 전자 장치 및 전자 장치에서 사용자 인증을 수행하는 방법
WO2022225188A1 (ko) 스캔 듀티에 기반한 백 오프 처리 방법 및 장치
WO2022215935A1 (ko) 개인화된 그룹 서비스를 제공하는 전자 장치 및 그 제어 방법
WO2021256720A1 (ko) 외부 장치로 요청을 전송하는 방법 및 이를 지원하는 전자 장치
WO2022119133A1 (ko) 오토메이션 서비스를 지원하는 전자 장치
WO2022060092A1 (ko) 블루투스 통신을 위한 무선 통신 회로를 포함하는 전자 장치 및 그의 동작 방법
WO2023075337A1 (ko) 외부 전자 장치와 통신하는 전자 장치 및 그 동작 방법
WO2022154531A1 (ko) 위치 추적 완화를 위한 전자 장치, 방법 및 비 일시적 저장 매체
WO2024072117A1 (ko) 전자 장치 및 어플리케이션 간의 통신 방법
WO2022191540A1 (ko) 어플리케이션을 공유하는 전자 장치

Legal Events

Date Code Title Description
121 Ep: the epo has been informed by wipo that ep was designated in this application

Ref document number: 22887621

Country of ref document: EP

Kind code of ref document: A1

WWE Wipo information: entry into national phase

Ref document number: 2022887621

Country of ref document: EP

ENP Entry into the national phase

Ref document number: 2022887621

Country of ref document: EP

Effective date: 20240126

NENP Non-entry into the national phase

Ref country code: DE