Skip to content

Latest commit

 

History

History
122 lines (88 loc) · 3.86 KB

README.md

File metadata and controls

122 lines (88 loc) · 3.86 KB

Flower

Flower

Build GitHub release License issues - flower

Flower is a powerful and flexible Go library for creating and executing workflows. It provides a simple and intuitive way to define workflows using a declarative YAML syntax and execute them programmatically.

Features

  • Define workflows using a simple and expressive YAML syntax
  • Execute workflows programmatically using the Flower engine
  • Built-in support for common actions (e.g., print, sleep, http)
  • Extensible architecture for adding custom actions
  • Comprehensive error handling and logging capabilities
  • Lightweight and easy to integrate into existing Go projects

Built-in Actions

⚠️ Note (WIP): This list is not exhaustive and may change over time. Please refer to the actions directory for the most up-to-date list of built-in actions.

Flower includes a number of built-in actions that can be used in workflows:

  • Core Actions:

  • core/test/print: Print a message to the console

  • Request Actions:

  • request/http: Perform an HTTP request

  • request/grpc: Perform a gRPC request

  • request/ws: Perform a WebSocket request

  • request/ftp: Perform an FTP request

  • request/sftp: Perform an SFTP request

  • request/ssh: Perform an SSH request

  • request/sql: Perform an SQL request

  • Parsing Actions:

  • parsing/regex: Perform a regular expression match

  • parsing/xpath: Extract data from XML using XPath

  • parsing/jsonpath: Extract data from JSON using JSONPath

  • parsing/delimiter: Split a string using a delimiter

Installation

To install the Flower library, use the following command:

go get github.com/Velka-DEV/flower

Usage

Here's a simple example of how to use Flower to define and execute a workflow:

package main

import (
    "fmt"
    "github.com/Velka-DEV/flower/pkg/flower"
)

func main() {
    // Define the workflow using YAML syntax
    workflowYAML := `
name: Example Workflow
steps:
  - id: step1
    name: Print Hello
    action: core/print
    inputs:
      message: Hello, World!
`

    // Parse the workflow YAML
    workflow, err := flower.FromYaml([]byte(workflowYAML))
    if err != nil {
        panic(err)
    }

    // Create a new Flower runtime
    runtime := flower.NewRuntime()

    // Set the workflow in the runtime
    runtime.SetFlow(workflow)

    // Execute the workflow
    err = runtime.Run(nil)
    if err != nil {
        panic(err)
    }
}

For more detailed examples and usage instructions, please refer to the examples directory.

Contributing

Contributions are welcome! If you'd like to contribute to Flower, please follow these steps:

  1. Fork the repository
  2. Create a new branch for your feature or bug fix
  3. Make your changes and commit them with descriptive commit messages
  4. Push your changes to your forked repository
  5. Submit a pull request to the main repository

Please ensure that your code follows the existing coding style and includes appropriate tests.

License

Flower is released under the GPLv3 License.

Contact

If you have any questions, suggestions, or feedback, please feel free to contact us at:

We appreciate your interest in Flower and look forward to hearing from you!