Distributed Multimedia Database System Phase 2

From Giss
Revision as of 20:14, 2 April 2009 by Sevy (talk | contribs)

Context And Goals

Due to the interest of G.I.S.S. users in the mediabase component version 1.0 released previously, as a real alternative to public systems like YouTube or Vimeo, improvements should be made to the actual mediabase version 1.0, to include more features like playlists, favorites, ...

Setting up the next developments

To achieve a number of new features like playlist or annotations, we first had to modify the cortado with additional functionalities :

  • Access to the timestamp of the video played from javascript :
Cortado = document.getElementById("cortado");
timecode = Cortado.getPlayPosition(); 
  • Call to an external javascript function when the end of the video is reached :
<applet code="com.fluendo.player.Cortado.class" archive="cortado-ovt-debug-giss.jar" height="240" width="320" MAYSCRIPT>
<param name="endCallback" value="nextTrack();"> 
  • We also found that to play videos more easily, the cortado applet should be modified to play several video at the same time.

The code has been modified so that Cortado can create more than one pipe-line.

  • Another thing missing in Cortado was the support for 16/9 format,

that was requested by some dmmdb 1.0 users. it has been implemented in dmmbd 2.0.

For using these features, you will need to download the [Giss Cortado], which is based on Cortado 0.2.2.

CVS version of cortado G.I.S.S.

The G.I.S.S. cortado can be obtained through CVS :

export CVSROOT=:pserver:anonymous@giss.tv:/home/cvs
cvs co cortado-giss

Adding of new blocks and funcionalities

  • Added a block of most viewed videos on the channel, updating the counter through ajax when a video is requested
  • Added a voting system and a block of favorite videos

Migration from version 1.0

If you have installed a version 1.0, you will need to do the following to the database, not to recreate it from scratch :

Create data for the view counter :

ALTER TABLE media ADD COLUMN viewed int(10) NOT NULL DEFAULT 0;
INSERT INTO blocks VALUES (NULL,'most_viewed','video',2,8,397,100,1,<user id>,NULL);
for users you have created before

Create data for the favorites :

CREATE TABLE `favorites` (
`ID` int(4) unsigned NOT NULL auto_increment,
`channel` varchar(256) collate utf8_bin NOT NULL,
`base_url` varchar(256) collate utf8_bin NOT NULL,
`media_id` int(4) NOT NULL,
`votes` int(4) NOT NULL DEFAULT 0,
UNIQUE KEY `ID` (`ID`)
) ENGINE=MyISAM AUTO_INCREMENT=0 DEFAULT CHARSET=utf8 COLLATE=utf8_bin;
INSERT INTO blocks VALUES (NULL,'favorites','video',2,9,397,100,1,<user id>,NULL);
for users you have created before

Create data for the playlists :

CREATE TABLE `playlist` (
`ID` int(4) unsigned NOT NULL auto_increment,
`channel` varchar(256) collate utf8_bin NOT NULL,
`name` text collate utf8_bin NOT NULL,
`base_url` varchar(256) collate utf8_bin NOT NULL,
`media_id` int(4) NOT NULL,
UNIQUE KEY `ID` (`ID`)
) ENGINE=MyISAM AUTO_INCREMENT=0 DEFAULT CHARSET=utf8 COLLATE=utf8_bin;
INSERT INTO blocks VALUES (NULL,'playlists','video',2,10,397,100,1,<user id>,NULL);
for users you have created before