Due to the insecure environment of the typical deployed vending machine (VM) location, the VM employs a series of physical security measures to prevent intrusion and unauthorized access to the VM. The basic method of access control is by securing the front door of the machine through the use of a heavy duty lock and key with limited access to the keys. The basic concept is to keep unauthorized users from accessing operational equipment inside the VM, such as a controller card, and manipulating sales price, inventory totals, and the like.
Features and advantages of embodiments of the present invention will become apparent from the appended claims, the following detailed description of one or more example embodiments, and the corresponding figures, in which:
In the following description, numerous specific details are set forth but embodiments of the invention may be practiced without these specific details. Well-known circuits, structures and techniques have not been shown in detail to avoid obscuring an understanding of this description. “An embodiment”, “various embodiments” and the like indicate embodiment(s) so described may include particular features, structures, or characteristics, but not every embodiment necessarily includes the particular features, structures, or characteristics. Some embodiments may have some, all, or none of the features described for other embodiments. “First”, “second”, “third” and the like describe a common object and indicate different instances of like objects are being referred to. Such adjectives do not imply objects so described must be in a given sequence, either temporally, spatially, in ranking, or in any other manner. “Connected” may indicate elements are in direct physical or electrical contact with each other and “coupled” may indicate elements co-operate or interact with each other, but they may or may not be in direct physical or electrical contact. Also, while similar or same numbers may be used to designate same or similar parts in different figures, doing so does not mean all figures including similar or same numbers constitute a single or same embodiment.
At times herein descriptions cover several different figures at once. For clarity, figures include components where the most significant value denotes the figure that includes the component (e.g., element 3XX would be found in
As mentioned above, due to the insecure environment of the typical deployed VM location, the VM employs a series of physical security measures to prevent intrusion and unauthorized access to the machine. In addition to physical locks, in an embodiment the VM may have one or more sensors to monitor the open/closed state of the VM door. These sensor(s) may be used by electronic and electro-mechanical devices within the VM to allow access to a protected set of commands and features. In this manner, certain functions such as sales price, actuation of mechanical systems, electronic records of inventory, and the like are enabled only when the door has been opened by what is presumably an authorized person.
Using the above system of access control, a standard part of the route driver's or technician's visit to a VM is to open the door, thereby enabling the acceptance of protected mode commands, and then either through manual entry or through the use of a hand-held controller, make updates to the VM that are only possible using the protected-mode commands. This may be a slow and somewhat error prone process with the person entering commands one by one from a worksheet. It may also be a slow and constricted process due to the need for the technician's physical presence, as well as the manual entry programming of the VM via a handheld device such as a tablet, cell phone, personal digital assistant, Smartphone, Ultrabook, notebook, laptop, mobile communications node, and the like. In addition, this manual process prevents the ability to dynamically program/adjust the VM itself due to the need for an on-site visit to the VM to enable programming
An embodiment leverages the inclusion of telemetry device(s) inside the VM with the ability to sense and control the door switch status to automate this manual process and convert it into an electronically monitored, centrally controlled activity. Furthermore, embodiments of the invention allow new and dynamic VM functionality/programming that enables, for example, variable pricing to match market demands, interactivity with the consumer, remote energy management and conservation, among other possibilities.
In an embodiment, protected mode commands (e.g., commands that may only be communicated to VMCC 105 during an open door state) may be transferred to VIU 115 from remote node 135 (e.g., remotely located central server that couples to many other VMs, a Smartphone wirelessly coupled to transceiver 120, a tablet, laptop, mobile communications node, and the like) over the wireless or mesh network 131 and transceiver 120 (see also
In an embodiment, DSIC 140 provides an electrically compatible switch status output that is coupled to a door sensor input of VMCC 105. This allows DSIC 140 to directly (or indirectly) drive door switch status (e.g., open, closed) to VMCC 105 regardless of the state of original door switch 110. In an embodiment, a connection from VIU 115 to switch 110 (e.g., an indirect connection or coupling between VIU 115 and switch 110 via DSIC 140) allows VIU 115 to sense the status of switch 110 (and, for example, communicate commands from VIU 115 to VMCC 105 upon detection of an open door state from switch 110). In an embodiment, a controlling input is used by VIU 115 to communicate desired door switch status to VMCC 105 (such as input 111 that couples to VMCC 105 via DSIC 140).
In an embodiment, DSIC 140 may be installed into VM 100 by terminating an existing two-wire door switch connection to sensor 110 and inserting the DISC in series between switch/sensor 110 and VMCC 105. Another connector from DSIC 140 may couple to VIU 115 (e.g., by interconnect 111), allowing the VIU to both sense the state of physical switch 110 and also define (e.g., override) the desired switch status that is sensed by VMCC.
In an embodiment, protected-mode commands may be initiated at any time and do not rely upon the need for a technician visit and an actual door open condition being sensed by sensor 110. Any desired commands (i.e., instructions, data, and the like) are communicated to VIU 115 from node 135 over a wireless or mesh network 131 along with, for example, time start, duration, and/or additional rules and details about how to deploy the commands.
In an embodiment, VIU 115 performs the following sequence of events to deploy a protected-mode command. As seen in
Thus, in an embodiment multiple commands may be queued for rules-based dispatch and/or the immediate deployment of a single, high-priority command as needed. An embodiment allows a fully-interactive session between VMCC 105, VIU 115, and node 135 such that real-time status may be used to drive the desired sequence of protected-mode commands.
There are numerous applications enabled by embodiments of the invention. For example, an embodiment remotely defines and executes protected mode commands on the VMCC, which opens a wide spectrum of valuable dynamic VM behavior. The following examples are not limiting and include: (1) Remote/Dynamic Price Changes—the ability to change product sales prices based upon policy, time, or other condition; (2) Remote Remediation—the correction of pricing, stocking, the remote reset of VMCC peripheral devices or other errors that have been detected; (3) Free Sample Promotions—the ability to execute marketing promotions based upon discounted or even free product based upon remotely defined rules and policies; (4) Customer Service—the ability to address a complaint from a customer for a product that was paid but not dispensed through the immediate vend function; (5) Energy Conservation—the ability to control the VM compressor and/or other high energy consumption devices allowing a VM “hibernation mode” during low usage hours; (6) Remote Display Messaging—the ability to update consumer-facing display content dynamically from the central server based upon policy and rules; (7) Technician Audit—the ability to track actual visit time and duration of a technician or salesman to a machine; and/or (8) Fraud Detection—in combination with the battery-powered VIU device, the ability to detect a power outage followed by an unauthorized door-open.
Note that there may be additional methods of sensing and/or simulating door switch events through other hardware connection methods.
Embodiments may be implemented in many different system types. Referring now to
Embodiments may be implemented in code and may be stored on storage medium having stored thereon instructions which can be used to program a system to perform the instructions. The storage medium may include, but is not limited to, any type of disk including floppy disks, optical disks, solid state drives (SSDs), compact disk read-only memories (CD-ROMs), compact disk rewritables (CD-RWs), and magneto-optical disks, semiconductor devices such as read-only memories (ROMs), random access memories (RAMs) such as dynamic random access memories (DRAMs), static random access memories (SRAMs), erasable programmable read-only memories (EPROMs), flash memories, electrically erasable programmable read-only memories (EEPROMs), magnetic or optical cards, or any other type of media suitable for storing electronic instructions.
Embodiments of the invention may be described herein with reference to data such as instructions, functions, procedures, data structures, application programs, configuration settings, code, and the like. When the data is accessed by a machine, the machine may respond by performing tasks, defining abstract data types, establishing low-level hardware contexts, and/or performing other operations, as described in greater detail herein. The data may be stored in volatile and/or non-volatile data storage. The terms “code” or “program” cover a broad range of components and constructs, including applications, drivers, processes, routines, methods, modules, and subprograms and may refer to any collection of instructions which, when executed by a processing system, performs a desired operation or operations. In addition, alternative embodiments may include processes that use fewer than all of the disclosed operations, processes that use additional operations, processes that use the same operations in a different sequence, and processes in which the individual operations disclosed herein are combined, subdivided, or otherwise altered. In one embodiment, use of the term control logic includes hardware, such as transistors, registers, or other hardware, such as programmable logic devices (535). However, in another embodiment, logic also includes software or code (531). Such logic may be integrated with hardware, such as firmware or micro-code (536). A processor or controller (e.g., VMCC 105) may include control logic intended to represent any of a wide variety of control logic known in the art and, as such, may well be implemented as a microprocessor, a micro-controller, a field-programmable gate array (FPGA), application specific integrated circuit (ASIC), programmable logic device (PLD) and the like. In some implementations, controller 105, 115 and the like are intended to represent content (e.g., software instructions, etc.), which when executed implements the features described herein
In an embodiment, reed-relay 605 serves to remove the interrupter from the circuit when VIU 115 power is lost. This allows for normal operation when the VIU has no power. When power is applied, the relay throws and VIU 115 is inserted into the circuit. U1 (opto-isolator) and D1 serve as isolation devices which prevent current flowing from the VMCC 105 to VIU 115.
DOOR PHYSICALLY CLOSED MODE: In normal operation with the VM door closed, the PULSE output is held high and the NC switch is also normally high. This causes the base of Q1 to rise and therefore Q1 becomes forward biased and switches on. This allows current to flow through the LED in U1 and turn on the transistor in U1. Current flowing through the transistor in U1 increases the voltage across R4 such that the base of Q2 is lowered to the point that it switches off. This is seen by VMCC 105 as a high-impedance or open circuit just as a switch open (door closed) would appear. Also in this state, when the collector of Q1 starts conducting, D2 becomes forward biased and the SENSE input of VIU 115 is pulled low such that VIU 115 also sees the door closed.
DOOR PHYSICALLY OPENED MODE: When the system is in the DOOR PHYSICALLY CLOSED MODE described above (the door is physically closed) and then the actual door is opened, the NC signal goes from high to low. This causes D3 to become forward-biased and conduct which pulls enough current through R1 that the base of Q1 is held low and Q1 does not conduct. This stops current through the LED in U1 and therefore the transistor in U1 is not conducting. This allows R4 to rise enough such that the base of Q2 becomes forward biased and Q2 switches on. This pulls the MACH input to ground and VMCC 105 sees the low state just as if it was sensing the actual switch closure (open door).
DOOR SIMULATED AS BEING OPEN MODE: When the system is in the DOOR PHYSICALLY CLOSED MODE described above (the door is physically closed) and VIU 115 wishes to simulate a door open, the PULSE output is lowered to zero. Just as above in the DOOR PHYSICALLY OPENED MODE, this causes D3 to be reverse biased and Q1 to switch off. VMCC 105 “sees” a switch closure (open door) without the actual switch changing state.
For
DOOR PHYSICALLY CLOSED MODE: In normal operation with door closed, PULSE is held HIGH and the NO signal is low at ground. This effectively grounds the emitter of Q1 allowing Q1 to switch on. This allows current to drive the LED and to switch on the transistor in U1. The current through the transistor in U1 increases the voltage across R4 which lowers the base of the PNP transistor Q2 which allows it to switch on. Q2 turning on effectively grounds the MACH input and the VMCC senses the switch closed state.
DOOR PHYSICALLY OPENED MODE: In the DOOR PHYSICALLY CLOSED MODE, when the door is opened the emitter of Q1 no longer has a path to ground and therefore switches off. This stops current through the LED in U1 and turns off the transistor in U1. This loss of current reduces the voltage across R4 and raises the base of Q2. Q2 switches off and the VMCC senses a high impedance or open-circuit (open door).
DOOR SIMULATED AS BEING OPEN MODE: When the system is in the DOOR PHYSICALLY CLOSED MODE described above (the door is physically closed) and VIU 115 wishes to simulate a door open state, the PULSE signal is forced low, this lowers the base of Q1 and Q1 switches off. Just as above, this eventually switches off Q2 and the VMCC “sees” the door switch change state (open door).
In an embodiment no door sensor is necessary. For example,
Further,
A module as used herein refers to any hardware, software, firmware, or a combination thereof. Often module boundaries (e.g., module 105, 115) that are illustrated as separate commonly vary and potentially overlap. For example, a first module and a second module may share hardware, software, firmware, or a combination thereof, while potentially retaining some independent hardware, software, or firmware. A control logic module may include VMCC 105, VIU 115, and DSIC 140 and/or sensor 110 and/or sensor 125 in separate packages or same packages.
An embodiment includes a vending machine comprising: a door; an inner compartment, coupled to the door, including at least one processor (e.g., VMCC 105 included in a module or distributed among several modules) and inventory space for vending products (e.g., cans of soda); a sensor (e.g., sensors 110, 125), coupled to the door, to determine when the door is open; a transceiver; and control logic (e.g., software and/or hardware in a module or distributed among several modules), coupled to the transceiver and at least one memory and including the sensor, to (a) receive instructions from a computing node, external to the vending machine, and store the instructions in the at least one memory; (b) communicate an open state signal to the at least one processor, the open state signal corresponding to a status of the door being open; and (c) communicate the instructions to the at least one processor in response to communicating the open state signal to the at least one processor; wherein the at least one processor is securely configured to accept the instructions in response to an indication that the door is open. An embodiment includes an additional sensor, coupled to the door, to detect when the door is open and to communicate an open state signal, corresponding to detecting when the door is open, to the control logic. In an embodiment the control logic is to communicate the open state signal to the at least one processor; and communicate the instructions to the at least one processor in response to the additional sensor detecting when the door is open. In an embodiment the control logic is to communicate the open state signal to the at least one processor independently of the sensor determining when the door is open. In an embodiment the control logic is to communicate the open state signal to the at least one processor when the door is closed. In an embodiment the control logic is to communicate the open state signal to the at least one processor in response to receiving the instructions from the computing node. For example, the open state signal may be issued (immediately or after a delay) once a system determines there are new instructions to load. In an embodiment the at least one processor is securely configured to accept the instructions only in response to an indication that the door is open and to reject the instructions in response to an indication that the door is closed. Such a rejection may include storing instructions in a memory but not displacing older instructions with similar newer instructions. In an embodiment the control logic is to store the instructions in the at least one memory when the door is closed and before communicating the open state signal to the at least one processor. In an embodiment the sensor couples to the at least one processor via a first route and the control logic communicates the open state signal to the at least one processor via the first route. In an embodiment the instructions correspond to at least one of a sales price, an inventory level, and energy conservation.
An embodiment includes control logic, to couple to a transceiver of a vending machine (VM), at least one memory, and a sensor to couple to a door of the VM and determine when the door is open, the control logic to: (a) receive instructions from a computing node, external to the VM, and store the instructions in the at least one memory; (b) communicate an open state signal to at least one processor included in the VM, the open state signal corresponding to a status of the door being open; and (c) communicate the instructions to the at least one processor in response to communicating the open state signal to the at least one processor; wherein the at least one processor is securely configured to accept the instructions in response to an indication that the door is open. Thus, an embodiment may include a component that may be added to a new or preexisting (already deployed in the field) VM that is being upgraded. An embodiment may include an additional sensor, to couple to the door, to detect when the door is open and to communicate an open state signal, corresponding to detecting when the door is open, to the control logic. In and embodiment the control logic is to communicate the open state signal to the at least one processor; and communicate the instructions to the at least one processor in response to the additional sensor detecting when the door is open. In and embodiment the control logic is to communicate the open state signal to the at least one processor independently of the sensor determining when the door is open. In an embodiment the control logic is to communicate the open state signal to the at least one processor when the door is closed. In an embodiment the control logic is to communicate the open state signal to the at least one processor in response to receiving the instructions from the computing node. In and embodiment the at least one processor is securely configured to accept the instructions only in response to an indication that the door is open and to reject the instructions in response to an indication that the door is closed. (a) the control logic is to communicate the open state signal to the at least one processor in response to the sensor determining when the door is open, and (b) the sensor is to couple to the at least one processor via a first route and the control logic communicates the open state signal to the at least one processor via a second route. In an embodiment the control logic is to store the instructions in the at least one memory when the door is closed and before communicating the open state signal to the at least one processor. In and embodiment the sensor is to couple to the at least one processor via a first route and the control logic communicates the open state signal to the at least one processor via the first route. In and embodiment the instructions correspond to at least one of a sales price, an inventory level, and energy conservation. In and embodiment the at least one processor is securely configured to only accept the instructions in response to an indication that the door is open and the sensor is included in the control logic.
An embodiment includes a system comprising: control logic, to couple to a transceiver of a vending machine (VM), at least one memory, and at least one controller included in the VM, the control logic to: (a) receive instructions from a computing node, external to the VM, and store the instructions in the at least one memory; (b) receive a first enablement communication from one of the computing node and an additional computing node that is external to the VM; (c) communicate a second enablement communication to the at least one controller in response to receiving the first enablement communication; and (d) communicate the instructions to the at least one controller in response to communicating the second enablement signal to the at least one controller; wherein the at least one controller is securely configured to accept the instructions only in response to receiving the second enablement signal. Thus, an embodiment may receive a signal (e.g., a near field communication from a nearby technician standing close to the VM) that indicates a programming is safe an appropriate for the controller. The communication may be secure and traceable to a reliable source based on security certificates and encryption mechanisms (e.g., symmetric or asymmetric keys). Based on receiving the signal or communication (e.g., a digital or analog signal, an instruction, a data packet, and the like) logic may send further communications to the controller (or controllers) to configure itself to receive instructions. In an embodiment the control logic is to communicate the second enablement communication to the at least one controller when a door of the VM is closed, the door providing access to inventory to be included in the VM. In and embodiment the control logic is to communicate the second enablement communication to the at least one controller when a door of the VM is open, the door providing access to inventory to be included in the VM.
An embodiment includes a system comprising: control logic to (a) couple to at least one controller included in a vending machine (VM); (b) receive a first enablement communication from one of a computing node external to the VM and sensor logic that determines a door of the VM is open; and (c) communicate a second enablement communication to the at least one controller in response to receiving the first enablement communication; wherein the at least one controller is securely configured to accept configuration instructions only in response to receiving the second enablement communication. Thus, an embodiment may concern itself more with communicating instruction acceptance enabling signals and not concern itself with conveyance of the programmable instructions themselves (e.g., instructions conveyed via interconnect 112). In an embodiment the control logic is to communicate the second enablement communication to the at least one controller when the door of the VM is closed.
An embodiment includes a system comprising: control logic, to couple to a transceiver of a vending machine (VM), at least one memory, at least one controller included in the VM, and additional control logic; wherein (a) the additional control logic is to receive instructions from a computing node, external to the VM, and store the instructions in the at least one memory; (b) the control logic is to receive a first enablement communication from one of the computing node and an additional computing node that is external to the VM; (c) the control logic is to communicate a second enablement communication to the at least one controller in response to receiving the first enablement communication; (d) the additional control logic is to communicate the instructions to the at least one controller in response to communicating the second enablement signal to the at least one controller; and (e) the at least one controller is securely configured to accept the instructions only in response to receiving the second enablement signal. In an embodiment the control logic is included in the DSIC and any related software or hardware in the same module as the DSIC or external to any DSIC module (e.g., in a portion of the VIU) and the additional logic is included in, for example, the VIU (e.g., another portion of the VIU). In another embodiment the control logic includes sensor 125 and related software or hardware in the same module or external thereto (e.g., in a portion of the VIU or located outside sensor 125 and VIU) and the additional logic is included in, for example, the VIU (e.g., another portion of the VIU) or external to the VIU and sensor 125.
While the present invention has been described with respect to a limited number of embodiments, those skilled in the art will appreciate numerous modifications and variations therefrom. It is intended that the appended claims cover all such modifications and variations as fall within the true spirit and scope of this present invention.