From 8a3863fbef20452ebd82921b82cbfcccb7227aaa Mon Sep 17 00:00:00 2001 From: Wilfred Almeida Date: Thu, 20 Jul 2023 19:50:21 +0530 Subject: [PATCH 1/6] feat: List APIs Signed-off-by: Wilfred Almeida --- features/api_list.go | 58 +++++++++++++++++++++++++++++++ features/api_list_test.go | 72 +++++++++++++++++++++++++++++++++++++++ 2 files changed, 130 insertions(+) create mode 100644 features/api_list.go create mode 100644 features/api_list_test.go diff --git a/features/api_list.go b/features/api_list.go new file mode 100644 index 0000000..10dbe3b --- /dev/null +++ b/features/api_list.go @@ -0,0 +1,58 @@ +package features + +import ( + "encoding/json" + "fmt" + "io" + "net/http" + + "github.com/WilfredAlmeida/unkey-go/utils" +) + +type APIListResponse struct { + ID string `json:"id"` + Name string `json:"name"` + WorkspaceID string `json:"workspaceId"` +} + +func APIList(apiID, authToken string) (APIListResponse, error) { + + // Create a new HTTP client + client := &http.Client{} + + // Create a new GET request + req, err := http.NewRequest("GET", utils.UNKEY_API_URL+"/apis/"+apiID, nil) + if err != nil { + return APIListResponse{}, err + } + + // Set the authorization header + req.Header.Set("Authorization", authToken) + + // Send the request + resp, err := client.Do(req) + if err != nil { + return APIListResponse{}, err + } + defer resp.Body.Close() + + // Read the response body + body, err := io.ReadAll(resp.Body) + if err != nil { + return APIListResponse{}, err + } + + // Check the response status code + if resp.StatusCode != http.StatusOK { + return APIListResponse{}, fmt.Errorf(string(body)) + } + + // Parse the response JSON + var response APIListResponse + err = json.Unmarshal(body, &response) + if err != nil { + return APIListResponse{}, err + } + + return response, nil +} diff --git a/features/api_list_test.go b/features/api_list_test.go new file mode 100644 index 0000000..aa109f0 --- /dev/null +++ b/features/api_list_test.go @@ -0,0 +1,72 @@ +package features + +import ( + "errors" + "os" + "reflect" + "testing" + + "github.com/joho/godotenv" +) + +func TestAPIList(t *testing.T) { + + err := godotenv.Load("../.env") + + if err != nil { + t.Errorf("Error loading .env file") + } + + testCases := []struct { + name string + apiId string + authToken string + expectedResult APIListResponse + expectedError error + }{ + { + name: "Successful Response", + apiId: os.Getenv("API_ID"), + authToken: os.Getenv("AUTH_TOKEN"), + expectedResult: APIListResponse{ + ID: os.Getenv("API_ID"), + Name: "first-api", + WorkspaceID: "ws_C4EkWVE5UFjG4gdZjKJ9wu", + }, + expectedError: nil, + }, + { + name: "Error Response", + apiId: "someId", + authToken: os.Getenv("AUTH_TOKEN"), + expectedResult: APIListResponse{}, + expectedError: errors.New(`{"error":"unable to find api: someId","code":"NOT_FOUND"}`), + }, + } + + for _, tc := range testCases { + t.Run(tc.name, func(t *testing.T) { + + response, err := APIList(tc.apiId, tc.authToken) + + if err != nil && tc.expectedError == nil { + t.Errorf("Unexpected error: %v", err) + return + } + if err == nil && tc.expectedError != nil { + t.Errorf("Expected error: %v, got nil", tc.expectedError) + return + } + if err != nil && tc.expectedError != nil && err.Error() != tc.expectedError.Error() { + t.Errorf("Expected error: %v, got: %v", tc.expectedError, err) + return + } + + if !reflect.DeepEqual(response, tc.expectedResult) { + t.Errorf("Expected response: %v, got: %v", tc.expectedResult, response) + return + } + + }) + } +} From c988659ee57bc03a6b2883af170b5b43ab531d09 Mon Sep 17 00:00:00 2001 From: Wilfred Almeida Date: Thu, 20 Jul 2023 20:18:34 +0530 Subject: [PATCH 2/6] feat: List API Keys Signed-off-by: Wilfred Almeida --- features/api_list_keys.go | 68 ++++++++++++++++++++++++++++++++++ features/api_list_keys_test.go | 65 ++++++++++++++++++++++++++++++++ 2 files changed, 133 insertions(+) create mode 100644 features/api_list_keys.go create mode 100644 features/api_list_keys_test.go diff --git a/features/api_list_keys.go b/features/api_list_keys.go new file mode 100644 index 0000000..c143e9d --- /dev/null +++ b/features/api_list_keys.go @@ -0,0 +1,68 @@ +package features + +import ( + "encoding/json" + "fmt" + "io" + "net/http" + + "github.com/WilfredAlmeida/unkey-go/utils" +) + + +type Key struct { + ID string `json:"id,omitempty"` + APIID string `json:"apiId,omitempty"` + WorkspaceID string `json:"workspaceId,omitempty"` + Start string `json:"start,omitempty"` + CreatedAt int64 `json:"createdAt,omitempty"` + Expires *int64 `json:"expires,omitempty"` + Ratelimit ratelimitResponse `json:"ratelimit,omitempty"` +} + +type APIListKeysResponse struct { + Keys []Key `json:"keys,omitempty"` + Total int `json:"total,omitempty"` +} + +func APIListKeys(apiID, authToken string) (APIListKeysResponse, error) { + + // Create a new HTTP client + client := &http.Client{} + + // Create a new GET request + req, err := http.NewRequest("GET", utils.UNKEY_API_URL+"/apis/"+apiID+"/keys", nil) + if err != nil { + return APIListKeysResponse{}, err + } + + // Set the authorization header + req.Header.Set("Authorization", authToken) + + // Send the request + resp, err := client.Do(req) + if err != nil { + return APIListKeysResponse{}, err + } + defer resp.Body.Close() + + // Read the response body + body, err := io.ReadAll(resp.Body) + if err != nil { + return APIListKeysResponse{}, err + } + + // Check the response status code + if resp.StatusCode != http.StatusOK { + return APIListKeysResponse{}, fmt.Errorf(string(body)) + } + + // Parse the response JSON + var response APIListKeysResponse + err = json.Unmarshal(body, &response) + if err != nil { + return APIListKeysResponse{}, err + } + + return response, nil +} diff --git a/features/api_list_keys_test.go b/features/api_list_keys_test.go new file mode 100644 index 0000000..77f11fd --- /dev/null +++ b/features/api_list_keys_test.go @@ -0,0 +1,65 @@ +package features + +import ( + "errors" + "os" + "testing" + + "github.com/joho/godotenv" +) + +func TestAPIListKeys(t *testing.T) { + + err := godotenv.Load("../.env") + + if err != nil { + t.Errorf("Error loading .env file") + } + + testCases := []struct { + name string + apiId string + authToken string + expectedResult APIListKeysResponse + expectedError error + }{ + { + name: "Successful Response", + apiId: os.Getenv("API_ID"), + authToken: os.Getenv("AUTH_TOKEN"), + expectedResult: APIListKeysResponse{ + }, // It'll list lots of keys which we cannot match here + expectedError: nil, + }, + { + name: "Error Response", + apiId: "someId", + authToken: os.Getenv("AUTH_TOKEN"), + expectedResult: APIListKeysResponse{}, + expectedError: errors.New(`{"error":"unable to find api: someId","code":"NOT_FOUND"}`), + }, + } + + for _, tc := range testCases { + t.Run(tc.name, func(t *testing.T) { + + _, err := APIListKeys(tc.apiId, tc.authToken) + + if err != nil && tc.expectedError == nil { + t.Errorf("Unexpected error: %v", err) + return + } + if err == nil && tc.expectedError != nil { + t.Errorf("Expected error: %v, got nil", tc.expectedError) + return + } + if err != nil && tc.expectedError != nil && err.Error() != tc.expectedError.Error() { + t.Errorf("Expected error: %v, got: %v", tc.expectedError, err) + return + } + + // If there's no error then it means we got a successful response + + }) + } +} From a66ac3512ebfbbdf251ca2a3da04172cef781675 Mon Sep 17 00:00:00 2001 From: Wilfred Almeida Date: Thu, 20 Jul 2023 20:20:15 +0530 Subject: [PATCH 3/6] chore: fmt formatting Signed-off-by: Wilfred Almeida --- features/api_list_keys.go | 15 +++++++-------- features/api_list_keys_test.go | 11 +++++------ main.go | 28 ++++++++++++++++++++++++++-- utils/constants.go | 2 +- 4 files changed, 39 insertions(+), 17 deletions(-) diff --git a/features/api_list_keys.go b/features/api_list_keys.go index c143e9d..8587f8d 100644 --- a/features/api_list_keys.go +++ b/features/api_list_keys.go @@ -9,15 +9,14 @@ import ( "github.com/WilfredAlmeida/unkey-go/utils" ) - type Key struct { - ID string `json:"id,omitempty"` - APIID string `json:"apiId,omitempty"` - WorkspaceID string `json:"workspaceId,omitempty"` - Start string `json:"start,omitempty"` - CreatedAt int64 `json:"createdAt,omitempty"` - Expires *int64 `json:"expires,omitempty"` - Ratelimit ratelimitResponse `json:"ratelimit,omitempty"` + ID string `json:"id,omitempty"` + APIID string `json:"apiId,omitempty"` + WorkspaceID string `json:"workspaceId,omitempty"` + Start string `json:"start,omitempty"` + CreatedAt int64 `json:"createdAt,omitempty"` + Expires *int64 `json:"expires,omitempty"` + Ratelimit ratelimitResponse `json:"ratelimit,omitempty"` } type APIListKeysResponse struct { diff --git a/features/api_list_keys_test.go b/features/api_list_keys_test.go index 77f11fd..583fed4 100644 --- a/features/api_list_keys_test.go +++ b/features/api_list_keys_test.go @@ -24,12 +24,11 @@ func TestAPIListKeys(t *testing.T) { expectedError error }{ { - name: "Successful Response", - apiId: os.Getenv("API_ID"), - authToken: os.Getenv("AUTH_TOKEN"), - expectedResult: APIListKeysResponse{ - }, // It'll list lots of keys which we cannot match here - expectedError: nil, + name: "Successful Response", + apiId: os.Getenv("API_ID"), + authToken: os.Getenv("AUTH_TOKEN"), + expectedResult: APIListKeysResponse{}, // It'll list lots of keys which we cannot match here + expectedError: nil, }, { name: "Error Response", diff --git a/main.go b/main.go index b90370c..9875539 100644 --- a/main.go +++ b/main.go @@ -2,8 +2,10 @@ package main import ( "fmt" + "os" "github.com/WilfredAlmeida/unkey-go/features" + "github.com/joho/godotenv" ) func main() { @@ -46,12 +48,34 @@ func main() { // fmt.Println("Response: ", response) - response, err := features.KeyVerify("key_3ZZSawUTYL1DdsgCycdp7Xdu") + // response, err := features.KeyVerify("key_3ZZSawUTYL1DdsgCycdp7Xdu") + // if err != nil { + // fmt.Println("Error:", err) + // return + // } + + // fmt.Printf("Response.ratelimit: %+v\n", response.Ratelimit) + + err := godotenv.Load("./.env") + + if err != nil { + fmt.Println("Error loading .env file") + fmt.Println(err) + } + + // response, err := features.APIList(os.Getenv("API_ID"),os.Getenv("AUTH_TOKEN")) + // if err != nil { + // fmt.Println("Error:", err) + // return + // } + + // fmt.Printf("Response: %+v\n", response) + response, err := features.APIListKeys(os.Getenv("API_ID"), os.Getenv("AUTH_TOKEN")) if err != nil { fmt.Println("Error:", err) return } - fmt.Printf("Response.ratelimit: %+v\n", response.Ratelimit) + fmt.Printf("Response: %+v\n", response) } diff --git a/utils/constants.go b/utils/constants.go index 78ca125..3ee90b1 100644 --- a/utils/constants.go +++ b/utils/constants.go @@ -2,4 +2,4 @@ package utils const UNKEY_API_VERSION = "v1" const UNKEY_BASE_URL = "https://api.unkey.dev" -const UNKEY_API_URL = UNKEY_BASE_URL + "/" + UNKEY_API_VERSION \ No newline at end of file +const UNKEY_API_URL = UNKEY_BASE_URL + "/" + UNKEY_API_VERSION From 20b2f14b071fed35f1c83c5cfe7ae8c6f879a50b Mon Sep 17 00:00:00 2001 From: Wilfred Almeida Date: Thu, 20 Jul 2023 20:56:27 +0530 Subject: [PATCH 4/6] refactor: rename 'APIList' to 'APIGet' The function returns information about the API Signed-off-by: Wilfred Almeida --- README.md | 2 ++ features/{api_list.go => api_get.go} | 16 ++++++++-------- features/{api_list_test.go => api_get_test.go} | 10 +++++----- main.go | 2 +- 4 files changed, 16 insertions(+), 14 deletions(-) rename features/{api_list.go => api_get.go} (73%) rename features/{api_list_test.go => api_get_test.go} (88%) diff --git a/README.md b/README.md index 02f633d..8139f86 100644 --- a/README.md +++ b/README.md @@ -179,6 +179,8 @@ type KeyCreateResponse struct { } ``` +**API + --- ## Contributing Refer the [CONTRIBUTING.md](https://github.com/WilfredAlmeida/unkey-go/blob/main/CONTRIBUTING.md) file for more information. \ No newline at end of file diff --git a/features/api_list.go b/features/api_get.go similarity index 73% rename from features/api_list.go rename to features/api_get.go index 10dbe3b..5c7784e 100644 --- a/features/api_list.go +++ b/features/api_get.go @@ -9,13 +9,13 @@ import ( "github.com/WilfredAlmeida/unkey-go/utils" ) -type APIListResponse struct { +type APIGetResponse struct { ID string `json:"id"` Name string `json:"name"` WorkspaceID string `json:"workspaceId"` } -func APIList(apiID, authToken string) (APIListResponse, error) { +func APIGet(apiID, authToken string) (APIGetResponse, error) { // Create a new HTTP client client := &http.Client{} @@ -23,7 +23,7 @@ func APIList(apiID, authToken string) (APIListResponse, error) { // Create a new GET request req, err := http.NewRequest("GET", utils.UNKEY_API_URL+"/apis/"+apiID, nil) if err != nil { - return APIListResponse{}, err + return APIGetResponse{}, err } // Set the authorization header @@ -32,26 +32,26 @@ func APIList(apiID, authToken string) (APIListResponse, error) { // Send the request resp, err := client.Do(req) if err != nil { - return APIListResponse{}, err + return APIGetResponse{}, err } defer resp.Body.Close() // Read the response body body, err := io.ReadAll(resp.Body) if err != nil { - return APIListResponse{}, err + return APIGetResponse{}, err } // Check the response status code if resp.StatusCode != http.StatusOK { - return APIListResponse{}, fmt.Errorf(string(body)) + return APIGetResponse{}, fmt.Errorf(string(body)) } // Parse the response JSON - var response APIListResponse + var response APIGetResponse err = json.Unmarshal(body, &response) if err != nil { - return APIListResponse{}, err + return APIGetResponse{}, err } return response, nil diff --git a/features/api_list_test.go b/features/api_get_test.go similarity index 88% rename from features/api_list_test.go rename to features/api_get_test.go index aa109f0..ccd2999 100644 --- a/features/api_list_test.go +++ b/features/api_get_test.go @@ -9,7 +9,7 @@ import ( "github.com/joho/godotenv" ) -func TestAPIList(t *testing.T) { +func TestAPIGet(t *testing.T) { err := godotenv.Load("../.env") @@ -21,14 +21,14 @@ func TestAPIList(t *testing.T) { name string apiId string authToken string - expectedResult APIListResponse + expectedResult APIGetResponse expectedError error }{ { name: "Successful Response", apiId: os.Getenv("API_ID"), authToken: os.Getenv("AUTH_TOKEN"), - expectedResult: APIListResponse{ + expectedResult: APIGetResponse{ ID: os.Getenv("API_ID"), Name: "first-api", WorkspaceID: "ws_C4EkWVE5UFjG4gdZjKJ9wu", @@ -39,7 +39,7 @@ func TestAPIList(t *testing.T) { name: "Error Response", apiId: "someId", authToken: os.Getenv("AUTH_TOKEN"), - expectedResult: APIListResponse{}, + expectedResult: APIGetResponse{}, expectedError: errors.New(`{"error":"unable to find api: someId","code":"NOT_FOUND"}`), }, } @@ -47,7 +47,7 @@ func TestAPIList(t *testing.T) { for _, tc := range testCases { t.Run(tc.name, func(t *testing.T) { - response, err := APIList(tc.apiId, tc.authToken) + response, err := APIGet(tc.apiId, tc.authToken) if err != nil && tc.expectedError == nil { t.Errorf("Unexpected error: %v", err) diff --git a/main.go b/main.go index 9875539..1d55d07 100644 --- a/main.go +++ b/main.go @@ -63,7 +63,7 @@ func main() { fmt.Println(err) } - // response, err := features.APIList(os.Getenv("API_ID"),os.Getenv("AUTH_TOKEN")) + // response, err := features.APIGet(os.Getenv("API_ID"),os.Getenv("AUTH_TOKEN")) // if err != nil { // fmt.Println("Error:", err) // return From 73ae82703d9a24a4efdfeac76a9942789dced8a4 Mon Sep 17 00:00:00 2001 From: Wilfred Almeida Date: Thu, 20 Jul 2023 21:02:15 +0530 Subject: [PATCH 5/6] docs: Get API Info & List API Keys Signed-off-by: Wilfred Almeida --- README.md | 70 ++++++++++++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 69 insertions(+), 1 deletion(-) diff --git a/README.md b/README.md index 8139f86..39147e6 100644 --- a/README.md +++ b/README.md @@ -128,6 +128,48 @@ func main() { ``` > Note: The API returns `{}` as a success response for revkoking key. For user convenience, unkey-go returns boolean +**Get API Information** +```go +package main + +import ( + "fmt" + + unkey "github.com/WilfredAlmeida/unkey-go/features" +) + +func main() { + response, err := features.APIGet("API_ID","AUTH_TOKEN") + if err != nil { + fmt.Println("Error:", err) + return + } + + fmt.Printf("Response: %+v\n", response) +} +``` + +**Get List Keys** +```go +package main + +import ( + "fmt" + + unkey "github.com/WilfredAlmeida/unkey-go/features" +) + +func main() { + response, err := features.APIListKeys("API_ID","AUTH_TOKEN") + if err != nil { + fmt.Println("Error:", err) + return + } + + fmt.Printf("Response: %+v\n", response) +} +``` + --- ### Structs Reference The structs used in code for you to get a better idea of the request & response bodies. @@ -179,7 +221,33 @@ type KeyCreateResponse struct { } ``` -**API +**APIGet** +```go +type APIGetResponse struct { + ID string `json:"id"` + Name string `json:"name"` + WorkspaceID string `json:"workspaceId"` +} +``` + +**APIListKeys** +```go +type Key struct { + ID string `json:"id,omitempty"` + APIID string `json:"apiId,omitempty"` + WorkspaceID string `json:"workspaceId,omitempty"` + Start string `json:"start,omitempty"` + CreatedAt int64 `json:"createdAt,omitempty"` + Expires *int64 `json:"expires,omitempty"` + Ratelimit ratelimitResponse `json:"ratelimit,omitempty"` +} + +type APIListKeysResponse struct { + Keys []Key `json:"keys,omitempty"` + Total int `json:"total,omitempty"` +} +``` +> Note: `ratelimitResponse` is defined in `KeyVerify` struct reference --- ## Contributing From 2d0113dc61626f5e17f05b54a9e8ca00dab844f8 Mon Sep 17 00:00:00 2001 From: Wilfred Almeida Date: Sat, 22 Jul 2023 11:42:34 +0530 Subject: [PATCH 6/6] feat: github actions workflows Signed-off-by: Wilfred Almeida --- .github/ISSUE_TEMPLATE/bug_report.yml | 40 ++++++++++++++++++++++ .github/ISSUE_TEMPLATE/config.yml | 5 +++ .github/ISSUE_TEMPLATE/doc_report.yml | 18 ++++++++++ .github/ISSUE_TEMPLATE/feature_request.yml | 24 +++++++++++++ .github/ISSUE_TEMPLATE/others.yml | 22 ++++++++++++ .github/pull_request_template.yml | 32 +++++++++++++++++ .github/workflows/greetings.yml | 15 ++++++++ .github/workflows/release.yml | 29 ++++++++++++++++ 8 files changed, 185 insertions(+) create mode 100644 .github/ISSUE_TEMPLATE/bug_report.yml create mode 100644 .github/ISSUE_TEMPLATE/config.yml create mode 100644 .github/ISSUE_TEMPLATE/doc_report.yml create mode 100644 .github/ISSUE_TEMPLATE/feature_request.yml create mode 100644 .github/ISSUE_TEMPLATE/others.yml create mode 100644 .github/pull_request_template.yml create mode 100644 .github/workflows/greetings.yml create mode 100644 .github/workflows/release.yml diff --git a/.github/ISSUE_TEMPLATE/bug_report.yml b/.github/ISSUE_TEMPLATE/bug_report.yml new file mode 100644 index 0000000..c25285c --- /dev/null +++ b/.github/ISSUE_TEMPLATE/bug_report.yml @@ -0,0 +1,40 @@ +name: Bug report +description: Create a report to help us improve +title: '[bug]' +labels: ['bug'] +body: + - type: textarea + attributes: + label: Describe the bug + description: A clear and concise description of what the bug is + validations: + required: false + - type: textarea + attributes: + label: To Reproduce + description: | + Steps to reproduce the behavior. + 1. Go to '...' + 2. Click on '...' + 3. Scroll down to '...' + 4. See error + validations: + required: false + - type: textarea + attributes: + label: Expected Behavior + description: A clear and concise description of what you expected to happen. + validations: + required: false + - type: textarea + attributes: + label: Screenshot/ Video + description: If applicable, add screenshots to help explain your problem. + validations: + required: false + - type: textarea + attributes: + label: Additional context + description: Add any other context about the problem here. + validations: + required: false \ No newline at end of file diff --git a/.github/ISSUE_TEMPLATE/config.yml b/.github/ISSUE_TEMPLATE/config.yml new file mode 100644 index 0000000..13f3339 --- /dev/null +++ b/.github/ISSUE_TEMPLATE/config.yml @@ -0,0 +1,5 @@ +blank_issues_enabled: false +contact_links: + - name: Discord community support + url: https://unkey.dev/discord + about: Need any help? Found any bug? Please chat with us via Discord. \ No newline at end of file diff --git a/.github/ISSUE_TEMPLATE/doc_report.yml b/.github/ISSUE_TEMPLATE/doc_report.yml new file mode 100644 index 0000000..50131da --- /dev/null +++ b/.github/ISSUE_TEMPLATE/doc_report.yml @@ -0,0 +1,18 @@ +name: Documentation request +description: Change regarding improving the docs to be more accessible +title: '[docs]' +labels: ['documentation'] +body: + - type: textarea + attributes: + label: Category of documentation update + description: | + What category does this change fall under.For example Typo error, New category addition, Rephrasing the sentences, fixing broken links etc + validations: + required: true + - type: textarea + attributes: + label: Describe the change you think might work + description: Please describe the change & need of change in atmost detail possible. + validations: + required: false \ No newline at end of file diff --git a/.github/ISSUE_TEMPLATE/feature_request.yml b/.github/ISSUE_TEMPLATE/feature_request.yml new file mode 100644 index 0000000..84321bc --- /dev/null +++ b/.github/ISSUE_TEMPLATE/feature_request.yml @@ -0,0 +1,24 @@ +name: Feature request +description: Suggest an idea for this project +title: '[feat]' +labels: ['enhancement'] +body: + - type: textarea + attributes: + label: Would you like to have a new feature? Please describe. + description: A clear and concise description of what the feature is + placeholder: Ex. Whenever I try to do (xyz) then [...] + validations: + required: false + - type: textarea + attributes: + label: How would this feature be beneficial for the project + description: A clear and concise description about the importance of the feature + validations: + required: false + - type: textarea + attributes: + label: Additional context + description: Add any other context or screenshots about the feature request here. + validations: + required: false \ No newline at end of file diff --git a/.github/ISSUE_TEMPLATE/others.yml b/.github/ISSUE_TEMPLATE/others.yml new file mode 100644 index 0000000..9d0b962 --- /dev/null +++ b/.github/ISSUE_TEMPLATE/others.yml @@ -0,0 +1,22 @@ +name: Other +description: Use this for any other issues. PLEASE do not create blank issues +title: "[other]" +labels: ["random"] +body: + - type: markdown + attributes: + value: "# Other issue" + - type: textarea + id: issuedescription + attributes: + label: What would you like to share? + description: Provide a clear and concise explanation of your issue. + validations: + required: true + - type: textarea + id: extrainfo + attributes: + label: Additional information + description: Is there anything else we should know about this issue? + validations: + required: false \ No newline at end of file diff --git a/.github/pull_request_template.yml b/.github/pull_request_template.yml new file mode 100644 index 0000000..0f3c345 --- /dev/null +++ b/.github/pull_request_template.yml @@ -0,0 +1,32 @@ + + +## Fixes Issue + +This PR fixes the following issues: + +#example + + +## Changes proposed + +Here comes all the changes proposed through this PR + + + + +## Check List (Check all the boxes which are applicable) + +- [ ] My code follows the code style of this project. +- [ ] My change requires a change to the documentation. +- [ ] I have updated the documentation accordingly. +- [ ] All new and existing tests passed. +- [ ] This PR does not contain plagiarized content. +- [ ] The title of my pull request is a short description of the requested changes. + + + +## Screenshots +Add all the screenshots which support your changes \ No newline at end of file diff --git a/.github/workflows/greetings.yml b/.github/workflows/greetings.yml new file mode 100644 index 0000000..ffe5e99 --- /dev/null +++ b/.github/workflows/greetings.yml @@ -0,0 +1,15 @@ +name: Greetings + +on: [pull_request_target, issues] + +jobs: + welcome: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v1 + - uses: EddieHubCommunity/gh-action-community/src/welcome@main + with: + github-token: ${{ secrets.GITHUB_TOKEN }} + issue-message: '

Hello 👋 Thank you very much for raising an issue 🙌 The maintainers will get back to you soon for discussion over the issue! Thank you for your contributions. 🚀

' + pr-message: '

Yeah! You did it 🎉 Now, Relax 😉 -> Grab a drink ☕ -> And wait for the maintainers to check your contributions. Meanwhile, you can discuss on other issues and solve them 😀

' + footer: 'Meanwhile you can discuss about the project in our Discord Server 😀' \ No newline at end of file diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml new file mode 100644 index 0000000..5d2ff78 --- /dev/null +++ b/.github/workflows/release.yml @@ -0,0 +1,29 @@ +name: Changelog +on: + push: + branches: + - main + +jobs: + changelog: + runs-on: ubuntu-latest + + steps: + - uses: actions/checkout@v2 + + - name: Conventional Changelog Action + id: changelog + uses: TriPSs/conventional-changelog-action@v3 + with: + github-token: ${{ secrets.GITHUB_TOKEN }} + output-file: "false" + + - name: Create Release + uses: actions/create-release@v1 + if: ${{ steps.changelog.outputs.skipped == 'false' }} + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + tag_name: ${{ steps.changelog.outputs.tag }} + release_name: ${{ steps.changelog.outputs.tag }} + body: ${{ steps.changelog.outputs.clean_changelog }} \ No newline at end of file