26 define(
"TITLE_UI_DEMOMOD", _(
"Demomod View"));
62 $MenuName =
"Demomod View";
68 $text = _(
"Demomod data");
88 if ($this->
State != PLUGIN_STATE_INVALID) {
return(1);
91 return($this->
State == PLUGIN_STATE_VALID);
106 $sql =
"select ars_pk from demomod_ars where upload_fk=$upload_pk and ars_success=true";
107 $result = pg_query($PG_CONN, $sql);
109 $rows = pg_num_rows($result);
110 pg_free_result($result);
112 if ($rows == 0) {
return _(
"There is no demomod data for this upload. Use Jobs > Schedule Agent.");
117 $sql =
"select pfile_fk from $this->uploadtree_tablename where uploadtree_pk=$uploadtree_pk and upload_fk=$upload_pk";
118 $result = pg_query($PG_CONN, $sql);
120 $rows = pg_num_rows($result);
121 if ($rows == 0) {
return _(
"Internal consistency error. Failed: $sql");
123 $row = pg_fetch_assoc($result);
124 $pfile_fk = $row[
'pfile_fk'];
125 pg_free_result($result);
128 $sql =
"select firstbytes from demomod where pfile_fk=$pfile_fk";
129 $result = pg_query($PG_CONN, $sql);
131 $rows = pg_num_rows($result);
132 if ($rows == 0) {
return _(
"Internal consistency error. Failed: $sql");
134 $row = pg_fetch_assoc($result);
135 $firstbytes = $row[
'firstbytes'];
136 pg_free_result($result);
138 $text = _(
"The first bytes of this file are: ");
139 return ($text . $firstbytes);
148 $uTime = microtime(
true);
149 if ($this->
State != PLUGIN_STATE_READY) {
156 $uploadDao = $GLOBALS[
'container']->get(
'dao.upload');
157 if (!$uploadDao->isAccessible($Upload,
Fossology\Lib\Auth\Auth::getGroupId()))
159 $text = _(
"Permission Denied");
160 return "<h2>$text</h2>";
173 $_SERVER[
'REQUEST_URI'] = preg_replace(
"/&updcache=[0-9]*/",
"",$_SERVER[
'REQUEST_URI']);
174 unset($_GET[
'updcache']);
186 switch($this->OutputType)
191 $V .=
"<font class='text'>\n";
200 $Uri = preg_replace(
"/&item=([0-9]*)/",
"",
Traceback());
202 $V .= $this->
ShowData($Upload, $Item);
218 if (!$this->OutputToStdout) {
222 $Time = microtime(
true) - $uTime;
223 $text = _(
"Elapsed time: %.2f seconds");
224 printf(
"<small>$text</small>", $Time);
229 $text1 = _(
"Update");
230 echo
" <i>$text</i> <a href=\"$_SERVER[REQUEST_URI]&updcache=1\"> $text1 </a>";
244 $NewPlugin->Initialize();
FUNCTION char * GetUploadtreeTableName(PGconn *pgConn, int upload_pk)
Get the uploadtree table name for this upload_pk If upload_pk does not exist, return "uploadtree"...
Dir2Browse($Mod, $UploadtreePk, $LinkLast=NULL, $ShowBox=1, $ShowMicro=NULL, $Enumerate=-1, $PreText='', $PostText='', $uploadtree_tablename="uploadtree")
Get an html linked string of a file browse path.
$DBaccess
DB access required.
ReportCachePut($CacheKey, $CacheValue)
This function is used to write a record to the report cache. If the record already exists...
$uploadtree_tablename
Upload tree table to use.
ShowData($upload_pk, $uploadtree_pk)
Display the demomod data.
browse an upload and display the demomod data (first bytes of the file)
#define PLUGIN_DB_READ
Plugin requires read permission on DB.
ReportCachePurgeByKey($CacheKey)
Purge from the report cache the record with $CacheKey.
RegisterMenus()
Customize submenus.
GetParm($parameterName, $parameterType)
This function will retrieve the variables and check data types.
$Dependency
Dependecy for plugin.
Namespace used by reuser agent.
char * uploadtree_tablename
upload.uploadtree_tablename
ReportCacheGet($CacheKey)
This function is used by Output() to see if the requested report is in the report cache...
This is the Plugin class. All plugins should:
foreach($Options as $Option=> $OptVal) if(0==$reference_flag &&0==$nomos_flag) $PG_CONN
DBCheckResult($result, $sql, $filenm, $lineno)
Check the postgres result for unexpected errors. If found, treat them as fatal.
Install()
Only used during installation.
Output()
This function returns the scheduler status.
Traceback_parm_keep($List)
Create a new URI, keeping only these items.
Traceback()
Get the URI + query to this location.
Initialize()
This is called before the plugin is used.