<?php

/**
 * Interface for Danga's Gearman job scheduling system
 *
 * PHP version 5.1.0+
 *
 * LICENSE: This source file is subject to the New BSD license that is
 * available through the world-wide-web at the following URI:
 * http://www.opensource.org/licenses/bsd-license.php. If you did not receive
 * a copy of the New BSD License and are unable to obtain it through the web,
 * please send a note to license@php.net so we can mail you a copy immediately.
 *
 * @category  Net
 * @package   ShSo\Net\Gearman
 * @author    Joe Stump <joe@joestump.net>
 * @copyright 2007-2008 Digg.com, Inc.
 * @license   http://www.opensource.org/licenses/bsd-license.php New BSD License
 * @version   CVS: $Id$
 * @link      http://pear.php.net/package/Net_Gearman
 * @link      http://www.danga.com/gearman/
 */

namespace ShSo\Net\Gearman\Job;

use ShSo\Net\Gearman\Connection;

/**
 * Base job class for all Gearman jobs
 *
 * @category  Net
 * @package   ShSo\Net\Gearman
 * @author    Joe Stump <joe@joestump.net>
 * @copyright 2007-2008 Digg.com, Inc.
 * @license   http://www.opensource.org/licenses/bsd-license.php New BSD License
 * @version   Release: @package_version@
 * @link      http://www.danga.com/gearman/
 * @see       ShSo\Net\Gearman\Job\Common, ShSo\Net\Gearman\Worker
 */
abstract class Common
{
    /**
     * Gearman job handle
     *
     * @var string $handle
     */
    protected $handle = '';

    /**
     * Connection to Gearman
     *
     * @var resource $conn
     * @see ShSo\Net\Gearman\Connection
     */
    protected $conn = null;

    /**
     * Parameters for Job instantiation
     * @var array $initParams
     */

    /**
     * Constructor
     *
     * @param resource $conn   Connection to communicate with
     * @param string   $handle Job ID / handle for this job
     * @param array $initParams initialization parameters
     *
     * @return void
     */
    public function __construct($conn, $handle, array $initParams=array())
    {
        $this->conn   = $conn;
        $this->handle = $handle;
        $this->initParams = $initParams;
    }

    /**
     * Run your job here
     *
     * @param array $arg Arguments passed from the client
     *
     * @return void
     * @throws ShSo\Net\Gearman\Exception
     */
    abstract public function run($arg);

    /**
     * Update Gearman with your job's status
     *
     * @param integer $numerator   The numerator (e.g. 1)
     * @param integer $denominator The denominator  (e.g. 100)
     *
     * @return void
     * @see ShSo\Net\Gearman\Connection::send()
     */
    public function status($numerator, $denominator)
    {
        Connection::send($this->conn, 'work_status', array(
            'handle' => $this->handle,
            'numerator' => $numerator,
            'denominator' => $denominator
        ));
    }

    /**
     * Mark your job as complete with its status
     *
     * ShSo\Net\Gearman communicates between the client and jobs in JSON. The main
     * benefit of this is that we can send fairly complex data types between
     * different languages. You should always pass an array as the result to
     * this function.
     *
     * @param array $result Result of your job
     *
     * @return void
     * @see ShSo\Net\Gearman\Connection::send()
     */
    public function complete(array $result)
    {
        Connection::send($this->conn, 'work_complete', array(
            'handle' => $this->handle,
            'result' => json_encode($result)
        ));
    }

    /**
     * Mark your job as failing
     *
     * If your job fails for some reason (e.g. a query fails) you need to run
     * this function and exit from your run() method. This will tell Gearman
     * (and the client by proxy) that the job has failed.
     *
     * @return void
     * @see ShSo\Net\Gearman\Connection::send()
     */
    public function fail()
    {
        Connection::send($this->conn, 'work_fail', array(
            'handle' => $this->handle
        ));
    }
}