The present disclosure generally relates to information handling systems (IHS) and in particular to an advanced message queuing protocol (AMQP) message brokering within information handling systems.
As the value and use of information continue to increase, individuals and businesses seek additional ways to process and store information. One option available to users is information handling systems. An information handling system (IHS) generally processes, compiles, stores, and/or communicates information or data for business, personal, or other purposes, thereby allowing users to take advantage of the value of the information. Because technology and information handling needs and requirements vary between different users or applications, information handling systems may also vary regarding what information is handled, how the information is handled, how much information is processed, stored, or communicated, and how quickly and efficiently the information may be processed, stored, or communicated. The variations in information handling systems allow for information handling systems to be general or configured for a specific user or specific use such as financial transaction processing, airline reservations, enterprise data storage, or global communications. In addition, information handling systems may include a variety of hardware and software components that may be configured to process, store, and communicate information and may include one or more computer systems, data storage systems, and networking systems.
The advanced message queuing protocol (AMQP) standard defines how clients should interact with an IHS server operating as a message broker. However, the AMQP standard offers little guidance to optimum practices for dealing with asynchronous messaging paradigms. Additionally, the protocol and common AMQP clients are designed with very low level message propagation and processing aspects that are orthogonal to the development of the various lines of business applications.
Traditional approaches to the challenges involving interactions between clients and a message broker include using a heavily weighted component that attempts to provide asynchronous workflows through many different types of back-ends. As a result, these approaches can only provide limited functionality. In addition, all messaging entities and infrastructure (i.e., artefacts) must be defined and established manually, or via embedded code prior to running the corresponding application. Finally, the traditional approaches generate raw messages that comprise several multiples of the payload size generated in additional message broker message headers.
Disclosed are a method and an information handling system (IHS) that transforms an initial message having an identified protocol format to an encapsulated message having an advanced message queuing protocol (AMQP) format. A dynamic message brokering (DMB) module interacts with an AMQP client application to generate a binding key and a routing key corresponding to message attributes of the initial message. The DMB module dynamically applies one or more of the binding key and the routing key to respective programming command modules, including a provider module, to generate an AMQP client message which is forwarded to an AMQP server. The AMQP server creates a queue for messages having attributes that are identifiable within the received client message, and uses the binding key to bind the queue to a specified exchange. The AMQP server routes the received client message to the queue, using the routing key, enabling subscribers to retrieve the messages.
The above summary contains simplifications, generalizations and omissions of detail and is not intended as a comprehensive description of the claimed subject matter but, rather, is intended to provide a brief overview of some of the functionality associated therewith. Other systems, methods, functionality, features and advantages of the claimed subject matter will be or will become apparent to one with skill in the art upon examination of the following figures and detailed written description.
The description of the illustrative embodiments can be read in conjunction with the accompanying figures. It will be appreciated that for simplicity and clarity of illustration, elements illustrated in the figures have not necessarily been drawn to scale. For example, the dimensions of some of the elements are exaggerated relative to other elements. Embodiments incorporating teachings of the present disclosure are shown and described with respect to the figures presented herein, in which:
The illustrative embodiments provide a method and an information handling system (IHS) that transforms an initial message having an identified protocol format to an encapsulated message having an advanced message queuing protocol (AMQP) format. A dynamic message brokering (DMB) module interacts with an AMQP client application to generate a binding key and a routing key corresponding to message attributes of the initial message. The DMB module dynamically applies one or more of the binding key and the routing key to respective programming command modules, including a provider module, to generate an AMQP client message which is forwarded to an AMQP server. The AMQP server creates a queue for messages having attributes that are identifiable within the received client message, and uses the binding key to bind the queue to a specified exchange. The AMQP server routes the received client message to the queue, using the routing key, enabling subscribers to retrieve the messages.
In the following detailed description of exemplary embodiments of the disclosure, specific exemplary embodiments in which the disclosure may be practiced are described in sufficient detail to enable those skilled in the art to practice the disclosed embodiments. For example, specific details such as specific method orders, structures, elements, and connections have been presented herein. However, it is to be understood that the specific details presented need not be utilized to practice embodiments of the present disclosure. It is also to be understood that other embodiments may be utilized and that logical, architectural, programmatic, mechanical, electrical and other changes may be made without departing from general scope of the disclosure. The following detailed description is, therefore, not to be taken in a limiting sense, and the scope of the present disclosure is defined by the appended claims and equivalents thereof.
References within the specification to “one embodiment,” “an embodiment,” “embodiments”, or “one or more embodiments” are intended to indicate that a particular feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment of the present disclosure. The appearance of such phrases in various places within the specification are not necessarily all referring to the same embodiment, nor are separate or alternative embodiments mutually exclusive of other embodiments. Further, various features are described which may be exhibited by some embodiments and not by others. Similarly, various requirements are described which may be requirements for some embodiments but not other embodiments.
It is understood that the use of specific component, device and/or parameter names and/or corresponding acronyms thereof, such as those of the executing utility, logic, and/or firmware described herein, are for example only and not meant to imply any limitations on the described embodiments. The embodiments may thus be described with different nomenclature and/or terminology utilized to describe the components, devices, parameters, methods and/or functions herein, without limitation. References to any specific protocol or proprietary name in describing one or more elements, features or concepts of the embodiments are provided solely as examples of one implementation, and such references do not limit the extension of the claimed embodiments to embodiments in which different element, feature, protocol, or concept names are utilized. Thus, each term utilized herein is to be given its broadest interpretation given the context in which that term is utilized.
Those of ordinary skill in the art will appreciate that the hardware, firmware/software utility, and software components and basic configuration thereof depicted in the following figures may vary. For example, the illustrative components of the IHS are not intended to be exhaustive, but rather are representative to highlight some of the components that are utilized to implement certain of the described embodiments. For example, different configurations of an IHS may be provided, containing other devices/components, which may be used in addition to, or in place of, the hardware depicted, and may be differently configured. The depicted example is not meant to imply architectural or other limitations with respect to the presently described embodiments and/or the general invention.
Referring specifically to
IHS 100 also comprises a network interface device (NID) 132. NID 132 enables IHS 100 to communicate and/or interface with other devices, services, and components that are located external to IHS 100. These devices, services, and components can interface with IHS 100 via an external network, such as example network 136, using one or more communication protocols. In particular, in one implementation, IHS 100 uses NID 132 to connect (indirectly) to remote IHS 140 via an external network, such as network 136. In the presented embodiments, remote IHS 140 is an example AMQP server.
Network 136 can be a wired local area network, a wireless wide area network, wireless personal area network, wireless local area network, and the like, and the connection to and/or between network 136 and IHS 100 can be wired or wireless or a combination thereof. For purposes of discussion, network 136 is indicated as a single collective component for simplicity. However, it is appreciated that network 136 can comprise one or more direct connections to other devices as well as a more complex set of interconnections as can exist within a wide area network, such as the Internet.
Publisher and subscriber 202, 208 include AMQP client messaging applications 204, 210 which further includes modules 206, 212, respectively. For example, modules 206, 212 include a provider creation module, a subscriber creation module, an exchange creation module, failure detection, and failover (FDF) module and various other functional modules described herein. Applications 204, 210 further comprise DMB modules 207, 214, respectively, separately identified as DMB module A 207 and DMB module B 214. DMB modules 207, 214 can selectively activate one or more modules within modules 206, 212 to support client messaging interactions.
Applications 204, 210 running on publisher and subscriber (clients) 202, 208 are able to dynamically issue, interpret and/or respond to programming instructions. According to one aspect, processor 102 (
As described herein, the program command based protocol refers to issuing of instructions using programming code, which includes classes, where each class covers a particular functionality and has a respective set of methods, the methods being operations. For example, the exchange class is a group of methods related to operations on exchanges, and a queue class is a group of methods related to operations on queues. Thus, AMQP is a programmable protocol in the sense that AMQP entities and routing schemes are defined by applications, and not by a broker administrator. Accordingly, DMB module 114 (
According to one or more aspects, application 204 uses one or more message attributes to dynamically provide a messaging infrastructure that support client interactions. In particular, application 204 receives a first message from a client (not shown) and identifies one or more message attributes. The first message is provided using a first (client) application protocol. For example, in one implementation, the first application protocol corresponds to a .Net application. Application 204 generates a binding key and a routing key corresponding to the one or more message attributes. Application 204 includes an exchange creation sub-component/module (206) which application 204 utilizes to send corresponding programming commands to AMQP server 140 to enable AMQP server 140 to dynamically provide/create an exchange corresponding the one or more message attributes. Application 204 includes a set of established classes which includes programming commands corresponding to a program command based protocol. AMQP server 140 uses the routing key to route the message via the exchange to one or more subscriber queues. According to one or more aspects, applications 204, 210 use a provider registration and/or a subscriber registration request to trigger AMQP server 140 to generate the exchange and a message queue, and to bind the exchange to the message queue.
In order for IHS/AMQP server 140 operating as a single broker to host multiple isolated “environments” (e.g., groups of users, exchanges, queues, etc.), AMQP server 140 can provide multiple virtual hosts (vhosts) which provide completely isolated environments in which AMQP entities operate. AMQP clients specify what vhosts they want to use during AMQP connection negotiation.
According to one or more aspects, application 210 receives, from a client, a first request for subscription to messages having a specified message type. The request is provided using the first/client application protocol. Application 210 identifies the client as a subscriber based on the request. Application 210 translates the first request created using the first application protocol to a second request that utilizes the AMQP format. Application 210 utilizes the specified message type to perform the generation of a binding key. Applications 204, 210 sends the second request to AMQP server 140 to enable AMQP server 140 to create a queue designated for storing messages having the specified message type. In addition, AMQP server 140 uses the binding key to automatically bind the queue to the exchange that receives the message from the sender/publisher. As a result of binding the queue to the exchange, AMQP server 140 performs the routing by forwarding the message having the specified message type identifier from the message queue to the subscriber.
According to one or more aspects, when binding the queue to the shared command exchange, the binding key, such as “Invoice.Issued.#”, is utilized. As a result, all messages published to that exchange that have a routing key starting with “Invoice.Issued” and then 0 or more “.” delimited components will be accepted. A wild card for matching “IssueInvoiceCommand messages can be used, whilst also allowing for other queues to be created outside this process that can use more specific bindings, and thereby receive a subset of the overall “IssueInvoiceCommands”.
The Message Binding Key attribute, illustrated in program module 300 (
According to one or more aspects, application 204 receives from a client a request to publish event messages. Application 204 includes multiple provider factory modules which include a first provider factory module for creating a first provider for event messages and a second provider factory module for creating a second provider for command messages. The first provider publishes events while a second provider delegates commands. More particularly, a published event is received by all consumers/listeners, while a provided command is received by only one consumer. Application 204 allows a client to use events to notify consumers when there has been an change in an entity that meets certain pre-established interest criteria. For example, application 204 can publish an event indicating that an invoice status changes from “pending” to “paid”. On the other hand, application 204 allows a client to use a command to send an instruction to execute a process. For example, application 204 can delegate a command requesting that a client issues a payment confirmation email. Application 204 uses first provider factory module, from within modules 206, to create a provider for handling event messages, and enables the client to operate as a publisher that is able to publish event messages. Application 204 sends the event message to AMQP server 140. AMQP server 140 utilizes a message routing key/identifier to route the received event message to an appropriate message queue. At a receiving subscriber client device, DMB module 214 uses an interface module to enable subscriber 208 to receive a notification of the event message transmitted by publisher 202. Subscriber 208 is able to retrieve message 226 from assigned message queue 224.
According to one or more aspects, using the distributed command provider module, AMQP client applications 204, 210 provide functionality for sending and receiving messages until applications 204, 210 dispose of tokens that allow the client applications to receive commands via the application provider. Applications 204, 210 utilize/include a corresponding token management module to create the tokens and to handle disposal of the tokens. Applications 204 and 210 respectively utilize queuing status modules (from within modules 206 and 212) to perform one of (a) removal of a message from a queue; (b) re-queuing a message; and (c) prevention of message re-queuing for a message that could not be processed.
According to one or more aspects, application 204 receives a request for a distributed event provider corresponding to a specific message class, and application 204 utilizes/includes provider creation module 206 that can be used to send and receive distributed event messages. Provider creation modules 206, 212 enable the client to operate as a publisher/subscriber with one or more of distributed event publishing capabilities and distributed event receiving capabilities for a message class that is specified in the request for the distributed event provider. Furthermore, provider creation module 206, 212 selectively enables one of (a) the event messages to be sent individually and (b) the event messages to be aggregated before sending as one or more aggregated blocks. Applications 204, 210 enable both event messages and command messages to use the same pattern for requesting a provider for an individual class of message.
According to one or more aspects, application 210 utilizes/includes subscriber creation module (212) that can be used to enable a client to subscribe to distributed event messages and receive published events. Subscriber creation module 212 includes an interface module that allows messaging libraries to notify a subscriber application when a message has been received. In addition, subscriber creation module 212 selectively enables the client to receive event messages on one of (a) a per application basis where a single queue is created for a corresponding application, and all application nodes can consume from the single queue, and (b) a per application node basis, where a new queue is created for each application node, using a naming mechanism that will prevent collision with other active application nodes. For example, a machine name and a process identifier can be used as differentiators.
According to one or more aspects, application 204 utilizes event broadcast module (206) to allow the application to publish an event which is a broadcast message that provides state change notification to subscribers, and for one or more subscribers to receive the state change notification of the published event via a respective provider. Event broadcast module (206, 212) enable each subscriber to be added and to be removed independently of an instantiation/registration of the publisher.
DMB module 207 activates provider creation module (206) to enable a client to operate as a sender/publisher. Provider creation module 206 includes channel and connection management (CCM) module (206) that (a) maintains communication channels, (b) tracks and logs commands issued to setup a communication infrastructure and (c) minimizes a number of redundant calls to setup entities, which include exchanges, queues and bindings. CCM module 206 is securely able to selectively close channels when corresponding tokens for registering a client as a subscriber are subsequently disposed of. Publisher and/or subscriber applications 204, 210 is used to create the tokens and to dispose of the tokens.
Publisher and/or subscriber applications 204, 210 determine whether a node failure is detected using failure detection and failover (FDF) module (206, 212). In response to publisher and/or subscriber applications 204, 210 determining that a node failure has been detected, publisher and/or subscriber applications 204, 210 perform a failover via an alternate node. Publisher and/or subscriber applications 204, 210 perform the failover by re-issuing/replaying module instructions associated with establishing one or more of exchanges, queues and bindings in a temporal order in which these instructions were previously issued prior to the failure.
According to one embodiment of the disclosure, the AMQP Client Application acts as a message subscriber and provides an instruction to register as a subscriber, the provided instruction being enriched with an expression to filter messages by specifying desired/established values for individual message properties, whereby those message properties have one or more message related attributes. Also, in the example embodiment, the AMQP server is configured to create a bespoke binding key and corresponding AMQP queue that results in a subscriber being able to receive only a subset of published messages. Thus, with this embodiment, the AMQP server performs filtering and routing of incoming messages instead of having this functionality being provided by the publishing or subscribing client applications.
According to one or more aspects, application 204 is able to send a distributed command message by serializing the message, with MessageBindingKey decorated properties going into the routing key while other properties are serialized and then converted into a byte array. Application 204 translates provider instructions (e.g., a set of .Net instructions) into AMQP commands. In addition to opening and subsequently closing a communication channel, application 204 when required can issue an exchange declaration command and a message publishing command. For example application 204 issues the exchange declaration command and the message publishing command as provided here:
The initial exchange declaration (i.e., “Exchange.Declare( . . . )”) happens only the first time the provider is invoked for a sequence of associated message transmissions/exchanges. The “SharedCommandExchangeName” is a variable that is kept in the application configuration. The “Invoice.Issued.abc.{Guid}” is the generated routing key for the message.
According to one or more aspects, a lambda expression is programming code that passes functionality as an argument to another method (i.e., a block of code), such as to indicate an action that should occur in response to a specified event. Thus, a lambda expression enables functionality to be treated as a method argument, or code as data. By using lambda expressions, one can write local functions that can be passed as arguments or returned as the value of function calls. As an anonymous function, a lambda expression which can be used to define an inline function can be written inside another function. For example, a lambda expression can be used to define an inline implementation of a functional interface.
In order to allow a client to participate in distributed event messaging and receive published events, application 210 creates an observer message class. The interface associated with and/or implemented by the observer message class is the “IDistributedStateObserver <TObservableStateChange>interface”, and “TObservableStateChange” is the class of message that will be received. As a result of the creation of the observer message class, the messaging libraries can notify the application when a message has been received.
In addition to providing commands directly associated with receiving messages, application 210 issues commands for establishing a connection/channel to enable a subscriber to receive messages. For example, publisher and/or subscriber applications 204, 210 may issue a “Channel.Open” command to establish the channel. The connection can be subsequently terminated by using a “Channel.Close” command. In setting up the infrastructure, DMB module 207/application 204 can dynamically issue a number of commands including an “Exchange.Declare( . . . )” command (i.e., an exchange declaration/creation command), a “Queue.Declare” command, and a “Queue.Bind ( . . . )” command. For example, the queue declaration can be provided using the following: “Queue.Declare(“SampleMessaging.App<Events.SampleStateChange”, 0, 1, 0, 0, 0, null)”, where application 204, 210 combine the executing application's name with the message type name. Furthermore, the exchange declaration can be provided using the following: “Exchange.Declare(“Sample.Entity”, “topic”, 0, 0, 0, 0, 0, null)”. To enable, a subscriber/consumer to receive the event message via the dynamically created infrastructure, application 210 can issue a “Basic.Consume( . . . )” command. For example, according to a per application subscription, application 210 issues the following: “Basic.Consume(“SampleMessaging.App<Events.SampleStateChange”, {consumer-tag})”. However, according to a per application node subscription, application 210 issues the following commands:
Method 600 begins at the start block and proceeds to block 602. At block 602, application 204, using DMB 207, creates a provider via a provider factory designated for a targeted message type. Using the provider, application 204 receives, via a first application protocol, a first message from a publisher, where the first message provides one or more message attributes (block 604). Using an exchange creation module, application 204 provides programming commands to configure AMQP server/broker 140 for handling the specific message type and/or to trigger AMQP server 140 to determine whether AMQP server/broker 140 has already been configured to handle the specified message type (decision block 606). According to one aspect of the disclosure, AMQP server/broker 140 is configured to handle the specific message type when a client application 204/210 provides AMQP instructions that enable AMQP server 140 to dynamically establish/create an exchange corresponding to the one or more message attributes. According to one or more aspects, publishing application 204 provides the programming commands to enable the establishment of the exchange. However, subscriber application 210 can separately provide programming commands to establish the exchange. In any case, AMQP server 140 enables only a one time creation of the exchange. If the exchange was not already established, the process proceeds to block 702 (
Method 700 starts at block 606 (
Method 800 begins at the start block and proceeds to block 802 at which subscriber application 210, using DMB 214, obtains a distributed state provider via an appropriate provider factory for a specific message type. Using the distributed state provider, application 210 receives, via a first application protocol, a first registration of an observer (i.e., a receiving client) for the specific message type (block 804). Using an exchange creation module, application 204 provides programming commands (block 805) to configure AMQP server/broker 140 for handling the specific message type and/or to trigger AMQP server 140 to determine whether AMQP server/broker 140 has already been configured to handle the specified message type (decision block 806). According to one aspect of the disclosure, AMQP server/broker 140 is configured to handle the specific message type when a client application 204/210 provides AMQP instructions that enable AMQP server 140 to dynamically establish/create an exchange corresponding to the one or more message attributes. According to one or more aspects, subscribing application 210 provides the programming commands to enable the establishment of the exchange. However, publisher application 204 can separately provide programming commands to establish the exchange. In any case, AMQP server 140 enables only a one-time creation of the exchange. If at decision block 806 the exchange was already established enabling AMQP server to be configured to handle the specified message type, the process proceeds to block 810. If the exchange was not already established, the process proceeds to block 808, at which DMB 214 generates a binding key for a specified message type in accordance with one or more message attributes. Following block 808, application 210 receives notification via the provider that a message corresponding to the one or more message attributes is located within the message queue at AMQP server 140 (block 810). According to one embodiment, the process can proceed to block 702 (
Method 900 begins at the start block and proceeds to block 902 at which DMB module 207 activates a failure detection and failover (FDF) module (206) of application 204 (block 902). DMB module 207/application 204 determines whether node failure has been detected, using FDF module 206 (decision block 904). In response to determining that a node failure has not been detected, application 204 maintains messaging operations on a current application node (block 906). However, in response to determining that a node failure has been detected, using FDF module 206, application 204 performs a failover using an alternate node, where instructions associated with establishing one or more of exchanges, queues, and bindings can be re-issued/replayed in an order in which instructions were issued prior to the failure (block 908). The process concludes at the end block.
In the above described flow charts, one or more of the methods may be embodied in a computer readable device containing computer readable code such that a series of functional processes are performed when the computer readable code is executed on a computing device. In some implementations, certain steps of the methods are combined, performed simultaneously or in a different order, or perhaps omitted, without deviating from the scope of the disclosure. Thus, while the method blocks are described and illustrated in a particular sequence, use of a specific sequence of functional processes represented by the blocks is not meant to imply any limitations on the disclosure. Changes may be made with regards to the sequence of processes without departing from the scope of the present disclosure. Use of a particular sequence is therefore, not to be taken in a limiting sense, and the scope of the present disclosure is defined only by the appended claims.
Aspects of the present disclosure are described above with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems) and computer program products according to embodiments of the disclosure. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer program instructions. Computer program code for carrying out operations for aspects of the present disclosure may be written in any combination of one or more programming languages, including an object oriented programming language, without limitation. These computer program instructions may be provided to a processor of a general purpose computer, special purpose computer such as a service processor, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, performs the method for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
As will be further appreciated, the processes in embodiments of the present disclosure may be implemented using any combination of software, firmware or hardware. Accordingly, aspects of the present disclosure may take the form of an entirely hardware embodiment or an embodiment combining software (including firmware, resident software, micro-code, etc.) and hardware aspects that may all generally be referred to herein as a “circuit,” “module,” or “system.” Furthermore, aspects of the present disclosure may take the form of a computer program product embodied in one or more computer readable storage device(s) having computer readable program code embodied thereon. Any combination of one or more computer readable storage device(s) may be utilized. The computer readable storage device may be, for example, but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, or device, or any suitable combination of the foregoing. More specific examples (a non-exhaustive list) of the computer readable storage device would include the following: an electrical connection having one or more wires, a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), an optical fiber, a portable compact disc read-only memory (CD-ROM), an optical storage device, a magnetic storage device, or any suitable combination of the foregoing. In the context of this document, a computer readable storage device may be any tangible medium that can contain, or store a program for use by or in connection with an instruction execution system, apparatus, or device.
While the disclosure has been described with reference to exemplary embodiments, it will be understood by those skilled in the art that various changes may be made and equivalents may be substituted for elements thereof without departing from the scope of the disclosure. In addition, many modifications may be made to adapt a particular system, device or component thereof to the teachings of the disclosure without departing from the essential scope thereof. Therefore, it is intended that the disclosure not be limited to the particular embodiments disclosed for carrying out this disclosure, but that the disclosure will include all embodiments falling within the scope of the appended claims. Moreover, the use of the terms first, second, etc. do not denote any order or importance, but rather the terms first, second, etc. are used to distinguish one element from another.
The terminology used herein is for the purpose of describing particular embodiments only and is not intended to be limiting of the disclosure. As used herein, the singular forms “a”, “an” and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise. It will be further understood that the terms “comprises” and/or “comprising,” when used in this specification, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or groups thereof.
The description of the present disclosure has been presented for purposes of illustration and description, but is not intended to be exhaustive or limited to the disclosure in the form disclosed. Many modifications and variations will be apparent to those of ordinary skill in the art without departing from the scope of the disclosure. The described embodiments were chosen and described in order to best explain the principles of the disclosure and the practical application, and to enable others of ordinary skill in the art to understand the disclosure for various embodiments with various modifications as are suited to the particular use contemplated.
Number | Name | Date | Kind |
---|---|---|---|
7974966 | Robie | Jul 2011 | B2 |
20100150139 | Lawson | Jun 2010 | A1 |
20110286444 | Petrovykh | Nov 2011 | A1 |
20120246337 | Ross | Sep 2012 | A1 |
20130205028 | Crockett | Aug 2013 | A1 |
20140351371 | Smith et al. | Nov 2014 | A1 |
20150256535 | Abbate | Sep 2015 | A1 |
20160174148 | Seed | Jun 2016 | A1 |
20160248871 | Seed | Aug 2016 | A1 |
20170118247 | Hussain | Apr 2017 | A1 |
20180115528 | Rotvold | Apr 2018 | A1 |
20180167476 | Hoffner | Jun 2018 | A1 |
20180316764 | Ferreira Gomes | Nov 2018 | A1 |
Number | Date | Country | |
---|---|---|---|
20180278551 A1 | Sep 2018 | US |