ここの情報は古いです。ご理解頂いた上でお取り扱いください。

source: OpenPNE/branches/2.8.x/webapp/lib/util/util.php @ 2923

Last change on this file since 2923 was 2923, checked in by ogawa, 13 years ago

#761:ファイルアップロード機能に拡張子制限機能を入れる
#741:0byteのファイルをアップロードできない

File size: 15.3 KB
Line 
1<?php
2/**
3 * @copyright 2005-2007 OpenPNE Project
4 * @license   http://www.php.net/license/3_01.txt PHP License 3.01
5 */
6
7/**
8 * リダイレクト
9 *
10 * @param string $module
11 * @param string $action
12 * @param array  $params
13 */
14function openpne_redirect($module, $action = '', $params = array())
15{
16    if ($module == 'ktai') {
17        if (session_id()) {
18            $params['ksid'] = session_id();
19        }
20    }
21    $url = openpne_gen_url($module, $action, $params);
22    client_redirect_absolute($url);
23}
24
25/**
26 * クライアントリダイレクト
27 *
28 * @param   string  $dest ジャンプ先URI(絶対パス)
29 */
30function client_redirect_absolute($dest)
31{
32    // 改行文字を削除
33    $dest = str_replace(array("\r", "\n"), '', $dest);
34    header('Location: '. $dest);
35    exit;
36}
37
38/**
39 * クライアントリダイレクト(ログインページ)
40 */
41function client_redirect_login()
42{
43    client_redirect_absolute(get_login_url());
44}
45
46/**
47 * ログインページを取得
48 *
49 * @return string ログインページURL
50 */
51function get_login_url()
52{
53    if (LOGIN_URL_PC) {
54        return LOGIN_URL_PC;
55    } else {
56        return openpne_gen_url('pc', 'page_o_login');
57    }
58}
59
60//---
61
62/**
63 * URLを生成
64 */
65function openpne_gen_url($module, $action = '', $params = array(), $absolute = true, $force = false)
66{
67    switch ($force) {
68    case 'ssl':
69        $url = OPENPNE_SSL_URL;
70        break;
71    case 'nonssl':
72        $url = OPENPNE_URL;
73        break;
74    default:
75        $url = openpne_gen_url_head($module, $action, $absolute);
76        break;
77    }
78
79    $p = array('m' => $module, 'a' => $action) + (array)$params;
80    if (need_ssl_param($module, $action, $force)) {
81        $p['ssl_param'] = 1;
82    } else {
83        unset($p['ssl_param']);
84    }
85    if ($q = http_build_query($p)) {
86        $url .= '?' . $q;
87    }
88    return $url;
89}
90
91function openpne_gen_url_head($module, $action = '', $absolute = true)
92{
93    if (OPENPNE_USE_PARTIAL_SSL) {
94        switch (openpne_ssl_type($module, $action)) {
95        case 'SSL_REQUIRED':
96            $head = ($absolute || !is_ssl()) ? OPENPNE_SSL_URL : './';
97            break;
98        case 'SSL_SELECTABLE':
99            if ($absolute) {
100                $head = (is_ssl()) ? OPENPNE_SSL_URL : OPENPNE_URL;
101            } else {
102                $head = './';
103            }
104            break;
105        case 'SSL_DISABLED':
106            $head = ($absolute || is_ssl()) ? OPENPNE_URL : './';
107            break;
108        }
109    } else {
110        $head = ($absolute) ? OPENPNE_URL : './';
111    }
112    return $head;
113}
114
115//---
116
117/**
118 * module / action が部分SSL対象かどうかを判別する
119 */
120function openpne_ssl_type($m, $a)
121{
122    if (in_array($a, (array)$GLOBALS['_OPENPNE_SSL_REQUIRED'][$m]) ||
123        in_array($m, (array)$GLOBALS['_OPENPNE_SSL_REQUIRED_MODULES'])
124    ) {
125        $type = 'SSL_REQUIRED';
126    } elseif (in_array($a, (array)$GLOBALS['_OPENPNE_SSL_SELECTABLE'][$m])) {
127        $type = 'SSL_SELECTABLE';
128    } else {
129        $type = 'SSL_DISABLED';
130    }
131    return $type;
132}
133
134/**
135 * 現在のリクエストがSSL通信であるかどうかを判別
136 */
137function is_ssl()
138{
139    static $is_ssl;
140    if (!isset($is_ssl)) {
141        if (isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') {
142            $is_ssl = true;
143        } elseif (OPENPNE_USE_SSL_PARAM && !empty($_REQUEST['ssl_param'])) {
144            $is_ssl = true;
145        } else {
146            $is_ssl = false;
147        }
148    }
149    return $is_ssl;
150}
151
152function need_ssl_param($module, $action = '', $force = false)
153{
154    $need = false;
155    if (OPENPNE_USE_PARTIAL_SSL && OPENPNE_USE_SSL_PARAM) {
156        switch ($force) {
157        case 'ssl':
158            $need = true;
159            break;
160        case 'nonssl':
161            $need = false;
162            break;
163        default:
164            switch (openpne_ssl_type($module, $action)) {
165            case 'SSL_REQUIRED':
166                $need = true;
167                break;
168            case 'SSL_SELECTABLE':
169                $need = is_ssl();
170                break;
171            case 'SSL_DISABLED':
172                break;
173            }
174            break;
175        }
176    }
177    return $need;
178}
179
180//---
181
182function is_ktai_mail_address($mail)
183{
184    $pieces = explode('@', $mail);
185    $domain = array_pop($pieces);
186
187    return in_array($domain, $GLOBALS['OpenPNE']['KTAI_DOMAINS']);
188}
189
190function db_common_is_mailaddress($value)
191{
192    if (preg_match('/^[^:;@,\s\x80-\xFF]+@\w[\w\-.]*\.[a-zA-Z]+$/', $value)) {
193        return true;
194    } else {
195        return false;
196    }
197}
198
199//---
200
201function _mt_srand()
202{
203    if (version_compare(phpversion(), '4.2.0', '<')) {
204        list($usec, $sec) = explode(' ', microtime());
205        $seed = (float)$sec + ((float)$usec * 100000);
206
207        mt_srand($seed);
208    }
209}
210
211function do_common_create_password($length = 8)
212{
213    // パスワードに使用する文字
214    $elem = 'abcdefghkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ2345679';
215    $max = strlen($elem) - 1;
216
217    _mt_srand();
218    $password = '';
219    for ($i = 0; $i < $length; $i++) {
220        $password .= substr($elem, mt_rand(0, $max), 1);
221    }
222    return $password;
223}
224
225function create_hash()
226{
227    _mt_srand();
228    return md5(uniqid(mt_rand(), true));
229}
230
231//---
232
233function &get_crypt_blowfish()
234{
235    static $singleton;
236    if (empty($singleton)) {
237        if (OPENPNE_USE_OLD_CRYPT_BLOWFISH) {
238            include_once 'Crypt/BlowfishOld.php';
239            $singleton = new Crypt_BlowfishOld(ENCRYPT_KEY);
240        } else {
241            include_once 'Crypt/Blowfish.php';
242            $singleton = new Crypt_Blowfish(ENCRYPT_KEY);
243        }
244    }
245    return $singleton;
246}
247
248/**
249 * 可逆的な暗号化をする
250 *
251 * @param string $str 平文
252 * @return string 暗号文
253 */
254function t_encrypt($str)
255{
256    if (!$str) return '';
257
258    $bf =& get_crypt_blowfish();
259    $str = $bf->encrypt($str);
260
261    //base64
262    $str = base64_encode($str);
263
264    return $str;
265}
266
267/**
268 * 可逆的な暗号を復号化する
269 *
270 * @param string $str 暗号文
271 * @return string 平文
272 */
273function t_decrypt($str)
274{
275    if (!$str) return '';
276
277    //base64
278    $str = base64_decode($str);
279
280    $bf =& get_crypt_blowfish();
281    return rtrim($bf->decrypt($str));
282}
283
284function t_wordwrap($str, $width = 80, $break = "\n")
285{
286    if (!$width) {
287        return $str;
288    }
289
290    $lines = explode($break, $str);
291    foreach ($lines as $key => $line) {
292        if (mb_strwidth($line) > $width) {
293            $new_line = '';
294            do {
295                if ($new_line) {
296                    $new_line .= $break;
297                }
298                $tmp = mb_strimwidth($line, 0, $width);
299                $new_line .= $tmp;
300                $line = substr($line, strlen($tmp));
301            } while (strlen($line) > 0);
302            $lines[$key] = $new_line;
303        }
304    }
305    return implode($break, $lines);
306}
307
308function util_is_unused_mail($name)
309{
310    $unused = explode(',', UNUSED_MAILS);
311    return in_array($name, $unused);
312}
313
314function util_get_c_navi($navi_type = 'h')
315{
316    switch ($navi_type) {
317    case 'global':
318        $navi_type = 'global';
319        $navi = array(
320            array('url' => '?m=pc&a=page_h_search', 'caption' => 'メンバー検索'),
321            array('url' => '?m=pc&a=page_h_com_find_all', 'caption' => 'コミュニティ検索'),
322            array('url' => '?m=pc&a=page_h_review_search', 'caption' => 'レビュー検索'),
323            array('url' => '?m=pc&a=page_h_home', 'caption' => 'マイホーム'),
324            array('url' => '?m=pc&a=page_h_invite', 'caption' => '友人を誘う'),
325            array('url' => '?m=pc&a=page_h_diary_list_all', 'caption' => '最新日記'),
326            array('url' => '?m=pc&a=page_h_ranking', 'caption' => 'ランキング'),
327            array('url' => '?m=pc&a=page_h_config', 'caption' => '設定変更'),
328        );
329        break;
330    case 'h':
331    default:
332        $navi_type = 'h';
333        $navi = array(
334            array('url' => '?m=pc&a=page_h_home', 'caption' => 'ホーム'),
335            array('url' => '?m=pc&a=page_fh_friend_list', 'caption' => WORD_MY_FRIEND),
336            array('url' => '?m=pc&a=page_fh_diary_list', 'caption' => '日記'),
337            array('url' => '?m=pc&a=page_h_message_box', 'caption' => 'メッセージ'),
338            array('url' => '?m=pc&a=page_h_ashiato', 'caption' => 'あしあと'),
339            array('url' => '?m=pc&a=page_h_bookmark_list', 'caption' => 'お気に入り'),
340            array('url' => '?m=pc&a=page_fh_review_list_member', 'caption' => 'マイレビュー'),
341            array('url' => '?m=pc&a=page_h_prof', 'caption' => 'マイページ確認'),
342            array('url' => '?m=pc&a=page_h_config_prof', 'caption' => 'プロフィール変更'),
343        );
344        break;
345    case 'f':
346        $navi = array(
347            array('url' => '?m=pc&a=page_f_home', 'caption' => 'ホーム'),
348            array('url' => '?m=pc&a=page_fh_friend_list', 'caption' => WORD_FRIEND),
349            array('url' => '?m=pc&a=page_fh_diary_list', 'caption' => '日記を読む'),
350            array('url' => '?m=pc&a=page_f_message_send', 'caption' => 'メッセージを送る'),
351            array('url' => '?m=pc&a=page_f_bookmark_add', 'caption' => 'お気に入りに追加'),
352            array('url' => '?m=pc&a=page_fh_review_list_member', 'caption' => 'レビュー'),
353            array('url' => '?m=pc&a=page_f_invite', 'caption' => WORD_MY_FRIEND.'に紹介'),
354            array('url' => '?m=pc&a=page_f_link_request', 'caption' => WORD_MY_FRIEND.'に追加'),
355            array('url' => '?m=pc&a=page_f_intro_edit', 'caption' => '紹介文を書く'),
356        );
357        break;
358    case 'c':
359        $navi = array(
360            array('url' => '?m=pc&a=page_c_home', 'caption' => 'コミュニティトップ'),
361            array('url' => '?m=pc&a=page_c_topic_list', 'caption' => '掲示板'),
362            array('url' => '?m=pc&a=page_c_member_review', 'caption' => 'おすすめレビュー'),
363            array('url' => '?m=pc&a=page_c_join_commu', 'caption' => 'コミュニティに参加'),
364            array('url' => '?m=pc&a=page_c_invite', 'caption' => WORD_MY_FRIEND.'に紹介'),
365            array('url' => '?m=pc&a=page_c_leave_commu', 'caption' => 'コミュニティを退会'),
366        );
367        break;
368    }
369    $db = db_get_c_navi($navi_type);
370    foreach ($db as $value) {
371        $i = $value['sort_order'] - 1;
372        $navi[$i] = array('url' => $value['url'], 'caption' => $value['caption']);
373    }
374    return $navi;
375}
376
377/**
378 * checkdate の wrapper function
379 * Warning 対策
380 */
381function t_checkdate($month, $day, $year)
382{
383    return checkdate(intval($month), intval($day), intval($year));
384}
385
386/**
387 * Date_Calc::isFutureDate の wrapper function
388 */
389function t_isFutureDate($day, $month, $year)
390{
391    include_once 'Date/Calc.php';
392    return Date_Calc::isFutureDate(intval($day), intval($month), intval($year));
393}
394
395//---
396
397/**
398 * Check c_diary.public_flag
399 *
400 * @param int $c_diary_id
401 * @param int $c_member_id
402 * @return bool allowed or not
403 */
404function pne_check_diary_public_flag($c_diary_id, $c_member_id)
405{
406    $c_diary = db_diary_get_c_diary4id($c_diary_id);
407    if ($c_diary['c_member_id'] == $c_member_id) {
408        return true;
409    }
410
411    switch ($c_diary['public_flag']) {
412    case 'public':
413        $allowed = true;
414        break;
415    case 'friend':
416        $allowed = db_friend_is_friend($c_diary['c_member_id'], $c_member_id);
417        break;
418    case 'private':
419    default:
420        $allowed = false;
421        break;
422    }
423
424    return $allowed;
425}
426
427function pne_url2a($url, $target = '_blank')
428{
429    $length = 60;
430    $etc = '...';
431
432    if (strlen($url) > $length) {
433        $length -= strlen($etc);
434        $urlstr = substr($url, 0, $length) . $etc;
435    } else {
436        $urlstr = $url;
437    }
438    if ($target) {
439        $target = sprintf(' target="%s"', $target);
440    }
441
442    $url = htmlspecialchars($url, ENT_QUOTES, 'UTF-8');
443    $urlstr = htmlspecialchars($urlstr, ENT_QUOTES, 'UTF-8');
444
445    return sprintf('<a href="%s"%s>%s</a>', $url, $target, $urlstr);
446}
447
448function get_auth_config($is_ktai = false)
449{
450    if (IS_SLAVEPNE) {
451        $config = $GLOBALS['_OPENPNE_AUTH_CONFIG'];
452    } else {
453        $config['storage'] = 'DB';
454        if ($is_ktai) {
455            $config['options'] = array(
456                'dsn'         => db_get_dsn(),
457                'table'       => 'c_member_secure',
458                'usernamecol' => 'ktai_address',
459                'passwordcol' => 'hashed_password',
460                'cryptType'   => 'md5',
461            );
462        } else {
463            $config['options'] = array(
464                'dsn'         => db_get_dsn(),
465                'table'       => 'c_member_secure',
466                'usernamecol' => 'pc_address',
467                'passwordcol' => 'hashed_password',
468                'cryptType'   => 'md5',
469            );
470        }
471    }
472    return $config;
473}
474
475function crypt_func($raw_value,$cryptType)
476{
477    if (   isset($cryptType) 
478        && $cryptType == 'none') {
479        $cryptFunction = 'strval';
480    } elseif (   isset($cryptType) 
481              && function_exists($cryptType)) {
482        $cryptFunction = $cryptType;
483    } else {
484        $cryptFunction = 'md5';
485    }
486   
487    return $cryptFunction($raw_value);
488}
489
490function check_action4pne_slave($is_ktai = false)
491{
492    if (IS_SLAVEPNE) {
493        if ($is_ktai) {
494                openpne_redirect('ktai');
495        } else {
496                openpne_redirect('pc');
497        }
498    }
499}
500
501function util_include_php_files($dir)
502{
503    if (!is_dir($dir)) {
504        return;
505    }
506    if ($dh = opendir($dir)) {
507        while (($file = readdir($dh)) !== false) {
508            if ($file[0] === '.') {
509                continue;
510            }
511            $path = realpath($dir . '/' . $file);
512            if (is_dir($path)) {
513                util_include_php_files($path);
514            } else {
515                if (substr($file, -4, 4) === '.php') {
516                    include_once $path;
517                }
518            }
519        }
520        closedir($dh);
521    }
522}
523
524function util_cast_public_flag_diary($public_flag, $default = 'public')
525{
526    switch ($public_flag) {
527    case 'public':
528    case 'friend':
529    case 'private':
530        break;
531    default:
532        $public_flag = $default;
533        break;
534    }
535    return $public_flag;
536}
537
538/**
539 * 登録してもよいメールアドレスかどうか
540 */
541function util_is_regist_mail_address($mail_address)
542{
543    if (!db_common_is_mailaddress($mail_address)) {
544        return false;
545    }
546   
547    if (db_member_is_sns_join4mail_address($mail_address)) {
548        return false;
549    }
550   
551    if (!db_member_is_limit_domain4mail_address($mail_address)) {
552        return false;
553    }
554   
555    return true;
556}
557
558/**
559 * アップロード可能な拡張子のリストを取得
560 */
561function util_get_file_allowed_extensions($format = null)
562{
563    $list = array();
564    if (FILE_ALLOWED_EXTENTIONS) {
565        $exts = explode(',', FILE_ALLOWED_EXTENTIONS);
566        foreach ((array)$exts as $ext) {
567            if (trim($ext) !== '') {
568                $list[] = trim($ext);
569            }
570        }
571    }
572    if ($format === 'string') {
573        if ($list) {
574            foreach ($list as $key => $value) {
575                $list[$key] = '*.' . $value;
576            }
577            $list = implode('; ', $list);
578        } else {
579            $list = '';
580        }
581    }
582    return $list;
583}
584
585/**
586 * アップロード可能な拡張子かどうか
587 */
588function util_check_file_extention($filename)
589{
590    $extension = pathinfo($filename, PATHINFO_EXTENSION);
591    $list = util_get_file_allowed_extensions();
592    return (!$list || in_array($extension, $list));
593}
594
595?>
Note: See TracBrowser for help on using the repository browser.