1. Technical Field
The present disclosure relates to accounting systems and methods, and more particularly, to accounting methods and machines for effecting accounting control for print jobs.
2. Description of Related Art
There are at least three recognizable independent dimensions or variables that have significant impact on accounting. Referring to
Traditionally, accounting methods tend to address a subset of the dimensions. At a minimum, the three independent variables come into play, namely, where the authentication of the customer information takes place, e.g., at the X-axis and whether off-box at X1 or on-box at X2; whether the customer activity is limited by funds availability, e.g., at the Y-axis and has no pre-established limit, as at Y1 or has a pre-established limit, as at Y2; and whether the customer activity is limited by number of images the customer can mark, e.g., at the Z-axis and has no pre-established limit, as at Z1 or has a pre-established limit, as at Z2.
The conditions of off-box authentication at X1, a pre-established limit of funds at Y2, and no pre-established limit of number of images at Z1 exemplify a foreign device interface 10, e.g., a vending box. The conditions of off-box authentication at X1, together with no pre-established limit of funds at Y1 and no pre-established limit of number of images at Z1 exemplify a job-based accounting (JBA) system 12. In contrast, the conditions of on-box authentication at X2, together with no pre-established limit of funds at Y1 and a pre-established limit of number of images at Z2 exemplify an on-box authentication based accounting system 14.
The present disclosure advances the field of systems and methods for accounting for print job usage quotas and limits. In particular, the present disclosure relates to a system for dynamically updating user information for a print job.
According to aspects illustrated herein, there is provided a system for accounting for a print job that includes at least one print device having at least one database and at least one server having at least one database, wherein the print device(s) and the server(s) communicate via a network. The one or more print devices and the one or more servers have means for dynamically updating accounting information for the print job. The means for dynamically updating communicates with the one or more print devices and with the one or more servers via the network. The accounting information resides in the one or more databases of the one or more print devices and/or in the one or more databases of the one or more servers.
One disclosed feature of the embodiments of the present disclosure is a method for accounting for a print job that includes providing at least one print device having at least one database and at least one server having at least one database; and communicating between the one or more print devices having at least one database and the one or more servers having at least one database via a network for dynamically updating accounting information for the print job stored on at least one of the one or more databases of the one or more print devices and the one or more databases of the one or more servers.
Various embodiments of the present disclosure will be described herein below with reference to the figures wherein:
The present disclosure relates to a system for accounting for a print job wherein at least one database of a print device and at least one database of at least one server are dynamically updated for accounting information for the print job. A corresponding method is also disclosed.
As defined herein, a print device refers to a device that produces a print output, e.g., a copier, a scanner, a facsimile machine, a printer, a multifunction device (MFD) or other suitable image forming device. Alternatively, a print device refers to a device that produces a copy-to-file, a print-to-file, a scan-to-file, a facsimile-to-file, and a multifunction device or other suitable image forming device performing the same functions to file. A print device may include an internal processor capable of hosting a database, e.g., a master print device, a slave print device having at least one database, or a slave print device not having a database.
Also as used herein, the terms dynamically and dynamic refer to an action occurring at the time of need for the action to occur or for an object to be created, as opposed to the capability of the action occurring having been established or the object being created apriori. Also as used herein, means for dynamically updating accounting information for the print job include firmware, software and/or hardware for dynamically updating accounting information for the print job according to the definition of dynamic or dynamically defined herein.
The system level architecture of the integrated accounting system according to the present disclosure does not differentiate based on the location of the authentication mechanism; the actual location of this mechanism depends on the implementation. The discussion here is related to marked images. However, this logic is pertinent to exported images as well; wherein the marking aspect of the logic is replaced by the appropriate export logic.
The present disclosure integrates existing methods of accounting with new logic to enable an integrated or unified adaptable accounting system. The present disclosure relates to dynamic updating of the accounting database and a notion of using authentication and authorization information to dynamically create temporary accounts as needed, dynamically update the user's privileges, and ensuring that every page marked is accounted for irrespective of the underlying monitoring mechanism used.
The requirements along all three dimensions of authentication (the X-axis), funds availability (the Y-axis) or image counting (the Z-axis) in a real-time or as-required or as needed basis indicate the approach to be adopted for accounting. Thus the system and method according to the present disclosure rely on a concept of dynamic update of user information, namely accounting information, database as well as easier administration of the database due to changeable parameters being stored in easily accessible lists. The method separates the authentication and authorization activity from the purely accounting activity. A separate authentication activity allows for the use of different authentication mechanisms and integration of network identity. A separate authorization activity allows for dynamic update of authorized capabilities and limits on number of transactions (such as pages copied, pages printed, color pages copied, etc.) allowed for each user. The system and method of the present disclosure also allow for external accounting systems (EAS) to supply variable limits and authorized services for external users, and ensure that every page marked or printed, scanned, faxed, etc. gets recorded, and encompasses all three dimensions and limits X1, Y1 and Z1, as indicated by the circle 16.
Depending on where the authentication database exists, the authentication will take place either off-box (an authentication database is located on a network entity different from the print device) or on-box (an authentication database is located on the print device). Higher-end print devices are likely to have on-board accounting databases and can support on-box authentication as well; however, lower-end print devices may rely on off-box accounting databases and off-box authentication. Generally, off-box authentication is associated with an EAS, e.g., Equitrac Office 4 (Equitrac, Inc, Plantation, Fla., USA). Off-box authentication relates to workflows associated with current job based accounting (JBA) and foreign device interface (FDI). On-box authentication relates to on-box accounting systems such as Xerox Standard Accounting (XSA, Xerox Corp. Stamford, Conn. USA).
The integration of discrete, mutually exclusive accounting mechanisms into a single, dynamically selectable accounting mode, complete accounting system that is dynamically updatable (accounting database is dynamically updatable) is the focus of the present disclosure.
The dynamically selectable accounting mechanism is based on user input, e.g., whether the controls are funds based, quota based or location of accounting database based, as well as based on the concept of dynamically being able to update the accounting database, both in terms of creating temporary/new accounts as well as updating the authorization controls on existing accounts.
As depicted in the flowcharts, different types of accounting customers, e.g. self-serve, enterprise, office departmental, can be supported by this mechanism. The determination of the accounting mode that is applicable is made dynamically. In the flowcharts, upon entry of user identity and indicator of location of authentication database, the appropriate authentication mechanism is launched—off-box (server based) or on-box (local to print device, e.g., MFD). The case of off-box authentication also simulates FDI, where the deposit of money corresponds to authentication. Upon valid off-box authentication, the print device requests the amount of funds, cost model (how cost of service should be computed) and authorized services (which services the user is authorized to use) from the external authentication database. If the funds available are finite, the applicable accounting mechanism is FDI. A self-serve account is created a priori in the local accounting database. Page activity is recorded in this account as well as the overall system account (existing a-priori in accounting database and has all user accounts associated with it), thereby ensuring that all page activity is accounted for. The FDI activity takes place with the cost model that was provided. If the funds available are unlimited, the expectation is that the external authentication corresponds to an EAS as previously mentioned above. In this situation a temporary account is created in the local accounting database with the authorized services and limits (if any) provided by the EAS. Once again, the creation of the temporary account allows for the counting of all page activity related to this method of accounting, namely Job Based Accounting, on both the temporary account and the system account. The temporary account can be deleted when the data has been transferred over to the EAS. Finally, if the authentication was locally located (on the print device), upon authentication by the device, the print device requests for authorization details for the user from the print device authentication database, and updates the limits and authorized services associated with the user's account in the accounting database. In reality these two databases could be collapsed into one. The separation is being maintained here to better explain the logic. This separate request for authorization information allows for dynamic update of the user's rights and quotas (via access control lists and limit tables) without having to go into each user's account to modify the rights and quotas. This capability to dynamically update the database is one of the novel and unobvious concepts presented herein.
Referring particularly now to
The system 100 includes also at least one server, e.g., an EAS or partner server 104 or a funds server 106 having at least one database, e.g., partner or EAS database 104a or funds server database 106a, respectively. The database e.g., database 102a of print device 102, database 112a of print device 112 and database 122a of print device 122, and the at least one database of the at least one server, e.g., EAS database 104a of EAS or partner server 104 or funds database 106a of funds server 106, are dynamically updated for accounting information for the print job. The server databases 104a and/or 106a may coexist on the same server but are otherwise described as separate databases herein.
The print devices 102, 112, and/or 122, may communicate with the at EAS or partner server 104 and/or funds server 106 via a network 110 for dynamically updating accounting information for the print job by print devices 102, 112 and/or 122, and the EAS or partner server 104 and/or partner server 106, dynamically creating a user account. A network administration mechanism 114, e.g., a browser, may interface with the network 110 to administer interfacing between the EAS or partner server 104, the funds server 106, and the print devices 102, 112 and/or 122.
As particularly illustrated in
Since the print device(s) 102, 112 and/or 122 is/are operatively coupled to a software decision module 144 that determines whether the authentication database is “on-box” or “off-box” (see
Correspondingly, the print device authorization software module 152a may interface via the network 110 through an authorization interface 152 with an EAS accounting software module 156b residing in the EAS or partner server 104. In addition, the print device accounting software module 156a may interface via the network 110 through an accounting interface 156 with an EAS accounting software module 156b residing in the EAS or partner server 104. The EAS accounting software module 156b is also linked to an EAS account database 150b and to a limits table 158b that implements a particular user cost model 162b based upon the limits table 158b. In addition, the EAS accounting software module 156b is also linked to an authorized services table 164.
Furthermore, the EAS or partner server 104 residing in the sub-system 100b may interface via the network 110 with the funds server 106 residing in the sub-system 100c through a partner funds server interface 158.
The user authentication function module 142′ is implemented via a local user 131, having print job originals 130 to be copied via the print device 102, 112 and/or 122, swiping the card at the card reader or inputting information at user interface 140. Alternatively, a remote user 132 at a terminal 160 that is linked to the print device(s) 102, 112 and/or 122 may send a print job thereto. Authentication of the remote user 132 occurs via information input at the terminal 160. In yet another alternative embodiment, a programmatic input user 133, e.g., a mainframe computer, that is also linked to the print device(s) 102, 112 and/or 122, may send a print job thereto. Authentication of the programmatic input user 133 occurs via information transmitted to the print device(s) 102,112 and/or 122 therefrom.
The print device 102, 112 and/or 122 performs an “On Box” versus “Off Box” authentication check via implementation of authentication function module 144 to determine whether the authentication database is an “On Box” or local database 102a residing on the print device(s) 102, 112 and/or 122 or whether the authentication database is an “Off Box ” remote database 104, 106 residing outside of the print device(s) 102, 112 and/or 122. Once authentication of the user 131, 132 or 133 has occurred, the user authorization function module 152′ is implemented. Authorized services for the particular user may be displayed on a graphical user interface 140′. Following implementation of the authorization function module 152′, either local accounting function module 156a′ or remote accounting function module 156b′ are implemented. The local accounting function module 156a′ is implemented via the print device(s) 102, 112, and/or 122. The remote accounting function module 156b′ is implemented by the print device(s) 102, 112, and/or 122 communicating with the EAS partner server 104 and/or the funds partner server 106 executing the EAS accounting software module 156b to query an account residing at a financial institution 170 in the case where the user account has a pre-established limit.
Referring to
In yet still another aspect of the present disclosure, communication occurs similarly via the network 110 wherein at least one print device 102, 112, and/or 122 and/or the server 104 and/or 106 authenticate user information associated with the accounting information and at least one of dynamically requesting an amount of funds to initiate the print job be made available to the system, dynamically identifying cost of services for the print job, and dynamically identifying authorized services associated with the user account corresponding to the print job. Authorized services may include but are not limited to copy, print, fax, scan, or other similar action or service.
Communication may similarly occur with the network 110 for dynamically updating accounting information of a user account for the print job via at least one of the print device(s) 102, 112, and/or 122, and/or the server 104 and/or 106 performing dynamic setting of user privileges corresponding to the user account. “Dynamic” setting of user privileges may include setting permissions to copy, print, fax, use color, scan set/reset limits or other similar service or action.
In another aspect of the present disclosure, communication may similarly occur with the network 110 for dynamically updating accounting information for the print job via at least one of the print device(s) 102, 112, and/or 122 and/or the server 104 and/or 106 performing dynamic updating of at least one user account database. The user account database is one of the databases 102a, 112a and/or 122a of print devices 102, 112, and/or 122, respectively, and/or the at least one database of the server, e.g., databases 104a and/or 106a of the server 104 and/or 106, respectively. Dynamic updating of at least one account user database may include but are not limited to update limit, update usage (for as many services authorized).
Furthermore, communication may similarly occur with the network 110 for dynamically updating accounting information for the print job via at least one print device(s) 102, 112 and/or 122 and the server(s) 104 and/or 106 dynamically billing to at least one user account database, wherein the user account database is one of the databases 102a, 112a and/or 122a of print devices 102, 112, and/or 122, respectively, and/or the databases 104a and/or 106a of the server 104 and/or 106, respectively. Dynamically billing to at least one user account database may include but is not limited to number of pages printed, copies made, color copies made, etc.
Communication may again occur via the network 110 via at least one of the print device(s) 102, 112 and/or 122 and the server 104 and/or 106 dynamically restricting dynamic billing to premium services associated with at least one user account database, wherein the user account database is one of the databases 102a, 112a and/or 122a of print devices 102, 112, and/or 122, respectively, and/or databases 104a and/or 106a of the server 104 and/or 106, respectively. Dynamic billing to premium services associated with at least one user account database may include but are not limited to large size paper, color paper, color printing, duplex printing, stapling, hole punching, etc.
Still further, communication may similarly occur via the network 110 via at least one of the print device(s) 102, 112 and/or 122 and the server 104 and/or 106 dynamically restricting implementation of the print job to premium services associated with at least one user account database. The user account database is one of the database(s) of the print device, e.g., databases 102a, 112a and/or 122a of print devices 102, 112, and/or 122, respectively, and/or the database of the server, e.g., databases 104a and/or 106a of the server 104 and/or 106, respectively. Dynamically restricting implementation of the print job to premium services associated with at least one user account database may include, for example, but are not limited to restricting color copies, restricting paper size or quality, or other similar premium services described above.
Yet again, communication may occur similarly via the network 110 via at least one of the print device(s) 102, 112 and/or 122 and the server 104 and/or 106 dynamically counting page activity for the print job, with the page activity being associated with the temporary account. Counting page activity may include counting of printed material output by the print device(s) 102, 112 and/or 122, e.g., not limited to prints, copies, facsimiles or other similar output.
(For simplicity, reference to print device 102 is interpreted to mean at least one print device, e.g., print device 102, and/or print device 112, and/or print device 122 or additional print devices. In addition, reference to other components or functions associated with print device 102, e.g., print device processor 102′, is interpreted to mean the analogous component or function of print device 112, e.g., print device processor 112′ or of print device 122, e.g., print device processor 122′).
The system 100 wait condition further includes step 206 of inputting user data via an enabled mechanism, e.g., a data processing card swiped or read by a card reader at user interface 140. Following step 206 of inputting the user data, step 208 is implemented of authenticating the user via an appropriate mechanism, e.g., via print device 102 or external accounting system (EAS) server 104. Decision step 210 is then implemented of determining whether the user identification has been authenticated remotely or externally via the EAS server 104 or whether the user has been authenticated locally or internally, e.g., via print device 102.
If the user identification has been authenticated remotely or externally via the EAS server 104, step 212 is implemented of the EAS server 104 supplying user identification credentials to the print device 102. Step 214 is then implemented of the print device 102 then displaying a “Valid” message to the user 131 at the user interface 140, or to the user 132 at terminal 160, or allowing use of the print device 102 by the programmatic input user 133 and transferring operation via continuation point A (see
Returning to decision step 210, if the user identification has been authenticated locally or internally, e.g., via print device 102, then step 216 is implemented of the print device identifying the account related to, or corresponding to, the user input and transferring operation via continuation point B (see
Now referring to
Step 224 is then implemented of displaying, e.g., via user interface 140′, authorized services and funds available to the local user. Following step 224, step 226 is implemented of the user 131 (explicit selection), 132, or 133 (implicit selection) selecting the type of service requested, programming a print job and initiating the print job. Subsequently, step 228 is implemented of the print device processor 102′ initiating a job log collection and initiating an accounting counter via print device accounting software 156a. Following step 228, decision step 230 is implemented of determining whether the remaining value associated with the user account is greater than the minimum amount required to complete the print job.
If yes, referring to
Returning now to decision step 234, if there are no premium options associated with the print job, step 242 is implemented of deactivating the premium indicator signal. Step 244 is then implemented of looking up a charge on cost model 162a or 162b for a “basic” option, after which step 240 is implemented of computing the charge to be debited to the associated user account, e.g., via computation module 160a. In effect, the system 100 transfers to a default condition of enabling basic services at basic prices. A further default condition may be wherein the system 100 is configured to assume that new or additional funds have been deposited and accounted for by the accounting software module 156a or 156b.
Returning now to
Referring to
Returning to decision step 248 in
Following step 266, decision step 268 is implemented of determining, if the time limit of the response timer has been exceeded for the user 131, 132 or 133 to add more financial value to the associated account. If yes, the job cancellation condition N (see
If no, the system 100 transfers back to decision step 268 (see
Returning now to
If no, step 274 is implemented of disabling the print device 102, e.g., via the processor 102a of the print device 102, followed by transfer to step 246 of informing the user 131, 132 or 133, e.g., via the print device 102, about insufficient funds available in the associated account and offering the user 131, 132 or 133 an opportunity to cancel the print job or deposit sufficient funds into the associated account and the succeeding steps are implemented as described above.
If yes, step 276 is implemented of debiting the charge computed in step 240 from the remaining value of the user account via the accounting software 156a or 156b. Step 278 is then implemented of enabling the print device 102 to proceed to implement the print job request. Decision step 280 is then implemented of determining whether the remaining value associated with the user account is greater than the minimum amount required to complete the print job.
If no, step 282 is implemented of printing the particular images or pages. Following step 282, step 283 is implemented of updating the job log and accounting counter. Then step 274 is implemented of disabling the print device 102 followed by transfer to step 246 as described above with respect to the steps following step 272.
If yes, step 284 is implemented of printing the images or particular page or image. Following step 284, step 286 is implemented of updating the job log (initiated in step 228—see
Now returning to decision step 220 (see
Upon completion of step 298, the system 100 transfers to user service selection condition K. User service selection condition K includes step 300 of the user 131 or 132 selecting the service and programming the print job request, followed by step 302 of initiating job log collection.
Following step 302, the system 100 transfers into condition H that includes step 304 of updating the job log with job attributes, which is then followed by transfer to decision step 306 (see
Referring to
Returning now to
Following step 320, step 322 is implemented of displaying services allowed to the user on the user interface 140. Upon completion of step 322, user selection condition I is implemented which includes step 324 of the user 131 or 132 selecting the desired service, programming the print job request, and initiating the print job. Following step 324 of condition I, step 326 is implemented of updating count limits for each controlled attribute for the selected account from the Account Limits Table 158a. Upon completion of step 326, the system 100 transfers to monitoring condition L which includes step 308 of monitoring the number of images printed, and steps 310 and 312 as described above.
In view of the foregoing description referring to
The method 200 may further include the at least one print device, e.g., print device 102, having at least one database, e.g., database 102a, communicating with the at least one server, e.g., the EAS server 104 or the funds server 106, via the network 110 for dynamically updating accounting information for the print job and dynamically creating a user account.
In addition, the method 200 may further include the at least one print device having at least one database, e.g., print device 102 having database 102a, communicating with the at least one server having at least one database, e.g., database 104a of EAS or partner server 104, or funds server database 106a of funds server 106 via the network 110 for dynamically updating accounting information for the print job and dynamically creating as the user account a temporary account included within at least one user account database, e.g., account database 150a or 150b, wherein the at least one user account database is one of the at least one database of the at least one print device and the at least one database of the server, e.g., database 102a of print device 102 and database 104a or 106a of EAS server 104 or funds server 106, respectively.
The method 200 may further include dynamically separating user authentication from user authorization included within at least one user account database, e.g., user account database 150a or 150b, wherein the at least one user account database is one of the at least one database of the at least one print device, e.g., print device database 102a of print device 102, and the at least one database of the server, e.g., database 104a or EAS server 104 or database 106a of funds server 106.
The method 200 may further include authenticating user information associated with the accounting information and at least one of dynamically requesting an amount of funds to initiate the print job be made available to the system 100, dynamically identifying cost of services for the print job, and dynamically identifying authorized services associated with the user account corresponding to the print job.
In addition, the method 200 further includes performing dynamic setting of user privileges corresponding to the user account. The method 200 may further include performing dynamic updating of at least one user account database, wherein the at least one user account database is one of the at least one database of the at least one print device and the at least one database of the server, e.g., databases 102a, 112a and/or 122a of print devices 102, 112, and/or 122, respectively, and the at least one database of the server, e.g., databases 104a and/or 106a of the server 104 and/or 106, respectively.
The method 200 may further include dynamically billing to at least one user account database, wherein the at least one user account database is one of the at least one database of the at least one print device and the at least one database of the server, e.g., databases 102a, 112a and/or 122a of print devices 102, 112, and/or 122, respectively, and the at least one database of the server, e.g., databases 104a and/or 106a of the server 104 and/or 106, respectively.
The method 200 may further include dynamically restricting dynamic billing to premium services associated with at least one user account database, wherein the at least one user account database is one of the at least one database of the at least one print device and the at least one database of the server, e.g., databases 102a, 112a and/or 122a of print devices 102, 112, and/or 122, respectively, and the at least one database of the server, e.g., databases 104a and/or 106a of the server 104 and/or 106, respectively.
The method 200 may further include dynamically restricting implementation of the print job to premium services associated with at least one user account database, wherein the at least one user account database is one of the at least one database of the at least one print device and the at least one database of the server, e.g., databases 102a, 112a and/or 122a of print devices 102, 112, and/or 122, respectively, and the at least one database of the server, e.g., databases 104a and/or 106a of the server 104 and/or 106, respectively.
The method 200 may further include dynamically counting page activity for the print job, with the page activity being associated with the temporary account.
It will be appreciated that variations of the above-disclosed and other features and functions, or alternatives thereof, may be desirably combined into many other different systems or applications. Also, various presently unforeseen or unanticipated alternatives, modifications, variations or improvements therein may be subsequently made by those skilled in the art which are also intended to be encompassed by the following claims.
This application is related to commonly owned and concurrently filed U.S. Patent Application No. {Attorney Docket No. 20061622-US-NP (1515-85)} by K. J. Buck et al., entitled “LOCAL COST COMPUTATION ACCOUNTING FOR A PRINT JOB”; U.S. Patent Application No. {Attorney Docket No. 20061622Q-US-NP (1515-85Q)} by K. J. Buck et al., entitled “LOCAL COST COMPUTATION ACCOUNTING FOR A PRINT JOB”; U.S. Patent Application No. {Attorney Docket No. 20061623-US-NP (1515-78)} by K. J. Buck et al., entitled “DATA PROCESSING CARD BASED COPY BILL PAYMENT CAPABILITY”; U.S. Patent Application No. {Attorney Docket No. 20061623Q-US-NP (1515-78Q)} by K. J. Buck et al., entitled “DATA PROCESSING CARD BASED COPY BILL PAYMENT CAPABILITY”; and U.S. Patent Application No. {Attorney Docket No. 20061634-US-NP (1515-79)} by V. Mukund et al., entitled “DISTRIBUTED LIMIT-BASED ACCOUNTING FOR PRINT JOBS”, the entire contents of each of which is incorporated by reference herein.