forked from gravitational/teleport
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Set some defaults from identity file.
This commit reduces the amount of typing some users have to do when using identity file: * Teleport user is set from the certificate * Auth preference is set to local In addition it fixes several UX problems: * Commands `tctl auth sign` and `tsh login -o` now include trusted CA keys in the identity file. * Command `tsh ssh -i` is now noninteractive and only uses identity file for authentication, in case if identity file can not authenticate, no other interactive or non-interactive authentication methods will be used. Before this commit, tsh tried to fallback to interactive login mode or read the keys from agent socket.
- Loading branch information
1 parent
a3dfe94
commit a1116b7
Showing
9 changed files
with
227 additions
and
58 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,59 @@ | ||
/* | ||
Copyright 2018 Gravitational, Inc. | ||
Licensed under the Apache License, Version 2.0 (the "License"); | ||
you may not use this file except in compliance with the License. | ||
You may obtain a copy of the License at | ||
http://www.apache.org/licenses/LICENSE-2.0 | ||
Unless required by applicable law or agreed to in writing, software | ||
distributed under the License is distributed on an "AS IS" BASIS, | ||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
See the License for the specific language governing permissions and | ||
limitations under the License. | ||
*/ | ||
|
||
package sshutils | ||
|
||
import ( | ||
"fmt" | ||
"net/url" | ||
"strings" | ||
) | ||
|
||
// MarshalAuthorizedKeysFormat returns the certificate authority public key exported as a single | ||
// line that can be placed in ~/.ssh/authorized_keys file. The format adheres to the | ||
// man sshd (8) authorized_keys format, a space-separated list of: options, keytype, | ||
// base64-encoded key, comment. | ||
// For example: | ||
// | ||
// cert-authority AAA... type=user&clustername=cluster-a | ||
// | ||
// URL encoding is used to pass the CA type and cluster name into the comment field. | ||
func MarshalAuthorizedKeysFormat(clusterName string, keyBytes []byte) (string, error) { | ||
comment := url.Values{ | ||
"type": []string{"user"}, | ||
"clustername": []string{clusterName}, | ||
} | ||
|
||
return fmt.Sprintf("cert-authority %s %s", strings.TrimSpace(string(keyBytes)), comment.Encode()), nil | ||
} | ||
|
||
// MarshalAuthorizedHostsFormat returns the certificate authority public key exported as a single line | ||
// that can be placed in ~/.ssh/authorized_hosts. The format adheres to the man sshd (8) | ||
// authorized_hosts format, a space-separated list of: marker, hosts, key, and comment. | ||
// For example: | ||
// | ||
// @cert-authority *.cluster-a ssh-rsa AAA... type=host | ||
// | ||
// URL encoding is used to pass the CA type and allowed logins into the comment field. | ||
func MarshalAuthorizedHostsFormat(clusterName string, keyBytes []byte, logins []string) (string, error) { | ||
comment := url.Values{ | ||
"type": []string{"host"}, | ||
"logins": logins, | ||
} | ||
|
||
return fmt.Sprintf("@cert-authority *.%s %s %s", | ||
clusterName, strings.TrimSpace(string(keyBytes)), comment.Encode()), nil | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.