Skip to content
Snippets Groups Projects
Select Git revision
  • develop
  • 6.0
  • 5.0
  • 4.0
  • scrutinizer-patch-4
  • 3.9 default
  • scrutinizer-patch-3
  • scrutinizer-patch-2
  • scrutinizer-patch-1
  • 3.7
  • 3.8
  • 3.6
  • 3.9_backported
  • 3.8_backported
  • 3.7_backported
  • 3.5
  • 3.6_backported
  • 3.5_backported
  • 3.4
  • 3.3_backported
  • 6.0.4
  • 6.0.3
  • 5.0.7
  • 6.0.2
  • 6.0.1
  • 5.0.6
  • 6.0.0
  • 5.0.5
  • 6.0.0-rc
  • 5.0.4
  • 6.0.0-beta
  • 5.0.3
  • 4.0.6
  • 5.0.2
  • 5.0.1
  • 4.0.5
  • 5.0.0
  • 4.0.4
  • 5.0.0-rc2
  • 5.0.0-rc1
40 results

myobject.php

Blame
  • myobject.php 4.70 KiB
    #!/usr/bin/env php
    <?php
    /* Copyright (C) 2007-2013 Laurent Destailleur  <eldy@users.sourceforge.net>
     * Copyright (C) ---Put here your own copyright and developer email---
     *
     * This program is free software; you can redistribute it and/or modify
     * it under the terms of the GNU General Public License as published by
     * the Free Software Foundation; either version 3 of the License, or
     * (at your option) any later version.
     *
     * 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.  See the
     * GNU General Public License for more details.
     *
     * You should have received a copy of the GNU General Public License
     * along with this program. If not, see <http://www.gnu.org/licenses/>.
     */
    
    /**
     *      \file       htdocs/modulebuilder/template/scripts/myobject.php
     *		\ingroup    mymodule
     *      \brief      This file is an example for a command line script to work on MyObject
     */
    
    $sapi_type = php_sapi_name();
    $script_file = basename(__FILE__);
    $path=dirname(__FILE__).'/';
    
    // Test if batch mode
    if (substr($sapi_type, 0, 3) == 'cgi') {
        echo "Error: You are using PHP for CGI. To execute ".$script_file." from command line, you must use PHP for CLI mode.\n";
    	exit(-1);
    }
    
    // Global variables
    $version='1.0';
    $error=0;
    
    
    // -------------------- START OF YOUR CODE HERE --------------------
    @set_time_limit(0);							// No timeout for this script
    define('EVEN_IF_ONLY_LOGIN_ALLOWED',1);		// Set this define to 0 if you want to lock your script when dolibarr setup is "locked to admin user only".
    
    // Include and load Dolibarr environment variables
    require_once($path."../../htdocs/master.inc.php");
    // After this $db, $mysoc, $langs, $conf and $hookmanager are defined (Opened $db handler to database will be closed at end of file).
    // $user is created but empty.
    
    //$langs->setDefaultLang('en_US'); 	// To change default language of $langs
    $langs->load("main");				// To load language file for default language
    
    // Load user and its permissions
    $result=$user->fetch('','admin');	// Load user for login 'admin'. Comment line to run as anonymous user.
    if (! $result > 0) { dol_print_error('',$user->error); exit; }
    $user->getrights();
    
    
    print "***** ".$script_file." (".$version.") pid=".dol_getmypid()." *****\n";
    if (! isset($argv[1])) {	// Check parameters
        print "Usage: ".$script_file." param1 param2 ...\n";
    	exit(-1);
    }
    print '--- start'."\n";
    print 'Argument 1='.$argv[1]."\n";
    print 'Argument 2='.$argv[2]."\n";
    
    
    // Start of transaction
    $db->begin();
    
    
    // Examples for manipulating class MyObject
    dol_include_once("/mymodule/class/myobject.class.php");
    $myobject=new MyObject($db);
    
    // Example for inserting creating object in database
    /*
    dol_syslog($script_file." CREATE", LOG_DEBUG);
    $myobject->prop1='value_prop1';
    $myobject->prop2='value_prop2';
    $id=$myobject->create($user);
    if ($id < 0) { $error++; dol_print_error($db,$myobject->error); }
    else print "Object created with id=".$id."\n";
    */
    
    // Example for reading object from database
    /*
    dol_syslog($script_file." FETCH", LOG_DEBUG);
    $result=$myobject->fetch($id);
    if ($result < 0) { $error; dol_print_error($db,$myobject->error); }
    else print "Object with id=".$id." loaded\n";
    */
    
    // Example for updating object in database ($myobject must have been loaded by a fetch before)
    /*
    dol_syslog($script_file." UPDATE", LOG_DEBUG);
    $myobject->prop1='newvalue_prop1';
    $myobject->prop2='newvalue_prop2';
    $result=$myobject->update($user);
    if ($result < 0) { $error++; dol_print_error($db,$myobject->error); }
    else print "Object with id ".$myobject->id." updated\n";
    */
    
    // Example for deleting object in database ($myobject must have been loaded by a fetch before)
    /*
    dol_syslog($script_file." DELETE", LOG_DEBUG);
    $result=$myobject->delete($user);
    if ($result < 0) { $error++; dol_print_error($db,$myobject->error); }
    else print "Object with id ".$myobject->id." deleted\n";
    */
    
    
    // An example of a direct SQL read without using the fetch method
    /*
    $sql = "SELECT field1, field2";
    $sql.= " FROM ".MAIN_DB_PREFIX."myobject";
    $sql.= " WHERE field3 = 'xxx'";
    $sql.= " ORDER BY field1 ASC";
    
    dol_syslog($script_file, LOG_DEBUG);
    $resql=$db->query($sql);
    if ($resql)
    {
    	$num = $db->num_rows($resql);
    	$i = 0;
    	if ($num)
    	{
    		while ($i < $num)
    		{
    			$obj = $db->fetch_object($resql);
    			if ($obj)
    			{
    				// You can use here results
    				print $obj->field1;
    				print $obj->field2;
    			}
    			$i++;
    		}
    	}
    }
    else
    {
    	$error++;
    	dol_print_error($db);
    }
    */
    
    
    // -------------------- END OF YOUR CODE --------------------
    
    if (! $error)
    {
    	$db->commit();
    	print '--- end ok'."\n";
    }
    else
    {
    	print '--- end error code='.$error."\n";
    	$db->rollback();
    }
    
    $db->close();	// Close $db database opened handler
    
    exit($error);