Пример #1
0
    def test_add_server_directives(self):
        nparser = parser.NginxParser(self.config_path, self.ssl_options)
        nparser.add_server_directives(
            nparser.abs_path('nginx.conf'),
            set(['localhost', r'~^(www\.)?(example|bar)\.']),
            [['foo', 'bar'], ['ssl_certificate', '/etc/ssl/cert.pem']],
            replace=False)
        ssl_re = re.compile(r'\n\s+ssl_certificate /etc/ssl/cert.pem')
        dump = nginxparser.dumps(
            nparser.parsed[nparser.abs_path('nginx.conf')])
        self.assertEqual(1, len(re.findall(ssl_re, dump)))

        server_conf = nparser.abs_path('server.conf')
        names = set(['alias', 'another.alias', 'somename'])
        nparser.add_server_directives(
            server_conf,
            names, [['foo', 'bar'], ['ssl_certificate', '/etc/ssl/cert2.pem']],
            replace=False)
        nparser.add_server_directives(server_conf,
                                      names, [['foo', 'bar']],
                                      replace=False)
        self.assertEqual(
            nparser.parsed[server_conf],
            [['server_name', 'somename  alias  another.alias'], ['foo', 'bar'],
             ['ssl_certificate', '/etc/ssl/cert2.pem']])
Пример #2
0
 def test_add_http_directives(self):
     nparser = parser.NginxParser(self.config_path, self.ssl_options)
     filep = nparser.abs_path('nginx.conf')
     block = [['server'], [['listen', '80'], ['server_name', 'localhost']]]
     nparser.add_http_directives(filep, block)
     self.assertEqual(nparser.parsed[filep][-1][0], ['http'])
     self.assertEqual(nparser.parsed[filep][-1][1][-1], block)
Пример #3
0
 def test_get_all_certs_keys(self):
     nparser = parser.NginxParser(self.config_path, self.ssl_options)
     filep = nparser.abs_path('sites-enabled/example.com')
     nparser.add_server_directives(
         filep, set(['.example.com', 'example.*']),
         [['ssl_certificate', 'foo.pem'],
          ['ssl_certificate_key', 'bar.key'], ['listen', '443 ssl']])
     c_k = nparser.get_all_certs_keys()
     self.assertEqual(set([('foo.pem', 'bar.key', filep)]), c_k)
Пример #4
0
    def prepare(self):
        """Prepare the authenticator/installer."""
        self.parser = parser.NginxParser(self.conf('server-root'),
                                         self.mod_ssl_conf)

        # Set Version
        if self.version is None:
            self.version = self.get_version()

        temp_install(self.mod_ssl_conf)
Пример #5
0
    def prepare(self):
        """Prepare the authenticator/installer."""
        # Verify Nginx is installed
        if not le_util.exe_exists(self.conf('ctl')):
            raise errors.NoInstallationError

        self.parser = parser.NginxParser(self.conf('server-root'),
                                         self.mod_ssl_conf)

        # Set Version
        if self.version is None:
            self.version = self.get_version()

        temp_install(self.mod_ssl_conf)
Пример #6
0
 def test_filedump(self):
     nparser = parser.NginxParser(self.config_path, self.ssl_options)
     nparser.filedump('test')
     # pylint: disable=protected-access
     parsed = nparser._parse_files(
         nparser.abs_path('sites-enabled/example.com.test'))
     self.assertEqual(3, len(glob.glob(nparser.abs_path('*.test'))))
     self.assertEqual(
         2, len(glob.glob(nparser.abs_path('sites-enabled/*.test'))))
     self.assertEqual(
         [[['server'],
           [['listen', '69.50.225.155:9000'], ['listen', '127.0.0.1'],
            ['server_name', '.example.com'], ['server_name', 'example.*']]]
          ], parsed[0])
Пример #7
0
    def test_add_http_directives(self):
        nparser = parser.NginxParser(self.config_path, self.ssl_options)
        filep = nparser.abs_path('nginx.conf')
        block = [['server'], [['listen', '80'], ['server_name', 'localhost']]]
        nparser.add_http_directives(filep, block)
        root = nparser.parsed[filep]
        self.assertTrue(util.contains_at_depth(root, ['http'], 1))
        self.assertTrue(util.contains_at_depth(root, block, 2))

        # Check that our server block got inserted first among all server
        # blocks.
        http_block = [x for x in root if x[0] == ['http']][0][1]
        server_blocks = [x for x in http_block if x[0] == ['server']]
        self.assertEqual(server_blocks[0], block)
Пример #8
0
 def test_replace_server_directives(self):
     nparser = parser.NginxParser(self.config_path, self.ssl_options)
     target = set(['.example.com', 'example.*'])
     filep = nparser.abs_path('sites-enabled/example.com')
     nparser.add_server_directives(filep, target,
                                   [['server_name', 'foo bar']], True)
     self.assertEqual(
         nparser.parsed[filep],
         [[['server'],
           [['listen', '69.50.225.155:9000'], ['listen', '127.0.0.1'],
            ['server_name', 'foo bar'], ['server_name', 'foo bar']]]])
     self.assertRaises(errors.MisconfigurationError,
                       nparser.add_server_directives, filep,
                       set(['foo', 'bar']),
                       [['ssl_certificate', 'cert.pem']], True)
Пример #9
0
    def test_load(self):
        """Test recursive conf file parsing.

        """
        nparser = parser.NginxParser(self.config_path, self.ssl_options)
        nparser.load()
        self.assertEqual(set([nparser.abs_path(x) for x in
                              ['foo.conf', 'nginx.conf', 'server.conf',
                               'sites-enabled/default',
                               'sites-enabled/example.com']]),
                         set(nparser.parsed.keys()))
        self.assertEqual([['server_name', 'somename  alias  another.alias']],
                         nparser.parsed[nparser.abs_path('server.conf')])
        self.assertEqual([[['server'], [['listen', '69.50.225.155:9000'],
                                        ['listen', '127.0.0.1'],
                                        ['server_name', '.example.com'],
                                        ['server_name', 'example.*']]]],
                         nparser.parsed[nparser.abs_path(
                             'sites-enabled/example.com')])
Пример #10
0
    def test_get_vhosts(self):
        nparser = parser.NginxParser(self.config_path, self.ssl_options)
        vhosts = nparser.get_vhosts()

        vhost1 = obj.VirtualHost(nparser.abs_path('nginx.conf'),
                                 [obj.Addr('', '8080', False, False)],
                                 False, True,
                                 set(['localhost',
                                      r'~^(www\.)?(example|bar)\.']),
                                 [])
        vhost2 = obj.VirtualHost(nparser.abs_path('nginx.conf'),
                                 [obj.Addr('somename', '8080', False, False),
                                  obj.Addr('', '8000', False, False)],
                                 False, True,
                                 set(['somename', 'another.alias', 'alias']),
                                 [])
        vhost3 = obj.VirtualHost(nparser.abs_path('sites-enabled/example.com'),
                                 [obj.Addr('69.50.225.155', '9000',
                                           False, False),
                                  obj.Addr('127.0.0.1', '', False, False)],
                                 False, True,
                                 set(['.example.com', 'example.*']), [])
        vhost4 = obj.VirtualHost(nparser.abs_path('sites-enabled/default'),
                                 [obj.Addr('myhost', '', False, True)],
                                 False, True, set(['www.example.org']), [])
        vhost5 = obj.VirtualHost(nparser.abs_path('foo.conf'),
                                 [obj.Addr('*', '80', True, True)],
                                 True, True, set(['*.www.foo.com',
                                                  '*.www.example.com']), [])

        self.assertEqual(5, len(vhosts))
        example_com = [x for x in vhosts if 'example.com' in x.filep][0]
        self.assertEqual(vhost3, example_com)
        default = [x for x in vhosts if 'default' in x.filep][0]
        self.assertEqual(vhost4, default)
        fooconf = [x for x in vhosts if 'foo.conf' in x.filep][0]
        self.assertEqual(vhost5, fooconf)
        localhost = [x for x in vhosts if 'localhost' in x.names][0]
        self.assertEquals(vhost1, localhost)
        somename = [x for x in vhosts if 'somename' in x.names][0]
        self.assertEquals(vhost2, somename)
Пример #11
0
    def prepare(self):
        """Prepare the authenticator/installer.

        :raises .errors.NoInstallationError: If Nginx ctl cannot be found
        :raises .errors.MisconfigurationError: If Nginx is misconfigured
        """
        # Verify Nginx is installed
        if not le_util.exe_exists(self.conf('ctl')):
            raise errors.NoInstallationError

        # Make sure configuration is valid
        self.config_test()

        self.parser = parser.NginxParser(self.conf('server-root'),
                                         self.mod_ssl_conf)

        # Set Version
        if self.version is None:
            self.version = self.get_version()

        temp_install(self.mod_ssl_conf)
Пример #12
0
 def test_abs_path(self):
     nparser = parser.NginxParser(self.config_path, self.ssl_options)
     self.assertEqual('/etc/nginx/*', nparser.abs_path('/etc/nginx/*'))
     self.assertEqual(os.path.join(self.config_path, 'foo/bar/'),
                      nparser.abs_path('foo/bar/'))
Пример #13
0
 def test_root_no_trailing_slash(self):
     nparser = parser.NginxParser(self.config_path + os.path.sep, None)
     self.assertEqual(nparser.root, self.config_path)
Пример #14
0
 def test_root_absolute(self):
     nparser = parser.NginxParser(os.path.relpath(self.config_path), None)
     self.assertEqual(nparser.root, self.config_path)
Пример #15
0
 def test_root_normalized(self):
     path = os.path.join(self.temp_dir, "etc_nginx/////"
                         "ubuntu_nginx/../../etc_nginx")
     nparser = parser.NginxParser(path, None)
     self.assertEqual(nparser.root, self.config_path)