本文整理匯總了Golang中github.com/juju/juju/cloud.NewCredential函數的典型用法代碼示例。如果您正苦於以下問題:Golang NewCredential函數的具體用法?Golang NewCredential怎麽用?Golang NewCredential使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了NewCredential函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: TestUpdateCloudCredentialsExisting
func (s *CloudCredentialsSuite) TestUpdateCloudCredentialsExisting(c *gc.C) {
err := s.State.AddCloud("stratus", cloud.Cloud{
Type: "low",
AuthTypes: cloud.AuthTypes{cloud.AccessKeyAuthType, cloud.UserPassAuthType},
})
c.Assert(err, jc.ErrorIsNil)
cred := cloud.NewCredential(cloud.AccessKeyAuthType, map[string]string{
"foo": "foo val",
"bar": "bar val",
})
tag := names.NewCloudCredentialTag("stratus/[email protected]/foobar")
err = s.State.UpdateCloudCredential(tag, cred)
c.Assert(err, jc.ErrorIsNil)
cred = cloud.NewCredential(cloud.UserPassAuthType, map[string]string{
"user": "bob's nephew",
"password": "simple",
})
cred.Revoked = true
err = s.State.UpdateCloudCredential(tag, cred)
c.Assert(err, jc.ErrorIsNil)
// The retrieved credentials have labels although cloud.NewCredential
// doesn't have them, so add it to the expected value.
cred.Label = "foobar"
out, err := s.State.CloudCredential(tag)
c.Assert(err, jc.ErrorIsNil)
c.Assert(out, jc.DeepEquals, cred)
}
示例2: TestUpdate
func (s *updateCredentialSuite) TestUpdate(c *gc.C) {
store := &jujuclienttesting.MemStore{
Controllers: map[string]jujuclient.ControllerDetails{
"controller": {},
},
CurrentControllerName: "controller",
Accounts: map[string]jujuclient.AccountDetails{
"controller": {
User: "[email protected]",
},
},
Credentials: map[string]jujucloud.CloudCredential{
"aws": {
AuthCredentials: map[string]jujucloud.Credential{
"my-credential": jujucloud.NewCredential(jujucloud.AccessKeyAuthType, nil),
"another-credential": jujucloud.NewCredential(jujucloud.UserPassAuthType, nil),
},
},
},
}
fake := &fakeUpdateCredentialAPI{}
cmd := cloud.NewUpdateCredentialCommandForTest(store, fake)
ctx, err := testing.RunCommand(c, cmd, "aws", "my-credential")
c.Assert(err, jc.ErrorIsNil)
output := testing.Stderr(ctx)
output = strings.Replace(output, "\n", "", -1)
c.Assert(output, gc.Equals, `Updated credential "my-credential" for user "[email protected]" on cloud "aws".`)
c.Assert(fake.creds, jc.DeepEquals, map[names.CloudCredentialTag]jujucloud.Credential{
names.NewCloudCredentialTag("aws/[email protected]/my-credential"): jujucloud.NewCredential(jujucloud.AccessKeyAuthType, nil),
})
}
示例3: SetUpTest
func (s *credentialsSuite) SetUpTest(c *gc.C) {
s.FakeJujuXDGDataHomeSuite.SetUpTest(c)
s.cloud = cloud.Cloud{
Type: "fake",
Regions: []cloud.Region{
{Name: "first-region"},
{Name: "second-region"},
},
}
dir := c.MkDir()
keyFile := filepath.Join(dir, "keyfile")
err := ioutil.WriteFile(keyFile, []byte("value"), 0600)
c.Assert(err, jc.ErrorIsNil)
s.store = jujuclienttesting.NewMemStore()
s.store.Credentials["cloud"] = cloud.CloudCredential{
DefaultRegion: "second-region",
AuthCredentials: map[string]cloud.Credential{
"interactive": cloud.NewCredential("interactive", map[string]string{
"username": "user",
}),
"secrets": cloud.NewCredential(cloud.UserPassAuthType, map[string]string{
"username": "user",
"password": "sekret",
"key-file": keyFile,
}),
},
}
}
示例4: SetUpTest
func (s *CredentialsSuite) SetUpTest(c *gc.C) {
s.FakeJujuXDGDataHomeSuite.SetUpTest(c)
s.store = jujuclient.NewFileCredentialStore()
s.cloudName = "testcloud"
s.credentials = cloud.CloudCredential{
DefaultCredential: "peter",
DefaultRegion: "east",
AuthCredentials: map[string]cloud.Credential{
"peter": cloud.NewCredential(cloud.AccessKeyAuthType, nil),
"paul": cloud.NewCredential(cloud.AccessKeyAuthType, nil),
},
}
}
示例5: FinalizeCredential
// FinalizeCredential is part of the environs.ProviderCredentials interface.
func (c environProviderCredentials) FinalizeCredential(
ctx environs.FinalizeCredentialContext,
args environs.FinalizeCredentialParams,
) (*cloud.Credential, error) {
switch authType := args.Credential.AuthType(); authType {
case cloud.UserPassAuthType:
fmt.Fprintf(ctx.GetStderr(), `
WARNING: The %q auth-type is deprecated, and will be removed soon.
Please update the credential in ~/.local/share/juju/credentials.yaml,
changing auth-type to %q, and dropping the tenant-id field.
`[1:],
authType, clientCredentialsAuthType,
)
attrs := args.Credential.Attributes()
delete(attrs, credAttrTenantId)
out := cloud.NewCredential(clientCredentialsAuthType, attrs)
out.Label = args.Credential.Label
return &out, nil
case deviceCodeAuthType:
subscriptionId := args.Credential.Attributes()[credAttrSubscriptionId]
applicationId, password, err := c.interactiveCreateServicePrincipal(
ctx.GetStderr(),
c.sender,
c.requestInspector,
args.CloudEndpoint,
args.CloudIdentityEndpoint,
subscriptionId,
clock.WallClock,
utils.NewUUID,
)
if err != nil {
return nil, errors.Trace(err)
}
out := cloud.NewCredential(clientCredentialsAuthType, map[string]string{
credAttrSubscriptionId: subscriptionId,
credAttrAppId: applicationId,
credAttrAppPassword: password,
})
out.Label = args.Credential.Label
return &out, nil
case clientCredentialsAuthType:
return &args.Credential, nil
default:
return nil, errors.NotSupportedf("%q auth-type", authType)
}
}
示例6: FinalizeCredential
// FinalizeCredential is part of the environs.ProviderCredentials interface.
func (c environProviderCredentials) FinalizeCredential(
ctx environs.FinalizeCredentialContext,
args environs.FinalizeCredentialParams,
) (*cloud.Credential, error) {
switch authType := args.Credential.AuthType(); authType {
case deviceCodeAuthType:
subscriptionId := args.Credential.Attributes()[credAttrSubscriptionId]
applicationId, password, err := c.interactiveCreateServicePrincipal(
ctx.GetStderr(),
c.sender,
c.requestInspector,
args.CloudEndpoint,
args.CloudIdentityEndpoint,
subscriptionId,
clock.WallClock,
utils.NewUUID,
)
if err != nil {
return nil, errors.Trace(err)
}
out := cloud.NewCredential(clientCredentialsAuthType, map[string]string{
credAttrSubscriptionId: subscriptionId,
credAttrAppId: applicationId,
credAttrAppPassword: password,
})
out.Label = args.Credential.Label
return &out, nil
case clientCredentialsAuthType:
return &args.Credential, nil
default:
return nil, errors.NotSupportedf("%q auth-type", authType)
}
}
示例7: TestRemoveCredentials
func (s *CloudCredentialsSuite) TestRemoveCredentials(c *gc.C) {
// Create it.
err := s.State.AddCloud("stratus", cloud.Cloud{
Type: "low",
AuthTypes: cloud.AuthTypes{cloud.AccessKeyAuthType, cloud.UserPassAuthType},
})
c.Assert(err, jc.ErrorIsNil)
tag := names.NewCloudCredentialTag("stratus/[email protected]/bobcred1")
cred := cloud.NewCredential(cloud.AccessKeyAuthType, map[string]string{
"foo": "foo val",
"bar": "bar val",
})
err = s.State.UpdateCloudCredential(tag, cred)
c.Assert(err, jc.ErrorIsNil)
_, err = s.State.CloudCredential(tag)
c.Assert(err, jc.ErrorIsNil)
// Remove it.
err = s.State.RemoveCloudCredential(tag)
c.Assert(err, jc.ErrorIsNil)
// Check it.
_, err = s.State.CloudCredential(tag)
c.Assert(err, jc.Satisfies, errors.IsNotFound)
}
示例8: TestBootstrapConfig
func (s *ConfigSuite) TestBootstrapConfig(c *gc.C) {
for i, test := range bootstrapConfigTests {
c.Logf("test %d: %s", i, test.info)
attrs := validAttrs().Merge(test.insert).Delete(test.remove...)
credentialAttrs := make(map[string]string, len(attrs))
for k, v := range attrs.Delete("type") {
credentialAttrs[k] = fmt.Sprintf("%v", v)
}
testConfig := newConfig(c, attrs)
preparedConfig, err := jp.Provider.BootstrapConfig(environs.BootstrapConfigParams{
Config: testConfig,
Credentials: cloud.NewCredential(
cloud.UserPassAuthType,
credentialAttrs,
),
})
if test.err == "" {
c.Check(err, jc.ErrorIsNil)
attrs := preparedConfig.AllAttrs()
for field, value := range test.expect {
c.Check(attrs[field], gc.Equals, value)
}
} else {
c.Check(preparedConfig, gc.IsNil)
c.Check(err, gc.ErrorMatches, test.err)
}
}
}
示例9: makeEnviron
func (suite *maas2Suite) makeEnviron(c *gc.C, controller gomaasapi.Controller) *maasEnviron {
if controller != nil {
suite.injectController(controller)
}
testAttrs := coretesting.Attrs{}
for k, v := range maasEnvAttrs {
testAttrs[k] = v
}
testAttrs["agent-version"] = version.Current.String()
cred := cloud.NewCredential(cloud.OAuth1AuthType, map[string]string{
"maas-oauth": "a:b:c",
})
cloud := environs.CloudSpec{
Type: "maas",
Name: "maas",
Endpoint: "http://any-old-junk.invalid/",
Credential: &cred,
}
attrs := coretesting.FakeConfig().Merge(testAttrs)
suite.controllerUUID = coretesting.FakeControllerConfig().ControllerUUID()
cfg, err := config.New(config.NoDefaults, attrs)
c.Assert(err, jc.ErrorIsNil)
env, err := NewEnviron(cloud, cfg)
c.Assert(err, jc.ErrorIsNil)
c.Assert(env, gc.NotNil)
return env
}
示例10: TestInitializeWithInvalidCredentialType
func (s *InitializeSuite) TestInitializeWithInvalidCredentialType(c *gc.C) {
owner := names.NewLocalUserTag("initialize-admin")
modelCfg := testing.ModelConfig(c)
controllerCfg := testing.FakeControllerConfig()
credentialTag := names.NewCloudCredentialTag("dummy/" + owner.Canonical() + "/borken")
_, err := state.Initialize(state.InitializeParams{
Clock: clock.WallClock,
ControllerConfig: controllerCfg,
ControllerModelArgs: state.ModelArgs{
CloudName: "dummy",
Owner: owner,
Config: modelCfg,
StorageProviderRegistry: storage.StaticProviderRegistry{},
},
CloudName: "dummy",
Cloud: cloud.Cloud{
Type: "dummy",
AuthTypes: []cloud.AuthType{
cloud.AccessKeyAuthType, cloud.OAuth1AuthType,
},
},
CloudCredentials: map[names.CloudCredentialTag]cloud.Credential{
credentialTag: cloud.NewCredential(cloud.UserPassAuthType, nil),
},
MongoInfo: statetesting.NewMongoInfo(),
MongoDialOpts: mongotest.DialOpts(),
})
c.Assert(err, gc.ErrorMatches,
`validating initialization args: validating cloud credentials: credential "dummy/[email protected]/borken" with auth-type "userpass" is not supported \(expected one of \["access-key" "oauth1"\]\)`,
)
}
示例11: TestMarshalAccessKey
func (s *credentialsSuite) TestMarshalAccessKey(c *gc.C) {
creds := map[string]cloud.CloudCredential{
"aws": {
DefaultCredential: "default-cred",
DefaultRegion: "us-west-2",
AuthCredentials: map[string]cloud.Credential{
"peter": cloud.NewCredential(cloud.AccessKeyAuthType, map[string]string{
"access-key": "key",
"secret-key": "secret",
}),
// TODO(wallyworld) - add anther credential once goyaml.v2 supports inline MapSlice.
//"paul": &cloud.AccessKeyCredentials{
// Key: "paulkey",
// Secret: "paulsecret",
//},
},
},
}
out, err := cloud.MarshalCredentials(creds)
c.Assert(err, jc.ErrorIsNil)
c.Assert(string(out), gc.Equals, `
credentials:
aws:
default-credential: default-cred
default-region: us-west-2
peter:
auth-type: access-key
access-key: key
secret-key: secret
`[1:])
}
示例12: TestMarshalOAuth2
func (s *credentialsSuite) TestMarshalOAuth2(c *gc.C) {
creds := map[string]cloud.CloudCredential{
"google": {
DefaultCredential: "default-cred",
DefaultRegion: "West US",
AuthCredentials: map[string]cloud.Credential{
"peter": cloud.NewCredential(cloud.OAuth2AuthType, map[string]string{
"client-id": "client-id",
"client-email": "client-email",
"private-key": "secret",
}),
},
},
}
out, err := cloud.MarshalCredentials(creds)
c.Assert(err, jc.ErrorIsNil)
c.Assert(string(out), gc.Equals, `
credentials:
google:
default-credential: default-cred
default-region: West US
peter:
auth-type: oauth2
client-email: client-email
client-id: client-id
private-key: secret
`[1:])
}
示例13: TestMarshalOAuth1
func (s *credentialsSuite) TestMarshalOAuth1(c *gc.C) {
creds := map[string]cloud.CloudCredential{
"maas": {
DefaultCredential: "default-cred",
DefaultRegion: "region-default",
AuthCredentials: map[string]cloud.Credential{
"peter": cloud.NewCredential(cloud.OAuth1AuthType, map[string]string{
"consumer-key": "consumer-key",
"consumer-secret": "consumer-secret",
"access-token": "access-token",
"token-secret": "token-secret",
}),
},
},
}
out, err := cloud.MarshalCredentials(creds)
c.Assert(err, jc.ErrorIsNil)
c.Assert(string(out), gc.Equals, `
credentials:
maas:
default-credential: default-cred
default-region: region-default
peter:
auth-type: oauth1
access-token: access-token
consumer-key: consumer-key
consumer-secret: consumer-secret
token-secret: token-secret
`[1:])
}
示例14: TestMarshalAzureCredntials
func (s *credentialsSuite) TestMarshalAzureCredntials(c *gc.C) {
creds := map[string]cloud.CloudCredential{
"azure": {
DefaultCredential: "default-cred",
DefaultRegion: "Central US",
AuthCredentials: map[string]cloud.Credential{
"peter": cloud.NewCredential(cloud.UserPassAuthType, map[string]string{
"application-id": "app-id",
"application-password": "app-secret",
"subscription-id": "subscription-id",
"tenant-id": "tenant-id",
}),
},
},
}
out, err := cloud.MarshalCredentials(creds)
c.Assert(err, jc.ErrorIsNil)
c.Assert(string(out), gc.Equals, `
credentials:
azure:
default-credential: default-cred
default-region: Central US
peter:
auth-type: userpass
application-id: app-id
application-password: app-secret
subscription-id: subscription-id
tenant-id: tenant-id
`[1:])
}
示例15: TestUnknownAttrsContainAgentName
func (suite *EnvironProviderSuite) TestUnknownAttrsContainAgentName(c *gc.C) {
attrs := testing.FakeConfig().Merge(testing.Attrs{
"type": "maas",
})
config, err := config.New(config.NoDefaults, attrs)
c.Assert(err, jc.ErrorIsNil)
cfg, err := providerInstance.BootstrapConfig(environs.BootstrapConfigParams{
Config: config,
CloudEndpoint: "http://maas.testing.invalid/maas/",
Credentials: cloud.NewCredential(
cloud.OAuth1AuthType,
map[string]string{
"maas-oauth": "aa:bb:cc",
},
),
})
c.Assert(err, jc.ErrorIsNil)
unknownAttrs := cfg.UnknownAttrs()
c.Assert(unknownAttrs["maas-server"], gc.Equals, "http://maas.testing.invalid/maas/")
uuid, ok := unknownAttrs["maas-agent-name"]
c.Assert(ok, jc.IsTrue)
c.Assert(uuid, jc.Satisfies, utils.IsValidUUIDString)
}