Methods and a system of licensing electronic data are provided. A method of ensuring proper licensing is provided, comprising the executable instructions of receiving a data file and removing at least a portion of the data file which prevents any use associated with the data file. Further, a license authenticating set of executable instructions are wrapped around the data file and executed to determine whether the data file is associated with a valid license. If the data file is associated with a valid license, the removed portion of the data file is restored making the data file available for use.
A method of authenticating a license set of executable instructions is provided, having executable instructions wherein the license set of executable instructions is received while a computing device housing the license set of executable instructions is in communication with one or more licensing computing devices. The license set of executable instructions is executed on the computing device to determine if a valid license exist, and the license set of executable instructions is prevented from further executing on the computing device if the valid license does not exist.
Furthermore, a system for validating data files is provided having a wrapping set of executable instructions operable to be executed prior to using a data file on a computing device. Moreover, a validation set of executable instructions is provided operable to permit the data file to be useable on the computing device if a valid license to use the data file exists on the computing device.
|
1. In a computing device, a method of ensuring proper licensing, comprising the steps of:
receiving a data file at the computing device;
removing at least a portion of the data file at the computing device preventing a use associated with the data file;
wrapping a license authentication set of executable instructions around the data file at the computing device;
executing the license authentication set of executable instructions at the computing device to determine whether the data file is associated with a valid license; and
at the computing device, restoring the removed portion of the data file if the valid license exists thereby making the data file available for use.
18. A system for validating data files on a stand alone computing device, comprising:
a wrapping set of executable instructions operable to be executed on the computing device prior to using a data file on the computing device, the wrapping set of executable instructions operable to remove a portion of the data file preventing a use associated with the data file; and
a validation set of executable instructions on the computing device called by the wrapping set of executable instructions operable to permit the data file to be useable on the computing device if a valid license to use the data file exists on the computing device, usability of the data file including restoration of the removed portion of the data file.
8. A method of authenticating a licensed set of executable instructions, comprising the executable instructions of:
receiving a license set of executable instructions while a computing device housing the license set of executable instructions is in communication with one or more licensing computing devices;
executing the license set of executable instructions exclusively at the computing device to determine if the license set of executable instructions is associated with a valid license;
permitting the license set of executable instructions to further execute on the computing device if the valid license exists; and
preventing the license set of executable instructions from further executing on computing device if the valid license does not exist.
2. The method of
preventing the data file from use if the valid license is not authenticated.
3. The method of
notifying an owner at other than the computing device location if the data file does not have the valid license.
6. The method of
customizing the license authentication set of executable instructions based on a user license.
7. The method of
providing the license authentication set of executable instructions to one or more application service providers wherein the license authentication set of executable instructions is customized based on one or more levels of service of the application service providers.
9. The method of
executing the license set of executable instructions while the computing device is not in communication with one or more of the licensing computing devices.
10. The method of
11. The method of
exclusively at the computing device, removing at least a portion of the license set of executable instructions prior to executing the license set of executable instructions.
12. The method of
exclusively at the computing device, restoring the removed portion of the license set of executable instructions only when the valid license exists.
13. The method of
14. The method of
15. The method of
16. The method of
at other than the computing device location, notifying electronically a licensor of the license set of executable instructions if an attempt to execute the license set of executable instructions occurs at the computing device location without the valid license.
17. The method of
20. The system of
|
The present invention relates to methods and systems for validating and customizing licenses associated with the distribution and use of electronic data.
Ensuring that licensees of electronic data files have the proper licensing prior to using the data is of major concern to industries related to software, information, entertainment, and others. Providers of electronic data have become increasingly frustrated with their lack of ability to control and enforce licenses in the wake of the Internet and the World-Wide Web (WWW). Distribution of electronic data is omnipresent over the WWW, and data providers lack the technical ability to track and enforce their intellectual rights associated with this distribution.
Encryption technology has provided some relief by translating the electronic data into a format which is not useable until successfully decrypted. Yet, once the electronic data is decrypted it becomes vulnerable to being copied in its decrypted format. Correspondingly, encryption techniques have provided little relief to data providers, beyond the initial distribution of the electronic data to a valid licensee of that data. If the valid licensee abuses the license by making unauthorized copies of the electronic data and distributing those copies, then the data provider has little to no ability to prevent the prospective unauthorized use by a non licensed user, and further the data provider has little ability to detect the unauthorized distribution of its initial licensee.
Moreover, attempts have been made to require users to be connected to an external license server before use of the electronic data may proceed in a normal fashion. In this way, a user using an existing connection to the Internet, or using a direct connection to the license server, authenticates the use of the electronic data before each use of the data. In this instance, the data itself includes disabling logic or instructions which are not enabled until the data is properly authenticated by the license server. However, as is obvious by the above description, the data cannot be used unless a connection is made and maintained with the license server to authenticate the data.
Further, data providers may alter the data themselves, particularly when the data is a set of executable instructions (e.g., software executables). In this way, the executable instructions performs validation checks each time it is run against itself to ensure a valid license exists. For example, upon initial installation the executable instructions may create an encrypted flat file having information regarding the date of installation, the current date, the location of licensing files, and the like. On any subsequent execution of the software, this encrypted flat file is evaluated against any valid licensing logic to determine if the executable instructions may properly be executed.
This technique provides some security in enforcing valid data licensing, but it is not without some expense since subsequent upgrades, patches, and releases of the data require reinstallation of the data and this presents maintenance problems for the data provider, particularly if the data was modified in a Myriad of customized manners in order to accommodate a variety of user licenses. Furthermore, astute programmers are still capable of modifying the instructions while it is running in the operating system's memory by disabling those locations in the instructions where the licensing checks are occurring. The modified software may then be distributed and used by others with the licensing checks disabled.
As will be readily apparent, providing valid licenses and license checking with data are problematic issues for data providers. Accordingly, methods and systems which provide true licenses for data is needed, and these true licenses must be easily customizable to accommodate a variety of user needs without requiring labor intensive modifications to the data.
Accordingly, an aspect of the present invention is to provide methods and a systems for licensing electronic data. Electronic data may be provided such that a wrapper is provided and associated with additional data. The wrapper may be customized to enforce any license which a user has validly acquired from the data provider. The wrapper is distinctly separate from the data, although it may be delivered as part of the data. In this way, the data provides the core functionality or content which the data provider is making available, and data will not require modification if a different or subsequent wrapper is changed to reflect a different user license arrangement.
Further, the wrapping set of executable instructions is operable to remove a key portion of the data. Alternatively, a key portion of the data may reside in a hidden file which only the wrapping set of executable instructions has the logic to locate and reassemble as one complete data file. A key portion of the data may be defined as any data or file, which the data requires to execute or be of use to a licensee of the data provider.
By way of example only, consider a MICROSOFT WINDOWS' executable, which requires one or more Dynamic Linked Libraries (DLL) to run successfully, and without these DLLs the executable cannot run. In this example, the location of the necessary DLLs and the logic to properly load the DLLs may reside within a wrapping set of executable instructions, such that the executable (e.g., data of the data provider) will not run properly, until the wrapping set of executable instructions locates and loads the required DLLs. The DLLs are key portions of the data, although they may not be physically included within the data.
Alternatively, a key portion may actually be a portion of the data contained within the data itself, and the wrapping set of executable instructions has the proper logic to create a complete data file having the key portion inserted in the proper location within the data, such that the data may be used as intended by the data provider.
Further, the wrapping set of executable instructions is operable to validate any license associated with the data such that once the license has been properly authenticated, the data is restored to a functional state and the user is permitted to proceed with a use associated with the data. As one skilled in the art will readily appreciate, even existing data may be equipped with the wrapping sets of executable instructions of the present invention to enforce licensing requirements of a data provider against any electronic data.
Additional aspects, advantages and novel features of the invention will be set forth in the description that follows and, in part, will become apparent to those skilled in the art upon examining or practicing the invention. The aspects and advantages of the invention may be realized and obtained by means of the instrumentalities and combinations particularly pointed out in the appended claims. To achieve the foregoing and other aspects and in accordance with the purpose of the present invention, methods and systems for authenticating a license associated with electronic data are provided.
One aspect of the present invention provides a method of ensuring proper licensing, having executable instructions comprising receiving a data file and removing at least a portion of the data file, the removed portion prevents the data file from being used. A license set of executable instructions is wrapped around the data file, or otherwise associated therewith. The license set of executable instructions is executed to determine whether the data file is associated with a valid license. If a valid license, to use the data file exists, then the removed portion of the data file is restored, and the data file is available for use.
In another aspect of the present invention, a method of authenticating a license set of executable instructions is provided, having executable instructions, comprising receiving a license set of executable instructions while a computing device housing the license set of executable instructions is in communication with one or more licensing computing devices. The license set of executable instructions is then executed to determine if the license set of executable instructions has a valid license. The license set of executable instructions is permitted to be further executed on the computing device if the valid license exist, otherwise the license set of executable instructions is prevented from further execution on the computing device.
Another aspect of the present invention provides a system for validating data, comprising a wrapping set of executable instructions operable to be executed prior to using data on a computing device. Further, a validation set of executable instructions operable to permit the data to be useable on the computing device if a valid license to use the data exists on the computing device.
Still other aspects of the present invention will become apparent to those skilled in the art from the following description of an exemplary embodiment, which is by way of illustration, one of the exemplary modes contemplated for carrying out the invention. As will be realized, the invention is capable of other different and obvious aspects, all without departing from the invention. Accordingly, the drawings and descriptions are illustrative in nature and not restrictive.
The accompanying drawings, incorporated in and forming part of the specification, illustrate several aspects of the present invention and, together with their descriptions, serve to explain the principles of the invention. In the drawings:
The present invention provides methods and systems for authenticating a license associated with data. One embodiment of the present invention is implemented in NOVELL's NetWare operating system environment and implemented with the C or C++ programming language, or scripting languages such as PERL, Active Server Pages, Javascript, and the like.
Of course other operating systems and programming languages (now known or hereafter developed) may also readily employed. Moreover, as will be apparent to one skilled in the art the present invention may be used in combination with existing validation technologies, such as public-private key encryption technologies, and others.
Initially a data provider desires to provide a data file to one or more licensees. By way of example only, a data file is any electronic data file and may include data files which are themselves executable, such as a software application programs. Further, the data file may be a piece of audio such as a piece of music, or video such as a movie. Moreover, the data file may be data associated with print media, such that its contents are associated with material which is read. Also, the data file may be images associated with art, photographs, or drawings. As will be apparent to those skilled in the art, a data file may include any electronic data which the data provider wishes to control and license its distribution and use within an electronic media, such as the Internet, WWW, wireless technology, cable technology, plain old telephone lines (POTS), point of sale (POS) technology, interactive/web television, and the like.
The data file itself is distributed either as one unit of contiguous data or in separate units of data which when assembled create a single unit of contiguous data. Moreover, either separately or in connection with the distribution of the data file a wrapping set of executable instructions is distributed and associated with the data file. The wrapping set of executable instructions is data which is operable to be executable on a computing device. Furthermore, the wrapping set of executable instructions includes logic which is operable to remove key portions of the data file and/or restore key portions of the data file, or to otherwise appropriately assemble the data file to create a single unit of contiguous data.
Yet, the wrapping set of executable instructions is not necessary for the data file to be used by any computing device. In fact, once the wrapping set of executable instructions validate and assembles/restores the data file, the data file is made available for use on the computing device. For example, if the data file is an executable program then once the wrapping set of executable instructions validates that the data file is associated with a valid license, a complete data file is provided to the computing device and the data file is permitted to execute normally. In this way, should any subsequent releases, patches, or upgrades be needed to the data file, the wrapping set of executable instructions may remain unchanged. Or, alternatively should a user desire to upgrade a license to acquire additional feature/function of the data file, an upgrade to the wrapping set of executable instructions may occur without modification to the data file.
Further, as one skilled in the art will readily appreciate the present description provides a data provider with an option to create new licenses for existing data files without changing the data files. In addition, the licenses are easily customized by providing customized wrappers based on the licenses purchased by the licensee. Unauthorized use is prevented because the data files are not operable until the wrapper assembles or validates them appropriately.
The wrapping set of executable instructions is operable to enforce logic associated with a particular license, which the user of the data file has acquired from the data provider. Enforcement of the logic may be hard coded within the wrapper set of executable instructions, or it may be contained within an encrypted file, which the wrapping set of executable instructions reads. Moreover, a license file which is acquired during a connection to a license server may be downloaded to the licensed computing device and used by a licensee in a stand alone operation mode. In other words, the computing device need not acquire permission from a network license server to use a piece of software (e.g., data file), since the wrapping set of executable instructions may be used to validate the license which resides on the computing device. As one skilled in the art will readily appreciate, this would permit networked clients to operate in a stand alone mode during network outages, and yet still acquire the necessary licensing authentication typically required by many software program applications (e.g., data files).
A valid license may be ascertainable from a single authenticated file granting permission, or from a series of logical checks, which if successfully validated indicate that a valid license is present. Additionally, a license may be encrypted using public-private key technology, such that the wrapping set of executable instructions has the public key associated with decrypting the license and another set of license authentication set of executable instructions includes the private key associated with a particular license of a licensee. In this way, a valid license is only acquired through using the wrapping set of executable instructions which has the public key of the license.
As one skilled in the art will readily appreciate, a variety of configurations and checks may be made to validate whether a valid license is present on any particular computing device, all of which are intended to be included within the scope of the present invention when used in connection with a wrapping set of executable instructions which is operable to enable a previously disabled data file, once a valid license is detected.
Although as one skilled in the art will appreciate, data need not actually be removed from the data file, as all that would be needed would be to disable or disallow some additional data needed by the data file before it could be of use. For example, a DLL may intentionally not be loaded thereby preventing a data file associated with a MICROSOFT WINDOWS' set of executable instructions from running, until some other application loads the required DLL.
Once the data file is disabled in some way, the data file is wrapped with a wrapping set of executable instructions in step 60. Although as is readily apparent, the wrapping set of executable instructions need not be physically included within the same data file as the wrapping set of executable instructions, since wrappers may simply be a script language which executes an additional program first followed by the data file, if the additional program successfully completes. If the data file is not an executable, then after executing the wrapping set of executable instructions, the data file is provided in a useable form to the licensee.
The wrapping set of executable instructions is executed in step 80. The wrapping set of executable instructions may be customized in step 70 to accommodate a variety of licenses offered by a data provider. For example, a licensee may acquire a license which expires after a period of time, which is common when licensees acquire trial period licenses. At some later point in time, the licensee may wish to purchase a complete license, which may be provided to the licensee simply by updating the wrapping set of executable instructions to permit the use of the data file beyond the trial period. In this way and others, the wrapping set of executable instructions may be customized.
A valid user's license is located or determined to exist logically by the wrapping set of executable instructions in step 50. As previously presented, this license may be a single file which is validated using encryption/decryption technology, or it may be determined by proceeding with the execution of some logical comparisons by the wrapping set of executable instructions, such as and by way of example only, validating a computing device, a current date, a current user, and the like.
Further, customized wrappers may be provided for distribution to application service providers (ASP) in step 90 along with a single data file. In this way, the ASP can make a single data file available to all of its subscribers, with each subscriber having different rights and privileges associated with using the data file. These rights and privileges are determined by the customized wrapping set of executable instructions distributed or associated with each user of the ASP. As one skilled in the art will readily appreciate, this significantly increases the attractiveness of ASPs to data providers, since reduced functionality of a data file may be provided at a low cost to ASP users simply by providing a customized wrapper and without the need to create variant versions of the data file itself. Moreover, the ASP is alleviated from the burdensome administration of distributing algorithms since only a single version of a data file needs to be maintained for distribution.
If a valid license is determined to exist by the wrapping set of executable instructions in step 100, then the data file is restored to a condition which permits its execution. In other words, any needed information is provided or put in the appropriate location which makes the data file useable. If a valid license is not determined to exist, then in step 120 the data file remains in a non useable condition. Optionally, in step 130 the owner of the data file may be electronically notified of any unauthorized attempt to use the data file. This would allow data providers, to track down unauthorized copies of their data files and potentially the location of any unauthorized distribution.
The data file may be a program such as audio/video program depicted in step 180, or it may be a flat file which is used by another program such as audio data in MP3 format or video data in MPEG format. The license set of executable instructions is executed in step 190. Moreover, the execution of the license set of executable instructions may occur when the computing device is not connected to any other computing device as depicted in step 210. As one skilled in the art will readily appreciate, this permits a normal server licensed program to be executed by a user off-line in a stand alone mode. This would be extremely advantageous when network traffic is heavy due to increased traffic or when the network itself was unavailable to a user.
In step 240, key portions of the data file are removed or restored as required based upon whether the license set of executable instructions determines whether or not a valid license exist. For example, in step 220 a DLL may be removed and then restored once a valid license is determined to exist. Further, a single license file may be encrypted in step 230 with the license set of executable instructions operable to decrypt the license file to determine if a valid license is present to use the data file. As previously presented, a variety of operations or files may be used individually or in combination to determine whether a valid license is present (step 20).
If a valid license is not present, then in step 250 the data file is prevented from executing or being of any use to an alleged licensee. Further, a licensor may be electronically notified in step 270 of any failed attempt to access or use the data file. This notification may occur as soon as the computing device is once again in communication with other computing devices in step 280, such as and by way of example only, when the computing device reacquires an Internet connection, or reconnects to a network server.
If a valid license is detected then the data file is permitted to be executed in step 260, even if the computing device using the data file is not connected to other computing devices (e.g., the computing device is in a stand alone mode of operation). In this way, a licensee may access network programs or files while not connected to the network and the authentication of the license may still be ensured.
The data file 330 may be an executable file as previously presented with the validating set of executable 320 instructions operable to determine whether a valid license 340 is present on the computing device 290, even when the computing device 290 is in a stand alone mode of operation and not in communication with any external computing devices.
Further, the wrapping set of executable instructions 310 is operable to remove a portion of the data file 330 preventing its use on the computing device 290 when a valid license 340 is not authenticated on the computing device 290. Moreover, the wrapping set of executable instructions 310 is operable to restore removed portions of the data file 330 when a valid license 340 is detected on the computing device 290.
The wrapping set of executable instructions may further be associated with a validation set of executable instructions 400 wherein the validation set of executable instructions 400 locates or determines whether a valid license exists or is otherwise permissible 410. If the license is permissible, the data file/program 390 is allowed to execute or be used in 430, otherwise an owner associated with the data file/program 390 is notified electronically in 420. Validation and execution need not occur while the computing device 370 is in communication with any other external computing devices such as devices 350 and 360, since once the data file/program 390 is acquired from one or more of the external devices 350 or 360 the computing device is free to use the data file/program 390 and with each such use validation ensures that a proper authority exists to use the data file/program 390.
The foregoing description of an exemplary embodiment of the invention has been presented for purposes of illustration and description. It is not intended to be exhaustive nor to limit the invention to the precise form disclosed. Many alternatives, modifications, and variations will be apparent to those skilled in the art in light of the above teaching. Accordingly, this invention is intended to embrace all alternatives, modifications, and variations that fall within the spirit and broad scope of the attached claims.
Patent | Priority | Assignee | Title |
10503877, | Sep 30 2004 | AVAYA LLC | Generation of enterprise-wide licenses in a customer environment |
7681245, | Aug 30 2002 | AVAYA Inc | Remote feature activator feature extraction |
7698225, | Aug 30 2002 | AVAYA LLC | License modes in call processing |
7707116, | Aug 30 2002 | AVAYA LLC | Flexible license file feature controls |
7707405, | Sep 21 2004 | AVAYA LLC | Secure installation activation |
7747851, | Sep 30 2004 | AVAYA LLC | Certificate distribution via license files |
7761921, | Oct 31 2003 | Caterpillar Inc | Method and system of enabling a software option on a remote machine |
7814023, | Sep 08 2005 | AVAYA LLC | Secure download manager |
7844572, | Aug 30 2002 | AVAYA LLC | Remote feature activator feature extraction |
7885896, | Jul 09 2002 | AVAYA LLC | Method for authorizing a substitute software license server |
7890997, | Dec 26 2002 | AVAYA LLC | Remote feature activation authentication file system |
7913301, | Jan 20 2003 | AVAYA LLC | Remote feature activation authentication file system |
7966520, | Aug 30 2002 | AVAYA LLC | Software licensing for spare processors |
8041642, | Jul 10 2002 | AVAYA LLC | Predictive software license balancing |
8145701, | Jun 28 1996 | DISTRIBUTED MEDIA SOLUTIONS, LLC | Methods and systems for providing storage of a data file over a computer network |
8229858, | Sep 30 2004 | AVAYA Inc | Generation of enterprise-wide licenses in a customer environment |
8620819, | Aug 30 2002 | AVAYA LLC | Remote feature activator feature extraction |
8805927, | Jun 28 1996 | DISTRIBUTED MEDIA SOLUTIONS, LLC | Methods and systems for a distributed group activity network |
9697372, | Mar 19 2013 | Raytheon Company | Methods and apparatuses for securing tethered data |
9712324, | Mar 19 2013 | FORCEPOINT FEDERAL HOLDINGS LLC F K A FORCEPOINT LLC | Methods and apparatuses for reducing or eliminating unauthorized access to tethered data |
Patent | Priority | Assignee | Title |
4937863, | Mar 07 1988 | HEWLETT-PACKARD DEVELOPMENT COMPANY, L P | Software licensing management system |
5138712, | Oct 02 1989 | SUN MICROSYSTEMS, INC , A CORP OF DE | Apparatus and method for licensing software on a network of computers |
5375206, | Mar 11 1991 | HEWLETT-PACKARD DEVELOPMENT COMPANY, L P | Method for licensing software |
5479612, | Apr 13 1994 | Unisys Corporation | Automated system and method to discourage access of unlicensed peripheral devices by a computer system |
5579479, | Oct 03 1994 | Plum Hall Inc. | Computer software licensing authentication method and apparatus |
5636277, | Sep 30 1994 | Fujitsu Limited | System for licensing to use software products |
5771347, | May 20 1994 | International Business Machines Corp. | Apparatus and method to allow a user a trial period before licensing a software program product |
5968175, | Mar 29 1994 | Kabushiki Kaisha Toshiba | Software use method control system |
6049789, | Jun 24 1998 | Mentor Graphics Corporation | Software pay per use licensing system |
6173446, | Feb 02 1999 | TUMBLEWEED HOLDINGS LLC | Apparatus for licensing software applications |
6189146, | Mar 18 1998 | Microsoft Technology Licensing, LLC | System and method for software licensing |
6233567, | Aug 29 1997 | Intel Corporation | Method and apparatus for software licensing electronically distributed programs |
20010034846, | |||
20030190043, | |||
20040225894, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Mar 01 2000 | MUSSON, ROBERT | Novell, Inc | COPY OF INTELLECTUAL PROPERTY AGREEMENT SIGNED BY ROBERT COPY OF PETITION TO PROCEED WITH NON-SIGNING INVENTOR UNDER 37 CFR 1 47 B | 026209 | /0449 | |
Mar 01 2000 | MUSSON, ROBERT | Novell, Inc | ASSIGNMENT COPY OF INTELLECTUAL PROPERTY AGREEMENT SIGNED BY ROBERT COPY OF PETITION TO PROCEED WITH NON-SIGNING INVENTOR UNDER 37 CFR 1 47 B | 026123 | /0842 | |
Jul 25 2001 | Novell, Inc. | (assignment on the face of the patent) | / | |||
Apr 27 2011 | NOVELL,INC | CPTN Holdings LLC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 027465 | /0227 | |
Sep 09 2011 | CPTN Holdings LLC | NOVELL INTELLECTUAL PROPERTY HOLDING, INC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 027325 | /0131 | |
Sep 09 2011 | CPTN Holdings LLC | NOVELL INTELLECTUAL PROPERTY HOLDINGS, INC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 027465 | /0206 | |
Feb 08 2016 | NOVELL INTELLECTUAL PROPERTY HOLDINGS, INC | RPX Corporation | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 037809 | /0057 | |
Feb 26 2016 | RPX Corporation | JPMORGAN CHASE BANK, N A , AS COLLATERAL AGENT | SECURITY AGREEMENT | 038041 | /0001 | |
Feb 26 2016 | RPX CLEARINGHOUSE LLC | JPMORGAN CHASE BANK, N A , AS COLLATERAL AGENT | SECURITY AGREEMENT | 038041 | /0001 | |
Dec 22 2017 | JPMORGAN CHASE BANK, N A | RPX CLEARINGHOUSE LLC | RELEASE REEL 038041 FRAME 0001 | 044970 | /0030 | |
Dec 22 2017 | JPMORGAN CHASE BANK, N A | RPX Corporation | RELEASE REEL 038041 FRAME 0001 | 044970 | /0030 | |
Jun 19 2018 | RPX Corporation | JEFFERIES FINANCE LLC | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 046486 | /0433 | |
Oct 23 2020 | JEFFERIES FINANCE LLC | RPX Corporation | RELEASE BY SECURED PARTY SEE DOCUMENT FOR DETAILS | 054486 | /0422 |
Date | Maintenance Fee Events |
Jan 05 2007 | ASPN: Payor Number Assigned. |
Jun 07 2010 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Jun 05 2014 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. |
Jul 16 2018 | REM: Maintenance Fee Reminder Mailed. |
Jan 07 2019 | EXP: Patent Expired for Failure to Pay Maintenance Fees. |
Date | Maintenance Schedule |
Dec 05 2009 | 4 years fee payment window open |
Jun 05 2010 | 6 months grace period start (w surcharge) |
Dec 05 2010 | patent expiry (for year 4) |
Dec 05 2012 | 2 years to revive unintentionally abandoned end. (for year 4) |
Dec 05 2013 | 8 years fee payment window open |
Jun 05 2014 | 6 months grace period start (w surcharge) |
Dec 05 2014 | patent expiry (for year 8) |
Dec 05 2016 | 2 years to revive unintentionally abandoned end. (for year 8) |
Dec 05 2017 | 12 years fee payment window open |
Jun 05 2018 | 6 months grace period start (w surcharge) |
Dec 05 2018 | patent expiry (for year 12) |
Dec 05 2020 | 2 years to revive unintentionally abandoned end. (for year 12) |