Skip to content

Commit

Permalink
Merge pull request #341 from rajapri28613/kaggle
Browse files Browse the repository at this point in the history
Add support for Kaggle CLI
  • Loading branch information
Arun Sathiya authored Jul 25, 2023
2 parents 3eaa0d5 + 07f6710 commit 0b46a42
Show file tree
Hide file tree
Showing 5 changed files with 188 additions and 0 deletions.
81 changes: 81 additions & 0 deletions plugins/kaggle/api_token.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,81 @@
package kaggle

import (
"context"

"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 APIToken() schema.CredentialType {
return schema.CredentialType{
Name: credname.APIToken,
DocsURL: sdk.URL("https://www.kaggle.com/docs/api"),
ManagementURL: sdk.URL("https://www.kaggle.com/settings/account"),
Fields: []schema.CredentialField{
{
Name: fieldname.Token,
MarkdownDescription: "API Token used to authenticate to Kaggle.",
Secret: true,
Composition: &schema.ValueComposition{
Length: 32,
Charset: schema.Charset{
Lowercase: true,
Digits: true,
},
},
},
{
Name: fieldname.Username,
MarkdownDescription: "Username to authenticate to Kaggle.",
Secret: false,
Composition: &schema.ValueComposition{
Charset: schema.Charset{
Lowercase: true,
Digits: true,
},
},
},
},
DefaultProvisioner: provision.EnvVars(defaultEnvVarMapping),
Importer: importer.TryAll(
importer.TryEnvVarPair(defaultEnvVarMapping),
TryKaggleConfigFile("~/.kaggle/kaggle.json"),
)}
}

var defaultEnvVarMapping = map[string]sdk.FieldName{
"KAGGLE_KEY": fieldname.Token,
"KAGGLE_USERNAME": fieldname.Username,
}

func TryKaggleConfigFile(path string) sdk.Importer {
return importer.TryFile(path, func(ctx context.Context, contents importer.FileContents, in sdk.ImportInput, out *sdk.ImportAttempt) {
var config Config
if err := contents.ToJSON(&config); err != nil {
out.AddError(err)
return
}

if config.Token == "" {
return
}

out.AddCandidate(sdk.ImportCandidate{
Fields: map[sdk.FieldName]string{
fieldname.Token: config.Token,
fieldname.Username: config.Username,
},
NameHint: importer.SanitizeNameHint(config.Username),
})
})
}

type Config struct {
Username string `json:"username"`
Token string `json:"key"`
}
59 changes: 59 additions & 0 deletions plugins/kaggle/api_token_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,59 @@
package kaggle

import (
"testing"

"github.com/1Password/shell-plugins/sdk"
"github.com/1Password/shell-plugins/sdk/plugintest"
"github.com/1Password/shell-plugins/sdk/schema/fieldname"
)

func TestAPITokenProvisioner(t *testing.T) {
plugintest.TestProvisioner(t, APIToken().DefaultProvisioner, map[string]plugintest.ProvisionCase{
"default": {
ItemFields: map[sdk.FieldName]string{
fieldname.Token: "z2pifkruzgbb17plmz2gux21fexample",
fieldname.Username: "username",
},
ExpectedOutput: sdk.ProvisionOutput{
Environment: map[string]string{
"KAGGLE_KEY": "z2pifkruzgbb17plmz2gux21fexample",
"KAGGLE_USERNAME": "username",
},
},
},
})
}

func TestAPITokenImporter(t *testing.T) {
plugintest.TestImporter(t, APIToken().Importer, map[string]plugintest.ImportCase{
"environment": {
Environment: map[string]string{
"KAGGLE_KEY": "z2pifkruzgbb17plmz2gux21fexample",
"KAGGLE_USERNAME": "username",
},
ExpectedCandidates: []sdk.ImportCandidate{
{
Fields: map[sdk.FieldName]string{
fieldname.Token: "z2pifkruzgbb17plmz2gux21fexample",
fieldname.Username: "username",
},
},
},
},
"config file": {
Files: map[string]string{
"~/.kaggle/kaggle.json": plugintest.LoadFixture(t, "config.json"),
},
ExpectedCandidates: []sdk.ImportCandidate{
{
Fields: map[sdk.FieldName]string{
fieldname.Token: "z2pifkruzgbb17plmz2gux21fexample",
fieldname.Username: "username",
},
NameHint: "username",
},
},
},
})
}
25 changes: 25 additions & 0 deletions plugins/kaggle/kaggle.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
package kaggle

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 KaggleCLI() schema.Executable {
return schema.Executable{
Name: "Kaggle CLI",
Runs: []string{"kaggle"},
DocsURL: sdk.URL("https://github.com/Kaggle/kaggle-api"),
NeedsAuth: needsauth.IfAll(
needsauth.NotForHelpOrVersion(),
needsauth.NotWithoutArgs(),
),
Uses: []schema.CredentialUsage{
{
Name: credname.APIToken,
},
},
}
}
22 changes: 22 additions & 0 deletions plugins/kaggle/plugin.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
package kaggle

import (
"github.com/1Password/shell-plugins/sdk"
"github.com/1Password/shell-plugins/sdk/schema"
)

func New() schema.Plugin {
return schema.Plugin{
Name: "kaggle",
Platform: schema.PlatformInfo{
Name: "Kaggle",
Homepage: sdk.URL("https://kaggle.com"),
},
Credentials: []schema.CredentialType{
APIToken(),
},
Executables: []schema.Executable{
KaggleCLI(),
},
}
}
1 change: 1 addition & 0 deletions plugins/kaggle/test-fixtures/config.json
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
{"username":"username","key":"z2pifkruzgbb17plmz2gux21fexample"}

0 comments on commit 0b46a42

Please sign in to comment.