mirror of
https://github.com/Yetangitu/ampache
synced 2025-10-05 19:41:55 +02:00

Move parsing from Song into Stream_URL and make it parse more things. Add the type parameter to all generated URLs instead of adding video to Video URLs.
128 lines
3.4 KiB
PHP
128 lines
3.4 KiB
PHP
<?php
|
|
/* vim:set softtabstop=4 shiftwidth=4 expandtab: */
|
|
/**
|
|
*
|
|
* LICENSE: GNU General Public License, version 2 (GPLv2)
|
|
* Copyright 2001 - 2013 Ampache.org
|
|
*
|
|
* This program is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU General Public License v2
|
|
* as published by the Free Software Foundation.
|
|
*
|
|
* 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, write to the Free Software
|
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
*
|
|
*/
|
|
|
|
class Video extends database_object implements media {
|
|
|
|
public $id;
|
|
public $title;
|
|
public $enabled;
|
|
public $file;
|
|
public $size;
|
|
|
|
/**
|
|
* Constructor
|
|
* This pulls the shoutbox information from the database and returns
|
|
* a constructed object, uses user_shout table
|
|
*/
|
|
public function __construct($id) {
|
|
|
|
// Load the data from the database
|
|
$info = $this->get_info($id);
|
|
foreach ($info as $key=>$value) {
|
|
$this->$key = $value;
|
|
}
|
|
|
|
return true;
|
|
|
|
} // Constructor
|
|
|
|
/**
|
|
* build_cache
|
|
* Build a cache based on the array of ids passed, saves lots of little queries
|
|
*/
|
|
public static function build_cache($ids=array()) {
|
|
|
|
if (!is_array($ids) OR !count($ids)) { return false; }
|
|
|
|
$idlist = '(' . implode(',',$ids) . ')';
|
|
|
|
$sql = "SELECT * FROM `video` WHERE `video`.`id` IN $idlist";
|
|
$db_results = Dba::read($sql);
|
|
|
|
while ($row = Dba::fetch_assoc($db_results)) {
|
|
parent::add_to_cache('video',$row['id'],$row);
|
|
}
|
|
|
|
} // build_cache
|
|
|
|
/**
|
|
* format
|
|
* This formats a video object so that it is human readable
|
|
*/
|
|
public function format() {
|
|
|
|
$this->f_title = scrub_out($this->title);
|
|
$this->f_link = scrub_out($this->title);
|
|
$this->f_codec = $this->video_codec . ' / ' . $this->audio_codec;
|
|
$this->f_resolution = $this->resolution_x . 'x' . $this->resolution_y;
|
|
$this->f_tags = '';
|
|
$this->f_length = floor($this->time/60) . ' ' . T_('minutes');
|
|
|
|
} // format
|
|
|
|
public function get_stream_types() {
|
|
|
|
return array('native');
|
|
|
|
} // native_stream
|
|
|
|
/**
|
|
* play_url
|
|
* This returns a "PLAY" url for the video in question here, this currently feels a little
|
|
* like a hack, might need to adjust it in the future
|
|
*/
|
|
public static function play_url($oid,$sid='',$force_http='') {
|
|
|
|
$video = new Video($oid);
|
|
|
|
if (!$video->id) { return false; }
|
|
|
|
$uid = intval($GLOBALS['user']->id);
|
|
$oid = intval($video->id);
|
|
|
|
$url = Stream::get_base_url() . "type=video&uid=$uid&oid=$oid";
|
|
|
|
return $url;
|
|
|
|
} // play_url
|
|
|
|
/**
|
|
* get_transcode_settings
|
|
*
|
|
* FIXME: Video transcoding is not implemented
|
|
*/
|
|
public function get_transcode_settings($target = null) {
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* has_flag
|
|
* returns true if the video has been flagged and we shouldn't try to re-read
|
|
* the meta data
|
|
*/
|
|
public function has_flag() {
|
|
|
|
|
|
|
|
} // has_flag
|
|
|
|
} // end Video class
|