Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
P
pve-manager
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Administrator
pve-manager
Commits
8c1d3a4e
Commit
8c1d3a4e
authored
Jun 21, 2013
by
Dietmar Maurer
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
add/use API for pveversion
We want to be able to diplay that information on the GUI.
parent
abc4a675
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
106 additions
and
61 deletions
+106
-61
APT.pm
PVE/API2/APT.pm
+82
-1
pveversion
bin/pveversion
+24
-60
No files found.
PVE/API2/APT.pm
View file @
8c1d3a4e
...
@@ -2,12 +2,15 @@ package PVE::API2::APT;
...
@@ -2,12 +2,15 @@ package PVE::API2::APT;
use
strict
;
use
strict
;
use
warnings
;
use
warnings
;
use
POSIX
;
use
File::
stat
();
use
File::
stat
();
use
IO::
File
;
use
IO::
File
;
use
File::
Basename
;
use
File::
Basename
;
use
LWP::
UserAgent
;
use
LWP::
UserAgent
;
use
PVE::
pvecfg
;
use
PVE::
Tools
qw(extract_param)
;
use
PVE::
Tools
qw(extract_param)
;
use
PVE::
Cluster
;
use
PVE::
Cluster
;
use
PVE::
SafeSyslog
;
use
PVE::
SafeSyslog
;
...
@@ -60,8 +63,9 @@ __PACKAGE__->register_method({
...
@@ -60,8 +63,9 @@ __PACKAGE__->register_method({
my
(
$param
)
=
@_
;
my
(
$param
)
=
@_
;
my
$res
=
[
my
$res
=
[
{
id
=>
'
update
'
},
{
id
=>
'
changelog
'
},
{
id
=>
'
changelog
'
},
{
id
=>
'
update
'
},
{
id
=>
'
versions
'
},
];
];
return
$res
;
return
$res
;
...
@@ -378,4 +382,81 @@ __PACKAGE__->register_method({
...
@@ -378,4 +382,81 @@ __PACKAGE__->register_method({
return
$data
;
return
$data
;
}});
}});
__PACKAGE__
->
register_method
({
name
=>
'
versions
',
path
=>
'
versions
',
method
=>
'
GET
',
description
=>
"
Get package information for important Proxmox packages.
",
permissions
=>
{
check
=>
['
perm
',
'
/nodes/{node}
',
[
'
Sys.Audit
'
]],
},
parameters
=>
{
additionalProperties
=>
0
,
properties
=>
{
node
=>
get_standard_option
('
pve-node
'),
},
},
returns
=>
{
type
=>
"
array
",
items
=>
{
type
=>
"
object
",
properties
=>
{},
},
},
code
=>
sub
{
my
(
$param
)
=
@_
;
my
$pkgname
=
$param
->
{
name
};
my
$cache
=
&
$get_apt_cache
();
my
$policy
=
$cache
->
policy
;
my
$pkgrecords
=
$cache
->
packages
();
# try to use a resonable ordering (most important things first)
my
@list
=
qw(proxmox-ve-2.6.32 pve-manager)
;
foreach
my
$pkgname
(
keys
%
$cache
)
{
if
(
$pkgname
=~
m/pve-kernel-/
)
{
my
$p
=
$cache
->
{
$pkgname
};
push
@list
,
$pkgname
if
$p
&&
$p
->
{
CurrentState
}
eq
'
Installed
';
}
}
push
@list
,
qw(lvm2 clvm corosync-pve openais-pve libqb0 redhat-cluster-pve resource-agents-pve fence-agents-pve pve-cluster qemu-server pve-firmware libpve-common-perl libpve-access-control libpve-storage-perl vncterm vzctl vzprocps vzquota pve-qemu-kvm ksm-control-daemon)
;
my
$pkglist
=
[]
;
my
(
undef
,
undef
,
$kernel_release
)
=
POSIX::
uname
();
my
$pvever
=
PVE::pvecfg::
version_text
();
foreach
my
$pkgname
(
@list
)
{
my
$p
=
$cache
->
{
$pkgname
};
my
$info
=
$pkgrecords
->
lookup
(
$pkgname
);
my
$candidate_ver
=
$policy
->
candidate
(
$p
);
my
$res
;
if
(
my
$current_ver
=
$p
->
{
CurrentVer
})
{
$res
=
&
$assemble_pkginfo
(
$pkgname
,
$info
,
$current_ver
,
$candidate_ver
||
$current_ver
);
}
elsif
(
$candidate_ver
)
{
$res
=
&
$assemble_pkginfo
(
$pkgname
,
$info
,
$candidate_ver
,
$candidate_ver
);
delete
$res
->
{
OldVersion
};
}
else
{
next
;
}
$res
->
{
CurrentState
}
=
$p
->
{
CurrentState
};
# hack: add some useful information (used by 'pveversion -v')
if
(
$pkgname
eq
'
pve-manager
')
{
$res
->
{
ManagerVersion
}
=
$pvever
;
}
elsif
(
$pkgname
eq
'
proxmox-ve-2.6.32
')
{
$res
->
{
RunningKernel
}
=
$kernel_release
;
}
push
@$pkglist
,
$res
;
}
return
$pkglist
;
}});
1
;
1
;
bin/pveversion
View file @
8c1d3a4e
#!/usr/bin/perl -w
#!/usr/bin/perl -w
use
strict
;
use
strict
;
use
POSIX
;
use
Getopt::
Long
;
use
Getopt::
Long
;
use
PVE::
pvecfg
;
use
PVE::
API2::
APT
;
sub
read_pkglist
{
my
$pkgarray
=
PVE::API2::
APT
->
versions
({
node
=>
'
localhost
'});
my
$pkglist
=
{};
my
$pkglist
=
{};
foreach
my
$pkg
(
@$pkgarray
)
{
$pkglist
->
{
$pkg
->
{
Package
}}
=
$pkg
;
open
(
TMP
,
"
dpkg-query --show -f '
\
${PACKAGE}
\
${VERSION}
\
${STATUS}
\n
'|
")
||
die
"
cant exec dpkg-query
\n
";
while
(
defined
(
my
$line
=
<
TMP
>
))
{
if
(
$line
=~
m/^(\S+)\s+(\S+)\s+install\s+ok\s+installed$/
)
{
my
(
$pkg
,
$version
)
=
(
$1
,
$2
);
$pkglist
->
{
$pkg
}
=
$version
;
}
}
return
$pkglist
;
}
}
my
$pkglist
=
read_pkglist
();
sub
print_status
{
sub
print_status
{
my
(
$pkg
,
$repoid
)
=
@_
;
my
(
$pkg
)
=
@_
;
my
$pkginfo
=
$pkglist
->
{
$pkg
};
if
(
!
$pkginfo
)
{
print
"
$pkg
: unknown package - internal error
\n
";
return
;
}
my
$version
=
"
not correctly installed
";
my
$version
=
"
not correctly installed
";
if
(
$pkg
list
->
{
$pkg
}
)
{
if
(
$pkg
info
->
{
OldVersion
}
&&
$pkginfo
->
{
CurrentState
}
eq
'
Installed
'
)
{
$version
=
$pkg
list
->
{
$pkg
};
$version
=
$pkg
info
->
{
OldVersion
};
}
}
if
(
$repoid
)
{
if
(
$pkginfo
->
{
RunningKernel
})
{
print
"
$pkg
:
$version
(
$repoid
)
\n
";
print
"
$pkg
:
$version
(running kernel:
$pkginfo
->{RunningKernel})
\n
";
}
elsif
(
$pkginfo
->
{
ManagerVersion
})
{
print
"
$pkg
:
$version
(running version:
$pkginfo
->{ManagerVersion})
\n
";
}
else
{
}
else
{
print
"
$pkg
:
$version
\n
";
print
"
$pkg
:
$version
\n
";
}
}
...
@@ -58,49 +54,17 @@ if (scalar (@ARGV) != 0) {
...
@@ -58,49 +54,17 @@ if (scalar (@ARGV) != 0) {
exit
(
-
1
);
exit
(
-
1
);
}
}
my
$ver
=
PVE::pvecfg::
package
();
my
$ver
=
PVE::pvecfg::
package
()
.
'
/
'
.
PVE::pvecfg::
version_text
();
$ver
.=
'
/
';
my
(
undef
,
undef
,
$kver
)
=
POSIX::
uname
();
$ver
.=
PVE::pvecfg::
version
();
$ver
.=
'
/
';
$ver
.=
PVE::pvecfg::
repoid
();
my
$kver
=
`
uname -r
`;
chomp
$kver
;
if
(
!
$opt_verbose
)
{
if
(
!
$opt_verbose
)
{
print
"
$ver
\n
";
print
"
$ver
(running kernel:
$kver
)
\n
";
exit
(
0
);
exit
(
0
);
}
}
print_status
("
pve-manager
",
$ver
);
foreach
my
$pkg
(
@$pkgarray
)
{
print
"
running kernel:
$kver
\n
";
print_status
(
$pkg
->
{
Package
});
my
@list
=
qw(lvm2 clvm corosync-pve openais-pve libqb0 redhat-cluster-pve resource-agents-pve fence-agents-pve pve-cluster qemu-server pve-firmware libpve-common-perl libpve-access-control libpve-storage-perl vncterm vzctl vzprocps vzquota)
;
my
$pkg
=
'
proxmox-ve-2.6.18
';
if
(
my
$v
=
$pkglist
->
{
$pkg
})
{
print
"
$pkg
:
$v
\n
";
push
@list
,
'
pve-qemu-kvm-2.6.18
';
}
$pkg
=
'
proxmox-ve-2.6.24
';
if
(
my
$v
=
$pkglist
->
{
$pkg
})
{
print
"
$pkg
:
$v
\n
";
push
@list
,
'
pve-qemu-kvm
';
}
$pkg
=
'
proxmox-ve-2.6.32
';
if
(
my
$v
=
$pkglist
->
{
$pkg
})
{
print
"
$pkg
:
$v
\n
";
push
@list
,
'
pve-qemu-kvm
';
push
@list
,
'
ksm-control-daemon
';
}
foreach
$pkg
(
grep
{
m/^pve-kernel-/
}
keys
%
$pkglist
)
{
print
"
$pkg
:
$pkglist
->{
$pkg
}
\n
";
}
foreach
my
$p
(
@list
)
{
print_status
(
$p
);
}
}
exit
0
;
exit
0
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment