vulnpkg - localbin - leot's localbin (~/bin)
(HTM) hg clone https://bitbucket.org/iamleot/localbin
(DIR) Log
(DIR) Files
(DIR) Refs
---
vulnpkg
---
1 #!/bin/sh
2
3 #
4 # Copyright (c) 2018 Leonardo Taccari
5 # All rights reserved.
6 #
7 # Redistribution and use in source and binary forms, with or without
8 # modification, are permitted provided that the following conditions
9 # are met:
10 #
11 # 1. Redistributions of source code must retain the above copyright
12 # notice, this list of conditions and the following disclaimer.
13 # 2. Redistributions in binary form must reproduce the above copyright
14 # notice, this list of conditions and the following disclaimer in the
15 # documentation and/or other materials provided with the distribution.
16 #
17 # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
18 # "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
19 # TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
20 # PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS
21 # BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
22 # CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
23 # SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
24 # INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
25 # CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
26 # ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
27 # POSSIBILITY OF SUCH DAMAGE.
28 #
29
30
31 #
32 # Print usage information and exit.
33 #
34 usage()
35 {
36
37 echo "usage: $0 pkgname ..."
38
39 exit 1
40 }
41
42
43 #
44 # Given a PKGNAME print all relevant pkg-vulnerabilities entries for it.
45 #
46 auditpkg()
47 {
48 pkgname="$1"
49 pkgbase="${pkgname%-*}"
50
51 pkg_admin audit-history "$pkgbase" | while read entry; do
52 pkg=${entry%% *}
53 pkg_admin pmatch "$pkg" "$pkgname" && echo $entry
54 done
55 }
56
57
58 #
59 # Given a list of PKGNAMEs print for each of them the vulnerabilities entries.
60 #
61 main()
62 {
63
64 if [ $# -eq 0 ]; then
65 usage
66 fi
67
68 for p in "$@"; do
69 auditpkg "$p"
70 done
71
72 exit 0
73 }
74
75
76 main "$@"