代码拉取完成,页面将自动刷新
// Copyright 2015 The Cockroach Authors.
//
// 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 cli
import (
"os"
"github.com/spf13/cobra"
"github.com/cockroachdb/cockroach/pkg/security"
"github.com/cockroachdb/cockroach/pkg/sql"
)
var password bool
// A getUserCmd command displays the config for the specified username.
var getUserCmd = &cobra.Command{
Use: "get [options] <username>",
Short: "fetches and displays a user",
Long: `
Fetches and displays the user for <username>.
`,
RunE: MaybeDecorateGRPCError(runGetUser),
}
func runGetUser(cmd *cobra.Command, args []string) error {
if len(args) != 1 {
return usageAndError(cmd)
}
conn, err := getPasswordAndMakeSQLClient()
if err != nil {
return err
}
defer conn.Close()
return runQueryAndFormatResults(conn, os.Stdout,
makeQuery(`SELECT * FROM system.users WHERE username=$1`, args[0]))
}
// A lsUsersCmd command displays a list of users.
var lsUsersCmd = &cobra.Command{
Use: "ls [options]",
Short: "list all users",
Long: `
List all users.
`,
RunE: MaybeDecorateGRPCError(runLsUsers),
}
func runLsUsers(cmd *cobra.Command, args []string) error {
if len(args) > 0 {
return usageAndError(cmd)
}
conn, err := getPasswordAndMakeSQLClient()
if err != nil {
return err
}
defer conn.Close()
return runQueryAndFormatResults(conn, os.Stdout,
makeQuery(`SELECT username FROM system.users`))
}
// A rmUserCmd command removes the user for the specified username.
var rmUserCmd = &cobra.Command{
Use: "rm [options] <username>",
Short: "remove a user",
Long: `
Remove an existing user by username.
`,
RunE: MaybeDecorateGRPCError(runRmUser),
}
func runRmUser(cmd *cobra.Command, args []string) error {
if len(args) != 1 {
return usageAndError(cmd)
}
conn, err := getPasswordAndMakeSQLClient()
if err != nil {
return err
}
defer conn.Close()
return runQueryAndFormatResults(conn, os.Stdout,
makeQuery(`DELETE FROM system.users WHERE username=$1`, args[0]))
}
// A setUserCmd command creates a new or updates an existing user.
var setUserCmd = &cobra.Command{
Use: "set [options] <username>",
Short: "create or update a user",
Long: `
Create or update a user for the specified username, prompting
for the password.
Valid usernames contain 1 to 63 alphanumeric characters. They must
begin with either a letter or an underscore. Subsequent characters
may be letters, numbers, or underscores.
`,
RunE: MaybeDecorateGRPCError(runSetUser),
}
// runSetUser prompts for a password, then inserts the user and hash
// into the system.users table.
// TODO(marc): once we have more fields in the user, we will need
// to allow changing just some of them (eg: change email, but leave password).
func runSetUser(cmd *cobra.Command, args []string) error {
if len(args) != 1 {
return usageAndError(cmd)
}
var err error
var username string
if username, err = sql.NormalizeAndValidateUsername(args[0]); err != nil {
return err
}
var hashed []byte
if password {
if hashed, err = security.PromptForPasswordAndHash(); err != nil {
return err
}
}
conn, err := getPasswordAndMakeSQLClient()
if err != nil {
return err
}
defer conn.Close()
// TODO(asubiotto): Implement appropriate server-side authorization rules
// for users to be able to change their own passwords.
return runQueryAndFormatResults(conn, os.Stdout,
makeQuery(`UPSERT INTO system.users VALUES ($1, $2)`, username, hashed))
}
var userCmds = []*cobra.Command{
getUserCmd,
lsUsersCmd,
rmUserCmd,
setUserCmd,
}
var userCmd = &cobra.Command{
Use: "user",
Short: "get, set, list and remove users",
RunE: func(cmd *cobra.Command, args []string) error {
return cmd.Usage()
},
}
func init() {
userCmd.AddCommand(userCmds...)
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。