*Moodle [#x3efde4c]

RIGHT:更新日 &lastmod();
 
Moodleはフリーの教育管理システム(e-ランニング)です。まず[[Moodleサイト:http://download.moodle.org/]]からDownloadする。
Moodleはフリーの教育管理システム(e-ラーニング)です。まず[[Moodleサイト:http://download.moodle.org/]]からDownloadする。

**ドメイン変更 [#a5a3a1a6]


moodle/config.php

 // $CFG->wwwroot   = 'http://manabi.mie-chukyo-u.ac.jp/moodle';
 $CFG->wwwroot   = 'http://manabi.stock-cube.net/moodle';

Web: ID adminでログイン

 サーバ: Eメール 
   No-replyアドレス
   noreply@manabi.stock-cube.net


**Moodel2.0をVine5.1にインストール [#p10c92aa]
このあたりが必要そう(不要なものもあるかも)

 apache2 mod_ssl-apache2 php5-apache2
 MySQL-client MySQL-server
 php5-pear php5-mysql php5-pdo php5-apache2 php5-xmlrpc php5 php5-devel
 zlib zlib-devel
 gd

インストールを始めると「Server Checks」でphp_extensionの「zip」でエラーする~
php5.3.3では zipがコンパイル時ADDできないようなので別途インストールしてphp.iniに記載する必要がある

***php_extension(zip)のインストール [#q24f78bf]
PECL(ピクル、PHP Extension Community Library)を利用してインストール
&color(red){これはVine5.1でmoodle1.9をインストールするとき必要なようだ、同じマシンにMoodel2.0(安定版)、Moodle1.9(安定版とWeekly)、三重大版を入れたがなぜか三重大版だけユーザ登録や、コース登録ができない。(Vine4.2では問題なく動作したが)・・・謎?};

 # pecl install zip
 downloading zip-1.10.2.tgz ...
 Starting to download zip-1.10.2.tgz (236,912 bytes)
 .............done: 236,912 bytes
 61 source files, building
 running: phpize5
 sh: phpize5: command not found
 ERROR: `phpize' failed

じかし上のようにphpizeがないでエラーするので、phpizeをインストール。これはphp5-develにあるので
 # apt-get install php5-devel
しかし、/usr/bin/phpizeだけなのでリンクを作成

 # cd /usr/bin
 # ln -s phpize phpize5

その後
 
 # pecl install zip
 downloading zip-1.10.2.tgz ...
 Starting to download zip-1.10.2.tgz (236,912 bytes)
 .............done: 236,912 bytes
 (略)
 Build complete.
 Don't forget to run 'make test'.
 
 (略)
 
 Build process completed successfully
 Installing '/usr/lib/php5/zip.so'
 install ok: channel://pecl.php.net/zip-1.10.2
 configuration option "php_ini" is not set to php.ini location
 You should add "extension=zip.so" to php.ini

そしてphp.iniに追加
 ;;extension_dir = /usr/lib/php5 <=[Vine]セッションにすでに記入されているときは不要
 extension=zip.so

Apache再起動

***確認 [#u8544960]

 # pecl list
 Installed packages, channel pecl.php.net:
 =========================================
 Package Version State
 zip     1.10.2  stable


Moodleのインストールを開始すると動作環境チェックで「php_extension intl」がWarningが出るが、とりあえずインストールをするとうまくできた。

''php.ini''

 extension=zip.so
 ; default_charset= EUC-JP
 default_charset=
 
 ; mbstring.encoding_translation= On
 mbstring.encoding_translation= Off

に変更

細かいチェックはまだだ。


**三重大版のMoodle [#o46506fe]

***三重大版の不思議 [#h6440ade]
なぜかCentOSやVine4.2では動作するがVine5.1では動作しなかったが以下のようにしたら動作した。

''moodle/lib/form/select.php''

   var $_helpbutton='';
    var $_hiddenLabel=false;
//--------------  追加 -----------------
    function MoodleQuickForm_select($elementName=null, $elementLabel=null, $options=null,$attributes=null) {
        parent::HTML_QuickForm_select($elementName, $elementLabel, $options, $attributes);
    }
//--------------  ここまで --------------
    function setHiddenLabel($hiddenLabel){
        $this->_hiddenLabel = $hiddenLabel;
    }

このように本家にあるコンストラクタを追加したら動作した

-------------------

[[奥村先生のサイト:http://oku.edu.mie-u.ac.jp/miemoodle/]]からDownloadして[[ここ:http://oku.edu.mie-u.ac.jp/~okumura/linux/?Moodle%201.9]]のインストール手順でインストール(Vine 4.2)

''MySQL''


 mysql --default-character-set=utf8 -u root -p
 create database moodle default character set utf8 collate utf8_unicode_ci; 
 grant select,insert,update,delete,create,create temporary
 tables,drop,index,alter on moodle.* to moodleuser@'hostname' identified by 'himitsu'; 

''hpd.conf''

 AcceptPathInfo on 



''config.php''

 $CFG->unicodedb = true;
 $CFG->unicodecleanfilename = true;

を追加

''インストール''

&color(red){途中で「「日本語(ja)」言語パックをダウンロードする」ボタンが現れるが,三重大学版はここは何もしない。};そうだ


適当にインストールしたらファイル提出でUploadはできるが教員から「この課題はまだ提出されていません。」という状態が続き見えない状態になった。

成功したときは moodle ディレクトリは var/www/html/moodle -> var/www/moodleにリンクしてインストールした。その後Apacheの/etc/apache2/conf.d/moodle.confなんかでAliasにした。失敗のときは初めからAliasだった。原因ではないかもしれないが・・・・


***はまった [#x48ddb2b]
Moodle1.9ベースをインストールし、adminでログインしようとしたら~
 残念ですが、あなたのブラウザーではクッキーの設定が有効にされていません。
と表示されログインできない

config.phpの最後の行「?>」以降に空行があると発生するようだ。

**Uploadファイル名の日本語の利用 [#h0f7ade3]

Moodle1.8の場合の例です.Moodle1.9の場合,必須設定項目は同じようで
指定しないと日本語ファイル名が「_」になってしまう。

''config.php''

 $CFG->directorypermissions = 00777; // try 02777 on a server in Safe Mode
 // 以下2行を追加
 $CFG->unicodedb = true; // Database is utf8
 $CFG->unicodecleanfilename = true;
  
 require_once

*** Download時の文字化けするときは以下を追加 [#a77e5ef2]

以下の2箇所の変更は1.9.3+では不要だったが、1.8.2+は必要だった。

''file.php''

   $filename = $args[count($args)-1];
 // 以下を追加
   $ua = $_SERVER['HTTP_USER_AGENT'];
    if (strstr($ua, "MSIE") && !strstr($ua, 'Opera')) {
       $filename = mb_convert_encoding($filename, "SJIS", get_string('thischarset'));
    } elseif (strstr($ua, "Safari")) {
       if (get_string('thischarset') == "UTF-8") {
          $filename = "";
       } else {
          $filename = preg_replace('/[^\.a-zA-Z\d\_-]/', '_', $filename);
       }
    } else {
       $filename = mb_convert_encoding($filename, "UTF-8", get_string('thischarset'));
    }
    $filename = str_replace('#', '%23', $filename);
 //ここまで
 
   send_file($pathname, $filename, $lifetime, $CFG->filteruploadedfiles, false, $forcedownload);

''lib/filelib.php''

以下の変更は1.9.3+は適用済だった。

変更前
    if ($forcedownload) {
       @header('Content-Disposition: attachment; filename='.$filename);
    } else {
       @header('Content-Disposition: inline; filename='.$filename);
    }

変更後
    if ($forcedownload) {
       @header('Content-Disposition: attachment; filename="' . $filename . '"');
    } else {
       @header('Content-Disposition: inline; filename="' . $filename . '"');
    }

**Moodle1.8でPOP認証 [#fee41e66]

***POP認証 [#o664a263]

認証サーバにPOPサーバを指定できる

php-imapをインストールする

 # apt-get install php5-imap

Moodleのユーザ=>認証~
POPサーバをアクティブにして

設定

タイプ:pop3notls

を選択する


***メールをエンコードせずテキストで送信 [#y3aa8c6a]

サーバ −> Eメールで文字セットを「ISO-2022-JP」にする

lib/moodlelib.php で 以下を挿入

            $mail->Body = $textlib->convert($mail->Body, 'utf-8', $mail->CharSet);         //Body
            $mail->AltBody = $textlib->convert($mail->AltBody, 'utf-8', $mail->CharSet);   //Subject
        }
    }
 
 //-------以下を挿入 
   if (strcasecmp($mail->CharSet, 'ISO-2022-JP') == 0) {
       $mail->Encoding = '7bit';
   } else {
       $mail->Encoding = '8bit';
   }
 //-------ここまで
 
    if ($mail->Send()) {
        set_send_count($user);
        $mail->IsSMTP();                               // use SMTP directly



    $data->link = $CFG->wwwroot .'/login/confirm.php?data='. $user->secret .'/'. urlencode($user->username);
    $message     = get_string('emailconfirmation', '', $data);
    $messagehtml = text_to_html(get_string('emailconfirmation', '', $data), false, false, true);
 
 //---------------以下の1行を変更
 //    $user->mailformat = 1;  // Always send HTML version as well
     $user->mailformat = 0;
 
    return email_to_user($user, $from, $subject, $message, $messagehtml);
 
 }


''テキストメールに各ユーザのDBのデータを変更''~
MySQLで

 mysql> update mdl_user set mailformat=0;

新しいユーザのデフォルトを変更

 mysql> alter table mdl_user alter mailformat set default 0;

同様にメールアドレス非公開

 update mdl_user set maildisplay=0;
 alter table mdl_user alter maildisplay set default 0;

''&color(red){注)上2つはユーザ登録時に指定したほうがよさそう};''

フォーラム投稿をメールで送らない
 update mdl_user set autosubscribe=0;
 alter table mdl_user alter autosubscribe set default 0;



 


**Moodle1.6のインストール [#hc4b43f3]

moodle1.6.1以降は日本語(ja)が選べたので、直接1.6.1がインストールできた。
この時は、特にlang用パッケージを事前にDownloadすることなく、インストール中に聞かれたときDownloadするこでインストールできた。

**MySQLでのmoodleDBのバックアップ/リストア [#t720b09a]

***バックアップ [#u35ae43e]
 $ /usr/local/bin/mysqldump -u root -p --default-character-set=utf8 moodle > moodle.out
 Enter password:

***リストア [#c3a8a81e]
もし、moodleというデータベースがない時は先に作成
 $ /usr/local/bin/mysqladmin -u root -p create moodle
 Enter password:
 
 $ /usr/local/bin/mysql -u root -p moodle < moodle.out
 Enter password:
 インストール

データベースとしてはMysqlを使用するので、事前にMysql側のSQL サーバにデータベースとしてmoodle、ユーザとしてmoodleuserを登録しておいて データベースにアクセスできるようにしておく。MySQLのインストールは[[ここ:https://wwwism.dyndns.org/hp/linux/mysql.htm]]。
データベースとしてはMysqlを使用するので、事前にMysql側のSQL サーバにデータベースとしてmoodle、ユーザとしてmoodleuserを登録しておいて データベースにアクセスできるようにしておく。MySQLのインストールは[[ここ>/Linux Memo/MySQL]]。


''ユーザ登録は''

 mysql> grant select,insert,update,delete,create,drop,index,alter on moodle.* to  moodleuser@localhost IDENTIFIED BY '*****' WITH GRANT OPTION;
 Query OK, 0 rows affected (0.00 sec)

 mysql> flush privileges;
 Query OK, 0 rows affected (0.00 sec)


 $ tar zxvf moodle-latest-14.tgz
 $ su
 # mv moodle /usr/local/apache2/htdocs/


phpの使用メモリが16MB以上必要なので/usr/local/lib/php.iniの

 memory_limit = 8M 
 を
 memory_limit = 32M
 に変更し、
 magic_quotes_runtime = 0  (必ず)
 file_uploads = 1
 session.auto_start = 0
 session.bug_compat_warn = 0
 tcpip_socket = true
を確認して

''apacheを再起動''


その後ブラウザで
 http://(マシン名)/moodle/
でアクセスしてパラメータを設定する

Choose a languageでJapanese(jp)を選択

「PHP設定を確認しています ...」でパスを確認
GDについてはパスするにはphpコンパイル時オプション --with-gd が必要

「Moodleのインストール先を確認してください。」で
 ウェブアドレス:http://(マシン名)/moodle
 Moodleディレクトリ:/usr/local/apache2/htdocs/moodle
 データ:/usr/local/moodledata

注)このとき/usr/local/moodledataを作成し、wwwに書き込み権限を与える
またこのディレクトリ場所は直接webアクセス出来ない場所にする。

「DataBaseの設定」
 タイプ:postgres7
 ホストサーバ:(サーバ名orIPアドレス)
 データベース:moodle
 ユーザ:moodle
 パスワード:(なし)  <---postgresql側でIPで制限する
 テーブル接頭辞:mdl_

注)このとき事前に createdb moodle でdbを作成しておく

「設定が完了しました。」

 <?php  /// Moodle Configuration File 
 
 unset($CFG);
 
 (略)
 
 // MAKE SURE WHEN YOU EDIT THIS FILE THAT THERE ARE NO SPACES, BLANK LINES,
 // RETURNS, OR ANYTHING ELSE AFTER THE TWO CHARACTERS ON THE NEXT LINE.
 ?>

上記のphpスクリプトを/usr/local/apache2/htdocs/moodle/config.phpに入れる
このファイルがないので作成しコピー&ペーストすればよい

apache2がapache2.0xなんかにlinkされていると以下のようなエラーが出る

 Please fix your settings in config.php: 
 You have: 
 $CFG->dirroot = "/usr/local/apache2/htdocs/moodle"; 
 but it should be: 
 $CFG->dirroot = "/usr/local/apache2050/htdocs/moodle";

のでconfig.phpを指示どおり書き換える。

うまく行くと「著作権表示」が表示される



「データベースの設定」

 Home ≫ データベースの設定  
  
 ----- (postgres7): CREATE TABLE mdl_config ( id SERIAL PRIMARY KEY, name
 varchar(255) NOT NULL default '', value text NOT NULL default '', CONSTRAINT
 mdl_config_name_uk UNIQUE (name)) ----- 
 
 成功    <---成功を確認
 ----- (postgres7): CREATE TABLE mdl_course ( id SERIAL PRIMARY KEY, category
 integer NOT NULL default '0', sortorder integer NOT NULL default '0', password
 varchar(50) NOT NULL default '', fullname varchar(254) NOT NULL default '',
 shortname varchar(15) NOT NULL default '', idnumber varchar(100) NOT NULL
 default '', summary text NOT NULL default '', format varchar(10) NOT NULL
 default 'topics', showgrades integer NOT NULL default '1', modinfo text NOT NULL default '', blockinfo 
 
 (以下略)

データベースのアップグレードが完了しました。

全てが成功したことを確認して「続ける」

 「詳細設定] http://uso5001.abc-u.ac.jp/moodle/admin/config.php



''2-3画面進み''

「データベースのアップグレード」で成功を確認

「ブロックテーブルの設定」で設定確認

最後までいくと「workshop テーブルが正常に設定されました。」
が表示されるその後
「サイトセッティング」をセットする

***設定 [#g76b5d4f]

管理者は 
 ユーザ名:admin
 パスワード:admin

http://uso5001.abc-u.ac.jp/moodle/login/index.php
からloginしてまずパスワードを変更

設定変更は右画面の「管理...」をクリック
メールの日本語の問題(1.6では問題なさそうなので不要)
Moodle から自動で出されるメールが生 EUC-JP の Quoted-Printableになるので文字化けを起こすそこで、 奥村先生のページを参考に以下のパッチを当てる。今回使用したPHPはVer5.0.1で このときmb_convert_encoding関数はmb_convert_encoding($mail->FromName, 'ISO-2022-JP', 'EUC-JP')のようにソースのencodeを'EUC-JP'と指定する必要があった。


moodle/lib/moodlelib.php の1750行目あたりと

 // Edit By JE2ISM
     $messagehtml = false;  // HTMLメールはいやよ  <---追加
 
     if ($messagehtml) {
         $mail->IsHTML(true);
         $mail->Encoding = "quoted-printable";           // Encoding to use
         $mail->Body    =  $messagehtml;
         $mail->AltBody =  "\n$messagetext\n";
     } else {
         $mail->IsHTML(false);
         $mail->Body =  "\n$messagetext\n";
     }


1770行あたり

    if ($attachment && $attachname) {
        if (ereg( "\\.\\." ,$attachment )) {    // Security check for ".." in  ir path
            $mail->AddAddress("$adminuser->email", fullname($adminuser) );
            $mail->AddStringAttachment("Error in attachment.  User attempted to
 attach a filename with a unsafe name.", "error.txt", "8bit", "text/plain");
        } else {
            include_once("$CFG->dirroot/files/mimetypes.php");
            $mimetype = mimeinfo("type", $attachname);
            $mail->AddAttachment("$CFG->dataroot/$attachment", "$attachname", "base64", "$mimetype");
        }
    }

(以下追加)

 // 日本語化 Edit By JE2ISM
    $mail->FromName =  mb_convert_encoding($mail->FromName, 'ISO-2022-JP', 'EUC-JP');
    $mail->FromName = "=?ISO-2022-JP?B?".base64_encode($mail->FromName)."?=";
    $mail->Subject  =  mb_convert_encoding($mail->Subject, 'ISO-2022-JP', 'EUC-JP');
    $mail->Subject  = "=?ISO-2022-JP?B?".base64_encode($mail->Subject)."?=";
    $mail->Body     =  mb_convert_encoding($mail->Body, 'ISO-2022-JP', 'EUC-JP');
    $mail->CharSet  =  'ISO-2022-JP';
    $mail->Encoding =  '7bit';
    $i = 0;
    while($mail->to[$i][1]) {
       $mail->to[$i][1] = mb_convert_encoding($mail->to[$i][1], 'ISO-2022-JP', 'EUC-JP');
       $mail->to[$i][1] = "=?ISO-2022-JP?B?".base64_encode($mail->to[$i][1])."?=";
       $i++;
    }
    $i = 0;
    while($mail->cc[$i][1]) {
       $mail->cc[$i][1] = mb_convert_encoding($mail->cc[$i][1], 'ISO-2022-JP', 'EUC-JP');
       $mail->cc[$i][1] = "=?ISO-2022-JP?B?".base64_encode($mail->cc[$i][1])."?=";
       $i++;
    }
    $i = 0;
    while($mail->bcc[$i][1]) {
       $mail->bcc[$i][1] = mb_convert_encoding($mail->bcc[$i][1], 'ISO-2022-JP',
'EUC-JP');
       $mail->bcc[$i][1] = "=?ISO-2022-JP?B?".base64_encode($mail->bcc[$i][1])."?=";
       $i++;
    }
 
 //--------------------------------------------

***ゲストログインボタンの削除 [#u1fc8474]

1.6.1では 管理>  ユーザ>  認証オプションで

  認証方法の選択: 手動アカウント作成のみ

を選択、説明にメッセージを適当に書くこと(必要)

  ゲストログインボタン:非表示

でゲストログインボタンが
消えた。

''以前の方法''

moodle/config.phpに

 $CFG->guestloginbutton=false;
 を追加

ユーザプロファイルの電話番号、住所の登録画面の削除

 moodle/user/edit.htmlの270行目あたりの
 <?php } ?>
 <!--
 <tr valign=top>
     <td align=right><p><?php print_string("phone") ?> 1:</td>
     <td><input type="text" name="phone1" size="25" maxlength="20" value="<?php p
 ($user->phone1) ?>"> <?php p($teacheronly) ?>
     <?php if (isset($err["phone1"])) formerr($err["phone1"]); ?>
     </td>
 </tr>
 
 (略)
 
 p($user->address) ?>"> <?php p($teacheronly) ?>
     <?php if (isset($err["address"])) formerr($err["address"]); ?>
     </td>
 </tr>
 -->
 <tr>
     <td></td>
     <td align=right><input type="submit" value="<?php  print_string("updatemyprof
 ile") ?>"></td>
 </table>

の表示部をコメントアウト。
ユーザ登録画面の削除

moodle/login/signup.phpに以下を追加

10行目程度に

 //ユーザ登録を開放しなようにする
     error("Sorry, you may not use this page.");

$CFG->auth変数の値がemailになっているが、どこで設定いているか不明なので、強制的に禁止した。


また、login画面で「初めての方ですか」のページの部分を表示させないようにするには、
管理->認証オプション ->認証方法の選択を「Emailベースの認証」から「手動アカウント作成のみ」に変更するし、説明のところを空白にする。説明のところに、説明文を入れると、初めての方ですかが表示されその下に説明文が表示される。どちらにせよ「新しいアカウントを作成する」のボタンは表示されない

**セキュリティメモ [#x7d5b335]

セキュリティメモ 2005年5月6日の内容により、admin/delete.php を削除。 
Backup/Cron/更新等
***Backup [#k6954421]

 Moodle > 管理 > 設定 > バックアップで 
 スケジュール アクティブ:Yes
 にする

保存先:/home/www/moodlebackup等をしていしておく。ここの書き込み権限はwwwがあればよさそう。
保存先:/home/www/moodlebackup等をしていしておく。&color(red){ここの書き込み権限は必ずwwwが必要。cron実行権限とは異なる。};

実際にバックアップが実行されるのは以下のcronが実行されたとき指定時間が通過しているとbackupされる。cronがエラーしていてもbackupされたメールが届くこのあたりどうなっているか不明(Ver1.6.1)

***Cron [#bcf76784]

Moodleはいくつかの処理を自動でする必要があるのでCronを以下のように設定しておく

以下のページが問題なく動作すことを確認し、
 http://uso5001.abc-u.ac.jp/moodle/admin/cron.php

にアクセスよければ一般ユーザでいいから crontab -e で次のように設定。
(毎5分ごとに実行)

 */5 * * * * /usr/bin/wget -q -O /dev/null http://uso5001.abc-u.ac.jp/moodle/admin/cron.php

このとき
 /usr/bin/wget http://uso5001.abc-u.ac.jp/moodle/admin/cron.php
でエラーないことの確認もしておく

**更新 [#l57b138c]

moodleのバージョンアップは以下のようにおこなう

 # cd /usr/local/apache2/htdocs
 # mv moodle moodle-bak
 # tar xvzf moodle-latest-XXX.tgz
 # cp -a moodle-bak/config.php moodle/

moodle/lib/weblib.php の htmlentities を htmlspecialchars に変換

**設定上のポイント [#kae494b6]

+小テストの時間制限の最大値は管理->設定->詳細設定の中のsessiontimeout: の時間から10分引いた値まで設定できる。(設定表示が20分の場合はsessiontimeout:が 30分に設定されている)
+小テスト最大評点を「評点無し」以外に設定すると学生が試験終了後これをベースにした評点が表示される。「評点無し」では表示されない。またレポート->概要も評点は表示されなくなる。
+アップロードファイルの容量については2MBがデフォルトのようだが、php.iniの以下のパラメータを変更

 ; Maximum size of POST data that PHP will accept.
 post_max_size = 8M

 ; Maximum allowed size for uploaded files.
 ;;upload_max_filesize = 2M
 upload_max_filesize = 8M

httpd.conf関係の存在すればLimitRequestを削除

をしたら、Moodleの詳細設定のパーミッションの中のmaxbytesや

管理 >設定 >モジュール管理 >課題のassignment_maxbytesは変更できた

その後コース設定の最大アップロードサイズを変更すると課題でUploadの容量を変更できる。


**ユーザのUpload [#f9352f18]

 username, password, firstname, lastname, email,mailformat
 okada, ****, okada, okada, okada@abc.com, 0

mailformat 0 ---プレーンテキスト
      1 ---HTML(デフォルト)

**提出課題の削除 [#p9974188]

保存ディレクトリ :moodledata/3/moddata/assignmentの下あたり

mdl_assignment_submissionsのテーブルに記録があるので削除

--------------------------------------------------------------------------------
RIGHT:[[元ページ:https://wwwism.dyndns.org/hp/linux/moodle.htm]]


トップ   新規 一覧 検索 最終更新   ヘルプ   最終更新のRSS