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

source: OpenPNE/branches/stable-2.10.x/webapp/lib/util/util.php @ 4402

Last change on this file since 4402 was 4402, checked in by ebihara, 15 years ago

#1410:配色設定未設定時のデフォルト値をユーザ配色設定にするようにした

File size: 21.8 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, $c_member_id = 0)
542{
543    if (!db_common_is_mailaddress($mail_address)) {
544        return false;
545    }
546
547    if (!db_member_is_limit_domain4mail_address($mail_address)) {
548        return false;
549    }
550
551    if (db_member_is_sns_join4mail_address($mail_address, $c_member_id)) {
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/**
596 * 参照可能なメッセージかどうか
597 *
598 * ・指定メンバーが送信者で、完全削除済でない
599 * ・指定メンバーが受信者で、送信済であり完全削除済でない
600 *
601 * @param int $c_member_id
602 * @param int $c_message_id
603 * @return bool
604 */
605function util_is_readable_message($c_member_id, $c_message_id)
606{
607    $c_message = db_message_c_message4c_message_id($c_message_id);
608
609    if ($c_message['c_member_id_from'] == $c_member_id) {  // 自分が送信者
610        if (!$c_message['is_kanzen_sakujo_from']) {  // 完全削除済でない
611            return true;
612        }
613    } elseif ($c_message['c_member_id_to'] == $c_member_id)  { // 自分が受信者
614        if ($c_message['is_send'] && !$c_message['is_kanzen_sakujo_to']) {  // 送信済であり完全削除済でない
615            return true;
616        }
617    }
618
619    return false;
620}
621
622/**
623 * DB内配色設定の未設定項目をデフォルトの配色設定で埋める
624 *
625 * @param array $c_config_color    DB内配色設定
626 * @param string $mode
627 * @return array
628 */
629function util_apply_color_default2current($c_config_color, $mode = 'pc')
630{
631    if ($mode == 'ktai') {
632        $default_color['color_23'] = $c_config_color['color_1'];
633        $default_color['color_24'] = $c_config_color['color_14'];
634        $default_color['color_25'] = $c_config_color['color_14'];
635        $default_color['color_26'] = $c_config_color['color_14'];
636        $default_color['color_27'] = $c_config_color['color_3'];
637        $default_color['color_28'] = $c_config_color['color_14'];
638    } else {
639        $default_color['color_19'] = $c_config_color['color_13'];
640    }
641
642    $empty_keys = array_keys($c_config_color, '');
643    foreach ($empty_keys as $key) {
644        if (array_key_exists($key, $default_color)) {
645            $c_config_color[$key] = $default_color[$key];
646        }
647    }
648
649    return $c_config_color;
650}
651
652function util_get_color_config()
653{
654    $c_config_color = db_etc_c_config_color();
655    $c_config_color = util_apply_color_default2current($c_config_color);
656
657    $color_config = array(
658        'border_01' => $c_config_color['color_1'],
659        'border_07' => $c_config_color['color_2'],
660        'border_10' => $c_config_color['color_3'],
661        'bg_00' => $c_config_color['color_4'],
662        'bg_01' => $c_config_color['color_5'],
663        'bg_02' => $c_config_color['color_6'],
664        'bg_03' => $c_config_color['color_7'],
665        'bg_04' => $c_config_color['color_8'],
666        'bg_05' => $c_config_color['color_9'],
667        'bg_06' => $c_config_color['color_10'],
668        'bg_07' => $c_config_color['color_11'],
669        'bg_08' => $c_config_color['color_12'],
670        'bg_09' => $c_config_color['color_13'],
671        'bg_10' => $c_config_color['color_14'],
672        'bg_11' => $c_config_color['color_15'],
673        'bg_12' => $c_config_color['color_16'],
674        'bg_13' => $c_config_color['color_17'],
675        'bg_14' => $c_config_color['color_18'],
676        'color_19' => $c_config_color['color_19'],
677    );
678    return $color_config;
679}
680
681function util_get_color_config_ktai()
682{
683    $c_config_color = db_etc_c_config_color_ktai();
684    $c_config_color = util_apply_color_default2current($c_config_color, 'ktai');
685
686    $color_config = array(
687        'bg_01' => $c_config_color['color_1'],
688        'bg_02' => $c_config_color['color_2'],
689        'bg_03' => $c_config_color['color_3'],
690        'bg_04' => $c_config_color['color_4'],
691        'bg_05' => $c_config_color['color_5'],
692        'bg_06' => $c_config_color['color_6'],
693        'bg_07' => $c_config_color['color_7'],
694        'bg_08' => $c_config_color['color_8'],
695        'bg_09' => $c_config_color['color_9'],
696        'bg_10' => $c_config_color['color_10'],
697        'border_01' => $c_config_color['color_11'],
698        'border_02' => $c_config_color['color_12'],
699        'border_03' => $c_config_color['color_13'],
700        'font_01' => $c_config_color['color_14'],
701        'font_02' => $c_config_color['color_15'],
702        'font_03' => $c_config_color['color_23'],
703        'font_04' => $c_config_color['color_17'],
704        'font_05' => $c_config_color['color_18'],
705        'font_06' => $c_config_color['color_19'],
706        'font_07' => $c_config_color['color_20'],
707        'font_08' => $c_config_color['color_21'],
708        'font_09' => $c_config_color['color_22'],
709        'color_24' => $c_config_color['color_24'],
710        'color_25' => $c_config_color['color_25'],
711        'color_26' => $c_config_color['color_26'],
712        'color_27' => $c_config_color['color_27'],
713        'color_28' => $c_config_color['color_28'],
714    );
715    return $color_config;
716}
717
718/**
719 * メンバー登録を行う
720 *
721 * @param array $c_member
722 * @param array $c_member_secure
723 * @param array $c_member_profile_list
724 * @param bool $is_password_encrypted    パスワードが既に暗号化済みかどうか
725 * @return int
726 */
727function util_regist_c_member($c_member, $c_member_secure, $c_member_profile_list = array(), $is_password_encrypted = false)
728{
729    // メール受信設定をデフォルト値に
730    $c_member['is_receive_mail'] = 1;
731    $c_member['is_receive_ktai_mail'] = 1;
732    $c_member['is_receive_daily_news'] = 1;
733
734    // メンバー登録
735    $u = db_member_insert_c_member($c_member, $c_member_secure, $is_password_encrypted);
736    if ($u === false) {  // メンバー登録に失敗した場合
737        return false;
738    }
739
740    if (OPENPNE_USE_POINT_RANK) {
741        //入会者にポイント加算
742        $point = db_action_get_point4c_action_id(1);
743        db_point_add_point($u, $point);
744
745        //メンバー招待をした人にポイント加算
746        $point = db_action_get_point4c_action_id(7);
747        db_point_add_point($c_member['c_member_id_invite'], $point);
748    }
749
750    // c_member_profile
751    db_member_update_c_member_profile($u, $c_member_profile_list);
752
753    // 招待者とフレンドリンク
754    db_friend_insert_c_friend($u, $c_member['c_member_id_invite']);
755
756    //管理画面で指定したコミュニティに強制参加
757    $c_commu_id_list = db_commu_regist_join_list();
758    foreach ($c_commu_id_list as $c_commu_id) {
759        db_commu_join_c_commu($c_commu_id, $u);
760    }
761
762    return $u;
763}
764
765function util_get_preset_color_list($dir = 'pc')
766{
767    $color_list_dir = OPENPNE_WEBAPP_DIR . '/lib/color/' . $dir . '/';
768    $color_list = array();
769
770    if ($dh = opendir($color_list_dir)) {
771        while (($file = readdir($dh)) !== false) {
772            if (array_pop(explode('.', $file)) == 'ini') {
773                $color_list[$file] = parse_ini_file($color_list_dir . $file);
774            }
775        }
776        closedir($dh);
777    }
778
779    ksort($color_list);
780
781    return array_values($color_list);
782}
783?>
Note: See TracBrowser for help on using the repository browser.