mirror of
https://github.com/JanDeDobbeleer/oh-my-posh.git
synced 2025-01-12 11:47:25 -08:00
rename jsonapi to http and add method to http request
This commit is contained in:
parent
277c1d84ef
commit
6b432e32dd
|
@ -104,7 +104,7 @@ const (
|
|||
// JAVA writes the active java version
|
||||
JAVA SegmentType = "java"
|
||||
// API writes the output of a custom JSON API
|
||||
JSONAPI SegmentType = "jsonapi"
|
||||
HTTP SegmentType = "http"
|
||||
// JULIA writes which julia version is currently active
|
||||
JULIA SegmentType = "julia"
|
||||
// KOTLIN writes the active kotlin version
|
||||
|
@ -261,7 +261,7 @@ var Segments = map[SegmentType]func() SegmentWriter{
|
|||
HELM: func() SegmentWriter { return &segments.Helm{} },
|
||||
IPIFY: func() SegmentWriter { return &segments.IPify{} },
|
||||
JAVA: func() SegmentWriter { return &segments.Java{} },
|
||||
JSONAPI: func() SegmentWriter { return &segments.JSONAPI{} },
|
||||
HTTP: func() SegmentWriter { return &segments.HTTP{} },
|
||||
JULIA: func() SegmentWriter { return &segments.Julia{} },
|
||||
KOTLIN: func() SegmentWriter { return &segments.Kotlin{} },
|
||||
KUBECTL: func() SegmentWriter { return &segments.Kubectl{} },
|
||||
|
|
60
src/segments/http.go
Normal file
60
src/segments/http.go
Normal file
|
@ -0,0 +1,60 @@
|
|||
package segments
|
||||
|
||||
import (
|
||||
"encoding/json"
|
||||
|
||||
"net/http"
|
||||
|
||||
"github.com/jandedobbeleer/oh-my-posh/src/properties"
|
||||
)
|
||||
|
||||
type HTTP struct {
|
||||
base
|
||||
|
||||
URL string
|
||||
Result map[string]interface{}
|
||||
}
|
||||
|
||||
const (
|
||||
HTTPURL properties.Property = "url"
|
||||
METHOD properties.Property = "method"
|
||||
)
|
||||
|
||||
func (cs *HTTP) Template() string {
|
||||
return " {{ .Result }} "
|
||||
}
|
||||
|
||||
func (cs *HTTP) Enabled() bool {
|
||||
url := cs.props.GetString(HTTPURL, "")
|
||||
if len(url) == 0 {
|
||||
return false
|
||||
}
|
||||
method := cs.props.GetString(METHOD, "GET")
|
||||
|
||||
result, err := cs.getResult(url, method)
|
||||
if err != nil {
|
||||
return false
|
||||
}
|
||||
|
||||
cs.Result = result
|
||||
return true
|
||||
}
|
||||
|
||||
func (cs *HTTP) getResult(url, method string) (map[string]interface{}, error) {
|
||||
setMethod := func(request *http.Request) {
|
||||
request.Method = method
|
||||
}
|
||||
|
||||
resultBody, err := cs.env.HTTPRequest(url, nil, 10000, setMethod)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
var result map[string]interface{}
|
||||
err = json.Unmarshal(resultBody, &result)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
return result, nil
|
||||
}
|
111
src/segments/http_test.go
Normal file
111
src/segments/http_test.go
Normal file
|
@ -0,0 +1,111 @@
|
|||
package segments
|
||||
|
||||
import (
|
||||
"errors"
|
||||
"testing"
|
||||
|
||||
"github.com/jandedobbeleer/oh-my-posh/src/properties"
|
||||
"github.com/jandedobbeleer/oh-my-posh/src/runtime/mock"
|
||||
|
||||
"github.com/stretchr/testify/assert"
|
||||
)
|
||||
|
||||
func TestHTTPSegmentEnabled(t *testing.T) {
|
||||
cases := []struct {
|
||||
caseName string
|
||||
url string
|
||||
method string
|
||||
response string
|
||||
responseID string
|
||||
isError bool
|
||||
expected bool
|
||||
}{
|
||||
{
|
||||
caseName: "Valid URL with GET response",
|
||||
url: "https://jsonplaceholder.typicode.com/posts/1",
|
||||
method: "GET",
|
||||
response: `{"id": "1"}`,
|
||||
responseID: "1",
|
||||
isError: false,
|
||||
expected: true,
|
||||
},
|
||||
{
|
||||
caseName: "Valid URL with POST response",
|
||||
url: "https://jsonplaceholder.typicode.com/posts",
|
||||
method: "POST",
|
||||
response: `{"id": "101"}`,
|
||||
responseID: "101",
|
||||
isError: false,
|
||||
expected: true,
|
||||
},
|
||||
{
|
||||
caseName: "Valid URL with error response",
|
||||
url: "https://api.example.com/data",
|
||||
method: "GET",
|
||||
response: ``,
|
||||
responseID: ``,
|
||||
isError: true,
|
||||
expected: false,
|
||||
},
|
||||
{
|
||||
caseName: "Empty URL",
|
||||
url: "",
|
||||
method: "GET",
|
||||
response: ``,
|
||||
responseID: ``,
|
||||
isError: false,
|
||||
expected: false,
|
||||
},
|
||||
}
|
||||
|
||||
for _, tc := range cases {
|
||||
t.Run(tc.caseName, func(t *testing.T) {
|
||||
env := new(mock.Environment)
|
||||
props := properties.Map{
|
||||
URL: tc.url,
|
||||
METHOD: tc.method,
|
||||
}
|
||||
|
||||
env.On("HTTPRequest", tc.url).Return([]byte(tc.response), func() error {
|
||||
if tc.isError {
|
||||
return errors.New("error")
|
||||
}
|
||||
return nil
|
||||
}())
|
||||
|
||||
cs := &HTTP{
|
||||
base: base{
|
||||
env: env,
|
||||
props: props,
|
||||
},
|
||||
}
|
||||
|
||||
enabled := cs.Enabled()
|
||||
assert.Equal(t, tc.expected, enabled)
|
||||
if enabled {
|
||||
assert.Equal(t, tc.responseID, cs.Result["id"])
|
||||
}
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
func TestHTTPSegmentTemplate(t *testing.T) {
|
||||
env := new(mock.Environment)
|
||||
props := properties.Map{
|
||||
URL: "https://jsonplaceholder.typicode.com/posts/1",
|
||||
}
|
||||
|
||||
env.On("HTTPRequest", "https://jsonplaceholder.typicode.com/posts/1").Return([]byte(`{"key": "value"}`), nil)
|
||||
|
||||
cs := &HTTP{
|
||||
base: base{
|
||||
env: env,
|
||||
props: props,
|
||||
},
|
||||
}
|
||||
|
||||
cs.Enabled()
|
||||
template := cs.Template()
|
||||
expectedTemplate := " {{ .Result }} "
|
||||
assert.Equal(t, expectedTemplate, template)
|
||||
}
|
|
@ -1,52 +0,0 @@
|
|||
package segments
|
||||
|
||||
import (
|
||||
"encoding/json"
|
||||
|
||||
"github.com/jandedobbeleer/oh-my-posh/src/properties"
|
||||
)
|
||||
|
||||
type JSONAPI struct {
|
||||
base
|
||||
|
||||
URL string
|
||||
Result map[string]interface{}
|
||||
}
|
||||
|
||||
const (
|
||||
JSONAPIURL properties.Property = "api_url"
|
||||
)
|
||||
|
||||
func (cs *JSONAPI) Template() string {
|
||||
return " {{ .Result }} "
|
||||
}
|
||||
|
||||
func (cs *JSONAPI) Enabled() bool {
|
||||
url := cs.props.GetString(JSONAPIURL, "")
|
||||
if len(url) == 0 {
|
||||
return false
|
||||
}
|
||||
|
||||
result, err := cs.getResult(url)
|
||||
if err != nil {
|
||||
return false
|
||||
}
|
||||
|
||||
cs.Result = result
|
||||
return true
|
||||
}
|
||||
|
||||
func (cs *JSONAPI) getResult(url string) (map[string]interface{}, error) {
|
||||
body, err := cs.env.HTTPRequest(url, nil, 10000)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
var result map[string]interface{}
|
||||
err = json.Unmarshal(body, &result)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
return result, nil
|
||||
}
|
|
@ -1,90 +0,0 @@
|
|||
package segments
|
||||
|
||||
import (
|
||||
"errors"
|
||||
"testing"
|
||||
|
||||
"github.com/jandedobbeleer/oh-my-posh/src/properties"
|
||||
"github.com/jandedobbeleer/oh-my-posh/src/runtime/mock"
|
||||
|
||||
"github.com/stretchr/testify/assert"
|
||||
)
|
||||
|
||||
func TestJSONAPISegmentEnabled(t *testing.T) {
|
||||
cases := []struct {
|
||||
caseName string
|
||||
url string
|
||||
response string
|
||||
isError bool
|
||||
expected bool
|
||||
}{
|
||||
{
|
||||
caseName: "Valid URL with response",
|
||||
url: "https://jsonplaceholder.typicode.com/posts/1",
|
||||
response: `{"id": "1"}`,
|
||||
isError: false,
|
||||
expected: true,
|
||||
},
|
||||
{
|
||||
caseName: "Valid URL with error response",
|
||||
url: "https://api.example.com/data",
|
||||
response: ``,
|
||||
isError: true,
|
||||
expected: false,
|
||||
},
|
||||
{
|
||||
caseName: "Empty URL",
|
||||
url: "",
|
||||
response: ``,
|
||||
isError: false,
|
||||
expected: false,
|
||||
},
|
||||
}
|
||||
|
||||
for _, tc := range cases {
|
||||
t.Run(tc.caseName, func(t *testing.T) {
|
||||
env := new(mock.Environment)
|
||||
props := properties.Map{
|
||||
JSONAPIURL: tc.url,
|
||||
}
|
||||
|
||||
env.On("HTTPRequest", tc.url).Return([]byte(tc.response), func() error {
|
||||
if tc.isError {
|
||||
return errors.New("error")
|
||||
}
|
||||
return nil
|
||||
}())
|
||||
|
||||
cs := &JSONAPI{
|
||||
base: base{
|
||||
env: env,
|
||||
props: props,
|
||||
},
|
||||
}
|
||||
|
||||
enabled := cs.Enabled()
|
||||
assert.Equal(t, tc.expected, enabled)
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
func TestJSONAPISegmentTemplate(t *testing.T) {
|
||||
env := new(mock.Environment)
|
||||
props := properties.Map{
|
||||
JSONAPIURL: "https://jsonplaceholder.typicode.com/posts/1",
|
||||
}
|
||||
|
||||
env.On("HTTPRequest", "https://jsonplaceholder.typicode.com/posts/1").Return([]byte(`{"key": "value"}`), nil)
|
||||
|
||||
cs := &JSONAPI{
|
||||
base: base{
|
||||
env: env,
|
||||
props: props,
|
||||
},
|
||||
}
|
||||
|
||||
cs.Enabled()
|
||||
template := cs.Template()
|
||||
expectedTemplate := " {{ .Result }} "
|
||||
assert.Equal(t, expectedTemplate, template)
|
||||
}
|
|
@ -328,8 +328,8 @@
|
|||
"go",
|
||||
"haskell",
|
||||
"helm",
|
||||
"http",
|
||||
"ipify",
|
||||
"jsonapi",
|
||||
"julia",
|
||||
"java",
|
||||
"kotlin",
|
||||
|
@ -3741,21 +3741,27 @@
|
|||
"if": {
|
||||
"properties": {
|
||||
"type": {
|
||||
"const": "jsonapi"
|
||||
"const": "http"
|
||||
}
|
||||
}
|
||||
},
|
||||
"then": {
|
||||
"title": "Display your any JSON property from any API",
|
||||
"description": "https://ohmyposh.dev/docs/segments/web/jsonapi",
|
||||
"description": "https://ohmyposh.dev/docs/segments/web/http",
|
||||
"properties": {
|
||||
"properties": {
|
||||
"properties": {
|
||||
"api_url": {
|
||||
"url": {
|
||||
"type": "string",
|
||||
"title": "API URL",
|
||||
"description": "The JSON API URL",
|
||||
"title": "URL",
|
||||
"description": "The HTTP URL",
|
||||
"default": "https://jsonplaceholder.typicode.com/posts/1"
|
||||
},
|
||||
"method": {
|
||||
"type": "string",
|
||||
"title": "HTTP method",
|
||||
"description": "The HTTP method",
|
||||
"default": "GET"
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,12 +1,12 @@
|
|||
---
|
||||
id: jsonapi
|
||||
title: JSON API
|
||||
sidebar_label: JSON API
|
||||
id: http
|
||||
title: HTTP Request
|
||||
sidebar_label: HTTP Request
|
||||
---
|
||||
|
||||
## What
|
||||
|
||||
JSON API is a simple segment to return any json data from any (anonymous) API.
|
||||
HTTP Request is a simple segment to return any json data from any (anonymous) HTTP call.
|
||||
|
||||
## Sample Configuration
|
||||
|
||||
|
@ -14,7 +14,7 @@ import Config from "@site/src/components/Config.js";
|
|||
|
||||
<Config
|
||||
data={{
|
||||
type: "jsonapi",
|
||||
type: "http",
|
||||
style: "diamond",
|
||||
foreground: "#ffffff",
|
||||
background: "#c386f1",
|
||||
|
@ -22,7 +22,8 @@ import Config from "@site/src/components/Config.js";
|
|||
trailing_diamond: "\uE0B0",
|
||||
template: "{{ .Result }}",
|
||||
properties: {
|
||||
api_url: "https://jsonplaceholder.typicode.com/posts/1",
|
||||
url: "https://jsonplaceholder.typicode.com/posts/1",
|
||||
method: "GET",
|
||||
},
|
||||
}}
|
||||
/>
|
||||
|
@ -30,8 +31,9 @@ import Config from "@site/src/components/Config.js";
|
|||
## Properties
|
||||
|
||||
| Name | Type | Default | Description |
|
||||
| --------- | :------: | :--------------------------------------------: | -------------------------------- |
|
||||
| `api_url` | `string` | `https://jsonplaceholder.typicode.com/posts/1` | The JSON API URL you want to use |
|
||||
| -------- | :------: | :--------------------------------------------: | ----------------------------- |
|
||||
| `url` | `string` | `https://jsonplaceholder.typicode.com/posts/1` | The HTTP URL you want to call |
|
||||
| `method` | `string` | `GET` | The HTTP method to use |
|
||||
|
||||
## Template ([info][templates])
|
||||
|
|
@ -199,7 +199,7 @@ module.exports = {
|
|||
"segments/web/brewfather",
|
||||
"segments/web/carbonintensity",
|
||||
"segments/web/ipify",
|
||||
"segments/web/jsonapi",
|
||||
"segments/web/http",
|
||||
"segments/web/nba",
|
||||
"segments/web/owm",
|
||||
"segments/web/wakatime",
|
||||
|
|
Loading…
Reference in a new issue