diff --git a/plugins/kiro/api_key.go b/plugins/kiro/api_key.go new file mode 100644 index 00000000..6083e6ae --- /dev/null +++ b/plugins/kiro/api_key.go @@ -0,0 +1,39 @@ +package kiro + +import ( + "github.com/1Password/shell-plugins/sdk" + "github.com/1Password/shell-plugins/sdk/importer" + "github.com/1Password/shell-plugins/sdk/provision" + "github.com/1Password/shell-plugins/sdk/schema" + "github.com/1Password/shell-plugins/sdk/schema/credname" + "github.com/1Password/shell-plugins/sdk/schema/fieldname" +) + +func APIKey() schema.CredentialType { + return schema.CredentialType{ + Name: credname.APIKey, + DocsURL: sdk.URL("https://kiro.dev/docs/cli/authentication/"), + ManagementURL: sdk.URL("https://app.kiro.dev"), + Fields: []schema.CredentialField{ + { + Name: fieldname.APIKey, + MarkdownDescription: "API Key used to authenticate to Kiro.", + Secret: true, + Composition: &schema.ValueComposition{ + Prefix: "ksk_", + Charset: schema.Charset{ + Uppercase: true, + Lowercase: true, + Digits: true, + }, + }, + }, + }, + DefaultProvisioner: provision.EnvVars(defaultEnvVarMapping), + Importer: importer.TryEnvVarPair(defaultEnvVarMapping), + } +} + +var defaultEnvVarMapping = map[string]sdk.FieldName{ + "KIRO_API_KEY": fieldname.APIKey, +} diff --git a/plugins/kiro/api_key_test.go b/plugins/kiro/api_key_test.go new file mode 100644 index 00000000..c08e8de4 --- /dev/null +++ b/plugins/kiro/api_key_test.go @@ -0,0 +1,43 @@ +package kiro + +import ( + "testing" + + "github.com/1Password/shell-plugins/sdk" + "github.com/1Password/shell-plugins/sdk/plugintest" + "github.com/1Password/shell-plugins/sdk/schema/fieldname" +) + +const exampleAPIKey = "ksk_12345678" + +func TestAPIKeyProvisioner(t *testing.T) { + plugintest.TestProvisioner(t, APIKey().DefaultProvisioner, map[string]plugintest.ProvisionCase{ + "default": { + ItemFields: map[sdk.FieldName]string{ + fieldname.APIKey: exampleAPIKey, + }, + ExpectedOutput: sdk.ProvisionOutput{ + Environment: map[string]string{ + "KIRO_API_KEY": exampleAPIKey, + }, + }, + }, + }) +} + +func TestAPIKeyImporter(t *testing.T) { + plugintest.TestImporter(t, APIKey().Importer, map[string]plugintest.ImportCase{ + "environment": { + Environment: map[string]string{ + "KIRO_API_KEY": exampleAPIKey, + }, + ExpectedCandidates: []sdk.ImportCandidate{ + { + Fields: map[sdk.FieldName]string{ + fieldname.APIKey: exampleAPIKey, + }, + }, + }, + }, + }) +} diff --git a/plugins/kiro/kiro.go b/plugins/kiro/kiro.go new file mode 100644 index 00000000..938a8134 --- /dev/null +++ b/plugins/kiro/kiro.go @@ -0,0 +1,22 @@ +package kiro + +import ( + "github.com/1Password/shell-plugins/sdk" + "github.com/1Password/shell-plugins/sdk/needsauth" + "github.com/1Password/shell-plugins/sdk/schema" + "github.com/1Password/shell-plugins/sdk/schema/credname" +) + +func KiroCLI() schema.Executable { + return schema.Executable{ + Name: "Kiro CLI", + Runs: []string{"kiro-cli"}, + DocsURL: sdk.URL("https://kiro.dev/docs/cli/"), + NeedsAuth: needsauth.NotForHelpOrVersion(), + Uses: []schema.CredentialUsage{ + { + Name: credname.APIKey, + }, + }, + } +} diff --git a/plugins/kiro/plugin.go b/plugins/kiro/plugin.go new file mode 100644 index 00000000..8d0fa90d --- /dev/null +++ b/plugins/kiro/plugin.go @@ -0,0 +1,22 @@ +package kiro + +import ( + "github.com/1Password/shell-plugins/sdk" + "github.com/1Password/shell-plugins/sdk/schema" +) + +func New() schema.Plugin { + return schema.Plugin{ + Name: "kiro", + Platform: schema.PlatformInfo{ + Name: "Kiro", + Homepage: sdk.URL("https://kiro.dev"), + }, + Credentials: []schema.CredentialType{ + APIKey(), + }, + Executables: []schema.Executable{ + KiroCLI(), + }, + } +}