WO2012071646A1 - System for internet enabled printing - Google Patents

System for internet enabled printing Download PDF

Info

Publication number
WO2012071646A1
WO2012071646A1 PCT/CA2011/001295 CA2011001295W WO2012071646A1 WO 2012071646 A1 WO2012071646 A1 WO 2012071646A1 CA 2011001295 W CA2011001295 W CA 2011001295W WO 2012071646 A1 WO2012071646 A1 WO 2012071646A1
Authority
WO
WIPO (PCT)
Prior art keywords
print
document
internet
printer
electronic document
Prior art date
Application number
PCT/CA2011/001295
Other languages
French (fr)
Inventor
Michael St. Laurent
Dharmesh Krishnammagara
Craig Tomlin
Michael Edward Kuindersma
Jonathan Stairs
Mark Onischke
Conrad Clement
Original Assignee
Printeron Inc.
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Printeron Inc. filed Critical Printeron Inc.
Priority to EP11845210.1A priority Critical patent/EP2646899B1/en
Publication of WO2012071646A1 publication Critical patent/WO2012071646A1/en

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/12Digital output to print unit, e.g. line printer, chain printer
    • G06F3/1201Dedicated interfaces to print systems
    • G06F3/1278Dedicated interfaces to print systems specifically adapted to adopt a particular infrastructure
    • G06F3/1285Remote printer device, e.g. being remote from client or server
    • G06F3/1289Remote printer device, e.g. being remote from client or server in server-client-printer device configuration, e.g. the server does not see the printer
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/12Digital output to print unit, e.g. line printer, chain printer
    • G06F3/1201Dedicated interfaces to print systems
    • G06F3/1202Dedicated interfaces to print systems specifically adapted to achieve a particular effect
    • G06F3/1203Improving or facilitating administration, e.g. print management
    • G06F3/1206Improving or facilitating administration, e.g. print management resulting in increased flexibility in input data format or job format or job type
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/12Digital output to print unit, e.g. line printer, chain printer
    • G06F3/1201Dedicated interfaces to print systems
    • G06F3/1223Dedicated interfaces to print systems specifically adapted to use a particular technique
    • G06F3/1237Print job management
    • G06F3/1244Job translation or job parsing, e.g. page banding
    • G06F3/1245Job translation or job parsing, e.g. page banding by conversion to intermediate or common format
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/12Digital output to print unit, e.g. line printer, chain printer
    • G06F3/1201Dedicated interfaces to print systems
    • G06F3/1278Dedicated interfaces to print systems specifically adapted to adopt a particular infrastructure
    • G06F3/1285Remote printer device, e.g. being remote from client or server
    • G06F3/1287Remote printer device, e.g. being remote from client or server via internet
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/12Digital output to print unit, e.g. line printer, chain printer
    • G06F3/1201Dedicated interfaces to print systems
    • G06F3/1278Dedicated interfaces to print systems specifically adapted to adopt a particular infrastructure
    • G06F3/1292Mobile client, e.g. wireless printing
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N1/00Scanning, transmission or reproduction of documents or the like, e.g. facsimile transmission; Details thereof
    • H04N1/00127Connection or combination of a still picture apparatus with another apparatus, e.g. for storage, processing or transmission of still picture signals or of information associated with a still picture
    • H04N1/00204Connection or combination of a still picture apparatus with another apparatus, e.g. for storage, processing or transmission of still picture signals or of information associated with a still picture with a digital computer or a digital computer system, e.g. an internet server
    • H04N1/00209Transmitting or receiving image data, e.g. facsimile data, via a computer, e.g. using e-mail, a computer network, the internet, I-fax
    • H04N1/00222Transmitting or receiving image data, e.g. facsimile data, via a computer, e.g. using e-mail, a computer network, the internet, I-fax details of image data generation or reproduction, e.g. scan-to-email or network printing
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N1/00Scanning, transmission or reproduction of documents or the like, e.g. facsimile transmission; Details thereof
    • H04N1/00127Connection or combination of a still picture apparatus with another apparatus, e.g. for storage, processing or transmission of still picture signals or of information associated with a still picture
    • H04N1/00204Connection or combination of a still picture apparatus with another apparatus, e.g. for storage, processing or transmission of still picture signals or of information associated with a still picture with a digital computer or a digital computer system, e.g. an internet server
    • H04N1/00244Connection or combination of a still picture apparatus with another apparatus, e.g. for storage, processing or transmission of still picture signals or of information associated with a still picture with a digital computer or a digital computer system, e.g. an internet server with a server, e.g. an internet server
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L51/00User-to-user messaging in packet-switching networks, transmitted according to store-and-forward or real-time protocols, e.g. e-mail
    • H04L51/07User-to-user messaging in packet-switching networks, transmitted according to store-and-forward or real-time protocols, e.g. e-mail characterised by the inclusion of specific contents
    • H04L51/08Annexed information, e.g. attachments

Definitions

  • TITLE SYSTEM FOR INTERNET ENABLED PRINTING
  • the present disclosure relates generally to a system for internet enabled printing, and more particularly for distributing print data in an internet enabled printing system.
  • Electronic documents can also be in any number of formats that may not be supported for viewing on the mobile device or printing on the printer-connected system. These incompatibilities can be the result of different applications or operating systems using different document formats. Electronic document incompatibilities can add an additional step for printing an electronic document located on a mobile device.
  • a system for printing electronic documents over the internet that comprises an internet print service for receiving a first electronic document over the internet, and a print client connected to a printer for receiving a second electronic document from the internet print service, the second document based on the first electronic document received by the internet print service, and initiating the printer to print the second electronic document.
  • the internet print service converts the first electronic document into an intermediate format supported by the print client. The conversion can be based on printing options that are provided with the first electronic document.
  • the intermediate format can be JPEG, TIFF or PDF, and may be supported natively by the printer.
  • the print client renders the second electronic document for printing with the printer.
  • the internet print service can receive the first electronic document by e-mail or through a web interface.
  • the internet print service has a registry database that associates the printer with an identifier that is received with the first electronic document.
  • the identifier can include an e-mail address at the internet domain of the internet print service.
  • the registry database stores printing options used to provide printing options used to the convert the first electronic document into the second electronic document.
  • the registry database stores authorization information associated with the printer that is used to authorize the first electronic document for printing on the printer.
  • the authorization information can include an access control list that contains whitelisted e-mail addresses.
  • the internet print service has a web portal that provides an interface for account creation and management that stores account information in the registry database.
  • the system further comprises a messaging module that is coupled to the internet print service for receiving presence information through a messaging protocol from the print client to notifiy the internet print service that the print client is available to receive the second electronic document.
  • the messaging module can be configured to send a message to the print client to notify the print client that the second electronic document is available.
  • the system further comprises a number of document distributors that have storage for a number of second electronic documents, the document distributors provide load distribution between themselves to efficiently deliver the second electronic documents to print clients by the internet print service.
  • the internet print service can distribute a second electronic document to one of the document distributors through the messaging module sending a message to the print client indicating that the second electronic document is available at the selected document distributor. Presence information received by the messaging module can be used to determine whether the send the message to the print client or store the message.
  • FIG. 1 a block diagram of a system for providing print services over the internet
  • FIG. 2 is a block diagram illustrating the components of internet print service shown in FIG. 1 ;
  • FIG. 3 is a block diagram illustrating the components of print client shown in FIG. 1 ;
  • FIG. 4 is a block diagram illustrating a distributed delivery system for an internet print service.
  • FIG. 1 shown is a block diagram of a system 100 for providing print services over internet 102.
  • a document is submitted over internet 102 by either an internet connected device 104 or a cloud document storage service 106 to an internet print service 110.
  • Internet print service 110 then renders the document into a format that is compatible with print client 1 12.
  • the rendered document is then provided to print client 112 over internet 102.
  • Print client 112 then renders the document in a format supported by printer 114 for printing the document.
  • internet 102 is shown, other embodiments can include other public or private wide area networks in the place of, or in combination with, the public internet.
  • Internet connected device 104 can send documents through e-mail or through web protocols, such as HTTP and HTTPS, to internet print service 1 10.
  • Internet connected device 104 can be any device capable of sending an e-mail and can include mobile e-mail devices, such as cell phones, smart phones, personal digital assistants, or tablet computers, and can also include internet-connected personal computers.
  • Internet connected device 104 could also include a server that forwards messages to an e-mail address. The forwarded messages could include e-mail messages, instant messaging platform messages, or SMS or MMS cell phone messages.
  • a document stored on internet connected device 104 can be printed on printer 114 by sending the document as an attachment to an e-mail message that is destined for internet print service 110.
  • Each printer managed by internet print service 1 10 will have its own unique e-mail address at the domain of internet print service 1 10 that can be assigned when a printer registers with the service.
  • printer 1 1 may have an e-mail address: printer114@internetprintservice1 10.com.
  • Documents can also be submitted by internet connected device 104 through a web portal hosted by internet print service 110 that allows internet connected device 104 to submit a document over the portal.
  • the web portal can also provide a web services interface that can be used by applications executing on internet connected device 104 to submit documents to internet print service 110.
  • the web services interface can also be utilized by servers that implement cloud document storage service 106 to allow documents stored on the service to be submitted to internet print service 110.
  • Internet connected device 104 can also manage access to printer 1 14 and other account details through an interface provided by internet print service 110.
  • Internet print service 110 is comprised of one or more servers that are interconnected and have access to internet 102.
  • the servers include one or more processors that execute program code from memory in order to configure the processor(s) to provide the functionality of internet print service 110.
  • the servers typically include a network interface for intercommunication between servers and internet 102.
  • the servers can also include storage for various databases relating to printers, users, and documents processed by internet print service 110.
  • Internet print service 110 provides an interface for receiving electronic documents from internet connected device 104 and provides an interface to allow users of internet print service 110 to manage their account.
  • User account information including information about the user and their printer 114 are stored in a database at internet print service 110.
  • Internet print service 110 will consult the database to authorize users and determine the options to use to render documents for compatibility with print client 1 12 and printer 114.
  • Internet print service 110 provides the rendered document to print client 1 12 for printing on printer 114.
  • Print client 112 can be any internet-connected device that connects to printer 1 14 to provide access to internet print service 110.
  • Print client 112 can include a personal computer that is running software to configure the personal computer to communicate with internet print service 1 10 to provide documents to printer 114.
  • Print client 112 can also operate on other hardware that acts as a print server for a connected printer 1 14.
  • consumer and small business networking hardware such as routers or network attached storage devices, include a print server feature and have a processor and memory that could be configured to run software to implement print client 112.
  • a set-top box connected to a television or software executing on a television could also serve as a print client 112, examples include, but are not limited to, cable boxes, IPTV receivers, DVD/Blu- Ray players, or application suites available on televisions.
  • Print client 1 12 can also be integrated into printer 1 14 in the form of software executing on a processor of printer 1 14.
  • Software can include firmware stored in non-volatile memory of printer 1 14.
  • Printer 1 14 produces text and graphics of electronic documents on physical print media (e.g. paper or transparencies).
  • Printer 114 can be connected to print client 1 12 as a local peripheral that is attached by a printer cable or USB cable.
  • Printer 114 can also be a network printer that includes a built-in network interface, typically wireless and/or Ethernet based.
  • a network printer can include print client 1 12 or print client 112 can be located on an external device connected to the same network as the network printer.
  • Printer 1 4 can have a number of different capabilities and options including, among others, supported paper formats, color printing, duplex printing, collating, scaling to fit paper, multi-page printing, orientation (e.g. landscape or portrait), print quality, and watermarks.
  • a record of capabilities and options of printer 114 can be stored by internet print service 110 and configured by a user, either globally, per job, or per user.
  • FIG. 2 shown is a block diagram 200 illustrating the components of internet print service 110 shown in FIG. 1.
  • the blocks in diagram 200 can represent a logical or functional separation of the elements of internet print service 110.
  • the blocks in diagram 200 can also represent hardware, such as a specifically tasked server or cluster of servers, or a software module executing on a server (or multiple servers) to perform a specific task.
  • Each block does not necessarily have to be co-located with other blocks shown in diagram 200.
  • internet print service 110 could have multiple print delivery servers located around the world that are separately located from other elements shown in block diagram 200.
  • Internet print service 1 10 may also include multiple servers for purposes of load balancing, redundancy, disaster recovery or back-up purposes that are not shown in FIG. 2.
  • Internet print service 110 includes a web portal 202 that can provide a user interface or application interface for interacting with internet print service 1 10.
  • Web portal 202 can be a web page that is hosted by internet print service 110 that allows a user to create and manage their account with the service.
  • web portal 202 can provide a web services application interface that allows an application running on a device external to access internet print service 110 to create and manage a user account.
  • print client 112 or internet connected device 104 could include an interface to web portal 202 that allows a user to create and manage their account from print client 114.
  • Web portal 202 can allow a user to create an account and associate the account with a printer client 112 or printer 1 14.
  • a user creates an account by providing their name, e-mail address, and other identifying information to internet print service 1 10 through web portal 202.
  • the other identifying information can include a street address, location information, such as geographical coordinates from a GPS or Wi-Fi-based location service, and details about printer 1 14 including, but not limited to, the printer manufacturer and model identification.
  • Creating an account typically includes setting up account credentials, such as a unique user name and a password for the user. Once the account is created a confirmation e-mail can be sent to the user that contains a link that a user clicks to activate the account.
  • Account creation may also involve a billing process that allows a user to pay for the service and any additional features of the service, such as having multiple printers or additional storage of electronic documents.
  • Information associated with the user's account, including the user name and password can be stored in registry database 204.
  • printer 1 14 can be registered with the user's account. Registration involves associating a unique identifier between a user account and an instance of print client 1 12.
  • the unique identifier can include a serial number or e-mail address that identifies print client 1 12 to internet print service 1 10.
  • the user can be provided the unique identifier as part of the account creation process that the user then provides to print client 1 12. Registration can also be performed by print client 1 12 requesting a unique identifier as part of the setup or installation process of print client 1 12.
  • the user can provide their account credentials to configure print client 1 12 that then uses the credentials to obtain a unique identifier from web portal 202.
  • the association between the unique identifier and the user account is then stored in the registry database 204.
  • internet print service 110 is configured for only a single printer 1 14 to be managed by print client 1 12, then the unique identifier may be used to send electronic documents to printer 1 14.
  • internet print service 1 10 could associate an e- mail address in the form of unique_identifier@internetprintservice1 10.com for printer 1 14.
  • internet print service 1 10 could be configured to include an additional layer of abstraction by also having a unique identifier for each printer 114. This can allow print client 1 12 to manage multiple printers 114.
  • Registry database 204 can store the printer identifiers and associate them with either a user account directly or indirectly through a print client 112 associated with a user account.
  • Web portal 202 can also provide an interface to allow user to manage printers associated with their account. Users can enable and disable internet print service 1 10 for a printer 1 14 associated with their user account via web portal 202. Available printing options and default printing options can be specified for an associated printer. Printing options can include paper size and print quality, among others. Changes made to printing options are then stored in registry database 204.
  • An access control list can also be specified through web portal 202 that allows a user to specify permissions to use printer 1 14.
  • the access control list can be a whitelist of e-mail addresses that the user has approved to send electronic documents to printer 1 14.
  • the whitelist can incorporate wildcards to allow all users from a certain domain or with a certain e-mail address format to be specified.
  • a whitelist entry can include " * @myworkplace.com" in order to accept documents from any e-mail address from the myworkplace.com domain.
  • Web portal 202 can also allow a user to provide release settings that are used to determine how to release a print job to a printer.
  • An automatic release setting can be specified to release all print jobs submitted to a printer through internet print service. The automatic release can be limited to only users specified on the whitelist. The user can also specify a manual release method that requires approval to release all print jobs.
  • a user can also request to receive notification when a print job is submitted to a printer associated with their account. The notification can include an e-mail to the address associated with the account that includes an HTTP link that when clicked releases the print job.
  • Releasing print jobs can be managed by internet print service 1 0 or print client 112. If print client 1 12 manages releasing jobs then the release settings can be propagated to the print client 1 12 from internet print service 1 10.
  • Web portal 202 can also provide reports of printing activity that a user can access to review print jobs that have been submitted to a printer associated to their account. Reports can include the file name of the electronic document, the document type (e.g. a word processor document, spreadsheet, PDF file, etc.), number of pages printed, printing options used, information identifying who submitted the electronic document, such as an e-mail address, and the result of print job (e.g. successful, pending, error, not in whitelist, etc.).
  • Internet print service 110 can obtain report information from document archive 206.
  • the reporting feature can also allow the user to preview or download the electronic documents from document archive 206 that were submitted to printer 114.
  • Document archive 206 can be provided as an optional feature to allow users to store all printed documents on internet print service 110 for later re-printing or reference. An option to resubmit a document to the printer may also be provided in reporting information.
  • Registry database 204 stores data associated with user accounts and printers registered with internet print service 110. Records in registry database 204 for users can include user name and password; e-mail address of user; access control lists; identification of registered printers associated with the user account; and other data related to the user's account. A user could also be identified or authenticated by a hardware identifier stored in registry database 204. The hardware identifier could include a MAC address for a network interface card or an International Mobile Equipment Identifier (IMEI).
  • IMEI International Mobile Equipment Identifier
  • Records in registry database 204 for printers and print clients can include identification information of printers, including name, network address, and printer capabilities and options.
  • a printer may be identified by a globally unique identifier that is used by internet print service 110.
  • Registry database 204 can also contain a mapping from a printer identifier, such as an e-mail address, to the globally unique identifier.
  • Print history records can also be stored in registry database 204 that provide a printing history for each printer and the status of each print job.
  • Document reception interface 208 receives electronic documents from internet connected device 104 or cloud document storage service 106.
  • Document reception interface 208 can include e-mail interface 210 for receiving electronic documents as attachments to e-mail messages received by internet print service 1 10.
  • Document reception interface 208 can also include web interface 212 for receiving electronic documents over an HTTP or HTTPS connection.
  • Web interface 212 can work in conjunction with web portal 202 to provide a web page that allows a user upload an electronic document through the web page.
  • Web interface 212 can also provide an application interface to allow applications to upload electronic documents to internet print service 110 over the web interface, such as from an application running on internet connected device 104 or cloud document storage service 106.
  • Document reception interface 208 can communicate with registry database 204 to determine whether a request to print an electronic document is authorized. This can include validating account credentials provided to web interface 212 or verifying if an e-mail sender is on the whitelist for a requested printer 114. Authorized print requests can then be forwarded to electronic document renderer 214 along with accompanying print request options (e.g. page ranges, paper size, print quality, etc.).
  • E-mail interface 210 can be implemented by an e-mail server that can further include an e-mail spam filter device.
  • E-mail spam can be filtered based on whitelist e-mail addresses provided by users.
  • E-mail spam can also be filtered by a third party service external to internet print service 110 to offload e-mail spam processing from internet print service 110.
  • e-mail interface 210 When an e-mail is received, e-mail interface 210 must determine which attachments should be printed. Attachments can be evaluated based on a number of factors, such as, for example, the file type and the physical size of the document. For example, in an e-mail with multiple attachments, e-mail interface 210 could determine not to print JPEG image attachments below a certain size since these may be signature images rather than pertinent electronic documents. The physical dimensions of an attachment can also be used to determine whether to print an attachment. E-mail attachments can also include transport or presentation information that may be used in determining whether an attachment should be printed. In some e-mails, included attachments are intended to provide assistance displaying the associated attachments and not intended to be printed itself.
  • E-mail interface 210 can also parse print options that are provided in the e- mail message. If a user does not wish to use their default print options provided through web portal 202, they can provide print options in the subject line or message body of the e- mail. For example, "PQUAL: DRAFT" in the subject line of the message could specify that the attached documents are to be printed as draft quality by printer 1 14.
  • E-mail interface 210 can also send e-mail notifications to users of internet print service 1 10.
  • E-mail notifications can include simple updates when a print job is completed, reporting account activity or reporting error conditions, such as when an electronic document is not able to be printed.
  • Interactive e-mail notifications can also be sent to users of internet print service 210 by including a link to web portal 202. The link can be used to seek authorization to release a print job to printer 114, request payment or billing information, or to present the user submitting an electronic document or creating an account with a challenge-response test to verify that the user is a human.
  • Electronic documents received by document reception interface 208 are provided to electronic document renderer 214 that renders the electronic document in a format that is supported by print client 112 and printer 114.
  • Electronic document renderer 214 can be implemented by one or more servers to provide enough processing power to render all electronic documents submitted through document reception interface 208 in a timely manner.
  • Document reception interface 208 also provides the printing options to electronic document renderer 214.
  • Electronic document renderer 214 can retrieve default printing options and printer capabilities of the destination print client 112 and printer 1 14 from registry database 204.
  • Electronic document renderer 214 can also determine whether the print request is authorized according to the access control list stored in registry database for printer 114.
  • the electronic document can be rendered into an intermediate document format that is supported by print client 112.
  • the intermediate document format is supported natively by the operating system of print client 112 or is a commonly available document format.
  • Examples of intermediate document formats can include the portable document format (PDF), Tagged Image File Format (TIFF), and JPEG file formats. If an electronic document is already in one of the acceptable formats, electronic document renderer 214 may still process the electronic document to conform to the options supported by printer 14 and print client 1 14, such as paper size, for example.
  • Electronic document renderer 214 can use a single intermediate document format or, if multiple formats are supported by internet print service 110, electronic document renderer can obtain the intermediate document format supported by print client 1 12 from registry database 204.
  • Print client 112 can provide its supported intermediate document types to registry database 204 upon installation of the software or upon registering printer 114.
  • Rendering electronic documents into an intermediate document format at internet print service 110 allows print client 112 to have a smaller subset of print rendering routines to handle the intermediate document format rather than all possible electronic document formats. This allows print client 1 2 to be deployed as a software application that does not require a large amount of storage memory. Print client 1 2 also does not require a large amount of processing power since the electronic document is rendered by internet print service 110 into an intermediate document format that is more efficient for print client 112 to process for printer 11 .
  • the intermediate document is generated by electronic document renderer 214
  • the intermediate document format is provided to document distributor 216 for delivery to print client 1 12. If print client 112 is connected to internet and internet print service 1 10, then document distributor 216 can provide the intermediate document to print client 112. Document distributor 216 can send a notification to print client 1 12 that a document is available, and when print client 112 receives the notification can request the document from document distributor 216.
  • document distributor 216 can not immediately provide the document to print client 112 then the document may be stored in delivery storage 218.
  • Document distributor 216 can periodically retry sending the document to print client 112.
  • internet print service 110 can provide a notification to print client 112 that a document is available from document distributor 216 when print client 12 connects to internet print service 1 10.
  • Internet print service 110 could also store an indication that print jobs are pending that print client 112 can check periodically or upon connecting to internet print service 110. If a certain time period expires or delivery storage 218 requires additional storage for other documents to be delivered to other print clients, the document may be removed from delivery storage 218. For example, delivery storage 218 can store a document for 24 hours after which the document will be removed and the print attempt failed.
  • FIG. 3 shown is a block diagram 300 illustrating the components of print client 1 12 shown in FIG. 1.
  • the elements shown in diagram 300 can include software and hardware elements. Some elements may be provided by a print client software program and other aspects may be provided, at least in part, by operating system software and system hardware.
  • Print client 1 12 includes a document retrieval interface 302 for receiving and/or retrieving documents from document distributor 216 of internet print service 1 10.
  • Document retrieval interface 302 can poll internet print service 110 to determine if any documents are available for print client 1 12 for printing. Alternatively, notification that a document is available can be provided to print client 1 12 by notification interface 308 that indicates that document retrieval interface 302 should download the document.
  • printer 1 14 can be capable of printing the intermediate document format natively where the received electronic document can be sent to the printer without rendering the document by print Tenderer 304.
  • Print Tenderer 304 can be a print driver that converts the intermediate document into the format expected by printer 114.
  • Print renderer 304 can be provided as part an operating system service, such as the Common Unix Printing System.
  • the rendered format can include printer command language for communicating with printer 114.
  • release queue 306 Prior to the document being rendered by print renderer 304 it can be stored in release queue 306 that awaits the occurrence of a release condition before providing the document to print renderer 304.
  • release queue 306 may simply act as a buffer for print renderer 304. If release of print jobs is handled under the direction of internet print service 10, a notification to release the print job may be received from internet print service 1 10 over notification interface 308 that then releases the print job from release queue 306.
  • a manual release method may also be used where user interface (not shown) provided by print client 1 2 allows a user to select a specific print job in release queue 306 for printing. Release queue 306 and print renderer 304 can also be re-ordered from that shown in FIG. 3 so that release queue 306 stores the rendered document produced by print renderer 304.
  • Notification interface 308 can include messaging with internet print service 1 10 to communicate status information between internet print service 1 10 and print client 1 12.
  • Notification interface 308 can provide notifications via e-mail, web messaging, SMS or other message protocols to update a user (or internet print service 1 10) on the status of print client 112. For example, a message can be sent to a user for the following events: an electronic document is received by the print client 112; a print job is released from release queue 306; status change of printer 1 16; and error messages generated by printer 114 or print client 112.
  • Web portal interface 310 provides an interface to web portal 202 of internet print service 1 0 to allow print client 112 to communicate with internet print service 10 to create or manage an account.
  • Web portal interface 210 can also interrogate printer 1 14 to determine the capabilities and options supported and then provide this information to internet print service 110 for storage in registry database 204.
  • FIG. 4 is a block diagram 400 illustrating a distributed delivery system for internet print service 0 using a messaging protocol.
  • the messaging protocol provides notifications between internet print service 110 and print clients 1 12 connected to printer 114.
  • the messaging protocol can be used to provide an efficient method of load distribution between a number of document distributors, illustrated as document distributors 216a and 216b in FIG. 4, that are used by internet print service 1 10.
  • document distributors are provided for example purposes but other embodiments can include any number of document distributors.
  • Document distributors 216a-b can also each include an electronic document renderer (not shown) to distribute the processing load of renderining the electronic document in a format that is supported by print client 12 and printer 114.
  • the messaging protocol can also provide additional print options associated with a print job.
  • the messaging protocol can also communicate presence information from print clients 1 12, such as, for example, a status indicator that conveys the ability of print client 112 to accept documents/print jobs for printing.
  • Any number of document distributors can be used in the system, and document distributors can be added over time to allow the system to scale to support a higher volume of documents. Multiple document distributors can also be used to provide a more efficient geographical distribution of print jobs. For example, a document distributor could be used to serve documents to the eastern half of the country and a separate document distributor could be used to serve documents to the western half of the country.
  • Internet print service 110 can use geographic information associated with the destination print client 1 12 to determine which document distributor 216a-b should receive the document. The geographic information can be obtained through the registration process or from network data, such as but not limited to an IP address or DNS geo-location.
  • Internet print service 110 can include a messaging module 410 to support the messaging protocol.
  • Messaging module 410 can be implemented as a specifically tasked messaging server or cluster of servers, or a software module executing on a server (or multiple servers) to perform the messaging protocol. Messaging module 410 can be collocated with other elements of internet print service 110, such as those shown in FIG. 2, or can be implemented as a separately located server.
  • Print client 112 also has a messaging interface 420 for communicating using the messaging protocol with the messaging module 410 of internet print service 1 10.
  • Messaging interface 420 can be provided as part of a print client software program. In other embodiments, messaging interface 420 can also be provided in part by the operating system of print client 112 that interfaces with a print client software program.
  • internet print service 110 decides which document distributor should receive the document for eventual delivery to print client 112.
  • Internet print service 110 can make this decision based on a number of factors. For example, internet print service 110 may determine based on load feedback or storage space data provided by document distributors 216a-b that document distributor 216b should receive the document for delivery to print client 112. In some embodiments this additional data may be communicated between the document distributors 216a-b and internet print service 110 using the messaging protocol. Alternatively, internet print service 110 may determine based on geographic information related to print client 1 12 that document distributor 216a should receive the document for delivery to print client 1 12 since document distributor 216a is nearest geographically.
  • internet print service 110 could distribute documents between the document distributors 216a-b in a round-robin manner; distributing documents either over all document distributors or within a group of document distributors that service a similar geographic region.
  • Other variations could utilize network information about internet 102 to select from document distributor 216a-b based on print client 112, such as, but not limited to, the number of network hops, the network link speed and congestion information.
  • Time of day could be another factor used to select from document distributors 216a-b since document distributors located in different time-zones may have a different load based on the business day in that time-zone.
  • Another factor used to select from document distributors 216a-b can include whether the document distributor can process the specified type or format of the electronic document for rendering for print client 112.
  • document distributor 216a may support a particular format of word processing document that is not supported by document distributor 216b such that document distributor 216a should be selected. This may be done to lower licensing costs by only having a limited number of document distributors with the capability to render a certain type or format of an electronic document.
  • Messaging module 410 sends a message to a destination print client 1 12 to indicate that internet print service 110 has stored the print job at one of document distributors 216a-b for delivery to print client 112.
  • print client 112 can then request the print job from the document distributor indicated in the message.
  • the message from internet print service 1 0 can indicate the document using a unique identifier and network address, such as but not limited to an IP address or domain name of the document distributor.
  • the message can also include print options associated with the print job, such as, for example, the number of copies, paper format, print quality and other options supported by printer 114.
  • Messaging module 410 can identify users associated with print client 1 2 and can maintain a database that associates user accounts with the appropriate print client 1 2.
  • Internet print service 110 may determine whether print client 1 12 is connected by receiving presence information through the messaging protocol from print client 112 that notifies internet print service 1 0 that it can accept print jobs. When a presence information message is received from print client 112, internet print servce 110 can then send any pending messages stored by messaging module 410.
  • An advantage of using a messaging protocol to send print job information is that if there are a large number of print clients 112, internet print service 110 will not be inundated with polling requests from print clients 112 to determine if print jobs are available.
  • Another advantage is that internet print service 1 10 does not require a persistent TCP network connection between every print client 1 12 which is very resource intensive.
  • Another advantage of using a messaging protocol between messaging module 410 of internet print service 110 and messaging interface 420 of print client 112 is that the messaging protocol can be used when the client software is behind a firewall.
  • An example messaging protocol can include XMPP which supports HTTP bindings to web servers, such as Apache, for example. This can be used by internet print server 110 to push notifications to print client 112 through messaging interface 420 making an HTTP connection to messaging module 410 to receive messages as soon as they are sent.
  • HTTP allows messaging interface 420 to fetch and post messages using commonly open ports without interuption from firewalls.
  • messaging interface 420 can connect to an Apache web server of internet printer server 110 using port 80 (or 443 for secure socket layer connections).
  • print client 112 uses a message protocol over HTTP, most firewalls will allow print client 112 to fetch and post HTTP messages without any hindrances.
  • internet printer server 1 120 can also listen on the normal HTTP/HTTPS ports and the traffic will not be intercepted by a firewall operating on the network of print client 112.

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • General Engineering & Computer Science (AREA)
  • Human Computer Interaction (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Computing Systems (AREA)
  • Multimedia (AREA)
  • Signal Processing (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Accessory Devices And Overall Control Thereof (AREA)

Abstract

A system for internet enabled printing is disclosed. The system includes an internet print service that renders electronic documents from internet connected devices into an intermediate format for printing by an internet connected print client. The print client allows a printer connected to the print client to print electronic documents received from internet print service. A user registers with the internet print service to obtain an identifier for their printer that is accessible over the internet. The identifier can include an e-mail address so that electronic documents can be submitted to the registered printer via e-mail.

Description

TITLE: SYSTEM FOR INTERNET ENABLED PRINTING
FIELD
[001] The present disclosure relates generally to a system for internet enabled printing, and more particularly for distributing print data in an internet enabled printing system.
BACKGROUND
[002] With the proliferation of mobile computing, users are often not directly connected to a printer but need hard copies of electronic documents. Since the devices are mobile, the users can be located anywhere, and are not necessarily connected to the same network as their printer. Printing an electronic document located on a mobile device is typically a disconnected two step process. The mobile device user will first transmit the document to a system connected to a printer using the mobile device, and then initiate printing the document from the printer-connected system. This requires that the user be located at the printer connected system to complete the process.
[003] Electronic documents can also be in any number of formats that may not be supported for viewing on the mobile device or printing on the printer-connected system. These incompatibilities can be the result of different applications or operating systems using different document formats. Electronic document incompatibilities can add an additional step for printing an electronic document located on a mobile device.
SUMMARY
[004] According to a first aspect, a system is provided for printing electronic documents over the internet that comprises an internet print service for receiving a first electronic document over the internet, and a print client connected to a printer for receiving a second electronic document from the internet print service, the second document based on the first electronic document received by the internet print service, and initiating the printer to print the second electronic document. In some aspects, the internet print service converts the first electronic document into an intermediate format supported by the print client. The conversion can be based on printing options that are provided with the first electronic document. The intermediate format can be JPEG, TIFF or PDF, and may be supported natively by the printer. In another aspect, the print client renders the second electronic document for printing with the printer. The internet print service can receive the first electronic document by e-mail or through a web interface.
[005] In another aspect, the internet print service has a registry database that associates the printer with an identifier that is received with the first electronic document. The identifier can include an e-mail address at the internet domain of the internet print service. In some aspects, the registry database stores printing options used to provide printing options used to the convert the first electronic document into the second electronic document. In other aspects, the registry database stores authorization information associated with the printer that is used to authorize the first electronic document for printing on the printer. In some aspects, the authorization information can include an access control list that contains whitelisted e-mail addresses. In another aspect, the internet print service has a web portal that provides an interface for account creation and management that stores account information in the registry database.
[006] In yet another aspect, the system further comprises a messaging module that is coupled to the internet print service for receiving presence information through a messaging protocol from the print client to notifiy the internet print service that the print client is available to receive the second electronic document. The messaging module can be configured to send a message to the print client to notify the print client that the second electronic document is available. In a related aspect, the system further comprises a number of document distributors that have storage for a number of second electronic documents, the document distributors provide load distribution between themselves to efficiently deliver the second electronic documents to print clients by the internet print service. The internet print service can distribute a second electronic document to one of the document distributors through the messaging module sending a message to the print client indicating that the second electronic document is available at the selected document distributor. Presence information received by the messaging module can be used to determine whether the send the message to the print client or store the message.
DRAWINGS
[007] For a better understanding of the various embodiments described herein and to show more clearly how they may be carried into effect, reference will now be made, by way of example only, to the accompanying drawings which show at least one exemplary embodiment, and in which:
[008] FIG. 1 a block diagram of a system for providing print services over the internet;
[009] FIG. 2 is a block diagram illustrating the components of internet print service shown in FIG. 1 ;
[0010] FIG. 3 is a block diagram illustrating the components of print client shown in FIG. 1 ; and
[0011] FIG. 4 is a block diagram illustrating a distributed delivery system for an internet print service.
DESCRIPTION OF VARIOUS EMBODIMENTS
[0012] It will be appreciated that for simplicity and clarity of illustration, where considered appropriate, numerous specific details are set forth in order to provide a thorough understanding of the exemplary embodiments described herein. However, it will be understood by those of ordinary skill in the art that the embodiments described herein may be practiced without these specific details. In other instances, well-known methods, procedures and components have not been described in detail so as not to obscure the embodiments described herein. Furthermore, this description is not to be considered as limiting the scope of the embodiments described herein in any way, but rather as merely describing the implementations of various embodiments described herein.
[0013] The embodiments of the systems, devices and methods described herein may be implemented in hardware or software, or a combination of both. Some of the embodiments described herein may be implemented in computer programs executing on programmable computers, each computer comprising at least one processor, a computer memory (including volatile and non-volatile memory), at least one input device, and at least one output device. For example, and without limitation, the programmable computers may be a server class computer having multiple processors and at least one network interface card. Program code may operate on input data to perform the functions described herein and generate output data. [0014] Reference is first made to FIG. 1 , shown is a block diagram of a system 100 for providing print services over internet 102. A document is submitted over internet 102 by either an internet connected device 104 or a cloud document storage service 106 to an internet print service 110. Internet print service 110 then renders the document into a format that is compatible with print client 1 12. The rendered document is then provided to print client 112 over internet 102. Print client 112 then renders the document in a format supported by printer 114 for printing the document. Although internet 102 is shown, other embodiments can include other public or private wide area networks in the place of, or in combination with, the public internet.
[0015] Internet connected device 104 can send documents through e-mail or through web protocols, such as HTTP and HTTPS, to internet print service 1 10. Internet connected device 104 can be any device capable of sending an e-mail and can include mobile e-mail devices, such as cell phones, smart phones, personal digital assistants, or tablet computers, and can also include internet-connected personal computers. Internet connected device 104 could also include a server that forwards messages to an e-mail address. The forwarded messages could include e-mail messages, instant messaging platform messages, or SMS or MMS cell phone messages.
[0016] A document stored on internet connected device 104 can be printed on printer 114 by sending the document as an attachment to an e-mail message that is destined for internet print service 110. Each printer managed by internet print service 1 10 will have its own unique e-mail address at the domain of internet print service 1 10 that can be assigned when a printer registers with the service. For example, printer 1 1 may have an e-mail address: printer114@internetprintservice1 10.com.
[0017] Documents can also be submitted by internet connected device 104 through a web portal hosted by internet print service 110 that allows internet connected device 104 to submit a document over the portal. The web portal can also provide a web services interface that can be used by applications executing on internet connected device 104 to submit documents to internet print service 110. The web services interface can also be utilized by servers that implement cloud document storage service 106 to allow documents stored on the service to be submitted to internet print service 110. Internet connected device 104 can also manage access to printer 1 14 and other account details through an interface provided by internet print service 110.
[0018] Internet print service 110 is comprised of one or more servers that are interconnected and have access to internet 102. The servers include one or more processors that execute program code from memory in order to configure the processor(s) to provide the functionality of internet print service 110. The servers typically include a network interface for intercommunication between servers and internet 102. The servers can also include storage for various databases relating to printers, users, and documents processed by internet print service 110.
[0019] Internet print service 110 provides an interface for receiving electronic documents from internet connected device 104 and provides an interface to allow users of internet print service 110 to manage their account. User account information, including information about the user and their printer 114 are stored in a database at internet print service 110. Internet print service 110 will consult the database to authorize users and determine the options to use to render documents for compatibility with print client 1 12 and printer 114. Internet print service 110 provides the rendered document to print client 1 12 for printing on printer 114.
[0020] Print client 112 can be any internet-connected device that connects to printer 1 14 to provide access to internet print service 110. Print client 112 can include a personal computer that is running software to configure the personal computer to communicate with internet print service 1 10 to provide documents to printer 114. Print client 112 can also operate on other hardware that acts as a print server for a connected printer 1 14. For example, consumer and small business networking hardware, such as routers or network attached storage devices, include a print server feature and have a processor and memory that could be configured to run software to implement print client 112. A set-top box connected to a television or software executing on a television could also serve as a print client 112, examples include, but are not limited to, cable boxes, IPTV receivers, DVD/Blu- Ray players, or application suites available on televisions. Print client 1 12 can also be integrated into printer 1 14 in the form of software executing on a processor of printer 1 14. Software can include firmware stored in non-volatile memory of printer 1 14. [0021] Printer 1 14 produces text and graphics of electronic documents on physical print media (e.g. paper or transparencies). Printer 114 can be connected to print client 1 12 as a local peripheral that is attached by a printer cable or USB cable. Printer 114 can also be a network printer that includes a built-in network interface, typically wireless and/or Ethernet based. A network printer can include print client 1 12 or print client 112 can be located on an external device connected to the same network as the network printer.
[0022] Printer 1 4 can have a number of different capabilities and options including, among others, supported paper formats, color printing, duplex printing, collating, scaling to fit paper, multi-page printing, orientation (e.g. landscape or portrait), print quality, and watermarks. A record of capabilities and options of printer 114 can be stored by internet print service 110 and configured by a user, either globally, per job, or per user.
[0023] Now referring to FIG. 2, shown is a block diagram 200 illustrating the components of internet print service 110 shown in FIG. 1. The blocks in diagram 200 can represent a logical or functional separation of the elements of internet print service 110. The blocks in diagram 200 can also represent hardware, such as a specifically tasked server or cluster of servers, or a software module executing on a server (or multiple servers) to perform a specific task. Each block does not necessarily have to be co-located with other blocks shown in diagram 200. For example, internet print service 110 could have multiple print delivery servers located around the world that are separately located from other elements shown in block diagram 200. Internet print service 1 10 may also include multiple servers for purposes of load balancing, redundancy, disaster recovery or back-up purposes that are not shown in FIG. 2.
[0024] Internet print service 110 includes a web portal 202 that can provide a user interface or application interface for interacting with internet print service 1 10. Web portal 202 can be a web page that is hosted by internet print service 110 that allows a user to create and manage their account with the service. In addition, web portal 202 can provide a web services application interface that allows an application running on a device external to access internet print service 110 to create and manage a user account. For example, print client 112 or internet connected device 104 could include an interface to web portal 202 that allows a user to create and manage their account from print client 114. [0025] Web portal 202 can allow a user to create an account and associate the account with a printer client 112 or printer 1 14. A user creates an account by providing their name, e-mail address, and other identifying information to internet print service 1 10 through web portal 202. The other identifying information can include a street address, location information, such as geographical coordinates from a GPS or Wi-Fi-based location service, and details about printer 1 14 including, but not limited to, the printer manufacturer and model identification. Creating an account typically includes setting up account credentials, such as a unique user name and a password for the user. Once the account is created a confirmation e-mail can be sent to the user that contains a link that a user clicks to activate the account. Account creation may also involve a billing process that allows a user to pay for the service and any additional features of the service, such as having multiple printers or additional storage of electronic documents. Information associated with the user's account, including the user name and password can be stored in registry database 204.
[0026] During or after the account creation process, printer 1 14 can be registered with the user's account. Registration involves associating a unique identifier between a user account and an instance of print client 1 12. The unique identifier can include a serial number or e-mail address that identifies print client 1 12 to internet print service 1 10. The user can be provided the unique identifier as part of the account creation process that the user then provides to print client 1 12. Registration can also be performed by print client 1 12 requesting a unique identifier as part of the setup or installation process of print client 1 12. For example, if a user downloads and installs print client 1 12 on their personal computer, the user can provide their account credentials to configure print client 1 12 that then uses the credentials to obtain a unique identifier from web portal 202. The association between the unique identifier and the user account is then stored in the registry database 204.
[0027] If internet print service 110 is configured for only a single printer 1 14 to be managed by print client 1 12, then the unique identifier may be used to send electronic documents to printer 1 14. For example, internet print service 1 10 could associate an e- mail address in the form of unique_identifier@internetprintservice1 10.com for printer 1 14. Alternatively, internet print service 1 10 could be configured to include an additional layer of abstraction by also having a unique identifier for each printer 114. This can allow print client 1 12 to manage multiple printers 114. Registry database 204 can store the printer identifiers and associate them with either a user account directly or indirectly through a print client 112 associated with a user account.
[0028] Web portal 202 can also provide an interface to allow user to manage printers associated with their account. Users can enable and disable internet print service 1 10 for a printer 1 14 associated with their user account via web portal 202. Available printing options and default printing options can be specified for an associated printer. Printing options can include paper size and print quality, among others. Changes made to printing options are then stored in registry database 204.
[0029] An access control list can also be specified through web portal 202 that allows a user to specify permissions to use printer 1 14. The access control list can be a whitelist of e-mail addresses that the user has approved to send electronic documents to printer 1 14. The whitelist can incorporate wildcards to allow all users from a certain domain or with a certain e-mail address format to be specified. For example, a whitelist entry can include "*@myworkplace.com" in order to accept documents from any e-mail address from the myworkplace.com domain.
[0030] Web portal 202 can also allow a user to provide release settings that are used to determine how to release a print job to a printer. An automatic release setting can be specified to release all print jobs submitted to a printer through internet print service. The automatic release can be limited to only users specified on the whitelist. The user can also specify a manual release method that requires approval to release all print jobs. A user can also request to receive notification when a print job is submitted to a printer associated with their account. The notification can include an e-mail to the address associated with the account that includes an HTTP link that when clicked releases the print job. Releasing print jobs can be managed by internet print service 1 0 or print client 112. If print client 1 12 manages releasing jobs then the release settings can be propagated to the print client 1 12 from internet print service 1 10.
[0031] Web portal 202 can also provide reports of printing activity that a user can access to review print jobs that have been submitted to a printer associated to their account. Reports can include the file name of the electronic document, the document type (e.g. a word processor document, spreadsheet, PDF file, etc.), number of pages printed, printing options used, information identifying who submitted the electronic document, such as an e-mail address, and the result of print job (e.g. successful, pending, error, not in whitelist, etc.). Internet print service 110 can obtain report information from document archive 206. The reporting feature can also allow the user to preview or download the electronic documents from document archive 206 that were submitted to printer 114. Document archive 206 can be provided as an optional feature to allow users to store all printed documents on internet print service 110 for later re-printing or reference. An option to resubmit a document to the printer may also be provided in reporting information.
[0032] Registry database 204 stores data associated with user accounts and printers registered with internet print service 110. Records in registry database 204 for users can include user name and password; e-mail address of user; access control lists; identification of registered printers associated with the user account; and other data related to the user's account. A user could also be identified or authenticated by a hardware identifier stored in registry database 204. The hardware identifier could include a MAC address for a network interface card or an International Mobile Equipment Identifier (IMEI).
[0033] Records in registry database 204 for printers and print clients can include identification information of printers, including name, network address, and printer capabilities and options. A printer may be identified by a globally unique identifier that is used by internet print service 110. Registry database 204 can also contain a mapping from a printer identifier, such as an e-mail address, to the globally unique identifier. Print history records can also be stored in registry database 204 that provide a printing history for each printer and the status of each print job.
[0034] Document reception interface 208 receives electronic documents from internet connected device 104 or cloud document storage service 106. Document reception interface 208 can include e-mail interface 210 for receiving electronic documents as attachments to e-mail messages received by internet print service 1 10. Document reception interface 208 can also include web interface 212 for receiving electronic documents over an HTTP or HTTPS connection. Web interface 212 can work in conjunction with web portal 202 to provide a web page that allows a user upload an electronic document through the web page. Web interface 212 can also provide an application interface to allow applications to upload electronic documents to internet print service 110 over the web interface, such as from an application running on internet connected device 104 or cloud document storage service 106.
[0035] Document reception interface 208 can communicate with registry database 204 to determine whether a request to print an electronic document is authorized. This can include validating account credentials provided to web interface 212 or verifying if an e-mail sender is on the whitelist for a requested printer 114. Authorized print requests can then be forwarded to electronic document renderer 214 along with accompanying print request options (e.g. page ranges, paper size, print quality, etc.).
[0036] E-mail interface 210 can be implemented by an e-mail server that can further include an e-mail spam filter device. E-mail spam can be filtered based on whitelist e-mail addresses provided by users. E-mail spam can also be filtered by a third party service external to internet print service 110 to offload e-mail spam processing from internet print service 110.
[0037] When an e-mail is received, e-mail interface 210 must determine which attachments should be printed. Attachments can be evaluated based on a number of factors, such as, for example, the file type and the physical size of the document. For example, in an e-mail with multiple attachments, e-mail interface 210 could determine not to print JPEG image attachments below a certain size since these may be signature images rather than pertinent electronic documents. The physical dimensions of an attachment can also be used to determine whether to print an attachment. E-mail attachments can also include transport or presentation information that may be used in determining whether an attachment should be printed. In some e-mails, included attachments are intended to provide assistance displaying the associated attachments and not intended to be printed itself.
[0038] E-mail interface 210 can also parse print options that are provided in the e- mail message. If a user does not wish to use their default print options provided through web portal 202, they can provide print options in the subject line or message body of the e- mail. For example, "PQUAL: DRAFT" in the subject line of the message could specify that the attached documents are to be printed as draft quality by printer 1 14.
[0039] E-mail interface 210 can also send e-mail notifications to users of internet print service 1 10. E-mail notifications can include simple updates when a print job is completed, reporting account activity or reporting error conditions, such as when an electronic document is not able to be printed. Interactive e-mail notifications can also be sent to users of internet print service 210 by including a link to web portal 202. The link can be used to seek authorization to release a print job to printer 114, request payment or billing information, or to present the user submitting an electronic document or creating an account with a challenge-response test to verify that the user is a human.
[0040] Electronic documents received by document reception interface 208 are provided to electronic document renderer 214 that renders the electronic document in a format that is supported by print client 112 and printer 114. Electronic document renderer 214 can be implemented by one or more servers to provide enough processing power to render all electronic documents submitted through document reception interface 208 in a timely manner. Document reception interface 208 also provides the printing options to electronic document renderer 214. Electronic document renderer 214 can retrieve default printing options and printer capabilities of the destination print client 112 and printer 1 14 from registry database 204. Electronic document renderer 214 can also determine whether the print request is authorized according to the access control list stored in registry database for printer 114.
[0041] Once electronic document renderer 214 has determined the appropriate printing options, the electronic document can be rendered into an intermediate document format that is supported by print client 112. Typically, the intermediate document format is supported natively by the operating system of print client 112 or is a commonly available document format. Examples of intermediate document formats can include the portable document format (PDF), Tagged Image File Format (TIFF), and JPEG file formats. If an electronic document is already in one of the acceptable formats, electronic document renderer 214 may still process the electronic document to conform to the options supported by printer 14 and print client 1 14, such as paper size, for example. Electronic document renderer 214 can use a single intermediate document format or, if multiple formats are supported by internet print service 110, electronic document renderer can obtain the intermediate document format supported by print client 1 12 from registry database 204. Print client 112 can provide its supported intermediate document types to registry database 204 upon installation of the software or upon registering printer 114.
[0042] Rendering electronic documents into an intermediate document format at internet print service 110 allows print client 112 to have a smaller subset of print rendering routines to handle the intermediate document format rather than all possible electronic document formats. This allows print client 1 2 to be deployed as a software application that does not require a large amount of storage memory. Print client 1 2 also does not require a large amount of processing power since the electronic document is rendered by internet print service 110 into an intermediate document format that is more efficient for print client 112 to process for printer 11 .
[0043] After the intermediate document is generated by electronic document renderer 214, the intermediate document format is provided to document distributor 216 for delivery to print client 1 12. If print client 112 is connected to internet and internet print service 1 10, then document distributor 216 can provide the intermediate document to print client 112. Document distributor 216 can send a notification to print client 1 12 that a document is available, and when print client 112 receives the notification can request the document from document distributor 216.
[0044] If document distributor 216 can not immediately provide the document to print client 112 then the document may be stored in delivery storage 218. Document distributor 216 can periodically retry sending the document to print client 112. As alternative to document distributor retrying, internet print service 110 can provide a notification to print client 112 that a document is available from document distributor 216 when print client 12 connects to internet print service 1 10. Internet print service 110 could also store an indication that print jobs are pending that print client 112 can check periodically or upon connecting to internet print service 110. If a certain time period expires or delivery storage 218 requires additional storage for other documents to be delivered to other print clients, the document may be removed from delivery storage 218. For example, delivery storage 218 can store a document for 24 hours after which the document will be removed and the print attempt failed.
[0045] Referring now to FIG. 3, shown is a block diagram 300 illustrating the components of print client 1 12 shown in FIG. 1. The elements shown in diagram 300 can include software and hardware elements. Some elements may be provided by a print client software program and other aspects may be provided, at least in part, by operating system software and system hardware.
[0046] Print client 1 12 includes a document retrieval interface 302 for receiving and/or retrieving documents from document distributor 216 of internet print service 1 10. Document retrieval interface 302 can poll internet print service 110 to determine if any documents are available for print client 1 12 for printing. Alternatively, notification that a document is available can be provided to print client 1 12 by notification interface 308 that indicates that document retrieval interface 302 should download the document.
[0047] After a document is received, typically in an intermediate document format, the document is then rendered by print Tenderer 304 for printer 1 14. In some embodiments, printer 1 14 can be capable of printing the intermediate document format natively where the received electronic document can be sent to the printer without rendering the document by print Tenderer 304. Print Tenderer 304 can be a print driver that converts the intermediate document into the format expected by printer 114. Print renderer 304 can be provided as part an operating system service, such as the Common Unix Printing System. The rendered format can include printer command language for communicating with printer 114.
[0048] Prior to the document being rendered by print renderer 304 it can be stored in release queue 306 that awaits the occurrence of a release condition before providing the document to print renderer 304. In the case of automatic print job release, release queue 306 may simply act as a buffer for print renderer 304. If release of print jobs is handled under the direction of internet print service 10, a notification to release the print job may be received from internet print service 1 10 over notification interface 308 that then releases the print job from release queue 306. A manual release method may also be used where user interface (not shown) provided by print client 1 2 allows a user to select a specific print job in release queue 306 for printing. Release queue 306 and print renderer 304 can also be re-ordered from that shown in FIG. 3 so that release queue 306 stores the rendered document produced by print renderer 304.
[0049] Notification interface 308 can include messaging with internet print service 1 10 to communicate status information between internet print service 1 10 and print client 1 12. Notification interface 308 can provide notifications via e-mail, web messaging, SMS or other message protocols to update a user (or internet print service 1 10) on the status of print client 112. For example, a message can be sent to a user for the following events: an electronic document is received by the print client 112; a print job is released from release queue 306; status change of printer 1 16; and error messages generated by printer 114 or print client 112.
[0050] Web portal interface 310 provides an interface to web portal 202 of internet print service 1 0 to allow print client 112 to communicate with internet print service 10 to create or manage an account. Web portal interface 210 can also interrogate printer 1 14 to determine the capabilities and options supported and then provide this information to internet print service 110 for storage in registry database 204.
[0051] Referring now to FIG. 4, is a block diagram 400 illustrating a distributed delivery system for internet print service 0 using a messaging protocol. The messaging protocol provides notifications between internet print service 110 and print clients 1 12 connected to printer 114. The messaging protocol can be used to provide an efficient method of load distribution between a number of document distributors, illustrated as document distributors 216a and 216b in FIG. 4, that are used by internet print service 1 10. Two document distributors are provided for example purposes but other embodiments can include any number of document distributors. Document distributors 216a-b can also each include an electronic document renderer (not shown) to distribute the processing load of renderining the electronic document in a format that is supported by print client 12 and printer 114.
[0052] The messaging protocol can also provide additional print options associated with a print job. The messaging protocol can also communicate presence information from print clients 1 12, such as, for example, a status indicator that conveys the ability of print client 112 to accept documents/print jobs for printing.
[0053] Any number of document distributors can be used in the system, and document distributors can be added over time to allow the system to scale to support a higher volume of documents. Multiple document distributors can also be used to provide a more efficient geographical distribution of print jobs. For example, a document distributor could be used to serve documents to the eastern half of the country and a separate document distributor could be used to serve documents to the western half of the country. Internet print service 110 can use geographic information associated with the destination print client 1 12 to determine which document distributor 216a-b should receive the document. The geographic information can be obtained through the registration process or from network data, such as but not limited to an IP address or DNS geo-location.
[0054] Internet print service 110 can include a messaging module 410 to support the messaging protocol. Messaging module 410 can be implemented as a specifically tasked messaging server or cluster of servers, or a software module executing on a server (or multiple servers) to perform the messaging protocol. Messaging module 410 can be collocated with other elements of internet print service 110, such as those shown in FIG. 2, or can be implemented as a separately located server.
[0055] Print client 112 also has a messaging interface 420 for communicating using the messaging protocol with the messaging module 410 of internet print service 1 10. Messaging interface 420 can be provided as part of a print client software program. In other embodiments, messaging interface 420 can also be provided in part by the operating system of print client 112 that interfaces with a print client software program.
[0056] When internet print service 110 has a document for delivery to a print client 1 12, internet print service 110 decides which document distributor should receive the document for eventual delivery to print client 112. Internet print service 110 can make this decision based on a number of factors. For example, internet print service 110 may determine based on load feedback or storage space data provided by document distributors 216a-b that document distributor 216b should receive the document for delivery to print client 112. In some embodiments this additional data may be communicated between the document distributors 216a-b and internet print service 110 using the messaging protocol. Alternatively, internet print service 110 may determine based on geographic information related to print client 1 12 that document distributor 216a should receive the document for delivery to print client 1 12 since document distributor 216a is nearest geographically. In yet another alternative, internet print service 110 could distribute documents between the document distributors 216a-b in a round-robin manner; distributing documents either over all document distributors or within a group of document distributors that service a similar geographic region. Other variations could utilize network information about internet 102 to select from document distributor 216a-b based on print client 112, such as, but not limited to, the number of network hops, the network link speed and congestion information. Time of day could be another factor used to select from document distributors 216a-b since document distributors located in different time-zones may have a different load based on the business day in that time-zone.
[0057] Another factor used to select from document distributors 216a-b can include whether the document distributor can process the specified type or format of the electronic document for rendering for print client 112. For example, document distributor 216a may support a particular format of word processing document that is not supported by document distributor 216b such that document distributor 216a should be selected. This may be done to lower licensing costs by only having a limited number of document distributors with the capability to render a certain type or format of an electronic document.
[0058] Messaging module 410 sends a message to a destination print client 1 12 to indicate that internet print service 110 has stored the print job at one of document distributors 216a-b for delivery to print client 112. When print client 112 receives the message, print client 112 can then request the print job from the document distributor indicated in the message. The message from internet print service 1 0 can indicate the document using a unique identifier and network address, such as but not limited to an IP address or domain name of the document distributor. The message can also include print options associated with the print job, such as, for example, the number of copies, paper format, print quality and other options supported by printer 114. Messaging module 410 can identify users associated with print client 1 2 and can maintain a database that associates user accounts with the appropriate print client 1 2. [0059] If print client 112 is not currently connected with the messaging module 410 of internet print service 0, then the message will be retained by messaging module 410 until print client 112 is available. Internet print service 110 may determine whether print client 1 12 is connected by receiving presence information through the messaging protocol from print client 112 that notifies internet print service 1 0 that it can accept print jobs. When a presence information message is received from print client 112, internet print servce 110 can then send any pending messages stored by messaging module 410. An advantage of using a messaging protocol to send print job information is that if there are a large number of print clients 112, internet print service 110 will not be inundated with polling requests from print clients 112 to determine if print jobs are available. Another advantage is that internet print service 1 10 does not require a persistent TCP network connection between every print client 1 12 which is very resource intensive.
[0060] Another advantage of using a messaging protocol between messaging module 410 of internet print service 110 and messaging interface 420 of print client 112 is that the messaging protocol can be used when the client software is behind a firewall. An example messaging protocol can include XMPP which supports HTTP bindings to web servers, such as Apache, for example. This can be used by internet print server 110 to push notifications to print client 112 through messaging interface 420 making an HTTP connection to messaging module 410 to receive messages as soon as they are sent. Using HTTP allows messaging interface 420 to fetch and post messages using commonly open ports without interuption from firewalls. For example, messaging interface 420 can connect to an Apache web server of internet printer server 110 using port 80 (or 443 for secure socket layer connections).
[0061] If print client 112 uses a message protocol over HTTP, most firewalls will allow print client 112 to fetch and post HTTP messages without any hindrances. Thus, in scenarios where the TCP port used by an XMPP implementation by print client 1 12 is blocked, internet printer server 1 120 can also listen on the normal HTTP/HTTPS ports and the traffic will not be intercepted by a firewall operating on the network of print client 112.
[0062] While the exemplary embodiments have been described herein, it is to be understood that the invention is not limited to the disclosed embodiments. The invention is intended to cover various modifications and equivalent arrangements included within the spirit and scope of the appended claims, and scope of the claims is to be accorded an interpretation that encompasses all such modifications and equivalent structures and functions.

Claims

A system for printing electronic documents over the internet, the system comprising: an internet print service for receiving a first electronic document over the internet; and a print client connected to a printer for receiving a second electronic document from the internet print service, the second document based on the first electronic document received by the internet print service, and initiating the printer to print the second electronic document.
The system of claim 1 , wherein the internet print service converts the first electronic document into the second electronic document, the second electronic document is an intermediate format supported by the print client.
The system of claim 2, wherein the print client renders the second electronic document for the printer.
The system of claim 2, wherein the intermediate format is selected from any one of JPEG, TIFF, and PDF.
The system of claim 4, wherein the printer is capable of printing the intermediate format natively.
The system of claim 2, where the internet print service receives the first electronic document by any one of an e-mail and a web interface.
The system of claim 6, wherein the internet print service has a registry database that associates the printer with an identifier that is received with the first electronic document.
The system of claim 7, wherein the identifier is an e-mail address at the domain of the internet print service.
The system of claim 7, wherein the internet print service converts the first electronic document into the second electronic document using printing options.
10. The system of claim 9, wherein the printing options are provided with the first electronic document or provided by the registry database.
11. The system of claim 7, wherein the registry database stores authorization information associated with the printer used to authorize the first electronic document for printing with the printer.
12. The system of claim 11 , wherein the authorization information includes an access control list containing whitelisted e-mail addresses.
13. The system of claim 7, wherein the internet print service further comprises a web portal that provides an interface for account creation and management that stores account information in the registry database.
14. The system of claim 1 further comprising: a messaging module coupled to the internet print service for receiving presence information through a messaging protocol from the print client to notifiy the internet print service that the print client is available to receive the second electronic document.
15. The system of claim 14, wherein the messaging module is configured to send a message to the print client to notify the print client that the second electronic document is available.
16. The system of claim 14 further comprising: a plurality of document distributors having storage for a plurality of second electronic documents, the plurality of document distributors to provide load distribution between the plurality of document distributors to efficiently deliver the plurality of second electronic documents to the print client, wherein the internet print service distributes the plurality of second electronic documents between the plurality of document distributors.
17. The system of claim 16 wherein the internet print service distributes the second electronic document to a selected one of the plurality of document distributors, and the messaging module sends a message to the print client indicating that the second electronic document is available at the selected document distributor.
18. The system of claim 17, the internet print service distributes the second electronic document to a selected one of the plurality of document distributors based on any one of geographical proximity; document distributor load feedback; document distributor available storage space; time of day; and network information.
19. The system of claim 18, wherein the messaging module determines whether print client is available based on presence information, and if the print client is available, sends the message, and if the print client is not available, stores the message for sending when the print client is available based on presence information received from the print client.
PCT/CA2011/001295 2010-11-30 2011-11-28 System for internet enabled printing WO2012071646A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
EP11845210.1A EP2646899B1 (en) 2010-11-30 2011-11-28 System for internet enabled printing

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US41814310P 2010-11-30 2010-11-30
US61/418,143 2010-11-30

Publications (1)

Publication Number Publication Date
WO2012071646A1 true WO2012071646A1 (en) 2012-06-07

Family

ID=46171115

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/CA2011/001295 WO2012071646A1 (en) 2010-11-30 2011-11-28 System for internet enabled printing

Country Status (4)

Country Link
US (1) US9760329B2 (en)
EP (1) EP2646899B1 (en)
CA (1) CA2759736C (en)
WO (1) WO2012071646A1 (en)

Families Citing this family (20)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20100309510A1 (en) * 2009-06-09 2010-12-09 Accipiter Innovations, Llc Systems, methods and devices for printing from a mobile device
US9019535B1 (en) 2009-06-09 2015-04-28 Breezyprint Corporation Secure mobile printing from a third-party device
US9134930B2 (en) 2011-03-30 2015-09-15 Hewlett-Packard Development Company, L.P. Delayed content production
JP5810761B2 (en) * 2011-09-01 2015-11-11 セイコーエプソン株式会社 Process control server and process control method
KR101758676B1 (en) * 2011-09-27 2017-07-19 에스프린팅솔루션 주식회사 Electronic apparatus, message server and method for controllng of printing
US9036185B2 (en) 2011-09-28 2015-05-19 Hewlett-Packard Development Company, L.P. Managing network connections
US9323483B2 (en) 2011-10-28 2016-04-26 Hewlett-Packard Development Company, L.P. Location-based print notifications
US9760326B2 (en) * 2012-03-30 2017-09-12 Hewlett-Packard Development Company, L.P. Print facilitation
RU2522024C2 (en) * 2012-10-15 2014-07-10 Общество С Ограниченной Ответственностью "Лаборатория Эландис" Method of signing electronic documents with analogue-digital signature with additional verification
US20140211243A1 (en) * 2013-01-31 2014-07-31 Hewlett-Packard Development Company, L.P. Printing from untrustworthy source
US9378437B2 (en) * 2013-02-27 2016-06-28 Hewlett-Packard Development Company, L.P. Sending print jobs using trigger distances
US20140320894A1 (en) * 2013-04-29 2014-10-30 Lexmark International, Inc. Intelligent Print Release
US20140320895A1 (en) * 2013-04-29 2014-10-30 Lexmark International, Inc. Intelligent Print Release
US20140320899A1 (en) * 2013-04-29 2014-10-30 Lexmark International, Inc. Time-Based, Intelligent Print Release
EP3066556B1 (en) * 2013-08-23 2021-09-29 Hewlett-Packard Development Company, L.P. Mobile device for automatically delivering print jobs to printers
US9380174B2 (en) * 2014-02-19 2016-06-28 Xerox Corporation Methods and systems for automatically converting a mobile rendering job to a secure rendering job
WO2015137988A1 (en) * 2014-03-14 2015-09-17 Hewlett-Packard Development Company, L.P. Dummy port pinging to maintain a fixed client nat
US10097729B1 (en) * 2017-10-31 2018-10-09 Canon Kabushiki Kaisha Techniques and methods for integrating a personal assistant platform with a secured imaging system
US10901664B2 (en) * 2019-03-04 2021-01-26 Ricoh Company, Ltd. Print job submission mechanism
US20230305761A1 (en) * 2022-03-25 2023-09-28 Kyocera Document Solutions Inc. Contactless document processing system using document management profile

Citations (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20020036793A1 (en) * 1998-03-20 2002-03-28 Roosen Monica Maria Wilhelmina Mathea Remote Printer control
WO2002033532A2 (en) 2000-10-16 2002-04-25 Electronics For Imaging, Inc. Methods and systems for the provision of printing services
US20020191206A1 (en) 2001-06-18 2002-12-19 Anderson Jeff M. Rendering broker service and method
CA2432063A1 (en) * 2002-06-26 2003-12-26 Microsoft Corporation System and method for users of mobile computing devices to print documents
US6922258B2 (en) * 2001-05-30 2005-07-26 Polaroid Corporation Method and apparatus for printing remote images using a mobile device and printer
EP1895402A2 (en) * 2006-08-09 2008-03-05 NEC Corporation Printing system, printing method, and printing program
US20090299905A1 (en) * 2008-05-27 2009-12-03 Xerox Corporation Web enabled color management service system and method
US20100149572A1 (en) * 2008-12-15 2010-06-17 Xerox Corporation Method and system for automatically providing for multi-point document storing, access, and retrieval
US20110225640A1 (en) * 2008-08-14 2011-09-15 Microsoft Corporation Cloud-based device information storage
WO2011130026A2 (en) * 2010-04-14 2011-10-20 Microsoft Corporation Dynamic configuration of connectors for system level communications

Family Cites Families (118)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6581092B1 (en) 1999-09-29 2003-06-17 Ricoh Co., Ltd. Method and system for remote diagnostic, control and information collection based on various communication modes for sending messages to users
US5220674A (en) 1987-07-17 1993-06-15 Digital Equipment Corporation Local area print server for requesting and storing required resource data and forwarding printer status message to selected destination
US6345288B1 (en) 1989-08-31 2002-02-05 Onename Corporation Computer-based communication system and method using metadata defining a control-structure
US5580177A (en) 1994-03-29 1996-12-03 Hewlett-Packard Company Printer/client network with centrally updated printer drivers and printer status monitoring
US5825759A (en) 1994-10-26 1998-10-20 Telefonaktiebolaget Lm Ericsson Distributing network services and resources in a mobile communications network
US5696898A (en) 1995-06-06 1997-12-09 Lucent Technologies Inc. System and method for database access control
US6049711A (en) 1995-08-23 2000-04-11 Teletrac, Inc. Method and apparatus for providing location-based information services
US5958006A (en) 1995-11-13 1999-09-28 Motorola, Inc. Method and apparatus for communicating summarized data
US5903723A (en) 1995-12-21 1999-05-11 Intel Corporation Method and apparatus for transmitting electronic mail attachments with attachment references
US6076109A (en) 1996-04-10 2000-06-13 Lextron, Systems, Inc. Simplified-file hyper text protocol
US5727159A (en) 1996-04-10 1998-03-10 Kikinis; Dan System in which a Proxy-Server translates information received from the Internet into a form/format readily usable by low power portable computers
WO1997032274A2 (en) * 1996-03-01 1997-09-04 Fmr Corp. Open systems printing
US5764235A (en) 1996-03-25 1998-06-09 Insight Development Corporation Computer implemented method and system for transmitting graphical images from server to client at user selectable resolution
US6377994B1 (en) 1996-04-15 2002-04-23 International Business Machines Corporation Method and apparatus for controlling server access to a resource in a client/server system
US5826062A (en) 1996-05-30 1998-10-20 International Business Machines Corporation Method and apparatus for converting and displaying a multimedia document at a client
US5872926A (en) * 1996-05-31 1999-02-16 Adaptive Micro Systems, Inc. Integrated message system
US6088451A (en) 1996-06-28 2000-07-11 Mci Communications Corporation Security system and method for network element access
US6438586B1 (en) 1996-09-30 2002-08-20 Emc Corporation File transfer utility which employs an intermediate data storage system
US5987611A (en) 1996-12-31 1999-11-16 Zone Labs, Inc. System and methodology for managing internet access on a per application basis for client computers connected to the internet
US6138162A (en) 1997-02-11 2000-10-24 Pointcast, Inc. Method and apparatus for configuring a client to redirect requests to a caching proxy server based on a category ID with the request
EP0966822A2 (en) 1997-03-10 1999-12-29 Internet Dynamics, Inc. Methods and apparatus for controlling access to information
US6408336B1 (en) 1997-03-10 2002-06-18 David S. Schneider Distributed administration of access to information
US6178505B1 (en) 1997-03-10 2001-01-23 Internet Dynamics, Inc. Secure delivery of information in a network
US6345300B1 (en) 1997-03-25 2002-02-05 Intel Corporation Method and apparatus for detecting a user-controlled parameter from a client device behind a proxy
IL121071A0 (en) 1997-03-27 1997-11-20 El Mar Software Ltd Automatic conversion server
JPH10304334A (en) 1997-04-25 1998-11-13 Canon Inc Communication method and device, transmission device and reception device, communication system and recording medium
US6202156B1 (en) 1997-09-12 2001-03-13 Sun Microsystems, Inc. Remote access-controlled communication
US6377993B1 (en) 1997-09-26 2002-04-23 Mci Worldcom, Inc. Integrated proxy interface for web based data management reports
JPH11110324A (en) 1997-10-07 1999-04-23 Hitachi Ltd Substitutive server selector and substitutive server
US20010044843A1 (en) 1997-10-28 2001-11-22 Philip Bates Multi-user computer system
US6064656A (en) 1997-10-31 2000-05-16 Sun Microsystems, Inc. Distributed system and method for controlling access control to network resources
US6151624A (en) 1998-02-03 2000-11-21 Realnames Corporation Navigating network resources based on metadata
JP3966598B2 (en) 1998-03-04 2007-08-29 富士通株式会社 Server selection system
US6148336A (en) 1998-03-13 2000-11-14 Deterministic Networks, Inc. Ordering of multiple plugin applications using extensible layered service provider with network traffic filtering
US6085227A (en) 1998-03-20 2000-07-04 International Business Machines Corporation System and method for operating scientific instruments over wide area networks
US6233618B1 (en) 1998-03-31 2001-05-15 Content Advisor, Inc. Access control of networked data
US6092114A (en) 1998-04-17 2000-07-18 Siemens Information And Communication Networks, Inc. Method and system for determining the location for performing file-format conversions of electronics message attachments
US6317838B1 (en) 1998-04-29 2001-11-13 Bull S.A. Method and architecture to provide a secured remote access to private resources
US6438585B2 (en) 1998-05-29 2002-08-20 Research In Motion Limited System and method for redirecting message attachments between a host system and a mobile data communication device
WO1999065256A2 (en) 1998-06-10 1999-12-16 Logica, Inc. System and method for delivering e-mail notification to mobile phones
US6308273B1 (en) 1998-06-12 2001-10-23 Microsoft Corporation Method and system of security location discrimination
US6604143B1 (en) 1998-06-19 2003-08-05 Sun Microsystems, Inc. Scalable proxy servers with plug-in filters
GB2339036A (en) 1998-07-03 2000-01-12 Ibm Set of objects for extracting data from a database, and visual builder
US6490624B1 (en) 1998-07-10 2002-12-03 Entrust, Inc. Session management in a stateless network system
US6182142B1 (en) 1998-07-10 2001-01-30 Encommerce, Inc. Distributed access management of information resources
US6453353B1 (en) 1998-07-10 2002-09-17 Entrust, Inc. Role-based navigation of information resources
US6925595B1 (en) 1998-08-05 2005-08-02 Spyglass, Inc. Method and system for content conversion of hypertext data using data mining
US7127493B1 (en) 1998-08-20 2006-10-24 Gautier Taylor S Optimizing server delivery of content by selective inclusion of optional data based on optimization criteria
US6212565B1 (en) 1998-08-26 2001-04-03 Sun Microsystems, Inc. Apparatus and method for improving performance of proxy server arrays that use persistent connections
US6219786B1 (en) 1998-09-09 2001-04-17 Surfcontrol, Inc. Method and system for monitoring and controlling network access
US6829646B1 (en) 1999-10-13 2004-12-07 L. V. Partners, L.P. Presentation of web page content based upon computer video resolutions
US6687732B1 (en) 1998-09-28 2004-02-03 Inktomi Corporation Adaptive traffic bypassing in an intercepting network driver
US6336124B1 (en) 1998-10-01 2002-01-01 Bcl Computers, Inc. Conversion data representing a document to other formats for manipulation and display
DE69936873T2 (en) 1998-10-14 2008-04-30 Bradley S. Sunnyvale Templeton Method and system for the transmission of sessions and calls
US6708220B1 (en) 1998-11-19 2004-03-16 X/Net Associates, Inc. System and method for in-stream data compression
US6457030B1 (en) 1999-01-29 2002-09-24 International Business Machines Corporation Systems, methods and computer program products for modifying web content for display via pervasive computing devices
US8407102B2 (en) * 1999-03-08 2013-03-26 Printingforless.Com Printing via E-commerce method and system
US6542892B1 (en) 1999-04-07 2003-04-01 Hewlett-Packard Development Company, L.P. Configuring a client for a printer using electronic mail
US6553422B1 (en) 1999-04-26 2003-04-22 Hewlett-Packard Development Co., L.P. Reverse HTTP connections for device management outside a firewall
US6349336B1 (en) 1999-04-26 2002-02-19 Hewlett-Packard Company Agent/proxy connection control across a firewall
CA2307970A1 (en) * 1999-05-10 2000-11-10 Nortel Networks Limited Dynamic resource modification and applications for using same in a communication network
US6226752B1 (en) 1999-05-11 2001-05-01 Sun Microsystems, Inc. Method and apparatus for authenticating users
US6615234B1 (en) * 1999-05-11 2003-09-02 Taylor Corporation System and method for network-based document delivery
US6463474B1 (en) 1999-07-02 2002-10-08 Cisco Technology, Inc. Local authentication of a client at a network device
US6690481B1 (en) 1999-07-20 2004-02-10 Canon Kabushiki Kaisha Internet-based push printing over cable network
US6606660B1 (en) 1999-08-31 2003-08-12 Accenture Llp Stream-based communication in a communication services patterns environment
US6549949B1 (en) 1999-08-31 2003-04-15 Accenture Llp Fixed format stream in a communication services patterns environment
US6771595B1 (en) 1999-08-31 2004-08-03 Intel Corporation Apparatus and method for dynamic resource allocation in a network environment
US6360252B1 (en) 1999-09-20 2002-03-19 Fusionone, Inc. Managing the transfer of e-mail attachments to rendering devices other than an original e-mail recipient
US6981045B1 (en) 1999-10-01 2005-12-27 Vidiator Enterprises Inc. System for redirecting requests for data to servers having sufficient processing power to transcast streams of data in a desired format
US20010044829A1 (en) 1999-11-05 2001-11-22 David Lundberg Remote e-mail management and communication system
US7037198B2 (en) 1999-12-07 2006-05-02 Nokia Corporation Recording game information into a server
US6510464B1 (en) 1999-12-14 2003-01-21 Verizon Corporate Services Group Inc. Secure gateway having routing feature
US6324648B1 (en) 1999-12-14 2001-11-27 Gte Service Corporation Secure gateway having user identification and password authentication
US6681392B1 (en) 1999-12-15 2004-01-20 Lexmark International, Inc. Method and apparatus for remote peripheral software installation
US6742039B1 (en) 1999-12-20 2004-05-25 Intel Corporation System and method for connecting to a device on a protected network
US6662228B1 (en) 2000-02-01 2003-12-09 Sun Microsystems, Inc. Internet server authentication client
US6704798B1 (en) 2000-02-08 2004-03-09 Hewlett-Packard Development Company, L.P. Explicit server control of transcoding representation conversion at a proxy or client location
US6718328B1 (en) 2000-02-28 2004-04-06 Akamai Technologies, Inc. System and method for providing controlled and secured access to network resources
CA2706691A1 (en) 2000-03-01 2001-09-07 Printeron Inc. Network resource communication system
CA2299824C (en) 2000-03-01 2012-02-21 Spicer Corporation Network resource control system
CA2301996A1 (en) 2000-03-13 2001-09-13 Spicer Corporation Wireless attachment enabling
US6728787B1 (en) 2000-03-31 2004-04-27 Mitsubishi Electric Research Labs, Inc System and method for locating and installing device drivers for peripheral devices
US6598076B1 (en) 2000-05-02 2003-07-22 Openshark, Inc. Method and apparatus for electronically communicating an electronic message having an electronic attachment
US20020016818A1 (en) 2000-05-11 2002-02-07 Shekhar Kirani System and methodology for optimizing delivery of email attachments for disparate devices
EP1170920A1 (en) 2000-07-06 2002-01-09 BRITISH TELECOMMUNICATIONS public limited company Location dependant service access
US6801962B2 (en) * 2000-07-26 2004-10-05 Sharp Kabushiki Kaisha Data output system, mobile terminal, data output method, data output program, and computer-readable recording medium storing data output program
US6978299B1 (en) 2000-10-16 2005-12-20 Electronics For Imaging, Inc. Print driver apparatus and methods for forwarding a print job over a network
US7155487B2 (en) 2000-11-30 2006-12-26 Intel Corporation Method, system and article of manufacture for data distribution over a network
US6885860B2 (en) 2001-01-19 2005-04-26 Microsoft Corporation Information management and processing in a wireless network
JP3499535B2 (en) 2001-03-05 2004-02-23 東芝テック株式会社 Content server and network system
US7454482B2 (en) 2001-06-28 2008-11-18 Canon Information Systems, Inc. Print queue manager
JP2005501341A (en) 2001-08-22 2005-01-13 ピアレス・システムズ・コーポレーション Output management system and method enabling printing via wireless device
US20030079030A1 (en) 2001-08-22 2003-04-24 Cocotis Thomas A. Output management system and method for enabling access to private network resources
US20030078965A1 (en) 2001-08-22 2003-04-24 Cocotis Thomas A. Output management system and method for enabling printing via wireless devices
US7305381B1 (en) * 2001-09-14 2007-12-04 Ricoh Co., Ltd Asynchronous unconscious retrieval in a network of information appliances
US20030090694A1 (en) 2001-11-13 2003-05-15 Kennedy Kelli H. Just-in-time printer discovery and driver installation system and method
JP4741768B2 (en) * 2001-12-04 2011-08-10 キヤノン株式会社 Network control device, network control method and program
US8681352B2 (en) 2002-04-18 2014-03-25 Hewlett-Packard Development Company, L.P. Pull based computer output devices
US20040125401A1 (en) 2002-07-31 2004-07-01 Earl David J. System and method for printing on the nearest printer
SE525748C2 (en) * 2002-10-28 2005-04-19 Devlabs Ab Procedure for direct printing on networks
US7460261B2 (en) * 2002-12-27 2008-12-02 Ricoh Company, Ltd. Printing system, printing management device, print server, printing method, and storage medium
US7365872B2 (en) 2003-01-03 2008-04-29 Microsoft Corporation Client computer system, method and computer readable medium comprising executable instructions for rendering printable documents in a native printer language on the network
US20040203358A1 (en) 2003-03-17 2004-10-14 Anderson Jeff M. Mobile-printing desktop assistant
US7545528B2 (en) 2003-03-31 2009-06-09 Seiko Epson Corporation Print system and print system control method
US7505172B2 (en) * 2003-10-31 2009-03-17 Hewlett-Packard Development Company, L.P. Method and systems for processing print jobs
US7532899B2 (en) 2004-04-15 2009-05-12 At&T Mobility Ii Llc System for providing location-based services in a wireless network, such as locating sets of desired locations
US20060274357A1 (en) * 2005-06-03 2006-12-07 Zhongming Shen Systems and methods for digital image printing
US7793285B2 (en) 2006-03-31 2010-09-07 Ricoh Company, Ltd. Web installer driver and management through a remote network
US7676750B2 (en) 2007-01-31 2010-03-09 Lexmark International, Inc. Method of printing, scanning, and faxing using device location
US7764922B2 (en) 2007-02-14 2010-07-27 Kabushiki Kaisha Toshiba Image forming apparatus with printed-paper storing function and printed-paper storing method thereof
US20080246988A1 (en) 2007-04-09 2008-10-09 Anthony Arnol Ashton Adaptive printer pools
JP4916401B2 (en) * 2007-08-28 2012-04-11 キヤノン株式会社 Job submission request apparatus, job submission request method, and computer program
JP2009188522A (en) * 2008-02-04 2009-08-20 Seiko Epson Corp Image printer and method of controlling image printer
US8572717B2 (en) 2008-10-09 2013-10-29 Juniper Networks, Inc. Dynamic access control policy with port restrictions for a network security appliance
JP2010097301A (en) 2008-10-15 2010-04-30 Seiko Epson Corp Network system, server device, and printer driver
JP5319237B2 (en) * 2008-10-28 2013-10-16 キヤノン株式会社 Printing system and control method thereof
US8477350B2 (en) * 2010-03-16 2013-07-02 Google Inc. Cloud-based print service

Patent Citations (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20020036793A1 (en) * 1998-03-20 2002-03-28 Roosen Monica Maria Wilhelmina Mathea Remote Printer control
WO2002033532A2 (en) 2000-10-16 2002-04-25 Electronics For Imaging, Inc. Methods and systems for the provision of printing services
US6922258B2 (en) * 2001-05-30 2005-07-26 Polaroid Corporation Method and apparatus for printing remote images using a mobile device and printer
US20020191206A1 (en) 2001-06-18 2002-12-19 Anderson Jeff M. Rendering broker service and method
CA2432063A1 (en) * 2002-06-26 2003-12-26 Microsoft Corporation System and method for users of mobile computing devices to print documents
EP1895402A2 (en) * 2006-08-09 2008-03-05 NEC Corporation Printing system, printing method, and printing program
US20090299905A1 (en) * 2008-05-27 2009-12-03 Xerox Corporation Web enabled color management service system and method
US20110225640A1 (en) * 2008-08-14 2011-09-15 Microsoft Corporation Cloud-based device information storage
US20100149572A1 (en) * 2008-12-15 2010-06-17 Xerox Corporation Method and system for automatically providing for multi-point document storing, access, and retrieval
WO2011130026A2 (en) * 2010-04-14 2011-10-20 Microsoft Corporation Dynamic configuration of connectors for system level communications

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
GOOGLE CLOUD, 3 November 2010 (2010-11-03), XP003031877, Retrieved from the Internet <URL:http://web.archive.org/web/20101103134500/http://code.google.com/apis/cloudprint/docs/overview.html> *

Also Published As

Publication number Publication date
CA2759736A1 (en) 2012-05-30
US20120300251A1 (en) 2012-11-29
EP2646899A1 (en) 2013-10-09
US9760329B2 (en) 2017-09-12
EP2646899B1 (en) 2020-02-26
CA2759736C (en) 2020-12-29
EP2646899A4 (en) 2015-05-06

Similar Documents

Publication Publication Date Title
US9760329B2 (en) System for internet enabled printing
US11716435B2 (en) System and method for selectively sending, delivery and receiving of faxes
US10397155B2 (en) System and method for sending, delivery and receiving of digital content
EP2695047B1 (en) Document management system using printer emulation
US10348930B2 (en) System, method and computer program product for multi-tenant facsimile system
EP2617160B1 (en) System and method for managing printer resources on an internal network
US20120293826A1 (en) Systems and methods for providing multiple images
US9398100B2 (en) Managing access of network services
US20120084365A1 (en) Delivering resource files to printers using email
JP5905019B2 (en) Printing system, printing apparatus, printing method, and program
US20100242091A1 (en) Network video messaging
JP2013164836A (en) Information processing system, network system and information processing method
US9179034B2 (en) Information processing system and information processing method for distributing job data among plurality of first information processing devices
US7542156B2 (en) Remote printing method and system
EP2807548B1 (en) System for scalable processing of files in the cloud
US20140189116A1 (en) Managing scope of network services
US9760327B2 (en) Determining rendering systems utilizing printer locations and rendering system attributes
KR20080002068A (en) System and method for providing remote file service
JP6838497B2 (en) Information processing system and information processing method
JP5104968B2 (en) Control in a control device connected to the network

Legal Events

Date Code Title Description
121 Ep: the epo has been informed by wipo that ep was designated in this application

Ref document number: 11845210

Country of ref document: EP

Kind code of ref document: A1

NENP Non-entry into the national phase

Ref country code: DE