Skip to content

Commit d5134e3

Browse files
Merge pull request #245 from andresayej/feature/laravel-vapor-plugin
Shell Plugin for Laravel Vapor CLI
2 parents 6b0ac07 + 75f3156 commit d5134e3

File tree

5 files changed

+165
-0
lines changed

5 files changed

+165
-0
lines changed

plugins/laravelvapor/api_token.go

Lines changed: 59 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,59 @@
1+
package laravelvapor
2+
3+
import (
4+
"context"
5+
6+
"github.com/1Password/shell-plugins/sdk"
7+
"github.com/1Password/shell-plugins/sdk/importer"
8+
"github.com/1Password/shell-plugins/sdk/provision"
9+
"github.com/1Password/shell-plugins/sdk/schema"
10+
"github.com/1Password/shell-plugins/sdk/schema/credname"
11+
"github.com/1Password/shell-plugins/sdk/schema/fieldname"
12+
)
13+
14+
func APIToken() schema.CredentialType {
15+
return schema.CredentialType{
16+
Name: credname.APIToken,
17+
DocsURL: sdk.URL("https://docs.vapor.build/1.0/introduction.html"),
18+
ManagementURL: sdk.URL("https://vapor.laravel.com/app/account/api-tokens"),
19+
Fields: []schema.CredentialField{
20+
{
21+
Name: fieldname.Token,
22+
MarkdownDescription: "API Token used to authenticate to Laravel Vapor.",
23+
Secret: true,
24+
},
25+
},
26+
DefaultProvisioner: provision.EnvVars(defaultEnvVarMapping),
27+
Importer: importer.TryAll(
28+
importer.TryEnvVarPair(defaultEnvVarMapping),
29+
TryLaravelVaporConfigFile(),
30+
)}
31+
}
32+
33+
var defaultEnvVarMapping = map[string]sdk.FieldName{
34+
"VAPOR_API_TOKEN": fieldname.Token,
35+
}
36+
37+
func TryLaravelVaporConfigFile() sdk.Importer {
38+
return importer.TryFile("~/.laravel-vapor/config.json", func(ctx context.Context, contents importer.FileContents, in sdk.ImportInput, out *sdk.ImportAttempt) {
39+
var config Config
40+
if err := contents.ToJSON(&config); err != nil {
41+
out.AddError(err)
42+
return
43+
}
44+
45+
if config.Token == "" {
46+
return
47+
}
48+
49+
out.AddCandidate(sdk.ImportCandidate{
50+
Fields: map[sdk.FieldName]string{
51+
fieldname.Token: config.Token,
52+
},
53+
})
54+
})
55+
}
56+
57+
type Config struct {
58+
Token string `json:"token"`
59+
}
Lines changed: 53 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,53 @@
1+
package laravelvapor
2+
3+
import (
4+
"testing"
5+
6+
"github.com/1Password/shell-plugins/sdk"
7+
"github.com/1Password/shell-plugins/sdk/plugintest"
8+
"github.com/1Password/shell-plugins/sdk/schema/fieldname"
9+
)
10+
11+
func TestAPITokenProvisioner(t *testing.T) {
12+
plugintest.TestProvisioner(t, APIToken().DefaultProvisioner, map[string]plugintest.ProvisionCase{
13+
"default": {
14+
ItemFields: map[sdk.FieldName]string{
15+
fieldname.Token: "eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9.eyJhdWQiOiIxIiwianRpIjoiYWFhODU2M2NkYjU5YzQyMmRkMGFlOTRlNTVjZTFjYzRiNjEwNzE3MTBiMTIzYWEzMzczNzc3MjIxOGVjN2Q5Yzc1MjgxYWEwNTVhOTFkZWQiLCJpYXQiOjE2ODEzNzUyMTkuNDg1NTUzLCJuYmYiOjE2ODEzNzUyMTkuNDg1NTU2LCJleHAiOjE5OTY5OTQ0MTkuNDc5MzUyLCJzdWIiOiIxNjkyMzQiLCJzY29wZXMiOltdfQ.a1Ny2UAzgSkKZGaXjrFBmjFuBAWerLj73l-ktK1iGmdCukD_9AXo75rsOq-BV11GWbZb1ws0LX_hkcSBKwxaD7ou_l9cQlkOM8vWni1dq0Vjd1OwctqemBqFl1SD-Gyw7-st7phELyZK77BVpyUu0oTAtRAREx0ybDj3UE672JF9LwgtOo7Nv2TUTWT-rlZPUIvOcwxliE-sWA29tPZOviRIveQ3-O3Bh8-LKY7gVjQv0UDfR3SM4SEPPuacaVRR5rnklFKlaar4sfnL5WL6-iazQ8o1J7IuNsBfDf9OJqslvtzQFg6GWcSC0AzxWsho5tzyvmsbbhSA5iOFZ7NMB93V53fByBDz4gLWD90HS0jYQ-gOVqOQBWrTJMuPu4C2TDpuow27Kc4rJrH6cKd7mZnf8B910jHPzlkEY33ommCT9Oe6C-wDGpM4CnUaVb9jaNMl67j2Ak7-pUzv7iiAajt5_Rhb4C7Kx9wFTZR6AIbP2GAfc4gXhOXWxV8tXz5LBJ_JXwgTDIfnBfqqKeYZ-GyCMmly6w2suxLwR00e4JCu1_LjDGoWA8-VPOVafhwA51t5nQ0HVzeyuEpVfqwRhsjk2ln56CY8sLd2YU12fPJiitN88t8YccLDugc8Q79OelJTgIO17d50kzXZ1twzwpimWTjgCIS90K19EXAMPLE",
16+
},
17+
ExpectedOutput: sdk.ProvisionOutput{
18+
Environment: map[string]string{
19+
"VAPOR_API_TOKEN": "eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9.eyJhdWQiOiIxIiwianRpIjoiYWFhODU2M2NkYjU5YzQyMmRkMGFlOTRlNTVjZTFjYzRiNjEwNzE3MTBiMTIzYWEzMzczNzc3MjIxOGVjN2Q5Yzc1MjgxYWEwNTVhOTFkZWQiLCJpYXQiOjE2ODEzNzUyMTkuNDg1NTUzLCJuYmYiOjE2ODEzNzUyMTkuNDg1NTU2LCJleHAiOjE5OTY5OTQ0MTkuNDc5MzUyLCJzdWIiOiIxNjkyMzQiLCJzY29wZXMiOltdfQ.a1Ny2UAzgSkKZGaXjrFBmjFuBAWerLj73l-ktK1iGmdCukD_9AXo75rsOq-BV11GWbZb1ws0LX_hkcSBKwxaD7ou_l9cQlkOM8vWni1dq0Vjd1OwctqemBqFl1SD-Gyw7-st7phELyZK77BVpyUu0oTAtRAREx0ybDj3UE672JF9LwgtOo7Nv2TUTWT-rlZPUIvOcwxliE-sWA29tPZOviRIveQ3-O3Bh8-LKY7gVjQv0UDfR3SM4SEPPuacaVRR5rnklFKlaar4sfnL5WL6-iazQ8o1J7IuNsBfDf9OJqslvtzQFg6GWcSC0AzxWsho5tzyvmsbbhSA5iOFZ7NMB93V53fByBDz4gLWD90HS0jYQ-gOVqOQBWrTJMuPu4C2TDpuow27Kc4rJrH6cKd7mZnf8B910jHPzlkEY33ommCT9Oe6C-wDGpM4CnUaVb9jaNMl67j2Ak7-pUzv7iiAajt5_Rhb4C7Kx9wFTZR6AIbP2GAfc4gXhOXWxV8tXz5LBJ_JXwgTDIfnBfqqKeYZ-GyCMmly6w2suxLwR00e4JCu1_LjDGoWA8-VPOVafhwA51t5nQ0HVzeyuEpVfqwRhsjk2ln56CY8sLd2YU12fPJiitN88t8YccLDugc8Q79OelJTgIO17d50kzXZ1twzwpimWTjgCIS90K19EXAMPLE",
20+
},
21+
},
22+
},
23+
})
24+
}
25+
26+
func TestAPITokenImporter(t *testing.T) {
27+
plugintest.TestImporter(t, APIToken().Importer, map[string]plugintest.ImportCase{
28+
"environment": {
29+
Environment: map[string]string{
30+
"VAPOR_API_TOKEN": "eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9.eyJhdWQiOiIxIiwianRpIjoiYWFhODU2M2NkYjU5YzQyMmRkMGFlOTRlNTVjZTFjYzRiNjEwNzE3MTBiMTIzYWEzMzczNzc3MjIxOGVjN2Q5Yzc1MjgxYWEwNTVhOTFkZWQiLCJpYXQiOjE2ODEzNzUyMTkuNDg1NTUzLCJuYmYiOjE2ODEzNzUyMTkuNDg1NTU2LCJleHAiOjE5OTY5OTQ0MTkuNDc5MzUyLCJzdWIiOiIxNjkyMzQiLCJzY29wZXMiOltdfQ.a1Ny2UAzgSkKZGaXjrFBmjFuBAWerLj73l-ktK1iGmdCukD_9AXo75rsOq-BV11GWbZb1ws0LX_hkcSBKwxaD7ou_l9cQlkOM8vWni1dq0Vjd1OwctqemBqFl1SD-Gyw7-st7phELyZK77BVpyUu0oTAtRAREx0ybDj3UE672JF9LwgtOo7Nv2TUTWT-rlZPUIvOcwxliE-sWA29tPZOviRIveQ3-O3Bh8-LKY7gVjQv0UDfR3SM4SEPPuacaVRR5rnklFKlaar4sfnL5WL6-iazQ8o1J7IuNsBfDf9OJqslvtzQFg6GWcSC0AzxWsho5tzyvmsbbhSA5iOFZ7NMB93V53fByBDz4gLWD90HS0jYQ-gOVqOQBWrTJMuPu4C2TDpuow27Kc4rJrH6cKd7mZnf8B910jHPzlkEY33ommCT9Oe6C-wDGpM4CnUaVb9jaNMl67j2Ak7-pUzv7iiAajt5_Rhb4C7Kx9wFTZR6AIbP2GAfc4gXhOXWxV8tXz5LBJ_JXwgTDIfnBfqqKeYZ-GyCMmly6w2suxLwR00e4JCu1_LjDGoWA8-VPOVafhwA51t5nQ0HVzeyuEpVfqwRhsjk2ln56CY8sLd2YU12fPJiitN88t8YccLDugc8Q79OelJTgIO17d50kzXZ1twzwpimWTjgCIS90K19EXAMPLE",
31+
},
32+
ExpectedCandidates: []sdk.ImportCandidate{
33+
{
34+
Fields: map[sdk.FieldName]string{
35+
fieldname.Token: "eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9.eyJhdWQiOiIxIiwianRpIjoiYWFhODU2M2NkYjU5YzQyMmRkMGFlOTRlNTVjZTFjYzRiNjEwNzE3MTBiMTIzYWEzMzczNzc3MjIxOGVjN2Q5Yzc1MjgxYWEwNTVhOTFkZWQiLCJpYXQiOjE2ODEzNzUyMTkuNDg1NTUzLCJuYmYiOjE2ODEzNzUyMTkuNDg1NTU2LCJleHAiOjE5OTY5OTQ0MTkuNDc5MzUyLCJzdWIiOiIxNjkyMzQiLCJzY29wZXMiOltdfQ.a1Ny2UAzgSkKZGaXjrFBmjFuBAWerLj73l-ktK1iGmdCukD_9AXo75rsOq-BV11GWbZb1ws0LX_hkcSBKwxaD7ou_l9cQlkOM8vWni1dq0Vjd1OwctqemBqFl1SD-Gyw7-st7phELyZK77BVpyUu0oTAtRAREx0ybDj3UE672JF9LwgtOo7Nv2TUTWT-rlZPUIvOcwxliE-sWA29tPZOviRIveQ3-O3Bh8-LKY7gVjQv0UDfR3SM4SEPPuacaVRR5rnklFKlaar4sfnL5WL6-iazQ8o1J7IuNsBfDf9OJqslvtzQFg6GWcSC0AzxWsho5tzyvmsbbhSA5iOFZ7NMB93V53fByBDz4gLWD90HS0jYQ-gOVqOQBWrTJMuPu4C2TDpuow27Kc4rJrH6cKd7mZnf8B910jHPzlkEY33ommCT9Oe6C-wDGpM4CnUaVb9jaNMl67j2Ak7-pUzv7iiAajt5_Rhb4C7Kx9wFTZR6AIbP2GAfc4gXhOXWxV8tXz5LBJ_JXwgTDIfnBfqqKeYZ-GyCMmly6w2suxLwR00e4JCu1_LjDGoWA8-VPOVafhwA51t5nQ0HVzeyuEpVfqwRhsjk2ln56CY8sLd2YU12fPJiitN88t8YccLDugc8Q79OelJTgIO17d50kzXZ1twzwpimWTjgCIS90K19EXAMPLE",
36+
},
37+
},
38+
},
39+
},
40+
"config file default path": {
41+
Files: map[string]string{
42+
"~/.laravel-vapor/config.json": plugintest.LoadFixture(t, "config.json"),
43+
},
44+
ExpectedCandidates: []sdk.ImportCandidate{
45+
{
46+
Fields: map[sdk.FieldName]string{
47+
fieldname.Token: "eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9.eyJhdWQiOiIxIiwianRpIjoiYWFhODU2M2NkYjU5YzQyMmRkMGFlOTRlNTVjZTFjYzRiNjEwNzE3MTBiMTIzYWEzMzczNzc3MjIxOGVjN2Q5Yzc1MjgxYWEwNTVhOTFkZWQiLCJpYXQiOjE2ODEzNzUyMTkuNDg1NTUzLCJuYmYiOjE2ODEzNzUyMTkuNDg1NTU2LCJleHAiOjE5OTY5OTQ0MTkuNDc5MzUyLCJzdWIiOiIxNjkyMzQiLCJzY29wZXMiOltdfQ.a1Ny2UAzgSkKZGaXjrFBmjFuBAWerLj73l-ktK1iGmdCukD_9AXo75rsOq-BV11GWbZb1ws0LX_hkcSBKwxaD7ou_l9cQlkOM8vWni1dq0Vjd1OwctqemBqFl1SD-Gyw7-st7phELyZK77BVpyUu0oTAtRAREx0ybDj3UE672JF9LwgtOo7Nv2TUTWT-rlZPUIvOcwxliE-sWA29tPZOviRIveQ3-O3Bh8-LKY7gVjQv0UDfR3SM4SEPPuacaVRR5rnklFKlaar4sfnL5WL6-iazQ8o1J7IuNsBfDf9OJqslvtzQFg6GWcSC0AzxWsho5tzyvmsbbhSA5iOFZ7NMB93V53fByBDz4gLWD90HS0jYQ-gOVqOQBWrTJMuPu4C2TDpuow27Kc4rJrH6cKd7mZnf8B910jHPzlkEY33ommCT9Oe6C-wDGpM4CnUaVb9jaNMl67j2Ak7-pUzv7iiAajt5_Rhb4C7Kx9wFTZR6AIbP2GAfc4gXhOXWxV8tXz5LBJ_JXwgTDIfnBfqqKeYZ-GyCMmly6w2suxLwR00e4JCu1_LjDGoWA8-VPOVafhwA51t5nQ0HVzeyuEpVfqwRhsjk2ln56CY8sLd2YU12fPJiitN88t8YccLDugc8Q79OelJTgIO17d50kzXZ1twzwpimWTjgCIS90K19EXAMPLE",
48+
},
49+
},
50+
},
51+
},
52+
})
53+
}

plugins/laravelvapor/plugin.go

Lines changed: 22 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,22 @@
1+
package laravelvapor
2+
3+
import (
4+
"github.com/1Password/shell-plugins/sdk"
5+
"github.com/1Password/shell-plugins/sdk/schema"
6+
)
7+
8+
func New() schema.Plugin {
9+
return schema.Plugin{
10+
Name: "laravelvapor",
11+
Platform: schema.PlatformInfo{
12+
Name: "Laravel Vapor",
13+
Homepage: sdk.URL("https://vapor.laravel.com"),
14+
},
15+
Credentials: []schema.CredentialType{
16+
APIToken(),
17+
},
18+
Executables: []schema.Executable{
19+
LaravelVaporCLI(),
20+
},
21+
}
22+
}
Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,4 @@
1+
{
2+
"token": "eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9.eyJhdWQiOiIxIiwianRpIjoiYWFhODU2M2NkYjU5YzQyMmRkMGFlOTRlNTVjZTFjYzRiNjEwNzE3MTBiMTIzYWEzMzczNzc3MjIxOGVjN2Q5Yzc1MjgxYWEwNTVhOTFkZWQiLCJpYXQiOjE2ODEzNzUyMTkuNDg1NTUzLCJuYmYiOjE2ODEzNzUyMTkuNDg1NTU2LCJleHAiOjE5OTY5OTQ0MTkuNDc5MzUyLCJzdWIiOiIxNjkyMzQiLCJzY29wZXMiOltdfQ.a1Ny2UAzgSkKZGaXjrFBmjFuBAWerLj73l-ktK1iGmdCukD_9AXo75rsOq-BV11GWbZb1ws0LX_hkcSBKwxaD7ou_l9cQlkOM8vWni1dq0Vjd1OwctqemBqFl1SD-Gyw7-st7phELyZK77BVpyUu0oTAtRAREx0ybDj3UE672JF9LwgtOo7Nv2TUTWT-rlZPUIvOcwxliE-sWA29tPZOviRIveQ3-O3Bh8-LKY7gVjQv0UDfR3SM4SEPPuacaVRR5rnklFKlaar4sfnL5WL6-iazQ8o1J7IuNsBfDf9OJqslvtzQFg6GWcSC0AzxWsho5tzyvmsbbhSA5iOFZ7NMB93V53fByBDz4gLWD90HS0jYQ-gOVqOQBWrTJMuPu4C2TDpuow27Kc4rJrH6cKd7mZnf8B910jHPzlkEY33ommCT9Oe6C-wDGpM4CnUaVb9jaNMl67j2Ak7-pUzv7iiAajt5_Rhb4C7Kx9wFTZR6AIbP2GAfc4gXhOXWxV8tXz5LBJ_JXwgTDIfnBfqqKeYZ-GyCMmly6w2suxLwR00e4JCu1_LjDGoWA8-VPOVafhwA51t5nQ0HVzeyuEpVfqwRhsjk2ln56CY8sLd2YU12fPJiitN88t8YccLDugc8Q79OelJTgIO17d50kzXZ1twzwpimWTjgCIS90K19EXAMPLE",
3+
"team": 0
4+
}

plugins/laravelvapor/vapor.go

Lines changed: 27 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,27 @@
1+
package laravelvapor
2+
3+
import (
4+
"github.com/1Password/shell-plugins/sdk"
5+
"github.com/1Password/shell-plugins/sdk/needsauth"
6+
"github.com/1Password/shell-plugins/sdk/schema"
7+
"github.com/1Password/shell-plugins/sdk/schema/credname"
8+
)
9+
10+
func LaravelVaporCLI() schema.Executable {
11+
return schema.Executable{
12+
Name: "Laravel Vapor CLI",
13+
Runs: []string{"vapor"},
14+
DocsURL: sdk.URL("https://docs.vapor.build/1.0/introduction.html#installing-the-vapor-cli"),
15+
NeedsAuth: needsauth.IfAll(
16+
needsauth.NotForHelpOrVersion(),
17+
needsauth.NotWithoutArgs(),
18+
needsauth.NotForExactArgs("login"),
19+
needsauth.NotForExactArgs("list"),
20+
),
21+
Uses: []schema.CredentialUsage{
22+
{
23+
Name: credname.APIToken,
24+
},
25+
},
26+
}
27+
}

0 commit comments

Comments
 (0)