File: computers-software-add.php

package info (click to toggle)
irm 1.5.3.1-1
  • links: PTS
  • area: main
  • in suites: sarge
  • size: 2,436 kB
  • ctags: 3,308
  • sloc: php: 16,796; sh: 127; perl: 97; pascal: 56; makefile: 48
file content (124 lines) | stat: -rw-r--r-- 4,395 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
<?php
#    IRM - The Information Resource Manager
#    Copyright (C) 1999 Yann Ramin
#
#    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 2 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 (in file COPYING) 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., 675 Mass Ave, Cambridge, MA 02139, USA.
#

require("../include/irm.inc");
require_once 'lib/Config.php';
require_once 'include/i18n.php';

AuthCheck("tech");

$installs = Count_installations($sID);
$licenses = Count_licenses($sID);
$lID = find_license($sID, $reqdliccnt);

$DB = Config::Database();

if($lID > 0 or @$force==1) 
{	# This block is run if we have found a license for our goal or
	# If we did not find a license for our goal and are installing
	# something else or forcing the install. In the later 2 cases
	# $gID is defined (from the form generated below) while in the 
	# first case $gID is not defined and should be our $sID.
	
	if (! $gID) { $gID = $sID; }; 

	if ($gID && $sID && $lID && $cID)
	{
		
		$vals = array(
			'cID' => $cID,
			'sID' => $sID,
			'lID' => $lID,
			'gID' => $gID,
			'lCnt' => $reqdliccnt
			);
		$DB->InsertQuery('inst_software', $vals);
	}
	header("Location: ".appendURLArguments($_SESSION['_sess_prevpage'], array('ID' => $cID)));
} else {
	commonHeader(_("Software") . " - " . _("Searching for Licenses"));
	# We couldn't find any direct licenses for the product so
	# lets check for any software bundles that contain the product.
	$qsID = $DB->getTextValue($sID);
	$query = "SELECT software.name FROM software
					WHERE ID=$qsID";
	$sname = $DB->getOne($query);

	$query = "SELECT software_bundles.bID, software.name 
		  FROM software_bundles 
		  LEFT JOIN software ON software.ID=software_bundles.bID
		  WHERE software_bundles.sID=$qsID 
		  ORDER BY software_bundles.bID";

	$data = $DB->getAll($query);
	$numRows = count($data);

	if (!$numRows)
	{
		printf ('<p>%s<a href="%s">%s</a><p><a href="%s">%s</a>',
			_("No licenses for the software package were found, and no bundles containing the software were found either."),
			Config::AbsLoc('users/software-index.php'),
			_("Please add one or more licenses or bundles using the Software Management System."),
			Config::AbsLoc("users/computers-info.php?ID=$cID"),
			_("Return to the computer info form.")
			);
		commonFooter();
		exit;
	}
	printf (_("I found the following %s Software
		bundles that contain the program you were
		looking for. You can either select the software you were 
		trying to install or you can select a bundle. Please note
		that this will force an installation even if there is no
		available license. This will also use goals to allow going
		back to see what license you wanted as opposed to which one
		you installed."), $numRows);
	$installs = Count_installations($sID);
	$licenses = Count_licenses($sID);
	$available = $licenses - $installs;

	print "\n<form action=computers-software-add.php method=post>
		<TABLE border=1 size=100%>
		<TR BGCOLOR=#BBBBBB><TD>&nbsp</TD><TD>Software</TD>
		<TD><B>Licenses</B> Available Installed/Licenses</TD></TR>
		<TR BGCOLOR=#DDDDDD><TD><input type=radio name=sID value=$sID></TD>
			<TD>$sname</TD>
			<TD>$available ($installs/$licenses)</TD><TR>";
	foreach ($data as $result)
	{
		$name = $result[name];
		$bID = $result[bID];
		print "\n<TR BGCOLOR=#DDDDDD><TD>
			<input type=radio name=sID value=$bID>
			</TD><TD>$name ($bID)</TD>";
				
		$installs = Count_installations($bID);
		$licenses = Count_licenses($bID);
		$available = $licenses - $installs;
		print "<TD>$available ($installs/$licenses)</TD>
			</TR>";
	}

	// Ignore the current page in the "history"
	$_SESSION['_sess_currpage'] = $_SESSION['_sess_prevpage'];
	print "</table><input type=submit  value=\""._("ADD")."\">
		<input type=hidden name=cID value=$cID>
		<input type=hidden name=gID value=$sID>
		<input type=hidden name=force value=1></form>\n\n";
}