2 # -*- encoding: utf-8; py-indent-offset: 4 -*-
3 # +------------------------------------------------------------------+
4 # | ____ _ _ __ __ _ __ |
5 # | / ___| |__ ___ ___| | __ | \/ | |/ / |
6 # | | | | '_ \ / _ \/ __| |/ / | |\/| | ' / |
7 # | | |___| | | | __/ (__| < | | | | . \ |
8 # | \____|_| |_|\___|\___|_|\_\___|_| |_|_|\_\ |
10 # | Copyright Mathias Kettner 2013 mk@mathias-kettner.de |
11 # +------------------------------------------------------------------+
13 # This file is part of Check_MK.
14 # The official homepage is at http://mathias-kettner.de/check_mk.
16 # check_mk is free software; you can redistribute it and/or modify it
17 # under the terms of the GNU General Public License as published by
18 # the Free Software Foundation in version 2. check_mk is distributed
19 # in the hope that it will be useful, but WITHOUT ANY WARRANTY; with-
20 # out even the implied warranty of MERCHANTABILITY or FITNESS FOR A
21 # PARTICULAR PURPOSE. See the GNU General Public License for more de-
22 # tails. You should have received a copy of the GNU General Public
23 # License along with GNU Make; see the file COPYING. If not, write
24 # to the Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
25 # Boston, MA 02110-1301 USA.
27 # pre 1.4.0i1 output (without edition, space separated)
28 # <<<mssql_versions>>>
29 # MSSQL_SQLEXPRESS 10.50.1600.1
32 # <<<mssql_versions:sep(124)>>>
33 # MSSQL_MSSQLSERVER|10.50.1600.1|Enterprise Edition
36 def inv_mssql_versions(info
):
37 node
= inv_tree_list("software.applications.mssql.instances:")
40 parts
= map(int, v
.split("."))
42 return "SQL Server 2014"
44 return "SQL Server 2012"
47 return "SQL Server 2008 R2"
48 return "SQL Server 2008"
50 return "SQL Server 2005"
52 return "SQL Server 2000"
54 return "SQL Server 7.0"
55 return "Unknown Product"
57 def get_list_item(key
, val
):
66 if len(line
) not in [2, 4]:
70 instance_id
= line
[0].split("_", 1)[1]
74 edition
= line
[2] if len(line
) == 4 else ''
75 clustered
= len(line
) == 4 and line
[3] != ""
76 cluster_name
= line
[3] if len(line
) == 4 else ''
78 instance
= get_list_item("name", instance_id
)
82 "product": product(version
),
84 "clustered": clustered
,
85 "cluster_name": cluster_name
,
89 inv_info
["mssql_versions"] = {
90 "inv_function": inv_mssql_versions
,