File: include/install.php

Recommend this page to a friend!
  Classes of Goffy G  >  XOOPS Modules Builder  >  include/install.php  >  Download  
File: include/install.php
Role: Example script
Content type: text/plain
Description: Example script
Class: XOOPS Modules Builder
Generate new modules for the XOOPS CMS
Author: By
Last change:
Date: 2 months ago
Size: 3,672 bytes
 

Contents

Class file image Download
<?php
/*
 You may not change or alter any portion of this comment or credits
 of supporting developers from this source code or any supporting source code
 which is considered copyrighted (c) material of the original comment or credit authors.

 This program is distributed in the hope that it will be useful,
 but WITHOUT ANY WARRANTY; without even the implied warranty of
 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
*/

/**
 * Modulebuilder module for xoops
 *
 * @copyright module for xoops
 * @license GPL 2.0 or later
 * @package Modulebuilder
 * @since 1.0
 * @min_xoops 2.5.9
 * @author Wedega - Email:<webmaster@wedega.com> - Website:<https://wedega.com> XOOPS Project (www.xoops.org) $
 */

use XoopsModules\Modulebuilder;
use
XoopsModules\Modulebuilder\Common;

/**
 * @param \XoopsModule $module
 * @return bool
 */
function xoops_module_pre_install_modulebuilder(\XoopsModule $module)
{
    require \
dirname(__DIR__) . '/preloads/autoloader.php';
   
/** @var Modulebuilder\Utility $utility */
   
$utility = new Modulebuilder\Utility();

   
//check for minimum XOOPS version
   
$xoopsSuccess = $utility::checkVerXoops($module);

   
// check for minimum PHP version
   
$phpSuccess = $utility::checkVerPhp($module);

    if (
false !== $xoopsSuccess && false !== $phpSuccess) {
       
$moduleTables = &$module->getInfo('tables');
        foreach (
$moduleTables as $table) {
           
$GLOBALS['xoopsDB']->queryF('DROP TABLE IF EXISTS ' . $GLOBALS['xoopsDB']->prefix($table) . ';');
        }
    }

    return
$xoopsSuccess && $phpSuccess;
}

/**
 * @param \XoopsModule $module
 * @return bool|string
 */
function xoops_module_install_modulebuilder(\XoopsModule $module)
{
    require \
dirname(__DIR__) . '/preloads/autoloader.php';

   
/** @var Modulebuilder\Helper $helper */
    /** @var Modulebuilder\Utility $utility */
    /** @var Common\Configurator $configurator */
   
$helper = Modulebuilder\Helper::getInstance();
   
$utility = new Modulebuilder\Utility();
   
$configurator = new Common\Configurator();

   
// Load language files
   
$helper->loadLanguage('admin');
   
$helper->loadLanguage('modinfo');
   
$helper->loadLanguage('common');

   
// --- CREATE FOLDERS ---------------
   
if ($configurator->uploadFolders && \is_array($configurator->uploadFolders)) {
       
// foreach (\array_keys($GLOBALS['uploadFolders']) as $i) {
       
foreach (\array_keys($configurator->uploadFolders) as $i) {
           
$utility::createFolder($configurator->uploadFolders[$i]);
        }
    }

   
// --- COPY blank.gif FILES ---------------
   
if ($configurator->copyBlankFiles && \is_array($configurator->copyBlankFiles)) {
       
$file = \dirname(__DIR__) . '/assets/images/blank.gif';
        foreach (\
array_keys($configurator->copyBlankFiles) as $i) {
           
$dest = $configurator->copyBlankFiles[$i] . '/blank.gif';
           
$utility::copyFile($file, $dest);
        }
       
$file = \dirname(__DIR__) . '/assets/images/blank.png';
        foreach (\
array_keys($configurator->copyBlankFiles) as $i) {
           
$dest = $configurator->copyBlankFiles[$i] . '/blank.png';
           
$utility::copyFile($file, $dest);
        }
    }
   
// --- COPY empty.png FILES ---------------
   
if ($configurator->copyBlankFiles && \is_array($configurator->copyBlankFiles)) {
       
$file = \dirname(__DIR__) . '/assets/images/modules/empty.png';
        foreach (\
array_keys($configurator->copyBlankFiles) as $i) {
           
$dest = $configurator->copyBlankFiles[$i] . '/empty.png';
           
$utility::copyFile($file, $dest);
        }
    }

    return
true;
}


For more information send a message to info at phpclasses dot org.