mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-11-14 19:45:11 +00:00
810 lines
30 KiB
Python
810 lines
30 KiB
Python
# These requirements were auto generated
|
|
# from software requirements specification (SRS)
|
|
# document by TestFlows v1.6.210312.1172513.
|
|
# Do not edit by hand but re-generate instead
|
|
# using 'tfs requirements generate' command.
|
|
from testflows.core import Specification
|
|
from testflows.core import Requirement
|
|
|
|
Heading = Specification.Heading
|
|
|
|
RQ_SRS_016_Kerberos = Requirement(
|
|
name='RQ.SRS-016.Kerberos',
|
|
version='1.0',
|
|
priority=None,
|
|
group=None,
|
|
type=None,
|
|
uid=None,
|
|
description=(
|
|
'[ClickHouse] SHALL support user authentication using [Kerberos] server.\n'
|
|
'\n'
|
|
),
|
|
link=None,
|
|
level=3,
|
|
num='4.1.1')
|
|
|
|
RQ_SRS_016_Kerberos_Ping = Requirement(
|
|
name='RQ.SRS-016.Kerberos.Ping',
|
|
version='1.0',
|
|
priority=None,
|
|
group=None,
|
|
type=None,
|
|
uid=None,
|
|
description=(
|
|
'Docker containers SHALL be able to ping each other.\n'
|
|
'\n'
|
|
),
|
|
link=None,
|
|
level=3,
|
|
num='4.2.1')
|
|
|
|
RQ_SRS_016_Kerberos_Configuration_MultipleAuthMethods = Requirement(
|
|
name='RQ.SRS-016.Kerberos.Configuration.MultipleAuthMethods',
|
|
version='1.0',
|
|
priority=None,
|
|
group=None,
|
|
type=None,
|
|
uid=None,
|
|
description=(
|
|
"[ClickHouse] SHALL generate an exception and TERMINATE in case some user in `users.xml` has a `<kerberos>` section specified alongside with any other authentication method's section, e.g. `ldap`, `password`.\n"
|
|
'\n'
|
|
),
|
|
link=None,
|
|
level=3,
|
|
num='4.3.1')
|
|
|
|
RQ_SRS_016_Kerberos_Configuration_KerberosNotEnabled = Requirement(
|
|
name='RQ.SRS-016.Kerberos.Configuration.KerberosNotEnabled',
|
|
version='1.0',
|
|
priority=None,
|
|
group=None,
|
|
type=None,
|
|
uid=None,
|
|
description=(
|
|
'[ClickHouse] SHALL reject [Kerberos] authentication in case user is properly configured for using Kerberos, but Kerberos itself is not enabled in `config.xml`. For example:\n'
|
|
'\n'
|
|
'```xml\n'
|
|
'<yandex>\n'
|
|
' <!- ... -->\n'
|
|
' <kerberos />\n'
|
|
'</yandex>\n'
|
|
'```\n'
|
|
'```xml\n'
|
|
'<yandex>\n'
|
|
' <!- ... -->\n'
|
|
' <kerberos>\n'
|
|
' <principal>HTTP/clickhouse.example.com@EXAMPLE.COM</principal>\n'
|
|
' </kerberos>\n'
|
|
'</yandex>\n'
|
|
'```\n'
|
|
'```xml\n'
|
|
'<yandex>\n'
|
|
' <!- ... -->\n'
|
|
' <kerberos>\n'
|
|
' <realm>EXAMPLE.COM</realm>\n'
|
|
' </kerberos>\n'
|
|
'</yandex>\n'
|
|
'```\n'
|
|
'\n'
|
|
),
|
|
link=None,
|
|
level=3,
|
|
num='4.3.2')
|
|
|
|
RQ_SRS_016_Kerberos_Configuration_MultipleKerberosSections = Requirement(
|
|
name='RQ.SRS-016.Kerberos.Configuration.MultipleKerberosSections',
|
|
version='1.0',
|
|
priority=None,
|
|
group=None,
|
|
type=None,
|
|
uid=None,
|
|
description=(
|
|
'[ClickHouse] SHALL disable [Kerberos] and reject [Kerberos] authentication in case multiple `kerberos` sections are present in `config.xml`.\n'
|
|
'\n'
|
|
),
|
|
link=None,
|
|
level=3,
|
|
num='4.3.3')
|
|
|
|
RQ_SRS_016_Kerberos_Configuration_WrongUserRealm = Requirement(
|
|
name='RQ.SRS-016.Kerberos.Configuration.WrongUserRealm',
|
|
version='1.0',
|
|
priority=None,
|
|
group=None,
|
|
type=None,
|
|
uid=None,
|
|
description=(
|
|
"[ClickHouse] SHALL reject [Kerberos] authentication if user's realm specified in `users.xml` doesn't match the realm of the principal trying to authenticate.\n"
|
|
'\n'
|
|
),
|
|
link=None,
|
|
level=3,
|
|
num='4.3.4')
|
|
|
|
RQ_SRS_016_Kerberos_Configuration_PrincipalAndRealmSpecified = Requirement(
|
|
name='RQ.SRS-016.Kerberos.Configuration.PrincipalAndRealmSpecified',
|
|
version='1.0',
|
|
priority=None,
|
|
group=None,
|
|
type=None,
|
|
uid=None,
|
|
description=(
|
|
'[ClickHouse] SHALL generate an exception and disable [Kerberos] in case both `realm` and `principal` sections are defined in `config.xml`.\n'
|
|
'\n'
|
|
),
|
|
link=None,
|
|
level=3,
|
|
num='4.3.5')
|
|
|
|
RQ_SRS_016_Kerberos_Configuration_MultiplePrincipalSections = Requirement(
|
|
name='RQ.SRS-016.Kerberos.Configuration.MultiplePrincipalSections',
|
|
version='1.0',
|
|
priority=None,
|
|
group=None,
|
|
type=None,
|
|
uid=None,
|
|
description=(
|
|
'[ClickHouse] SHALL generate an exception and disable [Kerberos] in case multiple `principal` sections are specified inside `kerberos` section in `config.xml`.\n'
|
|
'\n'
|
|
),
|
|
link=None,
|
|
level=3,
|
|
num='4.3.6')
|
|
|
|
RQ_SRS_016_Kerberos_Configuration_MultipleRealmSections = Requirement(
|
|
name='RQ.SRS-016.Kerberos.Configuration.MultipleRealmSections',
|
|
version='1.0',
|
|
priority=None,
|
|
group=None,
|
|
type=None,
|
|
uid=None,
|
|
description=(
|
|
'[ClickHouse] SHALL generate an exception and disable [Kerberos] in case multiple `realm` sections are specified inside `kerberos` section in `config.xml`.\n'
|
|
'\n'
|
|
),
|
|
link=None,
|
|
level=3,
|
|
num='4.3.7')
|
|
|
|
RQ_SRS_016_Kerberos_ValidUser_XMLConfiguredUser = Requirement(
|
|
name='RQ.SRS-016.Kerberos.ValidUser.XMLConfiguredUser',
|
|
version='1.0',
|
|
priority=None,
|
|
group=None,
|
|
type=None,
|
|
uid=None,
|
|
description=(
|
|
'[ClickHouse] SHALL accept [Kerberos] authentication for a user that is configured in `users.xml` and has [Kerberos] enabled, i.e.:\n'
|
|
'\n'
|
|
'```xml\n'
|
|
'<yandex>\n'
|
|
' <!- ... -->\n'
|
|
' <users>\n'
|
|
' <!- ... -->\n'
|
|
' <my_user>\n'
|
|
' <!- ... -->\n'
|
|
' <kerberos>\n'
|
|
' <realm>EXAMPLE.COM</realm>\n'
|
|
' </kerberos>\n'
|
|
' </my_user>\n'
|
|
' </users>\n'
|
|
'</yandex>\n'
|
|
'```\n'
|
|
'\n'
|
|
),
|
|
link=None,
|
|
level=3,
|
|
num='4.4.1')
|
|
|
|
RQ_SRS_016_Kerberos_ValidUser_RBACConfiguredUser = Requirement(
|
|
name='RQ.SRS-016.Kerberos.ValidUser.RBACConfiguredUser',
|
|
version='1.0',
|
|
priority=None,
|
|
group=None,
|
|
type=None,
|
|
uid=None,
|
|
description=(
|
|
'[ClickHouse] SHALL accept [Kerberos] authentication if user is configured to authenticate via [Kerberos] using SQL queries\n'
|
|
'\n'
|
|
'```sql\n'
|
|
"CREATE USER my_user IDENTIFIED WITH kerberos REALM 'EXAMPLE.COM'\n"
|
|
'```\n'
|
|
'\n'
|
|
'or\n'
|
|
'\n'
|
|
'```sql\n'
|
|
'CREATE USER my_user IDENTIFIED WITH kerberos\n'
|
|
'```\n'
|
|
'\n'
|
|
),
|
|
link=None,
|
|
level=3,
|
|
num='4.4.2')
|
|
|
|
RQ_SRS_016_Kerberos_ValidUser_KerberosNotConfigured = Requirement(
|
|
name='RQ.SRS-016.Kerberos.ValidUser.KerberosNotConfigured',
|
|
version='1.0',
|
|
priority=None,
|
|
group=None,
|
|
type=None,
|
|
uid=None,
|
|
description=(
|
|
'[ClickHouse] SHALL reject [Kerberos] authentication if username is valid but [ClickHouse] user is not configured to be authenticated using [Kerberos].\n'
|
|
'\n'
|
|
),
|
|
link=None,
|
|
level=3,
|
|
num='4.4.3')
|
|
|
|
RQ_SRS_016_Kerberos_InvalidUser = Requirement(
|
|
name='RQ.SRS-016.Kerberos.InvalidUser',
|
|
version='1.0',
|
|
priority=None,
|
|
group=None,
|
|
type=None,
|
|
uid=None,
|
|
description=(
|
|
'[ClickHouse] SHALL reject [Kerberos] authentication if name of the principal attempting to authenticate does not translate to a valid [ClickHouse] username configured in `users.xml` or via SQL workflow.\n'
|
|
'\n'
|
|
),
|
|
link=None,
|
|
level=3,
|
|
num='4.5.1')
|
|
|
|
RQ_SRS_016_Kerberos_InvalidUser_UserDeleted = Requirement(
|
|
name='RQ.SRS-016.Kerberos.InvalidUser.UserDeleted',
|
|
version='1.0',
|
|
priority=None,
|
|
group=None,
|
|
type=None,
|
|
uid=None,
|
|
description=(
|
|
'[ClickHouse] SHALL reject [Kerberos] authentication if [ClickHouse] user was removed from the database using an SQL query.\n'
|
|
'\n'
|
|
),
|
|
link=None,
|
|
level=3,
|
|
num='4.5.2')
|
|
|
|
RQ_SRS_016_Kerberos_KerberosNotAvailable_InvalidServerTicket = Requirement(
|
|
name='RQ.SRS-016.Kerberos.KerberosNotAvailable.InvalidServerTicket',
|
|
version='1.0',
|
|
priority=None,
|
|
group=None,
|
|
type=None,
|
|
uid=None,
|
|
description=(
|
|
"[ClickHouse] SHALL reject [Kerberos] authentication if [ClickHouse] user is configured to be authenticated using [Kerberos] and [Kerberos] server is unavailable, but [ClickHouse] doesn't have a valid Kerberos ticket or the ticket is expired.\n"
|
|
'\n'
|
|
),
|
|
link=None,
|
|
level=3,
|
|
num='4.6.1')
|
|
|
|
RQ_SRS_016_Kerberos_KerberosNotAvailable_InvalidClientTicket = Requirement(
|
|
name='RQ.SRS-016.Kerberos.KerberosNotAvailable.InvalidClientTicket',
|
|
version='1.0',
|
|
priority=None,
|
|
group=None,
|
|
type=None,
|
|
uid=None,
|
|
description=(
|
|
"[ClickHouse] SHALL reject [Kerberos] authentication if [ClickHouse] user is configured to to be authenticated using [Kerberos] and [Kerberos] server is unavailable, but the client doesn't have a valid Kerberos ticket or the ticket is expired.\n"
|
|
'\n'
|
|
),
|
|
link=None,
|
|
level=3,
|
|
num='4.6.2')
|
|
|
|
RQ_SRS_016_Kerberos_KerberosNotAvailable_ValidTickets = Requirement(
|
|
name='RQ.SRS-016.Kerberos.KerberosNotAvailable.ValidTickets',
|
|
version='1.0',
|
|
priority=None,
|
|
group=None,
|
|
type=None,
|
|
uid=None,
|
|
description=(
|
|
'[ClickHouse] SHALL accept [Kerberos] authentication if no [Kerberos] server is reachable, but [ClickHouse] is configured to use valid credentials and [ClickHouse] has already processed some valid kerberized request (so it was granted a ticket), and the client has a valid ticket as well.\n'
|
|
'\n'
|
|
),
|
|
link=None,
|
|
level=3,
|
|
num='4.6.3')
|
|
|
|
RQ_SRS_016_Kerberos_KerberosServerRestarted = Requirement(
|
|
name='RQ.SRS-016.Kerberos.KerberosServerRestarted',
|
|
version='1.0',
|
|
priority=None,
|
|
group=None,
|
|
type=None,
|
|
uid=None,
|
|
description=(
|
|
'[ClickHouse] SHALL accept [Kerberos] authentication if [Kerberos] server was restarted.\n'
|
|
'\n'
|
|
),
|
|
link=None,
|
|
level=3,
|
|
num='4.7.1')
|
|
|
|
RQ_SRS_016_Kerberos_Performance = Requirement(
|
|
name='RQ.SRS-016.Kerberos.Performance',
|
|
version='1.0',
|
|
priority=None,
|
|
group=None,
|
|
type=None,
|
|
uid=None,
|
|
description=(
|
|
"[ClickHouse]'s performance for [Kerberos] authentication SHALL be comparable to regular authentication.\n"
|
|
'\n'
|
|
),
|
|
link=None,
|
|
level=3,
|
|
num='4.8.1')
|
|
|
|
RQ_SRS_016_Kerberos_Parallel = Requirement(
|
|
name='RQ.SRS-016.Kerberos.Parallel',
|
|
version='1.0',
|
|
priority=None,
|
|
group=None,
|
|
type=None,
|
|
uid=None,
|
|
description=(
|
|
'[ClickHouse] SHALL support parallel authentication using [Kerberos].\n'
|
|
'\n'
|
|
),
|
|
link=None,
|
|
level=3,
|
|
num='4.9.1')
|
|
|
|
RQ_SRS_016_Kerberos_Parallel_ValidRequests_KerberosAndNonKerberos = Requirement(
|
|
name='RQ.SRS-016.Kerberos.Parallel.ValidRequests.KerberosAndNonKerberos',
|
|
version='1.0',
|
|
priority=None,
|
|
group=None,
|
|
type=None,
|
|
uid=None,
|
|
description=(
|
|
'[ClickHouse] SHALL support processing of simultaneous kerberized (for users configured to authenticate via [Kerberos]) and non-kerberized (for users configured to authenticate with any other means) requests.\n'
|
|
'\n'
|
|
),
|
|
link=None,
|
|
level=3,
|
|
num='4.9.2')
|
|
|
|
RQ_SRS_016_Kerberos_Parallel_ValidRequests_SameCredentials = Requirement(
|
|
name='RQ.SRS-016.Kerberos.Parallel.ValidRequests.SameCredentials',
|
|
version='1.0',
|
|
priority=None,
|
|
group=None,
|
|
type=None,
|
|
uid=None,
|
|
description=(
|
|
'[ClickHouse] SHALL support processing of simultaneously sent [Kerberos] requests under the same credentials.\n'
|
|
'\n'
|
|
),
|
|
link=None,
|
|
level=3,
|
|
num='4.9.3')
|
|
|
|
RQ_SRS_016_Kerberos_Parallel_ValidRequests_DifferentCredentials = Requirement(
|
|
name='RQ.SRS-016.Kerberos.Parallel.ValidRequests.DifferentCredentials',
|
|
version='1.0',
|
|
priority=None,
|
|
group=None,
|
|
type=None,
|
|
uid=None,
|
|
description=(
|
|
'[ClickHouse] SHALL support processing of simultaneously sent [Kerberos] requests under different credentials.\n'
|
|
'\n'
|
|
),
|
|
link=None,
|
|
level=3,
|
|
num='4.9.4')
|
|
|
|
RQ_SRS_016_Kerberos_Parallel_ValidInvalid = Requirement(
|
|
name='RQ.SRS-016.Kerberos.Parallel.ValidInvalid',
|
|
version='1.0',
|
|
priority=None,
|
|
group=None,
|
|
type=None,
|
|
uid=None,
|
|
description=(
|
|
"[ClickHouse] SHALL support parallel authentication of users using [Kerberos] server, some of which are valid and some invalid. Valid users' authentication should not be affected by invalid users' attempts.\n"
|
|
'\n'
|
|
),
|
|
link=None,
|
|
level=3,
|
|
num='4.9.5')
|
|
|
|
RQ_SRS_016_Kerberos_Parallel_Deletion = Requirement(
|
|
name='RQ.SRS-016.Kerberos.Parallel.Deletion',
|
|
version='1.0',
|
|
priority=None,
|
|
group=None,
|
|
type=None,
|
|
uid=None,
|
|
description=(
|
|
'[ClickHouse] SHALL not crash when two or more [Kerberos] users are simultaneously deleting one another.\n'
|
|
'\n'
|
|
),
|
|
link=None,
|
|
level=3,
|
|
num='4.9.6')
|
|
|
|
QA_SRS016_ClickHouse_Kerberos_Authentication = Specification(
|
|
name='QA-SRS016 ClickHouse Kerberos Authentication',
|
|
description=None,
|
|
author=None,
|
|
date=None,
|
|
status=None,
|
|
approved_by=None,
|
|
approved_date=None,
|
|
approved_version=None,
|
|
version=None,
|
|
group=None,
|
|
type=None,
|
|
link=None,
|
|
uid=None,
|
|
parent=None,
|
|
children=None,
|
|
headings=(
|
|
Heading(name='Revision History', level=1, num='1'),
|
|
Heading(name='Introduction', level=1, num='2'),
|
|
Heading(name='Terminology', level=1, num='3'),
|
|
Heading(name='Requirements', level=1, num='4'),
|
|
Heading(name='Generic', level=2, num='4.1'),
|
|
Heading(name='RQ.SRS-016.Kerberos', level=3, num='4.1.1'),
|
|
Heading(name='Ping', level=2, num='4.2'),
|
|
Heading(name='RQ.SRS-016.Kerberos.Ping', level=3, num='4.2.1'),
|
|
Heading(name='Configuration', level=2, num='4.3'),
|
|
Heading(name='RQ.SRS-016.Kerberos.Configuration.MultipleAuthMethods', level=3, num='4.3.1'),
|
|
Heading(name='RQ.SRS-016.Kerberos.Configuration.KerberosNotEnabled', level=3, num='4.3.2'),
|
|
Heading(name='RQ.SRS-016.Kerberos.Configuration.MultipleKerberosSections', level=3, num='4.3.3'),
|
|
Heading(name='RQ.SRS-016.Kerberos.Configuration.WrongUserRealm', level=3, num='4.3.4'),
|
|
Heading(name='RQ.SRS-016.Kerberos.Configuration.PrincipalAndRealmSpecified', level=3, num='4.3.5'),
|
|
Heading(name='RQ.SRS-016.Kerberos.Configuration.MultiplePrincipalSections', level=3, num='4.3.6'),
|
|
Heading(name='RQ.SRS-016.Kerberos.Configuration.MultipleRealmSections', level=3, num='4.3.7'),
|
|
Heading(name='Valid User', level=2, num='4.4'),
|
|
Heading(name='RQ.SRS-016.Kerberos.ValidUser.XMLConfiguredUser', level=3, num='4.4.1'),
|
|
Heading(name='RQ.SRS-016.Kerberos.ValidUser.RBACConfiguredUser', level=3, num='4.4.2'),
|
|
Heading(name='RQ.SRS-016.Kerberos.ValidUser.KerberosNotConfigured', level=3, num='4.4.3'),
|
|
Heading(name='Invalid User', level=2, num='4.5'),
|
|
Heading(name='RQ.SRS-016.Kerberos.InvalidUser', level=3, num='4.5.1'),
|
|
Heading(name='RQ.SRS-016.Kerberos.InvalidUser.UserDeleted', level=3, num='4.5.2'),
|
|
Heading(name='Kerberos Not Available', level=2, num='4.6'),
|
|
Heading(name='RQ.SRS-016.Kerberos.KerberosNotAvailable.InvalidServerTicket', level=3, num='4.6.1'),
|
|
Heading(name='RQ.SRS-016.Kerberos.KerberosNotAvailable.InvalidClientTicket', level=3, num='4.6.2'),
|
|
Heading(name='RQ.SRS-016.Kerberos.KerberosNotAvailable.ValidTickets', level=3, num='4.6.3'),
|
|
Heading(name='Kerberos Restarted', level=2, num='4.7'),
|
|
Heading(name='RQ.SRS-016.Kerberos.KerberosServerRestarted', level=3, num='4.7.1'),
|
|
Heading(name='Performance', level=2, num='4.8'),
|
|
Heading(name='RQ.SRS-016.Kerberos.Performance', level=3, num='4.8.1'),
|
|
Heading(name='Parallel Requests processing', level=2, num='4.9'),
|
|
Heading(name='RQ.SRS-016.Kerberos.Parallel', level=3, num='4.9.1'),
|
|
Heading(name='RQ.SRS-016.Kerberos.Parallel.ValidRequests.KerberosAndNonKerberos', level=3, num='4.9.2'),
|
|
Heading(name='RQ.SRS-016.Kerberos.Parallel.ValidRequests.SameCredentials', level=3, num='4.9.3'),
|
|
Heading(name='RQ.SRS-016.Kerberos.Parallel.ValidRequests.DifferentCredentials', level=3, num='4.9.4'),
|
|
Heading(name='RQ.SRS-016.Kerberos.Parallel.ValidInvalid', level=3, num='4.9.5'),
|
|
Heading(name='RQ.SRS-016.Kerberos.Parallel.Deletion', level=3, num='4.9.6'),
|
|
Heading(name='References', level=1, num='5'),
|
|
),
|
|
requirements=(
|
|
RQ_SRS_016_Kerberos,
|
|
RQ_SRS_016_Kerberos_Ping,
|
|
RQ_SRS_016_Kerberos_Configuration_MultipleAuthMethods,
|
|
RQ_SRS_016_Kerberos_Configuration_KerberosNotEnabled,
|
|
RQ_SRS_016_Kerberos_Configuration_MultipleKerberosSections,
|
|
RQ_SRS_016_Kerberos_Configuration_WrongUserRealm,
|
|
RQ_SRS_016_Kerberos_Configuration_PrincipalAndRealmSpecified,
|
|
RQ_SRS_016_Kerberos_Configuration_MultiplePrincipalSections,
|
|
RQ_SRS_016_Kerberos_Configuration_MultipleRealmSections,
|
|
RQ_SRS_016_Kerberos_ValidUser_XMLConfiguredUser,
|
|
RQ_SRS_016_Kerberos_ValidUser_RBACConfiguredUser,
|
|
RQ_SRS_016_Kerberos_ValidUser_KerberosNotConfigured,
|
|
RQ_SRS_016_Kerberos_InvalidUser,
|
|
RQ_SRS_016_Kerberos_InvalidUser_UserDeleted,
|
|
RQ_SRS_016_Kerberos_KerberosNotAvailable_InvalidServerTicket,
|
|
RQ_SRS_016_Kerberos_KerberosNotAvailable_InvalidClientTicket,
|
|
RQ_SRS_016_Kerberos_KerberosNotAvailable_ValidTickets,
|
|
RQ_SRS_016_Kerberos_KerberosServerRestarted,
|
|
RQ_SRS_016_Kerberos_Performance,
|
|
RQ_SRS_016_Kerberos_Parallel,
|
|
RQ_SRS_016_Kerberos_Parallel_ValidRequests_KerberosAndNonKerberos,
|
|
RQ_SRS_016_Kerberos_Parallel_ValidRequests_SameCredentials,
|
|
RQ_SRS_016_Kerberos_Parallel_ValidRequests_DifferentCredentials,
|
|
RQ_SRS_016_Kerberos_Parallel_ValidInvalid,
|
|
RQ_SRS_016_Kerberos_Parallel_Deletion,
|
|
),
|
|
content='''
|
|
# QA-SRS016 ClickHouse Kerberos Authentication
|
|
# Software Requirements Specification
|
|
|
|
## Table of Contents
|
|
|
|
* 1 [Revision History](#revision-history)
|
|
* 2 [Introduction](#introduction)
|
|
* 3 [Terminology](#terminology)
|
|
* 4 [Requirements](#requirements)
|
|
* 4.1 [Generic](#generic)
|
|
* 4.1.1 [RQ.SRS-016.Kerberos](#rqsrs-016kerberos)
|
|
* 4.2 [Ping](#ping)
|
|
* 4.2.1 [RQ.SRS-016.Kerberos.Ping](#rqsrs-016kerberosping)
|
|
* 4.3 [Configuration](#configuration)
|
|
* 4.3.1 [RQ.SRS-016.Kerberos.Configuration.MultipleAuthMethods](#rqsrs-016kerberosconfigurationmultipleauthmethods)
|
|
* 4.3.2 [RQ.SRS-016.Kerberos.Configuration.KerberosNotEnabled](#rqsrs-016kerberosconfigurationkerberosnotenabled)
|
|
* 4.3.3 [RQ.SRS-016.Kerberos.Configuration.MultipleKerberosSections](#rqsrs-016kerberosconfigurationmultiplekerberossections)
|
|
* 4.3.4 [RQ.SRS-016.Kerberos.Configuration.WrongUserRealm](#rqsrs-016kerberosconfigurationwronguserrealm)
|
|
* 4.3.5 [RQ.SRS-016.Kerberos.Configuration.PrincipalAndRealmSpecified](#rqsrs-016kerberosconfigurationprincipalandrealmspecified)
|
|
* 4.3.6 [RQ.SRS-016.Kerberos.Configuration.MultiplePrincipalSections](#rqsrs-016kerberosconfigurationmultipleprincipalsections)
|
|
* 4.3.7 [RQ.SRS-016.Kerberos.Configuration.MultipleRealmSections](#rqsrs-016kerberosconfigurationmultiplerealmsections)
|
|
* 4.4 [Valid User](#valid-user)
|
|
* 4.4.1 [RQ.SRS-016.Kerberos.ValidUser.XMLConfiguredUser](#rqsrs-016kerberosvaliduserxmlconfigureduser)
|
|
* 4.4.2 [RQ.SRS-016.Kerberos.ValidUser.RBACConfiguredUser](#rqsrs-016kerberosvaliduserrbacconfigureduser)
|
|
* 4.4.3 [RQ.SRS-016.Kerberos.ValidUser.KerberosNotConfigured](#rqsrs-016kerberosvaliduserkerberosnotconfigured)
|
|
* 4.5 [Invalid User](#invalid-user)
|
|
* 4.5.1 [RQ.SRS-016.Kerberos.InvalidUser](#rqsrs-016kerberosinvaliduser)
|
|
* 4.5.2 [RQ.SRS-016.Kerberos.InvalidUser.UserDeleted](#rqsrs-016kerberosinvaliduseruserdeleted)
|
|
* 4.6 [Kerberos Not Available](#kerberos-not-available)
|
|
* 4.6.1 [RQ.SRS-016.Kerberos.KerberosNotAvailable.InvalidServerTicket](#rqsrs-016kerberoskerberosnotavailableinvalidserverticket)
|
|
* 4.6.2 [RQ.SRS-016.Kerberos.KerberosNotAvailable.InvalidClientTicket](#rqsrs-016kerberoskerberosnotavailableinvalidclientticket)
|
|
* 4.6.3 [RQ.SRS-016.Kerberos.KerberosNotAvailable.ValidTickets](#rqsrs-016kerberoskerberosnotavailablevalidtickets)
|
|
* 4.7 [Kerberos Restarted](#kerberos-restarted)
|
|
* 4.7.1 [RQ.SRS-016.Kerberos.KerberosServerRestarted](#rqsrs-016kerberoskerberosserverrestarted)
|
|
* 4.8 [Performance](#performance)
|
|
* 4.8.1 [RQ.SRS-016.Kerberos.Performance](#rqsrs-016kerberosperformance)
|
|
* 4.9 [Parallel Requests processing](#parallel-requests-processing)
|
|
* 4.9.1 [RQ.SRS-016.Kerberos.Parallel](#rqsrs-016kerberosparallel)
|
|
* 4.9.2 [RQ.SRS-016.Kerberos.Parallel.ValidRequests.KerberosAndNonKerberos](#rqsrs-016kerberosparallelvalidrequestskerberosandnonkerberos)
|
|
* 4.9.3 [RQ.SRS-016.Kerberos.Parallel.ValidRequests.SameCredentials](#rqsrs-016kerberosparallelvalidrequestssamecredentials)
|
|
* 4.9.4 [RQ.SRS-016.Kerberos.Parallel.ValidRequests.DifferentCredentials](#rqsrs-016kerberosparallelvalidrequestsdifferentcredentials)
|
|
* 4.9.5 [RQ.SRS-016.Kerberos.Parallel.ValidInvalid](#rqsrs-016kerberosparallelvalidinvalid)
|
|
* 4.9.6 [RQ.SRS-016.Kerberos.Parallel.Deletion](#rqsrs-016kerberosparalleldeletion)
|
|
* 5 [References](#references)
|
|
|
|
|
|
## Revision History
|
|
|
|
This document is stored in an electronic form using [Git] source control management software
|
|
hosted in a [GitHub Repository].
|
|
All the updates are tracked using the [Git]'s [Revision History].
|
|
|
|
## Introduction
|
|
|
|
This document specifies the behavior for authenticating existing users via [Kerberos] authentication protocol.
|
|
Existing [ClickHouse] users, that are properly configured, have an ability to authenticate using [Kerberos]. Kerberos authentication is only supported for HTTP requests, and users configured to authenticate via Kerberos cannot be authenticated by any other means of authentication.
|
|
|
|
In order to use Kerberos authentication, Kerberos needs to be properly configured in the environment: Kerberos server must be present and user's and server's credentials must be set up. Configuring the Kerberos environment is outside the scope of this document.
|
|
|
|
## Terminology
|
|
|
|
* **Principal** -
|
|
A unique identity that uses [Kerberos].
|
|
|
|
* **Realm** -
|
|
A logical group of resources and identities that use [Kerberos].
|
|
|
|
* **Ticket** -
|
|
An encrypted block of data that authenticates principal.
|
|
|
|
* **Credentials** -
|
|
A Kerberos ticket and a session key.
|
|
|
|
* **Kerberized request** -
|
|
A HTTP query to ClickHouse server, which uses GSS [SPNEGO] and [Kerberos] to authenticate client.
|
|
|
|
* **Unkerberized request** -
|
|
A HTTP query to ClickHouse server, which uses any other mean of authentication than GSS [SPNEGO] or [Kerberos].
|
|
|
|
For a more detailed descriprion, visit [Kerberos terminology].
|
|
|
|
## Requirements
|
|
|
|
### Generic
|
|
|
|
#### RQ.SRS-016.Kerberos
|
|
version: 1.0
|
|
|
|
[ClickHouse] SHALL support user authentication using [Kerberos] server.
|
|
|
|
### Ping
|
|
|
|
#### RQ.SRS-016.Kerberos.Ping
|
|
version: 1.0
|
|
|
|
Docker containers SHALL be able to ping each other.
|
|
|
|
### Configuration
|
|
|
|
#### RQ.SRS-016.Kerberos.Configuration.MultipleAuthMethods
|
|
version: 1.0
|
|
|
|
[ClickHouse] SHALL generate an exception and TERMINATE in case some user in `users.xml` has a `<kerberos>` section specified alongside with any other authentication method's section, e.g. `ldap`, `password`.
|
|
|
|
#### RQ.SRS-016.Kerberos.Configuration.KerberosNotEnabled
|
|
version: 1.0
|
|
|
|
[ClickHouse] SHALL reject [Kerberos] authentication in case user is properly configured for using Kerberos, but Kerberos itself is not enabled in `config.xml`. For example:
|
|
|
|
```xml
|
|
<yandex>
|
|
<!- ... -->
|
|
<kerberos />
|
|
</yandex>
|
|
```
|
|
```xml
|
|
<yandex>
|
|
<!- ... -->
|
|
<kerberos>
|
|
<principal>HTTP/clickhouse.example.com@EXAMPLE.COM</principal>
|
|
</kerberos>
|
|
</yandex>
|
|
```
|
|
```xml
|
|
<yandex>
|
|
<!- ... -->
|
|
<kerberos>
|
|
<realm>EXAMPLE.COM</realm>
|
|
</kerberos>
|
|
</yandex>
|
|
```
|
|
|
|
#### RQ.SRS-016.Kerberos.Configuration.MultipleKerberosSections
|
|
version: 1.0
|
|
|
|
[ClickHouse] SHALL disable [Kerberos] and reject [Kerberos] authentication in case multiple `kerberos` sections are present in `config.xml`.
|
|
|
|
#### RQ.SRS-016.Kerberos.Configuration.WrongUserRealm
|
|
version: 1.0
|
|
|
|
[ClickHouse] SHALL reject [Kerberos] authentication if user's realm specified in `users.xml` doesn't match the realm of the principal trying to authenticate.
|
|
|
|
#### RQ.SRS-016.Kerberos.Configuration.PrincipalAndRealmSpecified
|
|
version: 1.0
|
|
|
|
[ClickHouse] SHALL generate an exception and disable [Kerberos] in case both `realm` and `principal` sections are defined in `config.xml`.
|
|
|
|
#### RQ.SRS-016.Kerberos.Configuration.MultiplePrincipalSections
|
|
version: 1.0
|
|
|
|
[ClickHouse] SHALL generate an exception and disable [Kerberos] in case multiple `principal` sections are specified inside `kerberos` section in `config.xml`.
|
|
|
|
#### RQ.SRS-016.Kerberos.Configuration.MultipleRealmSections
|
|
version: 1.0
|
|
|
|
[ClickHouse] SHALL generate an exception and disable [Kerberos] in case multiple `realm` sections are specified inside `kerberos` section in `config.xml`.
|
|
|
|
### Valid User
|
|
|
|
#### RQ.SRS-016.Kerberos.ValidUser.XMLConfiguredUser
|
|
version: 1.0
|
|
|
|
[ClickHouse] SHALL accept [Kerberos] authentication for a user that is configured in `users.xml` and has [Kerberos] enabled, i.e.:
|
|
|
|
```xml
|
|
<yandex>
|
|
<!- ... -->
|
|
<users>
|
|
<!- ... -->
|
|
<my_user>
|
|
<!- ... -->
|
|
<kerberos>
|
|
<realm>EXAMPLE.COM</realm>
|
|
</kerberos>
|
|
</my_user>
|
|
</users>
|
|
</yandex>
|
|
```
|
|
|
|
#### RQ.SRS-016.Kerberos.ValidUser.RBACConfiguredUser
|
|
version: 1.0
|
|
|
|
[ClickHouse] SHALL accept [Kerberos] authentication if user is configured to authenticate via [Kerberos] using SQL queries
|
|
|
|
```sql
|
|
CREATE USER my_user IDENTIFIED WITH kerberos REALM 'EXAMPLE.COM'
|
|
```
|
|
|
|
or
|
|
|
|
```sql
|
|
CREATE USER my_user IDENTIFIED WITH kerberos
|
|
```
|
|
|
|
#### RQ.SRS-016.Kerberos.ValidUser.KerberosNotConfigured
|
|
version: 1.0
|
|
|
|
[ClickHouse] SHALL reject [Kerberos] authentication if username is valid but [ClickHouse] user is not configured to be authenticated using [Kerberos].
|
|
|
|
### Invalid User
|
|
|
|
#### RQ.SRS-016.Kerberos.InvalidUser
|
|
version: 1.0
|
|
|
|
[ClickHouse] SHALL reject [Kerberos] authentication if name of the principal attempting to authenticate does not translate to a valid [ClickHouse] username configured in `users.xml` or via SQL workflow.
|
|
|
|
#### RQ.SRS-016.Kerberos.InvalidUser.UserDeleted
|
|
version: 1.0
|
|
|
|
[ClickHouse] SHALL reject [Kerberos] authentication if [ClickHouse] user was removed from the database using an SQL query.
|
|
|
|
### Kerberos Not Available
|
|
|
|
#### RQ.SRS-016.Kerberos.KerberosNotAvailable.InvalidServerTicket
|
|
version: 1.0
|
|
|
|
[ClickHouse] SHALL reject [Kerberos] authentication if [ClickHouse] user is configured to be authenticated using [Kerberos] and [Kerberos] server is unavailable, but [ClickHouse] doesn't have a valid Kerberos ticket or the ticket is expired.
|
|
|
|
#### RQ.SRS-016.Kerberos.KerberosNotAvailable.InvalidClientTicket
|
|
version: 1.0
|
|
|
|
[ClickHouse] SHALL reject [Kerberos] authentication if [ClickHouse] user is configured to to be authenticated using [Kerberos] and [Kerberos] server is unavailable, but the client doesn't have a valid Kerberos ticket or the ticket is expired.
|
|
|
|
#### RQ.SRS-016.Kerberos.KerberosNotAvailable.ValidTickets
|
|
version: 1.0
|
|
|
|
[ClickHouse] SHALL accept [Kerberos] authentication if no [Kerberos] server is reachable, but [ClickHouse] is configured to use valid credentials and [ClickHouse] has already processed some valid kerberized request (so it was granted a ticket), and the client has a valid ticket as well.
|
|
|
|
### Kerberos Restarted
|
|
|
|
#### RQ.SRS-016.Kerberos.KerberosServerRestarted
|
|
version: 1.0
|
|
|
|
[ClickHouse] SHALL accept [Kerberos] authentication if [Kerberos] server was restarted.
|
|
|
|
### Performance
|
|
|
|
#### RQ.SRS-016.Kerberos.Performance
|
|
version: 1.0
|
|
|
|
[ClickHouse]'s performance for [Kerberos] authentication SHALL be comparable to regular authentication.
|
|
|
|
### Parallel Requests processing
|
|
|
|
#### RQ.SRS-016.Kerberos.Parallel
|
|
version: 1.0
|
|
|
|
[ClickHouse] SHALL support parallel authentication using [Kerberos].
|
|
|
|
#### RQ.SRS-016.Kerberos.Parallel.ValidRequests.KerberosAndNonKerberos
|
|
version: 1.0
|
|
|
|
[ClickHouse] SHALL support processing of simultaneous kerberized (for users configured to authenticate via [Kerberos]) and non-kerberized (for users configured to authenticate with any other means) requests.
|
|
|
|
#### RQ.SRS-016.Kerberos.Parallel.ValidRequests.SameCredentials
|
|
version: 1.0
|
|
|
|
[ClickHouse] SHALL support processing of simultaneously sent [Kerberos] requests under the same credentials.
|
|
|
|
#### RQ.SRS-016.Kerberos.Parallel.ValidRequests.DifferentCredentials
|
|
version: 1.0
|
|
|
|
[ClickHouse] SHALL support processing of simultaneously sent [Kerberos] requests under different credentials.
|
|
|
|
#### RQ.SRS-016.Kerberos.Parallel.ValidInvalid
|
|
version: 1.0
|
|
|
|
[ClickHouse] SHALL support parallel authentication of users using [Kerberos] server, some of which are valid and some invalid. Valid users' authentication should not be affected by invalid users' attempts.
|
|
|
|
#### RQ.SRS-016.Kerberos.Parallel.Deletion
|
|
version: 1.0
|
|
|
|
[ClickHouse] SHALL not crash when two or more [Kerberos] users are simultaneously deleting one another.
|
|
|
|
## References
|
|
|
|
* **ClickHouse:** https://clickhouse.tech
|
|
* **GitHub Repository:** https://github.com/ClickHouse/ClickHouse/blob/master/tests/testflows/kerberos/requirements/requirements.md
|
|
* **Revision History:** https://github.com/ClickHouse/ClickHouse/commits/master/tests/testflows/kerberos/requirements/requirements.md
|
|
* **Git:** https://git-scm.com/
|
|
* **Kerberos terminology:** https://web.mit.edu/kerberos/kfw-4.1/kfw-4.1/kfw-4.1-help/html/kerberos_terminology.htm
|
|
|
|
[Kerberos]: https://en.wikipedia.org/wiki/Kerberos_(protocol)
|
|
[SPNEGO]: https://en.wikipedia.org/wiki/SPNEGO
|
|
[ClickHouse]: https://clickhouse.tech
|
|
[GitHub]: https://gitlab.com
|
|
[GitHub Repository]: https://github.com/ClickHouse/ClickHouse/blob/master/tests/testflows/kerberos/requirements/requirements.md
|
|
[Revision History]: https://github.com/ClickHouse/ClickHouse/commits/master/tests/testflows/kerberos/requirements/requirements.md
|
|
[Git]: https://git-scm.com/
|
|
[Kerberos terminology]: https://web.mit.edu/kerberos/kfw-4.1/kfw-4.1/kfw-4.1-help/html/kerberos_terminology.htm
|
|
''')
|