當前位置: 首頁>>代碼示例>>PHP>>正文


PHP Dir::scan方法代碼示例

本文整理匯總了PHP中Dir::scan方法的典型用法代碼示例。如果您正苦於以下問題:PHP Dir::scan方法的具體用法?PHP Dir::scan怎麽用?PHP Dir::scan使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Dir的用法示例。


在下文中一共展示了Dir::scan方法的8個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: scan

 public static function scan($path, $recursive = true, $excludeDir = true)
 {
     $path = self::formatPath($path);
     $dh = opendir($path);
     if (!$dh) {
         return [];
     }
     $files = [];
     while (false !== ($file = readdir($dh))) {
         if ($file == '.' || $file == '..') {
             continue;
         }
         $fileType = filetype($path . $file);
         if ('file' == $fileType) {
             $files[] = $path . $file;
         }
         if ('dir' == $fileType) {
             if (true === $recursive) {
                 $innerFiles = Dir::scan($path . $file . '/', $recursive, $excludeDir);
                 $files = Arr::join($files, $innerFiles);
             }
             if (false === $excludeDir) {
                 $files[] = $path . $file . '/';
             }
         }
     }
     closedir($dh);
     return $files;
 }
開發者ID:vimac,項目名稱:zan,代碼行數:29,代碼來源:Dir.php

示例2: getSiteThemes

 /**
  * Get Admin Themes
  */
 public static function getSiteThemes()
 {
     $themes_folders = array();
     // Get all themes folders
     $_themes_folders = Dir::scan(THEMES_SITE);
     // Create an array of valid themes folders
     foreach ($_themes_folders as $folder) {
         if (File::exists(THEMES_SITE . DS . $folder . DS . 'index.template.php')) {
             $__themes_folders[] = $folder;
         }
     }
     foreach ($__themes_folders as $theme) {
         $themes[$theme] = $theme;
     }
     return $themes;
 }
開發者ID:rowena-altastratus,項目名稱:altastratus,代碼行數:19,代碼來源:themes.plugin.php

示例3: main

 /**
  * System plugin admin
  */
 public static function main()
 {
     if (Session::exists('user_role') && in_array(Session::get('user_role'), array('admin'))) {
         $filters = Filter::$filters;
         $plugins = Plugin::$plugins;
         $components = Plugin::$components;
         $actions = Action::$actions;
         // Get pages table
         $pages = new Table('pages');
         // Get system timezone
         $system_timezone = Option::get('timezone');
         // Get languages files
         $language_files = File::scan(PLUGINS_BOX . DS . 'system' . DS . 'languages' . DS, '.lang.php');
         foreach ($language_files as $language) {
             $parts = explode('.', $language);
             $languages_array[$parts[0]] = I18n::$locales[$parts[0]];
         }
         // Get all pages
         $pages_array = array();
         $pages_list = $pages->select('[slug!="error404" and parent="" and status="published"]');
         foreach ($pages_list as $page) {
             $pages_array[$page['slug']] = Html::toText($page['title']);
         }
         // Create Sitemap
         // -------------------------------------
         if (Request::get('sitemap') == 'create') {
             if (Security::check(Request::get('token'))) {
                 Notification::set('success', __('Sitemap created', 'system'));
                 Sitemap::create();
                 Request::redirect('index.php?id=system');
             } else {
                 die('Request was denied because it contained an invalid security token. Please refresh the page and try again.');
             }
         }
         // Delete temporary files
         // -------------------------------------
         if (Request::get('temporary_files') == 'delete') {
             if (Security::check(Request::get('token'))) {
                 Monstra::cleanTmp();
                 if (count(File::scan(MINIFY, array('css', 'js', 'php'))) == 0 && count(Dir::scan(CACHE)) == 0) {
                     Notification::set('success', __('Temporary files deleted', 'system'));
                     Request::redirect('index.php?id=system');
                 }
             } else {
                 die('Request was denied because it contained an invalid security token. Please refresh the page and try again.');
             }
         }
         // Set maintenance state on or off
         // -------------------------------------
         if (Request::get('maintenance')) {
             if (Security::check(Request::get('token'))) {
                 if ('on' == Request::get('maintenance')) {
                     Option::update('maintenance_status', 'on');
                     Request::redirect('index.php?id=system');
                 }
                 if ('off' == Request::get('maintenance')) {
                     Option::update('maintenance_status', 'off');
                     Request::redirect('index.php?id=system');
                 }
             } else {
                 die('Request was denied because it contained an invalid security token. Please refresh the page and try again.');
             }
         }
         // Edit settings
         // -------------------------------------
         if (Request::post('edit_settings')) {
             if (Security::check(Request::post('csrf'))) {
                 // Add trailing slashes
                 $_site_url = Request::post('system_url');
                 Option::update(array('sitename' => Request::post('site_name'), 'keywords' => Request::post('site_keywords'), 'description' => Request::post('site_description'), 'slogan' => Request::post('site_slogan'), 'defaultpage' => Request::post('site_default_page'), 'siteurl' => $_site_url, 'timezone' => Request::post('system_timezone'), 'system_email' => Request::post('system_email'), 'language' => Request::post('system_language'), 'maintenance_message' => Request::post('site_maintenance_message')));
                 Notification::set('success', __('Your changes have been saved.', 'system'));
                 Request::redirect('index.php?id=system');
             } else {
                 die('Request was denied because it contained an invalid security token. Please refresh the page and try again.');
             }
         }
         // Its mean that you can add your own actions for this plugin
         Action::run('admin_system_extra_actions');
         // Display view
         View::factory('box/system/views/backend/index')->assign('pages_array', $pages_array)->assign('languages_array', $languages_array)->display();
     } else {
         Request::redirect('index.php?id=users&action=edit&user_id=' . Session::get('user_id'));
     }
 }
開發者ID:rowena-altastratus,項目名稱:altastratus,代碼行數:87,代碼來源:system.admin.php

示例4: cleanTmp

 /**
  * Clean Monstra TMP folder.
  */
 public static function cleanTmp()
 {
     // Cleanup minify
     if (count($files = File::scan(MINIFY, array('css', 'js', 'php'))) > 0) {
         foreach ($files as $file) {
             File::delete(MINIFY . DS . $file);
         }
     }
     // Cleanup cache
     if (count($namespaces = Dir::scan(CACHE)) > 0) {
         foreach ($namespaces as $namespace) {
             Dir::delete(CACHE . DS . $namespace);
         }
     }
 }
開發者ID:Repkit,項目名稱:monstra,代碼行數:18,代碼來源:Monstra.php

示例5: defined

<?php

defined('PANEL_ACCESS') or die('No direct script access.');
// new panel
$p = new Panel();
/*  = Sections
--------------------------------------------*/
/*
* @name   Dashboard | login
* @desc   if session user get Dashboard
* @desc   if not redirecto to login page
*/
$p->route('/', function () use($p) {
    if (Session::exists('user')) {
        // show dashboard
        $p->view('index', ['title' => $p::$lang['Dashboard'], 'pages' => count(File::scan(ROOTBASE . DS . 'storage' . DS . 'pages', 'md')), 'images' => count(File::scan(ROOTBASE . DS . 'public' . DS . 'images')), 'uploads' => count(File::scan(ROOTBASE . DS . 'public' . DS . 'uploads')), 'blocks' => count(File::scan(ROOTBASE . DS . 'storage' . DS . 'blocks', 'md')), 'themes' => count(Dir::scan(ROOTBASE . DS . 'themes' . DS)), 'plugins' => count(Dir::scan(ROOTBASE . DS . 'plugins' . DS))]);
    } else {
        // empty error
        $error = '';
        if (Request::post('login')) {
            if (Request::post('csrf')) {
                if (Request::post('pass') == $p::$site['backend_password'] && Request::post('email') == $p::$site['autor']['email']) {
                    @Session::start();
                    Session::set('user', uniqid('morfy_user'));
                    Request::redirect($p::$site['url'] . '/' . $p::$site['backend_folder']);
                } else {
                    // password not correct show error
                    $error = '<span class="login-error error">' . $p::$lang['Password_Error'] . '</span>';
                }
            } else {
                // crsf
開發者ID:Awilum,項目名稱:morfy-admin-panel,代碼行數:31,代碼來源:Morfy.routes.php

示例6: die

             }
             if (Dir::exists(CACHE_PATH . '/fenom/')) {
                 Dir::delete(CACHE_PATH . '/fenom/');
             }
             Request::redirect(Url::getBase());
         } else {
             die('crsf detect !');
         }
     }
     // logout
     if (Request::post('access_logout')) {
         Session::delete(Config::get('plugins.edit.name') . '_user');
         Request::redirect(Url::getCurrent());
     }
     // show template
     $template->display('admin.tpl', ['title' => $name, 'content' => $page, 'current' => $url, 'directory' => Dir::scan(STORAGE_PATH . '/pages')]);
 } else {
     // login
     if (Request::post('access_login')) {
         if (Request::post('token')) {
             if (sha1(md5(Request::post('password'))) == $password && Request::post('email') == $user) {
                 @Session::start();
                 Session::set(Config::get('plugins.edit.name') . '_user', $hash);
                 // show admin template
                 Request::redirect(Url::getCurrent());
             } else {
                 // password not correct show error
                 $template->display('partials/error.tpl', ['title' => 'Access Error', 'content' => Config::get('plugins.edit.errorPassword')]);
             }
         } else {
             // crsf
開發者ID:nakome,項目名稱:Fansoro-edit-plugin,代碼行數:31,代碼來源:edit.php

示例7: array

    if (Session::exists('user')) {
        // show Diagnostic
        $p->view('diag', array('title' => 'Diagnostic'));
    }
});
/*    DASHBOARD
-----------------------------*/
/*
* @name   Dashboard | login
* @desc   if session user get Dashboard
* @desc   if not redirecto to login page
*/
$p->route('/', function () use($p) {
    if (Session::exists('user')) {
        // show dashboard
        $p->view('index', array('title' => $p::$lang['Dashboard'], 'pages' => count(File::scan(PAGES, 'md')), 'media' => count(File::scan(MEDIA . '/album_thumbs')), 'uploads' => count(File::scan(UPLOADS)), 'blocks' => count(File::scan(BLOCKS, 'md')), 'themes' => count(Dir::scan(ROOTBASE . '/themes')), 'plugins' => count(Dir::scan(ROOTBASE . '/plugins'))));
    } else {
        // empty error
        $error = '';
        if (Request::post('login')) {
            if (Request::post('csrf')) {
                if (Request::post('pass') == $p::$site['backend_password'] && Request::post('email') == $p::$site['author']['email']) {
                    @Session::start();
                    Session::set('user', uniqid('morfy_user'));
                    Request::redirect($p::$site['url'] . '/' . $p::$site['backend_folder']);
                } else {
                    // password not correct show error
                    $error = '<span class="well red">' . $p::$lang['Password_Error'] . '</span>';
                }
            } else {
                // crsf
開發者ID:xxwebplus,項目名稱:morfy-admin-panel,代碼行數:31,代碼來源:pages.php

示例8: main


//.........這裏部分代碼省略.........
         if (Security::check(Request::post('csrf'))) {
             $id = (int) Request::post('delete_location');
             if (!LocationsRepository::hasEvents($id)) {
                 if (LocationsRepository::update($id, array('deleted' => 1))) {
                     Notification::set('success', __('Location has been moved to trash with success!', 'events'));
                 } else {
                     Notification::set('error', __('Table->update() returned an error. Location could not be deleted.', 'events'));
                 }
             } else {
                 Notification::set('error', __('Deletion failed. This location is assigned to at least one event. Remove this location from every event to delete it.', 'events'));
             }
             Request::redirect('index.php?id=events#locations');
         } else {
             Notification::set('error', __('Request was denied. Invalid security token. Please refresh the page and try again.', 'events'));
             die;
         }
     }
     // Request: delete trash location
     if (Request::post('delete_trash_location')) {
         if (Security::check(Request::post('csrf'))) {
             $id = (int) Request::post('delete_trash_location');
             if (LocationsRepository::delete($id)) {
                 Notification::set('success', __('Location has been deleted permanently with success!', 'events'));
             } else {
                 Notification::set('error', __('Table->delete() returned an error. Location could not be deleted.', 'events'));
             }
             Request::redirect('index.php?id=events#trash/trash-locations');
         } else {
             Notification::set('error', __('Request was denied. Invalid security token. Please refresh the page and try again.', 'events'));
             die;
         }
     }
     // get upload directories
     $directory_list = Dir::scan($path);
     $directories = array(DS => DS);
     if (!empty($directory_list)) {
         foreach ($directory_list as $directory_name) {
             $directories[$directory_name] = DS . $directory_name;
         }
         ksort($directories);
     }
     // Get files
     $file_list = File::scan($path . Option::get('events_image_directory'));
     $files = array('' => '');
     if (!empty($file_list)) {
         foreach ($file_list as $file_name) {
             $files[$file_name] = $file_name;
         }
         ksort($files);
     }
     if (Request::get('action')) {
         switch (Request::get('action')) {
             // Request: configuration
             case "configuration":
                 // Request: options
                 if (Request::post('events_options_update') or Request::post('events_options_update_and_exit')) {
                     if (Security::check(Request::post('csrf'))) {
                         Option::update('events_image_directory', (string) Request::post('events_image_directory'));
                         Option::update('events_placeholder_archive', (string) Request::post('events_placeholder_archive'));
                         Notification::set('success', __('Configuration has been saved with success!', 'events'));
                         Request::redirect('index.php?id=events' . (Request::post('events_options_update') ? '&action=configuration' : ''));
                     } else {
                         Notification::set('error', __('Request was denied. Invalid security token. Please refresh the page and try again.', 'events'));
                         die;
                     }
                 }
開發者ID:devmount-monstra,項目名稱:events,代碼行數:67,代碼來源:events.admin.php


注:本文中的Dir::scan方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。