For Development HEAD DRAFTSearch (procedure/syntax/module):

12.44 rfc.ftp - FTPクライアント

Module: rfc.ftp

このモジュールはFTPサーバーにアクセスするための便利関数群を提供します。

Class: <ftp-connection>

{rfc.ftp} ひとつのサーバーへのFTPコネクションを保持するオブジェクト。以下の公開 スロットがあります。

Instance Variable of <ftp-connection>: transfer-type

FTPの転送タイプ。以下のシンボルのどれかひとつでなければなりません。 asciibinary (デフォルト)、およびimage

Instance Variable of <ftp-connection>: passive

パッシブコネクションを使うとき真。

Instance Variable of <ftp-connection>: log-drain

このスロットは<log-drain>のインスタンス(gauche.logger - ユーザレベルのロギング参照) を保持しているかあるいは#fでなければなりません。<log-drain> のインスタンスを保持している場合、FTP通信のログがそこに記録されます。

Condition Type: <ftp-error>

{rfc.ftp} このタイプの例外はFTPサーバーがエラーコードを返したときに投げられます。 <error>を継承しています。メッセージフィールドにはステータスコー ドを含むサーバーからの返答が含まれます。

Function: call-with-ftp-connection host proc :key passive port username password account log-drain

{rfc.ftp} 高水準の便利関数で、ひとつのFTPサーバーへのFTPコネクションをオープンし、 与えられた手続きを呼びます。

接続するサーバーはhostで指定します。オプションでユーザー名、ポー ト番号をuser@servername:portという形式で指定 できます。もしあれば、hostの部分をキーワード引数にすることもでき ます。

hostへのFTPコネクション確立が成功したら、procが引数を1つとっ て呼ばれます。この引数は<ftp-connection>のインスタンスです。 procから返ったときにこのコネクションはクローズされ、procの 返り値がcall-with-ftp-connectionから返されます。例外がなげられ たら、その例外がcall-with-ftp-connectionから外へでる前にFTPコネ クションはクローズされます。

キーワード引数passiveに真値を与えると、FTPコネクションはパッシブ モードになります。デフォルトではアクティブモードです。

キーワード引数portusernameおよびpasswordは それぞれ、ポート番号、ユーザー名、パスワードを指定するのに使います。 省略された場合のデフォルトは、ポート番号が21,username"anonymous"password"anonymous@"にセットされま す。ポート番号とユーザー名はhost引数で指定されたものが優先されま す。

キーワード引数accountが与えられた場合には、その値が、ログイン時 にサーバーからの要求でFTPのACCTコマンドに渡されます。デフォルト では空文字列""です。

キーワード引数log-drainが生成したFTPコネクションの log-drainスロットに設定されます。

Function: ftp-transfer-type conn

{rfc.ftp} 指定したFTPコネクションconnの転送タイプを返します。セッターを適 用することもできます。たとえば、(set! (ftp-transfer-type conn) 'ascii) とします。

Function: ftp-passive? conn

{rfc.ftp} 指定したFTPコネクションがパッシブモードである場合でその場合に限り真を 返します。

Function: ftp-login host :key passive port username password account log-drain

{rfc.ftp} hostで指定されたFTPサーバーに接続し、ユーザー認証をすませ、新し く生成した<ftp-connection>のインスタンスを返します。この手続き はcall-with-ftp-connectionを使ったときに暗黙の内に呼ばれます。 host引数およびキーワード引数のセマンティクスは call-with-ftp-connectionと同じです。

Function: ftp-quit conn

{rfc.ftp} FTPのQUITコマンドをコネクションconnに送り、コネクションを シャットダウンします。この手続きはcall-with-ftp-connectionを使っ たときに暗黙の内に呼ばれます。

いったんシャットダウンしたコネクションをつかっての通信はできません。

Function: ftp-chdir conn dirname

{rfc.ftp} リモートディレクトリをdirnameに変更します。

Function: ftp-remove conn path

{rfc.ftp} pathで指定したリモートファイルを削除します。

Function: ftp-help conn :optional option …

{rfc.ftp} FTPコマンドHELPを送ります。Optionは文字列でなければなりま せん。これはHELPコマンドの引数にわたされます。

Function: ftp-mkdir conn dirname

{rfc.ftp} ディレクトリdirnameを作成します。作成されたディレクトリ名が返り ます。

Function: ftp-current-directory conn

{rfc.ftp} 現在のリモートディレクトリを返します。

Function: ftp-site conn arg

{rfc.ftp} FTPコマンドSITEを引数argとともに送ります。SITEコマ ンドのセマンティクスはサーバーに依存します。返り値はサーバーのリプライ です。

Function: ftp-rmdir conn dirname

{rfc.ftp} dirnameで指定したリモートディレクトリを削除します。返り値はサー バーのリプライです。

Function: ftp-stat conn :optional pathname

{rfc.ftp} FTPコマンドSTATをサーバーに送信します。 RFC959ではこのコマンドのセマンティクスをいくつか定義しています。詳細は RFC959を見てください。返り値はサーバーのリプライです。

Function: ftp-system conn

{rfc.ftp} FTPコマンドSYSTをつかってサーバーのオペレーティングシステムを問 合せます。返り値はステータスコードを含まないサーバーのリプライです。

(call-with-ftp-connection "localhost" ftp-system)
  ⇒ "UNIX Type: L8"
Function: ftp-size conn path

{rfc.ftp} pathで指定したリモートファイルのサイズを問合せます。 整数値が返ります。

註:コネクションがasciiモードかbinaryモードかによって、返されるサイズは 異なるかもしれません。ftpサーバによっては、binaryモードでしか sizeリクエストに答えないものもあります。この関数を呼ぶ際には、 コネクションに望みのtransfer typeがセットされているようにしてください。

Function: ftp-mdtm conn path

{rfc.ftp} pathで指定したリモートファイルの更新時刻を問合せます。この関数は サーバーからのリプライをステータスコードも含めそのまま返します。解析済 みの結果が欲しいときは後述のftp-mtimeを使ってください。

Function: ftp-mtime conn path :optional local-time?

{rfc.ftp} pathで指定したリモートファイルの更新日時を問合せます。結果は <date>オブジェクト(srfi.19 - 時間のデータ型と手続き参照)で 返ります。local-time?が真値に設定されている場合、日付はローカル 時刻で返ります。そうでない場合は日付はUTCです。

Function: ftp-noop conn

{rfc.ftp} FTPコマンドNOOPを送り、サーバーからのリプライを返します。

Function: ftp-list conn :optional path

{rfc.ftp} pathで指定されたリモートディレクトリあるいはリモートファイル内の ファイルに関する情報を返します。path指定がない場合は現在のリモー トディレクトリで、結果のフォーマットはls(1)のフォーマットと非常 によく似ています。文字列のリストが返り、それぞれの文字列はサーバーのリ プライの行に対応します。正確なフォーマットについてはサーバーに依存しま す。

Function: ftp-name-list conn :optional path
Function: ftp-ls conn :optional path

{rfc.ftp} pathで指定したパスもしくは現在のリモートディレクトリにあるファイ ル名リストを返します。ただし、他の情報は含みません。ftp-lsftp-name-listの別名です。便利なので定義してあります。

リモートディレクトリにファイルが含まれていないときにはサーバーはエラー を返すことがあることに注意してください。

Function: ftp-get conn path :key sink flusher

{rfc.ftp} リモートファイルpathを検索します。検索データはsinkで与えら れた出力ポートに送られます。すべてのデータが検索されたあと、 flusherで与えられた手続きをポートsinkを引数として呼びます。 返り値はftp-getから返されたものです。

sinkおよびflusherのデフォルト値はそれぞれ、新しく作成され た文字列ポートとget-output-stringです。すなわち、ftp-get はデフォルトでは検索データを文字列として返します。巨大なファイルの場合 このデフォルトの挙動ではありがたくありません。

Function: ftp-put conn from-file :optional to-file

{rfc.ftp} from-fileで指定したローカルファイルをto-fileで指定した名前 でリモートサーバーに送信します。to-fileが省略された場合にはベー ス名としてfrom-fileが使われます。返り値はサーバーのレスポンスで す。

Function: ftp-put-unique conn from-file

{rfc.ftp} from-fileで指定したローカルファイルをリモートサーバーへ送信しま す。リモート側のファイル名重複しないことを保証します。返り値は2つで、 最終的なリモートサーバーからのレスポンスとリモートファイル名です。2つ めの値は、リモートサーバーがRFC1123をサポートしていない(ほとんどない) 場合に#fになります。

Function: ftp-rename conn from-name to-name

{rfc.ftp} from-nameで指定したリモートファイル名をto-nameに変更する。 返り値は最終的なサーバーのレスポンスです。



For Development HEAD DRAFTSearch (procedure/syntax/module):
DRAFT