Dotclear

source: admin/blog_pref.php @ 852:969647a6c35e

Revision 852:969647a6c35e, 13.8 KB checked in by Dsls <dsls@…>, 13 years ago (diff)

sexy step 3 : no more media.

Line 
1<?php
2# -- BEGIN LICENSE BLOCK ---------------------------------------
3#
4# This file is part of Dotclear 2.
5#
6# Copyright (c) 2003-2011 Olivier Meunier & Association Dotclear
7# Licensed under the GPL version 2.0 license.
8# See LICENSE file or
9# http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
10#
11# -- END LICENSE BLOCK -----------------------------------------
12
13$standalone = !isset($edit_blog_mode);
14
15$blog_id = false;
16
17if ($standalone)
18{
19     require dirname(__FILE__).'/../inc/admin/prepend.php';
20     dcPage::check('admin');
21     $blog_id = $core->blog->id;
22     $blog_status = $core->blog->status;
23     $blog_name = $core->blog->name;
24     $blog_desc = $core->blog->desc;
25     $blog_settings = $core->blog->settings;
26     $blog_url = $core->blog->url;
27     
28     $action = 'blog_pref.php';
29     $redir = 'blog_pref.php?upd=1';
30}
31else
32{
33     dcPage::checkSuper();
34     try
35     {
36          if (empty($_REQUEST['id'])) {
37               throw new Exception(__('No given blog id.'));
38          }
39          $rs = $core->getBlog($_REQUEST['id']);
40         
41          if (!$rs) {
42               throw new Exception(__('No such blog.'));
43          }
44         
45          $blog_id = $rs->blog_id;
46          $blog_status = $rs->blog_status;
47          $blog_name = $rs->blog_name;
48          $blog_desc = $rs->blog_desc;
49          $blog_settings = new dcSettings($core,$blog_id);
50          $blog_url = $rs->blog_url ; 
51     }
52     catch (Exception $e)
53     {
54          $core->error->add($e->getMessage());
55     }
56     
57     $action = 'blog.php';
58     $redir = 'blog.php?id=%s&upd=1';
59}
60
61# Language codes
62$langs = l10n::getISOcodes(1,1);
63foreach ($langs as $k => $v) {
64     $lang_avail = $v == 'en' || is_dir(DC_L10N_ROOT.'/'.$v);
65     $lang_combo[] = new formSelectOption($k,$v,$lang_avail ? 'avail10n' : '');
66}
67
68# Status combo
69foreach ($core->getAllBlogStatus() as $k => $v) {
70     $status_combo[$v] = (string) $k;
71}
72
73# URL scan modes
74$url_scan_combo = array(
75     'PATH_INFO' => 'path_info',
76     'QUERY_STRING' => 'query_string'
77);
78
79# Post URL combo
80$post_url_combo = array(
81     __('year/month/day/title') => '{y}/{m}/{d}/{t}',
82     __('year/month/title') => '{y}/{m}/{t}',
83     __('year/title') => '{y}/{t}',
84     __('title') => '{t}'
85);
86if (!in_array($blog_settings->system->post_url_format,$post_url_combo)) {
87     $post_url_combo[html::escapeHTML($blog_settings->system->post_url_format)] = html::escapeHTML($blog_settings->system->post_url_format);
88}
89
90
91# Robots policy options
92$robots_policy_options = array(
93     'INDEX,FOLLOW' => __("I would like search engines and archivers to index and archive my blog's content."),
94     'INDEX,FOLLOW,NOARCHIVE' => __("I would like search engines and archivers to index but not archive my blog's content."),
95     'NOINDEX,NOFOLLOW,NOARCHIVE' => __("I would like to prevent search engines and archivers from indexing or archiving my blog's content."),
96);
97
98# Update a blog
99if ($blog_id && !empty($_POST) && $core->auth->check('admin',$blog_id))
100{
101     $cur = $core->con->openCursor($core->prefix.'blog');
102     if ($core->auth->isSuperAdmin()) {
103          $cur->blog_id = $_POST['blog_id'];
104          $cur->blog_url = preg_replace('/\?+$/','?',$_POST['blog_url']); 
105          if (in_array($_POST['blog_status'],$status_combo)) {
106               $cur->blog_status = (integer) $_POST['blog_status'];
107          }
108     }
109     $cur->blog_name = $_POST['blog_name'];
110     $cur->blog_desc = $_POST['blog_desc'];
111     
112     $nb_post_per_page = abs((integer) $_POST['nb_post_per_page']);
113     if ($nb_post_per_page <= 1) { $nb_post_per_page = 1; }
114     
115     $nb_post_per_feed = abs((integer) $_POST['nb_post_per_feed']);
116     if ($nb_post_per_feed <= 1) { $nb_post_per_feed = 1; }
117     
118     try
119     {
120          if ($cur->blog_id != null && $cur->blog_id != $blog_id) {
121               $rs = $core->getBlog($cur->blog_id);
122               
123               if ($rs) {
124                    throw new Exception(__('That blog Id is already in use.'));
125               }
126          }
127         
128          # --BEHAVIOR-- adminBeforeBlogUpdate
129          $core->callBehavior('adminBeforeBlogUpdate',$cur,$blog_id);
130         
131          if (!preg_match('/^[a-z]{2}(-[a-z]{2})?$/',$_POST['lang'])) {
132               throw new Exception(__('Invalid language code'));
133          }
134         
135          $core->updBlog($blog_id,$cur);
136         
137          # --BEHAVIOR-- adminAfterBlogUpdate
138          $core->callBehavior('adminAfterBlogUpdate',$cur,$blog_id);
139         
140          if ($cur->blog_id != null && $cur->blog_id != $blog_id) {
141               if ($blog_id == $core->blog->id) {
142                    $core->setBlog($cur->blog_id);
143                    $_SESSION['sess_blog_id'] = $cur->blog_id;
144                    $blog_settings = $core->blog->settings;
145               } else {
146                    $blog_settings = new dcSettings($core,$cur->blog_id);
147               }
148               
149               $blog_id = $cur->blog_id;
150          }
151         
152         
153          $blog_settings->addNameSpace('system');
154         
155          $blog_settings->system->put('editor',$_POST['editor']);
156          $blog_settings->system->put('copyright_notice',$_POST['copyright_notice']);
157          $blog_settings->system->put('post_url_format',$_POST['post_url_format']);
158          $blog_settings->system->put('lang',$_POST['lang']);
159          $blog_settings->system->put('blog_timezone',$_POST['blog_timezone']);
160          $blog_settings->system->put('date_format',$_POST['date_format']);
161          $blog_settings->system->put('time_format',$_POST['time_format']);
162          $blog_settings->system->put('enable_xmlrpc',!empty($_POST['enable_xmlrpc']));
163         
164          $blog_settings->system->put('nb_post_per_page',$nb_post_per_page);
165          $blog_settings->system->put('use_smilies',!empty($_POST['use_smilies']));
166          $blog_settings->system->put('nb_post_per_feed',$nb_post_per_feed);
167          $blog_settings->system->put('short_feed_items',!empty($_POST['short_feed_items']));
168         
169          if (isset($_POST['robots_policy'])) {
170               $blog_settings->system->put('robots_policy',$_POST['robots_policy']);
171          }
172         
173          # --BEHAVIOR-- adminBeforeBlogSettingsUpdate
174          $core->callBehavior('adminBeforeBlogSettingsUpdate',$blog_settings);
175         
176          if ($core->auth->isSuperAdmin() && in_array($_POST['url_scan'],$url_scan_combo)) {
177               $blog_settings->system->put('url_scan',$_POST['url_scan']);
178          }
179         
180          http::redirect(sprintf($redir,$blog_id));
181     }
182     catch (Exception $e)
183     {
184          $core->error->add($e->getMessage());
185     }
186}
187
188dcPage::open(__('Blog settings'),
189     '<script type="text/javascript">'."\n".
190     "//<![CDATA["."\n".
191     dcPage::jsVar('dotclear.msg.warning_path_info',
192          __('Warning: except for special configurations, it is generally advised to have a trailing "/" in your blog URL in PATH_INFO mode.'))."\n".
193     dcPage::jsVar('dotclear.msg.warning_query_string',
194          __('Warning: except for special configurations, it is generally advised to have a trailing "?" in your blog URL in QUERY_STRING mode.'))."\n".
195     "//]]>".
196     "</script>".
197     dcPage::jsConfirmClose('blog-form').
198     dcPage::jsLoad('js/_blog_pref.js').
199     
200     
201     # --BEHAVIOR-- adminBlogPreferencesHeaders
202     $core->callBehavior('adminBlogPreferencesHeaders').
203     
204     dcPage::jsPageTabs()
205);
206
207if ($blog_id)
208{
209     echo '<h2>'.(!$standalone ? '<a href="blogs.php">'.__('Blogs').'</a> &rsaquo; ' : '').
210     html::escapeHTML($blog_name).' &rsaquo; <span class="page-title">'.
211     __('Blog settings').'</span></h2>';
212     
213     if (!empty($_GET['add'])) {
214          echo '<p class="message">'.__('Blog has been successfully created.').'</p>';
215     }
216     
217     if (!empty($_GET['upd'])) {
218          echo '<p class="message">'.__('Blog has been successfully updated.').'</p>';
219     }
220     
221     echo
222     '<div class="multi-part" id="params" title="'.__('Parameters').'">'.
223     '<h3>'.__('Parameters').'</h3>'.
224     '<form action="'.$action.'" method="post" id="blog-form">';
225     
226     echo
227     '<fieldset><legend>'.__('Blog details').'</legend>'.
228     $core->formNonce();
229     
230     if ($core->auth->isSuperAdmin())
231     {
232          echo
233          '<p><label for="blog_id" class="required"><abbr title="'.__('Required field').'">*</abbr> '.__('Blog ID:').
234          form::field('blog_id',30,32,html::escapeHTML($blog_id)).'</label></p>'.
235          '<p class="form-note">'.__('At least 2 characters using letters, numbers or symbols.').'</p> '.
236          '<p class="form-note warn">'.__('Please note that changing your blog ID may require changes in your public index.php file.').'</p>';
237     }
238     
239     echo
240     '<p><label for="blog_name" class="required"><abbr title="'.__('Required field').'">*</abbr> '.__('Blog name:').
241     form::field('blog_name',30,255,html::escapeHTML($blog_name)).'</label></p>';
242     
243     if ($core->auth->isSuperAdmin())
244     {
245          echo
246          '<p><label for="blog_url" class="required"><abbr title="'.__('Required field').'">*</abbr> '.__('Blog URL:').
247          form::field('blog_url',30,255,html::escapeHTML($blog_url)).'</label></p>'.
248         
249          '<p><label for="url_scan">'.__('URL scan method:').
250          form::combo('url_scan',$url_scan_combo,$blog_settings->system->url_scan).'</label></p>'.
251         
252          '<p><label for="blog_status">'.__('Blog status:').
253          form::combo('blog_status',$status_combo,$blog_status).'</label></p>';
254     }
255     
256     echo
257     '<p class="area"><label for="blog_desc">'.__('Blog description:').'</label>'.
258     form::textarea('blog_desc',60,5,html::escapeHTML($blog_desc)).'</p>'.
259     '</fieldset>';
260     
261     
262     echo
263     '<fieldset><legend>'.__('Blog configuration').'</legend>'.
264     '<div class="two-cols">'.
265     '<div class="col">'.
266     '<p><label for="editor">'.__('Blog editor name:').
267     form::field('editor',30,255,html::escapeHTML($blog_settings->system->editor)).
268     '</label></p>'.
269     
270     '<p><label for="lang">'.__('Default language:').
271     form::combo('lang',$lang_combo,$blog_settings->system->lang,'l10n').
272     '</label></p>'.
273     
274     '<p><label for="blog_timezone">'.__('Blog timezone:').
275     form::combo('blog_timezone',dt::getZones(true,true),html::escapeHTML($blog_settings->system->blog_timezone)).
276     '</label></p>'.
277     '</div>'.
278     
279     '<div class="col">'.
280     '<p><label for="copyright_notice">'.__('Copyright notice:').
281     form::field('copyright_notice',30,255,html::escapeHTML($blog_settings->system->copyright_notice)).
282     '</label></p>'.
283     
284     '<p><label for="post_url_format">'.__('New post URL format:').
285     form::combo('post_url_format',$post_url_combo,html::escapeHTML($blog_settings->system->post_url_format)).
286     '</label></p>'.
287     
288     '<p><label for="enable_xmlrpc" class="classic">'.
289     form::checkbox('enable_xmlrpc','1',$blog_settings->system->enable_xmlrpc).
290     __('Enable XML/RPC interface').'</label>'.
291     ' - <a href="#xmlrpc">'.__('more information').'</a></p>'.
292     '</div>'.
293     '</div>'.
294     '<br class="clear" />'. //Opera sucks
295     '</fieldset>';
296     
297     echo
298     '<fieldset><legend>'.__('Blog presentation').'</legend>'.
299     '<div class="two-cols">'.
300     '<div class="col">'.
301     '<p><label for="date_format">'.__('Date format:').
302     form::field('date_format',30,255,html::escapeHTML($blog_settings->system->date_format)).
303     '</label></p>'.
304     
305     '<p><label for="time_format">'.__('Time format:').
306     form::field('time_format',30,255,html::escapeHTML($blog_settings->system->time_format)).
307     '</label></p>'.
308     
309     '<p><label for="use_smilies" class="classic">'.
310     form::checkbox('use_smilies','1',$blog_settings->system->use_smilies).
311     __('Display smilies on entries and comments').'</label></p>'.
312     '</div>'.
313     
314     '<div class="col">'.
315     '<p><label for="nb_post_per_page" class="classic">'.sprintf(__('Display %s entries per page'),
316     form::field('nb_post_per_page',2,3,$blog_settings->system->nb_post_per_page)).
317     '</label></p>'.
318     
319     '<p><label for="nb_post_per_feed" class="classic">'.sprintf(__('Display %s entries per feed'),
320     form::field('nb_post_per_feed',2,3,$blog_settings->system->nb_post_per_feed)).
321     '</label></p>'.
322     
323     '<p><label for="short_feed_items" class="classic">'.
324     form::checkbox('short_feed_items','1',$blog_settings->system->short_feed_items).
325     __('Truncate feeds').'</label></p>'.
326     '</div>'.
327    '</div>'.
328     '<br class="clear" />'. //Opera sucks
329     '</fieldset>';
330     
331     
332     echo
333     '<fieldset><legend>'.__('Search engines robots policy').'</legend>';
334     
335     $i = 0;
336     foreach ($robots_policy_options as $k => $v)
337     {
338          echo '<p><label for="robots_policy-'.$i.'" class="classic">'.
339          form::radio(array('robots_policy','robots_policy-'.$i),$k,$blog_settings->system->robots_policy == $k).' '.$v.'</label></p>';
340          $i++;
341     }
342     
343     echo '</fieldset>';
344     
345     
346     # --BEHAVIOR-- adminBlogPreferencesForm
347     $core->callBehavior('adminBlogPreferencesForm',$core,$blog_settings);
348     
349     echo
350     '<p><input type="submit" accesskey="s" value="'.__('Save').'" />'.
351     (!$standalone ? form::hidden('id',$blog_id) : '').
352     '</p>'.
353     '</form>';
354     
355     if ($core->auth->isSuperAdmin() && $blog_id != $core->blog->id)
356     {
357          echo
358          '<form action="blog_del.php" method="post">'.
359          '<p><input type="submit" class="delete" value="'.__('Delete this blog').'" />'.
360          form::hidden(array('blog_id'),$blog_id).
361          $core->formNonce().'</p>'.
362          '</form>';
363     }
364     
365     # XML/RPC information
366     echo '<h3 id="xmlrpc">'.__('XML/RPC interface').'</h3>';
367     
368     echo '<p>'.__('XML/RPC interface allows you to edit your blog with an external client.').'</p>';
369     
370     if (!$blog_settings->system->enable_xmlrpc)
371     {
372          echo '<p>'.__('XML/RPC interface is not active. Change settings to enable it.').'</p>';
373     }
374     else
375     {
376          echo
377          '<p>'.__('XML/RPC interface is active. You should set the following parameters on your XML/RPC client:').'</p>'.
378          '<ul>'.
379          '<li>'.__('Server URL:').' <strong>'.
380          sprintf(DC_XMLRPC_URL,$core->blog->url,$core->blog->id).
381          '</strong></li>'.
382          '<li>'.__('Blogging system:').' <strong>Movable Type</strong></li>'.
383          '<li>'.__('User name:').' <strong>'.$core->auth->userID().'</strong></li>'.
384          '<li>'.__('Password:').' <strong>'.__('your password').'</strong></li>'.
385          '<li>'.__('Blog ID:').' <strong>1</strong></li>'.
386          '</ul>';
387     }
388     
389     echo '</div>';
390     
391     #
392     # Users on the blog (with permissions)
393     
394     $blog_users = $core->getBlogPermissions($blog_id,$core->auth->isSuperAdmin());
395     $perm_types = $core->auth->getPermissionsTypes();
396     
397     echo
398     '<div class="multi-part" id="users" title="'.__('Users').'">'.
399     '<h3>'.__('Users on this blog').'</h3>';
400     
401     if (empty($blog_users))
402     {
403          echo '<p>'.__('No users').'</p>';
404     }
405     else
406     {
407          if ($core->auth->isSuperAdmin()) {
408               $user_url_p = '<a href="user.php?id=%1$s">%1$s</a>';
409          } else {
410               $user_url_p = '%1$s';
411          }
412         
413          foreach ($blog_users as $k => $v)
414          {
415               if (count($v['p']) > 0)
416               {
417                    echo
418                    '<h4>'.sprintf($user_url_p,html::escapeHTML($k)).
419                    ' ('.html::escapeHTML(dcUtils::getUserCN(
420                         $k, $v['name'], $v['firstname'], $v['displayname']
421                    )).')';
422                   
423                    if (!$v['super'] && $core->auth->isSuperAdmin()) {
424                         echo
425                         ' - <a href="permissions.php?blog_id[]='.$blog_id.'&amp;user_id[]='.$k.'">'
426                         .__('Change permissions').'</a>';
427                    }
428                   
429                    echo '</h4>';
430                   
431                    echo '<ul>';
432                    if ($v['super']) {
433                         echo '<li>'.__('Super administrator').'</li>';
434                    } else {
435                         foreach ($v['p'] as $p => $V) {
436                              echo '<li>'.__($perm_types[$p]).'</li>';
437                         }
438                    }
439                    echo '</ul>';
440               }
441          }
442     }
443     
444     echo '</div>';
445}
446
447dcPage::helpBlock('core_blog_pref');
448dcPage::close();
449?>
Note: See TracBrowser for help on using the repository browser.

Sites map