# `Twilio.Trusthub.V1.TrustProductsService`
[🔗](https://github.com/jeffhuen/twilio_elixir/blob/main/lib/twilio/trusthub/v1/trust_products_service.ex#L2)

Service for TrustProducts API operations.

Operations: `list`, `create`, `fetch`, `update`, `delete`

# `create`

```elixir
@spec create(Twilio.Client.t(), map(), keyword()) ::
  {:ok, Twilio.Resources.Trusthub.V1.TrustProducts.t()}
  | {:ok, map(), map()}
  | :ok
  | {:error, Twilio.Error.t()}
```

Create a new Trust Product.

Operation: `CreateTrustProduct` | Tags: TrusthubV1TrustProducts

## Required Parameters

| Parameter | Type | Description |
|-----------|------|-------------|
| `Email` | string | The email address that will receive updates when the Trust Product resource changes status. |
| `FriendlyName` | string | The string that you assigned to describe the resource. |
| `PolicySid` | string | The unique string of a policy that is associated to the Trust Product resource. |
## Optional Parameters

| Parameter | Type | Description |
|-----------|------|-------------|
| `StatusCallback` | string (uri) | The URL we call to inform your application of status changes. |

# `delete`

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

Delete a specific Trust Product.

Operation: `DeleteTrustProduct` | Tags: TrusthubV1TrustProducts

# `fetch`

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

Fetch a specific Trust Product instance.

Operation: `FetchTrustProduct` | Tags: TrusthubV1TrustProducts

# `list`

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

Retrieve a list of all Trust Products for an account.

Operation: `ListTrustProduct` | Tags: TrusthubV1TrustProducts

## Query Parameters

| Parameter | Type | Description |
|-----------|------|-------------|
| `Status` | string | The verification status of the Trust Product resource. |
| `FriendlyName` | string | The string that you assigned to describe the resource. |
| `PolicySid` | string | The unique string of a policy that is associated to the Trust Product resource. |

# `stream`

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

Stream: Retrieve a list of all Trust Products for an account. (lazy auto-pagination).

# `update`

```elixir
@spec update(Twilio.Client.t(), String.t(), map(), keyword()) ::
  {:ok, Twilio.Resources.Trusthub.V1.TrustProducts.t()}
  | {:ok, map(), map()}
  | :ok
  | {:error, Twilio.Error.t()}
```

Updates a Trust Product in an account.

Operation: `UpdateTrustProduct` | Tags: TrusthubV1TrustProducts

## Optional Parameters

| Parameter | Type | Description |
|-----------|------|-------------|
| `Email` | string | The email address that will receive updates when the Trust Product resource changes status. |
| `FriendlyName` | string | The string that you assigned to describe the resource. |
| `Status` | string |  Values: `draft`, `pending-review`, `in-review`, `twilio-rejected`, `twilio-approved` |
| `StatusCallback` | string (uri) | The URL we call to inform your application of status changes. |

---

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