Seditio Source
Root |
./othercms/ips_4.3.4/applications/core/sources/ShareLinks/Service.php
<?php
/**
 * @brief        Share Links Node
 * @author        <a href='https://www.invisioncommunity.com'>Invision Power Services, Inc.</a>
 * @copyright    (c) Invision Power Services, Inc.
 * @license        https://www.invisioncommunity.com/legal/standards/
 * @package        Invision Community
 * @since        12 Jun 2013
 */

namespace IPS\core\ShareLinks;

/* To prevent PHP errors (extending class does not exist) revealing path */
if ( !defined( '\IPS\SUITE_UNIQUE_KEY' ) )
{
   
header( ( isset( $_SERVER['SERVER_PROTOCOL'] ) ? $_SERVER['SERVER_PROTOCOL'] : 'HTTP/1.0' ) . ' 403 Forbidden' );
    exit;
}

/**
 * Share Link Node
 */
class _Service extends \IPS\Node\Model
{
   
/**
     * @brief    [ActiveRecord] Multiton Store
     */
   
protected static $multitons;
   
   
/**
     * @brief    [ActiveRecord] Database Table
     */
   
public static $databaseTable = 'core_share_links';
   
   
/**
     * @brief    [ActiveRecord] Database Prefix
     */
   
public static $databasePrefix = 'share_';
   
   
/**
     * @brief    [ActiveRecord] ID Database Column
     */
   
public static $databaseColumnId = 'id';

   
/**
     * @brief    [ActiveRecord] Database ID Fields
     */
   
protected static $databaseIdFields = array( 'share_key' );
   
   
/**
     * @brief    [ActiveRecord] Multiton Map
     */
   
protected static $multitonMap    = array();
   
   
/**
     * @brief    [Node] Order Database Column
     */
   
public static $databaseColumnOrder = 'position';
   
   
/**
     * @brief    [Node] Node Title
     */
   
public static $nodeTitle = 'sharelinks';
   
   
/**
     * @brief    [Node] Show forms modally?
     */
   
public static $modalForms = TRUE;
   
   
/**
     * @brief    [Node] ACP Restrictions
     */
   
protected static $restrictions = array(
       
'app'        => 'core',
       
'module'    => 'settings',
       
'prefix'    => 'sharelinks_',
    );

   
/**
     * [Node] Reset our roots so they can be reloaded
     *
     * @return    void
     */
   
public static function resetRootResult()
    {
        static::
$rootsResult    = NULL;
    }
   
   
/**
     * Fetch All Nodes
     *
     * @return    array
     */
   
public static function shareLinks()
    {
        if ( !isset( \
IPS\Data\Store::i()->shareLinks ) )
        {
            \
IPS\Data\Store::i()->shareLinks = iterator_to_array( \IPS\Db::i()->select( '*', static::$databaseTable, NULL, static::$databasePrefix . static::$databaseColumnOrder ) );
        }
       
       
$return = array();
        foreach ( \
IPS\Data\Store::i()->shareLinks as $service )
        {
           
$return[] = static::constructFromData( $service );
        }
       
        return
$return;
    }
   
   
/**
     * Fetch All Share Services
     *
     * @param    \IPS\Http\Url        $url    URL to the content [optional - if omitted, some services will figure out on their own]
     * @param    string                $title    Default text for the content, usually the title [optional - if omitted, some services will figure out on their own]
     * @param    \IPS\Member|NULL    $member    Member the links will display to or NULL for currently logged in member
     * @return    array
     */
   
public static function getAllServices( \IPS\Http\Url $url, $title, \IPS\Member $member = NULL, \IPS\Content $item = NULL )
    {
       
$member = $member ?: \IPS\Member::loggedIn();
       
$services = array();
        foreach( static::
shareLinks() as $node )
        {
            if(
$node->enabled and ( $node->groups === "*" or $member->inGroup( explode( ',', $node->groups ) ) ) )
            {
                try
                {
                   
$services[ $node->key ]    = $node->getService( $url, $title, $item );
                }
                catch ( \
LogicException $e ) { }
            }
        }
        return
$services;
    }
   
   
/**
     * Get \IPS\Content\ShareServices class
     *
     * @param    \IPS\Http\Url    $url    URL to the content [optional - if omitted, some services will figure out on their own]
     * @param    string            $title    Default text for the content, usually the title [optional - if omitted, some services will figure out on their own]
     * @return    array
     */
   
public function getService( \IPS\Http\Url $url, $title, $item )
    {
        if(
file_exists( \IPS\ROOT_PATH . '/system/Content/ShareServices/' . ucwords( $this->key ) . '.php' ) )
        {
           
$className    = "IPS\\Content\\ShareServices\\" . ucwords( $this->key );
            return new
$className( $url, $title, $item );
        }
        throw new \
LogicException;
    }

   
/**
     * [Node] Get buttons to display in tree
     * Example code explains return value
     *
     * @code
         array(
             array(
                 'icon'    =>    'plus-circle', // Name of FontAwesome icon to use
                 'title'    => 'foo',        // Language key to use for button's title parameter
                 'link'    => \IPS\Http\Url::internal( 'app=foo...' )    // URI to link to
                 'class'    => 'modalLink'    // CSS Class to use on link (Optional)
             ),
             ...                            // Additional buttons
         );
     * @endcode
     * @param    string    $url        Base URL
     * @param    bool    $subnode    Is this a subnode?
     * @return    array
     */
   
public function getButtons( $url, $subnode=FALSE )
    {        
       
$buttons = array();
       
        if (
$subnode )
        {
           
$url = $url->setQueryString( array( 'subnode' => 1 ) );
        }

        if(
$this->canEdit() )
        {
           
$buttons['edit'] = array(
               
'icon'    => 'pencil',
               
'title'    => 'edit',
               
'link'    => $url->setQueryString( array( 'do' => 'form', 'id' => $this->_id ) ),
               
'data'    => ( static::$modalForms ? array( 'ipsDialog' => '', 'ipsDialog-title' => \IPS\Member::loggedIn()->language()->addToStack('edit') ) : array() ),
               
'hotkey'=> 'e return'
               
);
        }

        return
$buttons;
    }

   
/**
     * [Node] Add/Edit Form
     *
     * @param    \IPS\Helpers\Form    $form    The form
     * @return    void
     */
   
public function form( &$form )
    {
       
$form->add( new \IPS\Helpers\Form\Text( 'share_title', $this->title, TRUE ) );
       
$form->add( new \IPS\Helpers\Form\Select( 'share_groups', ( $this->groups != '*' ) ? explode( ",", $this->groups ) : $this->groups, FALSE, array( 'options' => \IPS\Member\Group::groups(), 'parse' => 'normal', 'multiple' => TRUE, 'unlimited' => '*', 'unlimitedLang' => 'everyone' ) ) );

       
/* Find the service and see if it has any additional settings... */
       
$className    = "\\IPS\\Content\\ShareServices\\" . ucwords( $this->key );

       
$className::modifyForm( $form, $this );
    }
   
   
/**
     * [Node] Format form values from add/edit form for save
     *
     * @param    array    $values    Values from the form
     * @return    array
     */
   
public function formatFormValues( $values )
    {
        if(
count( $values ) )
        {
            if ( isset(
$values[ 'share_autoshare_' . ucwords( $this->key ) ] ) )
            {
               
$values['share_autoshare'] = $values[ 'share_autoshare_' . ucwords( $this->key ) ];
                unset(
$values[ 'share_autoshare_' . ucwords( $this->key ) ] );
                               
               
$loginHandlers = \IPS\Login::handlers(TRUE);
                if ( isset(
$loginHandlers[ ucwords( $this->key ) ] ) )
                {
                   
$settings = $loginHandlers[ ucwords( $this->key ) ]->settings;
                   
$settings['autoshare'] = $values['share_autoshare'];
                   
$loginHandlers[ ucwords( $this->key ) ]->settings = json_encode( $settings );
                   
$loginHandlers[ ucwords( $this->key ) ]->save();
                }
            }
           
           
$settingsToUpdate = array();
            foreach (
$values as $k => $v )
            {
                if( !
in_array( $k, array( 'share_title', 'share_groups', 'share_autoshare' ) ) )
                {
                    if (
$v instanceof \IPS\GeoLocation )
                    {
                       
$v = json_encode( $v );
                    }
                    if (
is_array( $v ) )
                    {
                       
$v = implode( ',', $v );
                    }
                   
                   
$settingsToUpdate[ $k ] = $v;
                    unset(
$values[ $k ] );
                }
            }

            \
IPS\Settings::i()->changeValues( $settingsToUpdate );

           
/* Remove prefix */
           
$_values = $values;
           
$values = array();
            foreach (
$_values as $k => $v )
            {
                if(
mb_substr( $k, 0, 6 ) === 'share_' )
                {
                   
$values[ mb_substr( $k, 6 ) ] = $v;
                }
                else
                {
                   
$values[ $k ]    = $v;
                }
            }
        }

        return
$values;
    }
   
   
/**
     * [Node] Get Node Title
     *
     * @return    string
     */
   
protected function get__title()
    {
        if ( !
$this->id )
        {
            return
'';
        }
       
        return
$this->title;
    }
   
   
/**
     * [Node] Get whether or not this node is enabled
     *
     * @note    Return value NULL indicates the node cannot be enabled/disabled
     * @return    bool|null
     */
   
protected function get__enabled()
    {
        return (
$this->enabled ) ? TRUE : FALSE;
    }

   
/**
     * [Node] Set whether or not this node is enabled
     *
     * @param    bool|int    $enabled    Whether to set it enabled or disabled
     * @return    void
     */
   
protected function set__enabled( $enabled )
    {
       
$this->enabled    = $enabled;
    }

   
/**
     * [Node] Does the currently logged in user have permission to add a child node to this node?
     *
     * @return    bool
     */
   
public function canAdd()
    {
        return
FALSE;
    }

   
/**
     * [Node] Does the currently logged in user have permission to copy this node?
     *
     * @return    bool
     */
   
public function canCopy()
    {
        return
FALSE;
    }

   
/**
     * [Node] Does the currently logged in user have permission to edit permissions for this node?
     *
     * @return    bool
     */
   
public function canManagePermissions()
    {
        return
FALSE;
    }

   
/**
     * [Node] Does the currently logged in user have permission to delete this node?
     *
     * @return    bool
     */
   
public function canDelete()
    {
        return
FALSE;
    }

   
/**
     * Search
     *
     * @param    string        $column    Column to search
     * @param    string        $query    Search query
     * @param    string|null    $order    Column to order by
     * @param    mixed        $where    Where clause
     * @return    array
     */
   
public static function search( $column, $query, $order=NULL, $where=array() )
    {    
        if (
$column === '_title' )
        {
           
$column = 'share_title';
        }
        if (
$order === '_title' )
        {
           
$order = 'share_title';
        }
        return
parent::search( $column, $query, $order, $where );
    }
   
   
/**
     * Save Changed Columns
     *
     * @return    void
     */
   
public function save()
    {
       
parent::save();
        unset( \
IPS\Data\Store::i()->shareLinks );
    }
   
   
/**
     * [ActiveRecord] Delete Record
     *
     * @return    void
     */
   
public function delete()
    {
       
parent::delete();
        unset( \
IPS\Data\Store::i()->shareLinks );
    }
}