GNSをメール環境で使うための方法を解説します。WWWサーバにCGIの形で導入し、メールで日記を書き込み、そのまま公開することができます。
WWWサーバ環境は、*BSD・LinuxなどUNIX系のOSに、apacheを導入したものを想定しています。
UNIX環境でGNSを動作させるには、以下のツールが必要です。
Perlは、Perl言語で書かれたプログラムを動かすためのプログラムです。GNSは、その大部分をPerlで書いています。現在のUNIX環境では、すでにPerlがインストール済みであったり、個々のOSの専用パッケージとしてPerlが用意されていることが多いですが、もし必要であれば以下からインストールファイルをダウンロードし、コンパイル・インストールをしてください。
GNSは、バージョン5以上のPerlでの動作を想定しています。もし特定のバージョンのPerlでの動作による不具合を発見した場合は、当方までお知らせいただければ幸いです。
Perlではさまざまな追加モジュールをインストールして使うことができますが、GNSはPerlの追加モジュールの導入の必要はありません。
nkfは、日本語ファイルの文字コードを変換するツールです。お使いのOSにnkfのパッケージがあればそれを導入、なければ以下からインストールファイルをダウンロードし、コンパイル・インストールをしてください。
GNSは、nkf v2.0以降での動作を想定しています。もし特定のバージョンのnkfでの動作による不具合を発見した場合は、当方までお知らせいただければ幸いです。
メール更新を行うには、送信を行うためのメーラが必要です。
通常のテキストが記述できるものであれば、何でもかまいません。
tidyは、HTMLファイルを整形するツールです。初期状態のGNSでは不要ですが、AtomをXHTML形式で出力する「$ATOM_XHTML」スイッチをONにするとき必要になります。以下からインストールファイルをダウンロードし、インストールをしてください。
これらの他に、GNS配布パッケージには、再配布可能なjcode.plというツールを組み込んでいます。もし必要であれば、以下からより新しいバージョンのjcode.plをダウンロードし、置き換えてください。
GNSは、zip版とtgz版の2つの配布形態をとっています。GNS本体としては同じものですが、UNIX版のインストーラが入っているのはtgz版のみです。
GNSの配布パッケージとなっているファイルを、tar+gzipなどを使用して解凍してください。解凍先はどこでも構いませんが、ここでは「public_html/GNS」を解凍先とします。このフォルダを「GNSフォルダ」と呼びます。
解凍が終了すると、「public_html/GNS」の下に"gns400"などの名前のフォルダ("400"はバージョン番号です)が作成されます。これがGNSのプログラムや設定データが入っている部分です。同様に、このフォルダを「GNSプログラムフォルダ」と呼びます。
# Set Mail Address and URL |
「install.sh」をエディタで開いて、右の部分をインストール先の状況に応じて書き換えます。
"my_mail"は、自分のメールアドレスです。
"my_url"は、「GNSフォルダ」をURLにしたものです。
|
「install.sh」を実行すると、右のような表示が出て、一時停止します。
表示内容が正しいことを確認してから、[Enter]キーを押すと、各種フォルダやファイルの作成・コピーが行われます。
インストールを行うと、日記マスタを収めるフォルダが準備されます。「GNSフォルダ」に、"d"という名前のフォルダが作成されたのを確認してください。このフォルダを「日記マスタフォルダ」と呼びます。
GNSは、cssに対応したHTMLファイルを出力します。「[GNSプログラムフォルダ]/style」フォルダに、これらのHTMLに対応したcssファイルセットが収められています。これは「インストール」ではコピーが行われないので、好きなcssファイルを各自で「GNSフォルダ」にコピーして利用してください。
plain | ほとんどスタイル指定のないcssファイルです。オリジナルのスタイルを作るときの雛形として使います。 |
---|---|
simple | デフォルトのスタイル指定が入ったcssファイルです。 |
日記を作成するための作業の一部は、GNSプログラムフォルダ内のページをブラウザからアクセスする必要があります。ここは、著者であるあなた以外のアクセスはできないようにしておくべきです。.htaccessによるBASIC認証などを使って、あなた以外のアクセスを封じるようにしてください。
yourmail@example.ne.jp |
一般的なUNIX環境では、メールが届くたびに特定のプログラムが起動するようにすることができます。一般的なシステムでは「‾/.forward」ファイルに起動するプログラムを記述するようになっています。
GNSは、「[GNSプログラムフォルダ]/recvmail.pl」を起動させることで、日記の更新を行うことができます。「‾/.forward」には以下のように書きます。
1行目には、自分自身のメールアドレスを書きます。これがないと、GNSがメールを処理したあと、そのメールは消去されてしまいます。自分自身のメールアドレスを書くことで、GNSにメール処理をさせると同時に、メールボックスにもメールが残ります。
2行目には、「recvmail.pl」を起動するためのコマンドラインを記述します。パイプを示す"|"文字に続いて、perlプログラムのフルパス、最後にrecvmail.plのフルパスを書き、全体をダブルクォートでくくります。
GNSプログラムフォルダには、初期設定となる設定データがすでに入っています。しかし、このままでは各種情報がまだ仮のものです。まず、基本設定を行う必要があります。
ここでは、最小限の変更についてのみ解説します。詳細は、「config.phによる設定」をご覧ください。
"config.ph"というファイルが、GNSの基本設定を司るファイルです。テキストエディタで、このファイルを開いてください。
このファイルには多くの設定項目がありますが、ここで編集を行う必要があるのは、そのごく一部です。以下、順に編集項目を説明します。
# 公開URLベース名 |
日記を公開するときの、URLのディレクトリ名までの部分を編集します。この例では、公開URLのディレクトリ名「http://www.example.ne.jp/GNS/」フォルダにします。この下に日記ページが置かれます。
# ダイジェストファイル名 |
日記を公開するときの、ダイジェストページのURLのファイル名部分を編集します。この例では、ダイジェストページのURLを「index.html」とします。「公開URLベース名」の例と組み合わせると、この日記のダイジェストページのURLは、「http://www.example.ne.jp/GNS/index.html」となります。
# 日記名 |
日記の名前を編集します。この例では、「だいだい だいありー」という名前になります。
この項目は、出力される日記のすべてのページに埋め込まれます。
# 著者名 |
日記の著者名を編集します。この例では、「あおい」という名前になります。
この項目は、出力される日記のすべてのページに埋め込まれます。
# 著者メールアドレス |
著者宛てのメールアドレスを編集します。この例では、「aoi@example.ne.jp」というアドレスになります。
この項目は、出力される日記のすべてのページに埋め込まれます。
# 日記の説明 |
この日記の簡単な説明文を編集します。この例では、「あおいの日々の記録です。」という説明になります。
この項目は、「RSS/Atomファイル」に埋め込まれます。
# 著作権表記 |
この日記の著作権表記を編集します。この例では、「Copyright (C)2005 あおい.」という著作権表記となります。
この項目は、「RSS/Atomファイル」に埋め込まれます。
# メール更新で受け取るメールの発信先メールアドレス (recvmail.pl) |
日記更新メールと認めるメールを限定したい、あるいはしたくないときに編集します。
複数のメールアドレスを指定したいときは、「'aoi@example.ne.jp, akai@example.ne.jp'」などのように、カンマで区切って記述します。
メールアドレスによる制限を外すには、空文字列('')を記述します。
# 1でデフォルトが追記モードになる |
日記更新メールで、追記モードをデフォルトにしたいときに編集します。
追記モードをONにすると、すでに日記マスタが存在する日に対して更新メールを送ると、その日記マスタに更新内容が追加されます。
この設定に関わらず、GNS更新メールヘッダに「#ADD」を追加することで追記モードONに、「#OVER」を追加することで追記モードOFFになります。
以上で、編集は終了です。
以上が完了したら、メールからの更新を行うためのチェックを、ブラウザから行います。アクセス先は、「GNSプログラムフォルダのindex.html」です。上の例の場合は、「http://www.example.ne.jp/GNS/gns400/index.html」へアクセスしてください。右のような画面になります。
一番下の、[動作環境のチェック]をクリックしてください。
動作チェックが正しく終了した場合、右のような出力が得られます。何かエラーが発生した場合は、赤文字で表示されます。
動作チェックが終了したら、「GNSプログラムフォルダのindex.html」ページから[パスワードの登録]をクリックして、パスワードを登録します。パスワードを登録しないと、日記を書くことはできません。
パスワード登録画面になったら、「PASSWORD」と「RETYPE PASSWORD」に同じパスワードを入れ、[OK]ボタンをクリックします。パスワードが同じでない場合は、受け付けられません。
すでにパスワードが登録されているときは、パスワードの登録を受け付けません。パスワードを再登録したいときは、ftpやシェルなどから「日記マスタフォルダのkeepディレクトリ」にある"upload.pass"を削除してください。
From: aoi@example.ne.jp |
パスワードの登録が終了したら、メーラを起動して、日記マスタとなるメールを書きます。今回は、右のようなメールにします。
"--------"までは、メールヘッダです。メール本文に記述するのではなく、お使いのメーラで相当の設定をするようにしてください。
発信者です。今回の設定では、"aoi@example.ne.jp"からしかメール更新を受け付けないように設定しているので、そのように記述します。
受信者です。GNSのメール更新プログラムが起動されるメールアドレスにしてください。
表題です。「@@GNS-POSTMAIL」の文で始まっていないと、更新メールとして認識されません。文の末尾には、自由な文字列を追加することができます。
メール本文に書く、GNSのメール更新プログラムに対して送信するデータです。文法は以下のようになっています。
順に「固定値」「年」「月」「日」「パスワード」となっています。
10 | D-Head | ダイジェストページに埋め込まれる、「先頭からメモブロック直前まで」の部分です。タイトルや、各種注釈・注意書きなどをここで表示することを想定しています。 |
---|---|---|
11 | D-Memo1 | ダイジェストページに埋め込まれる、「日記本文より手前のメモブロック」の部分です。読者に対して告知性の高いメモをここで表示することを想定しています。 |
20 | D-Memo2 | ダイジェストページに埋め込まれる、「日記本文より後のメモブロック」の部分です。著者にとってのメモをここで表示することを想定しています。 |
21 | D-Foot | ダイジェストページに埋め込まれる、「メモブロックから末尾まで」の部分です。著作権表記・メールアドレス・著者名などをここで表示することを想定しています。 |
30 | B-Head | ベースページに埋め込まれる、「日記本文より手前」の部分です。タイトルや、各種注釈・注意書きなどをここで表示することを想定しています |
40 | B-Foot | ベースページに埋め込まれる、「日記本文より後」の部分です。著作権表記・メールアドレス・著者名などをここで表示することを想定しています。 |
50 | L1-Head | 年次インデックスページに埋め込まれる、「本文より手前」の部分です。タイトルや、各種注釈・注意書きなどをここで表示することを想定しています。 |
51 | L1-Foot | 年次インデックスページに埋め込まれる、「本文より後」の部分です。著作権表記・メールアドレス・著者名などをここで表示することを想定しています。 |
52 | L2-Head | カテゴリインデックスページに埋め込まれる、「本文より手前」の部分です。タイトルや、各種注釈・注意書きなどをここで表示することを想定しています。 |
53 | L2-Foot | カテゴリインデックスページに埋め込まれる、「本文より手後」の部分です。著作権表記・メールアドレス・著者名などをここで表示することを想定しています。 |
60 | TB-Head | トラックバック/コメントページに埋め込まれる、「本文より手前」の部分です。タイトルや、各種注釈・注意書きなどをここで表示することを想定しています。 |
61 | TB-Foot | トラックバック/コメントページに埋め込まれる、「本文より後」の部分です。著作権表記・メールアドレス・著者名などをここで表示することを想定しています。 |
96 | Ping | 更新Pingの送信先一覧を呼び出します。詳細は、以下をご覧ください。
|
97 | Macro | 名前と引数を与えることでさまざまな文を自動生成できる、ユーザーマクロのデータベースファイルを呼び出します。詳細は、以下をご覧ください。
|
98 | Item | 日付部などに埋め込まれるアイテム文字列を呼び出します。詳細は、以下をご覧ください。
|
99 | URI | ダイジェストページに埋め込まれる、「先頭からメモブロック直前まで」を表示します。タイトルや、各種注釈・注意書きなどをここで表示することを想定しています。
|
"#OVER"で、上書きモードであることを明示します。追記モードのときは"#ADD"と書きます。
更新時にインデックスを作成するときは1、しないときは0にします。
省略したときは、前回更新時の指定を引き継ぎます。
更新時に更新Pingを送信するときは1、しないときは0にします。
省略したときは、前回更新時の指定を引き継ぎます。
GNS更新メールヘッダと、日記マスタ本文の間には、空行(改行のみの行)が必要です。
空行のあとは、メールの末尾までが日記マスタの内容となります。
作業中になんらかのエラーが発生した場合は、「[GNSプログラムフォルダ]/tmp/recvmail.log」にエラーログが記録されます。
「WWW環境」で日記の更新を行うとき、更新内容を記述した「更新通知メール」を発信することができます。このメールは、このページの「メール環境」で使用するものと同一のフォーマットになっています。
これを利用して、「サイトAの日記をWWW環境で更新する」→「更新通知メールをサイトBに送る」→「サイトBの日記を更新する」といったことが可能です。