summaryrefslogtreecommitdiffstats
path: root/import-layers/meta-openembedded/meta-networking/recipes-connectivity/ufw/ufw/0002-lp1044361.patch
blob: 804c18bc9eed44b93226673e464440253c77b5fd (plain)
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
Origin: r795, r796
Description: move netfilter capabilities checking into initcaps(), and call
 initcaps() only when we need it.
Bug-Ubuntu: https://launchpad.net/bugs/1044361

Upstream-Status: Inappropriate [ not author ]

Signed-off-by: Joe MacDonald <joe_macdonald@mentor.com>

Index: ufw-0.33/src/backend_iptables.py
===================================================================
--- ufw-0.33.orig/src/backend_iptables.py	2012-09-23 09:58:34.000000000 -0500
+++ ufw-0.33/src/backend_iptables.py	2012-09-23 09:58:36.000000000 -0500
@@ -160,6 +160,9 @@
             out += "> " + _("Checking raw ip6tables\n")
             return out
 
+        # Initialize the capabilities database
+        self.initcaps()
+
         args = ['-n', '-v', '-x', '-L']
         items = []
         items6 = []
@@ -470,6 +473,9 @@
         if self.dryrun:
             return False
 
+        # Initialize the capabilities database
+        self.initcaps()
+
         prefix = "ufw"
         exe = self.iptables
         if v6:
@@ -684,6 +690,9 @@
         except Exception:
             raise
 
+        # Initialize the capabilities database
+        self.initcaps()
+
         chain_prefix = "ufw"
         rules = self.rules
         if v6:
@@ -830,6 +839,10 @@
         * updating user rules file
         * reloading the user rules file if rule is modified
         '''
+
+        # Initialize the capabilities database
+        self.initcaps()
+
         rstr = ""
 
         if rule.v6:
@@ -1073,6 +1086,9 @@
         if self.dryrun:
             return
 
+        # Initialize the capabilities database
+        self.initcaps()
+
         rules_t = []
         try:
             rules_t = self._get_logging_rules(level)
Index: ufw-0.33/src/backend.py
===================================================================
--- ufw-0.33.orig/src/backend.py	2012-09-23 09:58:34.000000000 -0500
+++ ufw-0.33/src/backend.py	2012-09-23 09:59:03.000000000 -0500
@@ -21,7 +21,7 @@
 import stat
 import sys
 import ufw.util
-from ufw.util import warn, debug
+from ufw.util import error, warn, debug
 from ufw.common import UFWError, config_dir, iptables_dir, UFWRule
 import ufw.applications
 
@@ -68,6 +68,17 @@
             err_msg = _("Couldn't determine iptables version")
             raise UFWError(err_msg)
 
+        # Initialize via initcaps only when we need it (LP: #1044361)
+        self.caps = None
+
+    def initcaps(self):
+        '''Initialize the capabilities database. This needs to be called
+           before accessing the database.'''
+
+        # Only initialize if not initialized already
+        if self.caps != None:
+            return
+
         self.caps = {}
         self.caps['limit'] = {}
 
@@ -78,14 +89,20 @@
         # Try to get capabilities from the running system if root
         if self.do_checks and os.getuid() == 0 and not self.dryrun:
             # v4
-            nf_caps = ufw.util.get_netfilter_capabilities(self.iptables)
+            try:
+                nf_caps = ufw.util.get_netfilter_capabilities(self.iptables)
+            except OSError as e:
+                error("initcaps\n%s" % e)
             if 'recent-set' in nf_caps and 'recent-update' in nf_caps:
                 self.caps['limit']['4'] = True
             else:
                 self.caps['limit']['4'] = False
 
             # v6
-            nf_caps = ufw.util.get_netfilter_capabilities(self.ip6tables)
+            try:
+                nf_caps = ufw.util.get_netfilter_capabilities(self.ip6tables)
+            except OSError as e:
+                error("initcaps\n%s" % e)
             if 'recent-set' in nf_caps and 'recent-update' in nf_caps:
                 self.caps['limit']['6'] = True
             else:
OpenPOWER on IntegriCloud