Not Applicable
The present invention relates to a golf shot API proxy utilized with golf range entertainment venues.
Currently, TOPGOLF™ shot trace events can only be done if the client application was connected to the same local network as the local TOPTRACER™ API. Also, to integrate with the local TOPTRACER™ API, a client app had to either be compatible with websocket communication, or if not, use “HTTP Long Polling” as a way to request and receive shot events.
The disadvantages included that any third-party client that wanted to receive shot events would need to first authenticate to the local private network at a TOPGOLF golf driving range entertainment venue. This essentially prevented any non-TOPGOLF application from receiving such events as access to the local private network would pose a security risk.
In the case of the TOPTRACER™ Range App, this created friction with the app users as they would need to gain access to the respective driving range's WiFi before being able to use said app HTTP Long Polling consumes server resources as the server persists a client connection for a specified amount of time.
This presents a problem if there are multiple clients requesting the same shot event, as the load on the server will increase with the number of persisted requests.
As such, making specific shot events available to more than one client at a time has a detrimental effect to the servers handling the request; one of the reasons why cross-bay/cross-venue gameplay has yet to be implemented.
Further, Long Polling also, in certain situations, does not guarantee proper ordering or delivery of responses if there is a high volume of requests from the same client app.
This could potentially pose a problem in a cross-bay/cross-venue scenario as the ordering of shot events could be crucial to the game experience.
Further, User experience would also be impacted if a response for an event is never received by the client app.
A primary purpose of the solution is to democratize/publicize shot event data in such a way that it: Allows for client apps to access shot event data, securely, over the public internet, in a manner that simplifies the process of integration, allows for the scaling of client app connections to large volumes, while only increasing local Shot API server load by a minimal amount, and allows for shot event data to be shared across bays, venues, and devices/platforms/client app.
One aspect of the present invention is a system for providing shot tracking data to a client device. The system comprises multiple golf ball tracking sensors positioned at multiple golf driving ranges, multiple shot application programming interfaces (API), and a shot API proxy. Each of the shot APIs is configured to receive shot data from each of the golf ball tracking sensors at a corresponding golf driving range. The shot API proxy is configured to receive shot data from each of the shot APIs. The shot API proxy is configured to receive calls for shot data from a client device. The shot API proxy is configured to transmit shot data to the client device.
Another aspect of the present invention is a method for providing shot tracking data to a client device. The method includes generating shot data at a plurality of golf ball tracking sensors positioned at a plurality of golf driving ranges. The method also includes receiving, at a plurality of shot application programming interfaces (API), shot data from each of the plurality of golf ball tracking sensors. The method also includes receiving shot data at a shot API proxy from each of a plurality of shot APIs. The method also includes receiving a call for shot data at the shot API proxy from a client device. The method also includes transmitting the shot data from the shot API proxy to the client device.
Having briefly described the present invention, the above and further objects, features and advantages thereof will be recognized by those skilled in the pertinent art from the following detailed description of the invention when taken in conjunction with the accompanying drawings.
The solution will be implemented as such:
An AsyncAPI, developed with the Mulesoft platform, deployed to TOPGOLF's Runtime Fabric Cluster (Mulesoft,) runs in a cloud computing service such as Amazon Web Services (AWS).
This AsyncAPI serves as a public proxy for the underlying Shot API instances running at each golf driving range (venue) 50.
The API is secured with the API Policies supplied by Mulesoft's Anypoint Platform, as well as any custom policies deemed necessary.
For a client app 65 to subscribe to shot event data, it will first authenticate against the policies applied to the AsyncAPI.
Once authenticated, the client app 65 will request subscriptions to specific bay(s) at specific venue(s) 50.
Behind the AsyncAPI is an integration workflow containing a custom built Socket.io connector. The Socket.io connector handles the subscription requests from the client apps 65 on the mobile device 60 of the users.
The workflow will first make an HTTP call to an internal API containing hostnames for each of the individual Shot APIs 70.
Once the required hostname(s) is (are) pulled, the workflow uses the custom Socket.io connector to establish a connection to the underlying Shot API(s) 70.
After a successful connection attempt, all shot events will be sent back through the Socket.io connector, back through the AsyncAPI, and to the client in real-time; similar to a push notification.
This solution leverages the following key cutting edge technologies and maintains their inherent positive characteristics:
AsyncAPI deployed to an instance of a Mulesoft RTF
Mulesoft Anypoint Platform (API Manager, Monitoring, Log forwarding)
Socket.io
AWS Infrastructure (EC2, NLB, Route53, etc. . . . )
Other features of the present invention include:
From the foregoing it is believed that those skilled in the pertinent art will recognize the meritorious advancement of this invention and will readily understand that while the present invention has been described in association with a preferred embodiment thereof, and other embodiments illustrated in the accompanying drawings, numerous changes, modifications and substitutions of equivalents may be made therein without departing from the spirit and scope of this invention which is intended to be unlimited by the foregoing except as may appear in the following appended claims. Therefore, the embodiments of the invention in which an exclusive property or privilege is claimed are defined in the following appended claims.
The Present Applications claims priority to U.S. Provisional Patent Application No. 63/393,384, filed on Jul. 29, 2022, which is hereby incorporated by reference in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
5413345 | Nauck | May 1995 | A |
7056221 | Thirkettle | Jun 2006 | B2 |
7160196 | Thirkettle et al. | Jan 2007 | B2 |
7337965 | Thirkettle et al. | Mar 2008 | B2 |
7806777 | Cheng | Oct 2010 | B2 |
7847808 | Cheng et al. | Dec 2010 | B2 |
8077917 | Forsgren | Dec 2011 | B2 |
9675862 | Solheim | Jun 2017 | B2 |
10596416 | Forsgren | Mar 2020 | B2 |
10610757 | Marty | Apr 2020 | B1 |
10695646 | Marten | Jun 2020 | B2 |
10898757 | Johansson et al. | Jan 2021 | B1 |
11335013 | Forsgren et al. | May 2022 | B2 |
11409411 | Levin | Aug 2022 | B1 |
11504582 | Johansson et al. | Nov 2022 | B2 |
11513208 | Eriksson | Nov 2022 | B2 |
11557044 | Forsgren et al. | Jan 2023 | B2 |
11644562 | Hugmark et al. | May 2023 | B2 |
20050227792 | McCreary | Oct 2005 | A1 |
20150196822 | Voutiliainen et al. | Jul 2015 | A1 |
20160136502 | Voutiliainen | May 2016 | A1 |
20160354671 | Nuesmeyer et al. | Dec 2016 | A1 |
20160361617 | Luciano, Jr. et al. | Dec 2016 | A1 |
20200108302 | Marten | Apr 2020 | A1 |
20200269089 | Tuxen | Aug 2020 | A1 |
20200391077 | Forsgren | Dec 2020 | A1 |
20210236904 | Korpach | Aug 2021 | A1 |
20220040534 | Imes | Feb 2022 | A1 |
20220203178 | Burdette et al. | Jun 2022 | A1 |
20220288479 | Won | Sep 2022 | A1 |
20230085842 | Hugmark | Mar 2023 | A1 |
20230124155 | Ines | Apr 2023 | A1 |
Number | Date | Country | |
---|---|---|---|
63393384 | Jul 2022 | US |