CUPS
CUPS(カップス、以前の名称はCommon UNIX Printing System)とはUnix系オペレーティングシステム (OS) 用のモジュール化された印刷システムである。CUPSは、Mac OSやWindowsの印刷機構に遅れをとっていたUnix系OSに強力な印刷機能をもたらすことになった。CUPSではUnix系OSでプリンターの形式・型ごとに独自に書き上げねばならなかったデバイスドライバの作成が極めて容易になり、過去にUnix系OSが対応していた特殊なラインプリンターとPostScriptプリンターのみならず、Macintosh/Windows向けに市販されているプリンターのほぼ全てがUnix系OS上から利用できるようになるとされている。
作者 | マイケル・スイート (Easy Software Products) |
---|---|
開発元 | Apple |
初版 | 1999年6月9日 |
最新版 |
2.3.6
/ 2022年5月25日[1] |
リポジトリ | |
プログラミング 言語 | C言語 |
対応OS | |
後継 | OpenPrinting CUPS |
種別 | プリントサーバ |
ライセンス | |
公式サイト |
www |
作者 | OpenPrintingとコミュニティ |
---|---|
最新版 |
2.3.3op2
/ 2021年2月1日 |
リポジトリ |
github |
前身 | Apple CUPS |
ライセンス | Apache-2.0 |
公式サイト |
openprinting |
CUPSを運用しているコンピュータは、クライアントのコンピュータから印刷ジョブを受け取るサーバとなり、それらのジョブを処理して適切なプリンターへと送る。また、その際にはHTTPのBasic認証およびDigest認証、ローカル認証、128ビットTLS/SSL暗号化などを用いることもできる。
CUPSはUnixの印刷スプーラとスケジューラ、フィルタシステム、およびバックエンド・システムからなる。このうち、フィルタシステムは印刷データをプリンターが理解可能な形式へ変換することを受け持ち、バックエンドシステムはそのデータをプリンターへと送ることを受け持つ。CUPSは印刷ジョブとキューを取り扱う基盤としてIPP (Internet Printing Protocol) を用いている。またCUPSはUnixで伝統的なSystem V形式とBSD(バークレー)形式のコマンドラインインタフェースもサポートしており、さらにSMBプロトコルも部分的にサポートしている。CUPSが提供するデバイスドライバは、アドビのPPD (PostScript Printer Description) 形式のテキストファイルを用いて設定が可能である。CUPSを設定するためCUPS自身はウェブ (HTTP) を用いた組込みのインタフェースを有している。また多くのユーザインタフェースがさまざまなプラットフォームに対して用意されており、ESP Print Proといった商用パッケージだけでなく、KUPS、GtkLP、QtKUPS、XPPなどのオープンソースライセンスで開発されているGUIがいくつも存在する。CUPSはmacOS版のみプロプライエタリライセンス、その他のOS向けにはApache License[2]の元で配布されている。以前はGNU General Public LicenseとGNU Lesser General Public License, Version 2で配布されていた。
歴史
編集CUPSはまず、Easy Software Productsのマイケル・スイートとアンドルー・ゼンフトによって1999年の秋に作成された[3]。最初のリリース版が公開されるまでのアルファ版とベータ版に2年間を要している。初期にはlpd (line printer daemon) を用いるよう開発努力が傾けられたが、ときとしてプリンターとの相性が悪いためにIPPも代替としてサポートされた。CUPSはすぐさま、Red Hat LinuxなどいくつかのLinuxディストリビューションで標準の印刷システムとして採用された。Apple ComputerはMac OS X v10.2のデフォルトの印刷システムとして2002年3月にCUPSを採用している[4]。2007年2月にアップルは主たる開発者であるマイケル・スイートを雇用し、CUPSのソースコードを取得している[5]。2019年12月20日、マイケル・スイートは自身のブログでアップルを退職したことを発表した[6]。 2020年にはOpenPrinting organizationによりプロジェクトがフォークされ、マイケル・スイートはそこでCUPSの開発を継続している[7]。
CUPSは当初、"Common UNIX Printing System" と呼ばれていたが、UNIX商標の法的な懸念からCUPS 1.4より "CUPS" と短縮されるようになった[8]。
概要
編集CUPSは、標準的な方法で印刷ジョブをプリンターに送ることを可能とする機構を与えるものである。印刷データはまずスケジューラへと送られ、スケジューラはジョブをプリンターが理解できる形式へと変換するためフィルタシステムに送る。さらにフィルタシステムはデータを、デバイスやネットワークへと送るための特殊なフィルタであるバックエンドへと受け渡す。CUPSのシステムはデータをプリンターが理解できる言葉へと変換するのにPostScriptとラスタ・グラフィックスをフルに活用している。
CUPSの最大の利点は、それが、印刷サーバ上で様々なデータ様式を処理できる標準的でモジュール化された印刷システムであることである。CUPS以前には、それぞれ独自の言語と形式を用いていた様々な市場のプリンターに対応している標準的なプリンターの処理システムは見当たらなかった。例えば、System Vとバークレイの印刷システムは互いの互換性がほとんどなく、しかもプログラムのデータ形式からプリンターが理解できる形式へと変換するための複雑なスクリプトと急場しのぎの手段とを用意する必要があった。さらにこれらはしばしばプリンターへと送られているファイル形式を検出する手段を持たないために、データ列を正しく自動的に変換することができなかった。また中心となるサーバ上ではなく各ワークステーション上でデータの変換を行っていた。
CUPSでは、プリンターのメーカーやドライバの開発者が印刷用サーバで専用に動くドライバを製作することが以前よりもはるかに容易なものとなっている。また、サーバ上で処理が成されることによって、他のUnixの印刷システムで行われていたことと較べネットワークを介する印刷も非常に容易なものとなる。ひとつの利点はSambaを用いるときで、プリンターはリモートのWindowsコンピュータで用いられ、しかも一般的なPostScriptドライバをネットワークを介する印刷に用いることができる。
スケジューラ
編集CUPSスケジューラはIPP (Internet Printing Protocol) もしくはlpd (line printer daemon) プロトコルのどちらかを用いることができる。スケジューラはHTTP/1.1のリクエストを解釈し印刷ジョブの管理、サーバの設定、およびCUPS自体の説明資料のためにウェブを用いたインタフェースを提供している。
スケジューラは、IPPとHTTPのどのメッセージがシステムに受け渡せるかを制御するための承認モジュールを有している。IPP/HTTPパケットは一旦承認されると、やって来る接続を監視しそれを処理しているクライアント・モジュールに送られる。クライアントモジュールはまた、必要に応じてウェブ基盤のプリンター、「クラス」、ジョブの実行状況のモニタと管理をサポートするための外部CGIプログラムの実行を受け持っている。クライアントモジュールがリクエストを処理すると、次にデータはさらなる処理のためにIPPモジュールへと送られる。このモジュールは、クライアントがHTTPサーバ上のアクセス制限または認証を回避することを防ぐためにURI (Uniform Resource Identifier) の検証を行う。
スケジューラではプリンターがクラスを持つことを認めている。これは複数のプリンターをグループ化するひとつの方法であり、ジョブをあるクラスへと送るような用い方を可能としている。すなわち、スケジューラはクラス内で最初に利用できるプリンターを選び出してジョブをそのプリンターへと送る。ジョブモジュールは、最終的な変換と印刷のために印刷ジョブをフィルタやバックエンドの処理へと送ることで印刷ジョブを管理する。またそれらフィルタやバックエンドからのステータスメッセージも監視している。
スケジューラのコンフィギュレーションモジュールはCUPSのデータ構造を初期化するとともに設定ファイルを解析し、CUPSプログラムをスタートさせる。コンフィギュレーションモジュールは設定ファイルを処理している間はCUPSサービスを停止させ、処理が完了するとサービスを再開させる。
ログ・モジュールはアクセス、エラー、ログ・ファイル操作のスケジューラの事象のログを取り扱い、一方メインモジュールはタイムアウトとクライアントからの接続に対するI/Oリクエストの送出を受け持ち、またシグナルを監視し、必要に応じサーバの設定ファイルの再読み込み、さらに子プロセスのエラーと終了を取り扱う。
スケジューラで用いられているその他のモジュールには、印刷デバイスが理解できる形式に印刷データを変換するときのフィルター処理に用いられるMIME型と変換データベースを取り扱うMIMEモジュール、PPD (Postscript Printer Description) ファイルのリストを扱うPPDモジュール、システムで利用可能なデバイスのリストを扱うデバイスモジュール、CUPS内のプリンターとPPDを扱うプリンターモジュールがある。
フィルタ・システム
編集CUPSの大きな利点のひとつは、様々なデータ形式を印刷サーバ上で処理できるということである。印刷ジョブは一連のフィルターを介してプリンターの最終的な言語・形式へと変換される。このデータ形式と変換方法はMIME型を利用して抽象化されている。CUPSはmime.types
とmime.convs
の2つのMIMEデータのファイルを使用する。mime.types
はCUPSがファイルのMIME型を決定するために用いられ、mime.convs
はあるMIME型を別のMIME型に処理するためのプログラムを定義している。
例えば、HTMLファイルを検出するためのmime.types
の行は、
text/html html htm \ printable(0,1024) + (string(0,"<HTML>") string(0,"<!DOCTYPE"))
となっている。これは、ファイルのサフィックス(拡張子)がhtml
もしくはhtm
であるか、ファイルのテキストの始めの1KiBが印刷可能な文字からなっていて、かつ<HTML>
か<!DOCTYPE
から始まっているなら、ファイルはMIME型text/htmlであるものと見なされることを意味している。一方、mime.convs
ファイルは以下のような行からなっている。
text/plain application/postscript 50 texttops
1番目のカラムと2番目のカラムはともにMIME型であり、それぞれ変換前のMIME型と変換後のMIME型とを表している。3番目のカラムはファイルを変換するために支払うべき「コスト」を表し、フィルタ・システムがファイルを変換するときに別々のフィルタの組合せの中からどれを選ぶかを決定するための評価基準とされる。最後のカラムはデータを変換するためのフィルタプログラムを表す。よって、text/plain
型のファイルはフィルタtexttops
によってコスト50でapplication/postscript
型に変換できることになる。
フィルタシステムは、プリンターキューまたは印刷フィルタの名前、印刷ジョブのジョブ番号、ユーザ名、ジョブ名、印刷部数、その他印刷のオプション、ファイル名(標準入力からリダイレクトされた場合は不要)の引数とともに入力データを受け取る。その後、上述のようにMIMEデータベースを用いて入力データの型と使用されるフィルタを決定する。例えば、画像データが検出されればそれ用の特定のフィルタで処理され、HTMLのデータならまた別の特定のフィルタで処理される。これらのデータはその後PostScriptデータに変換されるか、直接ラスタデータに変換しうる。PostScriptデータへ変換された場合には、プレフィルタと呼ばれるさらなるフィルタが適用され、これは印刷するページ範囲の指定や、複数のページを1ページに埋め込むN-Upモードの設定などプリンターに特定のオプションを加えることができるようにPostScriptデータにたいして別のPostScript変換プログラムを適用する。
プレフィルタによる処理が終わると、PostScriptプリンタを用いている場合にはそのままデータはCUPSのバックエンドに送られ、そうでない場合には(linuxprinting.orgのFoomaticのような)別のフィルタかGhostscriptで処理される。これはPostScriptをプリンターに依存しない中間形式のCUPS-rasterフォーマット(MIME 型 application/vnd.cups-raster
)へと変換する。最後にこの中間ラスタ形式はプリンター個別の形式へと最終フィルタで処理される。
このラスタ形式からのフィルタとしてCUPSにデフォルトで含まれているものは、PCL (Printer Command Language)、ESC/PまたはESC/P2、およびDymoへのフィルタである。ただし、CUPSで用いることができるいくつかの代替フィルタもある。CUPSの開発元であるEasy Software Productsは独自のCUPSフィルタをリリースしている。Gimp-Printは幅広い範囲の(主として)インクジェット・プリンターに対する高精度なドライバであり、LinuxのTurbo-Printはやはり様々な種類のプリンターに対しての種々のドライバを有している。
バックエンド
編集バックエンドはデータをプリンターに送る手段である。CUPSで有効なバックエンドには、パラレルポート、シリアルポート、およびUSBポートのプリンターとともに、IPP (Internet Printing Protocol)、JetDirect (AppSocket)、lpd (line printer daemon)、SMB (Server Message Block) プロトコルを介して処理されるネットワーク・バックエンドがある。
互換性
編集伝統的な印刷コマンドがCUPSでも用いることができるようにCUPSはSystem V形式とBSD形式の両方の印刷コマンドを与えている。CUPSは伝統的なlpdポートであるポート515を監視し、それを「バックエンド」として取り扱う。CUPSをインストールすると、System Vの印刷システムに対応するlp
コマンドとBSDの印刷システムに対応するlpr
コマンドとが互換プログラムとしてインストールされる。これらはCUPSへの標準的なインタフェースとなり、これらの印刷システムに依存する現存するアプリケーションとの最大限の互換性を保つ。
注釈
編集- ^ “CUPS.org”. Apple. 2023年7月6日閲覧。
- ^ “CUPS Software License Agreement”. 2017年11月10日時点のオリジナルよりアーカイブ。2017年11月11日閲覧。
- ^ Michael Sweet (June 9, 1999), "A Bright New Future for Printing on Linux", Linux Today, および続報記事 Michael Sweet (June 11, 1999), "The Future Brightens for Linux Printing", Linux Today
- ^ Easy Software Products, CUPS Licensed for Use in Apple Operating Systems! (press release), March 1, 2002
- ^ CUPS Purchased by Apple Inc. (press release), July 11, 2007
- ^ “Thoughts on Leaving Apple...”. www.msweet.org (2019年12月20日). 2023年3月18日閲覧。 “So today was my last day at Apple.”
- ^ Michael Sweet (October 17, 2020). “Add an OpenPrinting changes file.”. CUPS (OpenPrinting fork) repository. GitHub. 2020年12月31日閲覧。
- ^ “CUPS Presentation at 2012 Open Printing Summit” (April 24, 2012). February 14, 2017時点のオリジナルよりアーカイブ。2020年11月7日閲覧。