Skip to content
GitLab
Projects
Groups
Snippets
Help
Loading...
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
Knot DNS
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
22
Issues
22
List
Boards
Labels
Service Desk
Milestones
Merge Requests
16
Merge Requests
16
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Incidents
Environments
Packages & Registries
Packages & Registries
Container Registry
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Knot projects
Knot DNS
Commits
2642d78c
Commit
2642d78c
authored
Dec 18, 2018
by
Libor Peltan
Committed by
Daniel Salzman
Dec 18, 2018
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
offline_ksk: keymgr generate-ksr requires specified from-to
parent
99168b7a
Changes
6
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
26 additions
and
22 deletions
+26
-22
doc/man/keymgr.8in
doc/man/keymgr.8in
+1
-1
doc/man_keymgr.rst
doc/man_keymgr.rst
+1
-1
src/utils/keymgr/main.c
src/utils/keymgr/main.c
+11
-8
src/utils/keymgr/offline_ksk.c
src/utils/keymgr/offline_ksk.c
+11
-10
src/utils/keymgr/offline_ksk.h
src/utils/keymgr/offline_ksk.h
+1
-1
tests-extra/tests/dnssec/offline_ksk/test.py
tests-extra/tests/dnssec/offline_ksk/test.py
+1
-1
No files found.
doc/man/keymgr.8in
View file @
2642d78c
...
...
@@ -140,7 +140,7 @@ Delete pre\-generated offline key\-related records in specified time interval.
\fBdel\-all\-old\fP
Delete old keys that are in state \(aqremoved\(aq.
.TP
\fBgenerate\-ksr\fP \fItimestamp\fP
\fBgenerate\-ksr\fP \fItimestamp\
-from\fP \fItimestamp\-to\
fP
Print to stdout KeySigningRequest based on pre\-generated ZSKs for specified period.
.TP
\fBsign\-ksr\fP \fIksr_file\fP
...
...
doc/man_keymgr.rst
View file @
2642d78c
...
...
@@ -117,7 +117,7 @@ Commands related to Offline KSK feature
**del-all-old**
Delete old keys that are in state 'removed'.
**generate-ksr** *timestamp*
**generate-ksr** *timestamp
-from* *timestamp-to
*
Print to stdout KeySigningRequest based on pre-generated ZSKs for specified period.
**sign-ksr** *ksr_file*
...
...
src/utils/keymgr/main.c
View file @
2642d78c
...
...
@@ -85,7 +85,7 @@ static void print_help(void)
" (syntax: del-offline <from> <to>)
\n
"
" del-all-old Delete old keys that are in state 'removed'.
\n
"
" generate-ksr Print to stdout KeySigningRequest based on pre-generated ZSKS.
\n
"
" (syntax: generate-ksr <
timestamp
>)
\n
"
" (syntax: generate-ksr <
from> <to
>)
\n
"
" sign-ksr Read KeySigningRequest from a file, sign it and print SignedKeyResponse to stdout.
\n
"
" (syntax: sign-ksr <ksr_file>)
\n
"
" import-skr Import DNSKEY record signatures from a SignedKeyResponse.
\n
"
...
...
@@ -144,6 +144,13 @@ static int key_command(int argc, char *argv[], int opt_ind)
goto main_end; \
}
#define CHECK_MISSING_ARG2(msg) \
if (argc < 4) { \
printf("%s\n", (msg)); \
ret = KNOT_EINVAL; \
goto main_end; \
}
bool
print_ok_on_succes
=
true
;
if
(
strcmp
(
argv
[
1
],
"generate"
)
==
0
)
{
ret
=
keymgr_generate_key
(
&
kctx
,
argc
-
2
,
argv
+
2
);
...
...
@@ -229,17 +236,13 @@ static int key_command(int argc, char *argv[], int opt_ind)
CHECK_MISSING_ARG
(
"Timestamp not specified"
);
ret
=
keymgr_print_offline_records
(
&
kctx
,
argv
[
2
],
argc
>
3
?
argv
[
3
]
:
NULL
);
}
else
if
(
strcmp
(
argv
[
1
],
"del-offline"
)
==
0
)
{
if
(
argc
<
4
)
{
printf
(
"Timestamps from-to not specified
\n
"
);
ret
=
KNOT_EINVAL
;
goto
main_end
;
}
CHECK_MISSING_ARG2
(
"Timestamps from-to not specified"
);
ret
=
keymgr_delete_offline_records
(
&
kctx
,
argv
[
2
],
argv
[
3
]);
}
else
if
(
strcmp
(
argv
[
1
],
"del-all-old"
)
==
0
)
{
ret
=
keymgr_del_all_old
(
&
kctx
);
}
else
if
(
strcmp
(
argv
[
1
],
"generate-ksr"
)
==
0
)
{
CHECK_MISSING_ARG
(
"Timestamp
not specified"
);
ret
=
keymgr_print_ksr
(
&
kctx
,
argv
[
2
]);
CHECK_MISSING_ARG
2
(
"Timestamps from-to
not specified"
);
ret
=
keymgr_print_ksr
(
&
kctx
,
argv
[
2
]
,
argv
[
3
]
);
print_ok_on_succes
=
false
;
}
else
if
(
strcmp
(
argv
[
1
],
"sign-ksr"
)
==
0
)
{
CHECK_MISSING_ARG
(
"Input file not specified"
);
...
...
src/utils/keymgr/offline_ksk.c
View file @
2642d78c
...
...
@@ -221,28 +221,29 @@ done:
return
ret
;
}
int
keymgr_print_ksr
(
kdnssec_ctx_t
*
ctx
,
char
*
arg
)
int
keymgr_print_ksr
(
kdnssec_ctx_t
*
ctx
,
char
*
arg
_from
,
char
*
arg_to
)
{
knot_time_t
upto
;
int
ret
=
parse_timestamp
(
arg
,
&
upto
);
knot_time_t
from
,
to
;
int
ret
=
parse_timestamp
(
arg_from
,
&
from
);
if
(
ret
!=
KNOT_EOK
)
{
return
ret
;
}
ret
=
parse_timestamp
(
arg_to
,
&
to
);
if
(
ret
!=
KNOT_EOK
)
{
return
ret
;
}
knot_time_t
next
=
ctx
->
now
;
ret
=
KNOT_EOK
;
char
*
buf
=
NULL
;
size_t
buf_size
=
4096
;
while
(
ret
==
KNOT_EOK
&&
knot_time_cmp
(
next
,
upto
)
<
0
)
{
ctx
->
now
=
next
;
ret
=
ksr_once
(
ctx
,
&
buf
,
&
buf_size
,
&
next
);
while
(
ret
==
KNOT_EOK
&&
knot_time_cmp
(
from
,
to
)
<
0
)
{
ctx
->
now
=
from
;
ret
=
ksr_once
(
ctx
,
&
buf
,
&
buf_size
,
&
from
);
}
if
(
ret
!=
KNOT_EOK
)
{
free
(
buf
);
return
ret
;
}
ctx
->
now
=
up
to
;
ctx
->
now
=
to
;
// force end of period as a KSR timestamp
ret
=
ksr_once
(
ctx
,
&
buf
,
&
buf_size
,
NULL
);
...
...
src/utils/keymgr/offline_ksk.h
View file @
2642d78c
...
...
@@ -26,7 +26,7 @@ int keymgr_delete_offline_records(kdnssec_ctx_t *ctx, char *arg_from, char *arg_
int
keymgr_del_all_old
(
kdnssec_ctx_t
*
ctx
);
int
keymgr_print_ksr
(
kdnssec_ctx_t
*
ctx
,
char
*
arg
);
int
keymgr_print_ksr
(
kdnssec_ctx_t
*
ctx
,
char
*
arg
_from
,
char
*
arg_to
);
int
keymgr_sign_ksr
(
kdnssec_ctx_t
*
ctx
,
const
char
*
ksr_file
);
...
...
tests-extra/tests/dnssec/offline_ksk/test.py
View file @
2642d78c
...
...
@@ -120,7 +120,7 @@ key_zsk1 = knot.key_gen(ZONE, ksk="false", created="+0", publish="+0", active="+
KSR
=
knot
.
keydir
+
"/ksr"
SKR
=
knot
.
keydir
+
"/skr"
Keymgr
.
run_check
(
knot
.
confile
,
ZONE
,
"pregenerate"
,
"+"
+
str
(
FUTURE
))
_
,
out
,
_
=
Keymgr
.
run_check
(
knot
.
confile
,
ZONE
,
"generate-ksr"
,
"+"
+
str
(
FUTURE
))
_
,
out
,
_
=
Keymgr
.
run_check
(
knot
.
confile
,
ZONE
,
"generate-ksr"
,
"+
0"
,
"+
"
+
str
(
FUTURE
))
writef
(
KSR
,
out
)
_
,
out
,
_
=
Keymgr
.
run_check
(
signer
.
confile
,
ZONE
,
"sign-ksr"
,
KSR
)
writef
(
SKR
,
out
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment