# `Twilio.Flex.V1.PluginService.Plugin.PluginVersionsService`
[🔗](https://github.com/jeffhuen/twilio_elixir/blob/main/lib/twilio/flex/v1/plugin_service/plugin/plugin_versions_service.ex#L2)

Service for PluginVersions API operations.

Operations: `list`, `create`, `fetch`

# `create`

```elixir
@spec create(Twilio.Client.t(), String.t(), map(), keyword()) ::
  {:ok, Twilio.Resources.Flex.V1.PluginService.Plugin.PluginVersions.t()}
  | {:ok, map(), map()}
  | :ok
  | {:error, Twilio.Error.t()}
```

Operation: `CreatePluginVersion` | Tags: FlexV1PluginVersions

## Required Parameters

| Parameter | Type | Description |
|-----------|------|-------------|
| `PluginUrl` | string (uri) | The URL of the Flex Plugin Version bundle |
| `Version` | string | The Flex Plugin Version's version. |
## Optional Parameters

| Parameter | Type | Description |
|-----------|------|-------------|
| `Changelog` | string | The changelog of the Flex Plugin Version. |
| `CliVersion` | string | The version of Flex Plugins CLI used to create this plugin |
| `Private` | boolean | Whether this Flex Plugin Version requires authorization. |
| `ValidateStatus` | string | The validation status of the plugin, indicating whether it has been validated |

# `fetch`

```elixir
@spec fetch(Twilio.Client.t(), String.t(), String.t(), keyword()) ::
  {:ok, Twilio.Resources.Flex.V1.PluginService.Plugin.PluginVersions.t()}
  | {:ok, map(), map()}
  | :ok
  | {:error, Twilio.Error.t()}
```

Operation: `FetchPluginVersion` | Tags: FlexV1PluginVersions

# `list`

```elixir
@spec list(Twilio.Client.t(), String.t(), map(), keyword()) ::
  {:ok, Twilio.Page.t()}
  | {:ok, map(), map()}
  | :ok
  | {:error, Twilio.Error.t()}
```

Operation: `ListPluginVersion` | Tags: FlexV1PluginVersions

# `stream`

```elixir
@spec stream(Twilio.Client.t(), String.t(), map(), keyword()) :: Enumerable.t()
```

Stream:  (lazy auto-pagination).

---

*Consult [api-reference.md](api-reference.md) for complete listing*
