> For clean Markdown of any page, append .md to the page URL.
> For a complete documentation index, see https://docs.itspropel.com/llms.txt.
> For full documentation content, see https://docs.itspropel.com/llms-full.txt.
> For AI client integration (Claude Code, Cursor, etc.), connect to the MCP server at https://docs.itspropel.com/_mcp/server.

# Update Masking Settings

PUT https://communications/settings
Content-Type: multipart/form-data

Updates the masking-settings row. Enabling (false → true) triggers DLC brand registration if platform-owned + pending. Mode changes trigger ModeTransitionHandler (audit + provisioning). Pre-enable: all customer_contacts phones must be E.164 (422 otherwise). Includes inbound-callback routing destinations + back-office whisper config (FR-1, FR-6, FR-7).

Reference: https://docs.itspropel.com/propel-biz/29-communications/29-communications-settings/update-masking-settings

## OpenAPI Specification

```yaml
openapi: 3.1.0
info:
  title: PropelBiz
  version: 1.0.0
paths:
  /communications/settings:
    put:
      operationId: update-masking-settings
      summary: Update Masking Settings
      description: >-
        Updates the masking-settings row. Enabling (false → true) triggers DLC
        brand registration if platform-owned + pending. Mode changes trigger
        ModeTransitionHandler (audit + provisioning). Pre-enable: all
        customer_contacts phones must be E.164 (422 otherwise). Includes
        inbound-callback routing destinations + back-office whisper config
        (FR-1, FR-6, FR-7).
      tags:
        - >-
          subpackage_29Communications.subpackage_29Communications/29CommunicationsSettings
      parameters:
        - name: '{{tenant_key_name}}'
          in: header
          required: false
          schema:
            type: string
      responses:
        '200':
          description: Successful response
          content:
            application/json:
              schema:
                $ref: >-
                  #/components/schemas/29 Communications_29 Communications >
                  Settings_Update Masking Settings_Response_200
      requestBody:
        content:
          multipart/form-data:
            schema:
              type: object
              properties:
                enabled:
                  type: string
                  description: >-
                    Optional: Flip masking on/off for this location - true|false
                    - defaults to stored value
                masking_mode:
                  type: string
                  description: >-
                    Optional: Allocation strategy -
                    shared_tenant|shared_location|per_technician|per_job_ephemeral
                cooldown_days:
                  type: string
                  description: >-
                    Optional: Cooldown before a released number is
                    re-allocatable - 0..180 days
                masking_policy:
                  type: string
                  description: >-
                    Optional: enforced (always mask) or offered (tech can
                    opt-in) - enforced|offered
                retention_days:
                  type: string
                  description: 'Optional: Days to retain Message rows before purge - 1..3650'
                store_sms_body:
                  type: string
                  description: >-
                    Optional: Persist SMS body on Message row (encrypted at
                    rest) - true|false
                grace_window_days:
                  type: string
                  description: >-
                    Optional: M4 post-job grace period before releasing the
                    number - 0..60 days
                provider_ownership:
                  type: string
                  description: >-
                    Optional: platform (our Twilio ISV) or tenant_byo (tenant's
                    own provider) - platform|tenant_byo
                record_voice_calls:
                  type: string
                  description: >-
                    Optional: Record masked voice calls - true|false - requires
                    disclosure playback
                max_masking_numbers:
                  type: string
                  description: 'Optional: Pool-size cap per tenant - 1..500'
                voice_no_match_action:
                  type: string
                  description: >-
                    Optional: What to do when inbound voice has no session -
                    hangup|voicemail|dispatcher_queue
                backoffice_whisper_text:
                  type: string
                  description: >-
                    Optional: announcement up to 500 chars. Templated — supports
                    {customer_name}, {tech_name}, {location_name}, {accept_key}.
                    Empty falls back to built-in default.
                backoffice_whisper_enabled:
                  type: string
                  description: >-
                    Optional: master switch for the whisper announcement on the
                    back-office leg. Ignored unless route resolves to backoffice
                    AND the bound provider implements SupportsCallWhisper
                    (Twilio at v1; RC v2 follow-up).
                eager_provisioning_enabled:
                  type: string
                  description: >-
                    Optional: Pre-provision per-tech numbers on new hire + M4
                    sessions on WO assignment - true|false
                masking_default_channels[]:
                  type: string
                  description: >-
                    Optional: Channels to mask - sms|voice - repeat key for
                    multiple
                backoffice_whisper_accept_key:
                  type: string
                  description: >-
                    Optional: single DTMF digit — must match /^[0-9*#]$/.
                    Default 1.
                smart_callback_window_minutes:
                  type: string
                  description: 'Optional: Inbound reply routing window - 1..1440 minutes'
                inbound_callback_route_in_hours:
                  type: string
                  description: >-
                    Optional: destination during business hours — one of
                    technician|backoffice|voicemail. Default technician
                    (preserves pre-feature behavior).
                backoffice_whisper_require_accept:
                  type: string
                  description: >-
                    Optional: when true the staffer must press accept_key to
                    bridge; when false the announcement is informational and
                    bridge proceeds automatically. FR-7 rejects true with
                    multiple active back-office lines.
                backoffice_whisper_timeout_seconds:
                  type: string
                  description: >-
                    Optional: integer 1–60 seconds before treating no-press as
                    reject. Default 10.
                inbound_callback_route_out_of_hours:
                  type: string
                  description: >-
                    Optional: destination outside business hours / on holidays —
                    one of technician|backoffice|voicemail. Default technician.
              required:
                - enabled
                - masking_mode
                - cooldown_days
                - masking_policy
                - retention_days
                - store_sms_body
                - grace_window_days
                - provider_ownership
                - record_voice_calls
                - max_masking_numbers
                - voice_no_match_action
                - backoffice_whisper_text
                - backoffice_whisper_enabled
                - eager_provisioning_enabled
                - masking_default_channels[]
                - backoffice_whisper_accept_key
                - smart_callback_window_minutes
                - inbound_callback_route_in_hours
                - backoffice_whisper_require_accept
                - backoffice_whisper_timeout_seconds
                - inbound_callback_route_out_of_hours
servers:
  - url: https:/
components:
  schemas:
    29 Communications_29 Communications > Settings_Update Masking Settings_Response_200:
      type: object
      properties: {}
      description: Empty response body
      title: >-
        29 Communications_29 Communications > Settings_Update Masking
        Settings_Response_200

```

## SDK Code Examples

```python
import requests

url = "https://https/communications/settings"

payload = "-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"enabled\"\r\n\r\ntrue\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"masking_mode\"\r\n\r\nshared_location\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"cooldown_days\"\r\n\r\n30\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"masking_policy\"\r\n\r\nenforced\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"retention_days\"\r\n\r\n365\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"store_sms_body\"\r\n\r\ntrue\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"grace_window_days\"\r\n\r\n14\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"provider_ownership\"\r\n\r\nplatform\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"record_voice_calls\"\r\n\r\nfalse\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"max_masking_numbers\"\r\n\r\n100\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"voice_no_match_action\"\r\n\r\nvoicemail\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"backoffice_whisper_text\"\r\n\r\nIncoming call from {customer_name} for {tech_name} at {location_name}. Press {accept_key} to accept.\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"backoffice_whisper_enabled\"\r\n\r\ntrue\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"eager_provisioning_enabled\"\r\n\r\ntrue\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"masking_default_channels[]\"\r\n\r\nsms,voice\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"backoffice_whisper_accept_key\"\r\n\r\n1\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"smart_callback_window_minutes\"\r\n\r\n60\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"inbound_callback_route_in_hours\"\r\n\r\ntechnician\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"backoffice_whisper_require_accept\"\r\n\r\nfalse\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"backoffice_whisper_timeout_seconds\"\r\n\r\n10\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"inbound_callback_route_out_of_hours\"\r\n\r\nvoicemail\r\n-----011000010111000001101001--\r\n"
headers = {
    "{{tenant_key_name}}": "{{tenant_key_value1}}|{{tenant_key_value2}}",
    "Content-Type": "multipart/form-data; boundary=---011000010111000001101001"
}

response = requests.put(url, data=payload, headers=headers)

print(response.json())
```

```javascript
const url = 'https://https/communications/settings';
const form = new FormData();
form.append('enabled', 'true');
form.append('masking_mode', 'shared_location');
form.append('cooldown_days', '30');
form.append('masking_policy', 'enforced');
form.append('retention_days', '365');
form.append('store_sms_body', 'true');
form.append('grace_window_days', '14');
form.append('provider_ownership', 'platform');
form.append('record_voice_calls', 'false');
form.append('max_masking_numbers', '100');
form.append('voice_no_match_action', 'voicemail');
form.append('backoffice_whisper_text', 'Incoming call from {customer_name} for {tech_name} at {location_name}. Press {accept_key} to accept.');
form.append('backoffice_whisper_enabled', 'true');
form.append('eager_provisioning_enabled', 'true');
form.append('masking_default_channels[]', 'sms,voice');
form.append('backoffice_whisper_accept_key', '1');
form.append('smart_callback_window_minutes', '60');
form.append('inbound_callback_route_in_hours', 'technician');
form.append('backoffice_whisper_require_accept', 'false');
form.append('backoffice_whisper_timeout_seconds', '10');
form.append('inbound_callback_route_out_of_hours', 'voicemail');

const options = {
  method: 'PUT',
  headers: {'{{tenant_key_name}}': '{{tenant_key_value1}}|{{tenant_key_value2}}'}
};

options.body = form;

try {
  const response = await fetch(url, options);
  const data = await response.json();
  console.log(data);
} catch (error) {
  console.error(error);
}
```

```go
package main

import (
	"fmt"
	"strings"
	"net/http"
	"io"
)

func main() {

	url := "https://https/communications/settings"

	payload := strings.NewReader("-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"enabled\"\r\n\r\ntrue\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"masking_mode\"\r\n\r\nshared_location\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"cooldown_days\"\r\n\r\n30\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"masking_policy\"\r\n\r\nenforced\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"retention_days\"\r\n\r\n365\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"store_sms_body\"\r\n\r\ntrue\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"grace_window_days\"\r\n\r\n14\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"provider_ownership\"\r\n\r\nplatform\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"record_voice_calls\"\r\n\r\nfalse\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"max_masking_numbers\"\r\n\r\n100\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"voice_no_match_action\"\r\n\r\nvoicemail\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"backoffice_whisper_text\"\r\n\r\nIncoming call from {customer_name} for {tech_name} at {location_name}. Press {accept_key} to accept.\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"backoffice_whisper_enabled\"\r\n\r\ntrue\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"eager_provisioning_enabled\"\r\n\r\ntrue\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"masking_default_channels[]\"\r\n\r\nsms,voice\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"backoffice_whisper_accept_key\"\r\n\r\n1\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"smart_callback_window_minutes\"\r\n\r\n60\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"inbound_callback_route_in_hours\"\r\n\r\ntechnician\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"backoffice_whisper_require_accept\"\r\n\r\nfalse\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"backoffice_whisper_timeout_seconds\"\r\n\r\n10\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"inbound_callback_route_out_of_hours\"\r\n\r\nvoicemail\r\n-----011000010111000001101001--\r\n")

	req, _ := http.NewRequest("PUT", url, payload)

	req.Header.Add("{{tenant_key_name}}", "{{tenant_key_value1}}|{{tenant_key_value2}}")

	res, _ := http.DefaultClient.Do(req)

	defer res.Body.Close()
	body, _ := io.ReadAll(res.Body)

	fmt.Println(res)
	fmt.Println(string(body))

}
```

```ruby
require 'uri'
require 'net/http'

url = URI("https://https/communications/settings")

http = Net::HTTP.new(url.host, url.port)
http.use_ssl = true

request = Net::HTTP::Put.new(url)
request["{{tenant_key_name}}"] = '{{tenant_key_value1}}|{{tenant_key_value2}}'
request.body = "-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"enabled\"\r\n\r\ntrue\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"masking_mode\"\r\n\r\nshared_location\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"cooldown_days\"\r\n\r\n30\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"masking_policy\"\r\n\r\nenforced\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"retention_days\"\r\n\r\n365\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"store_sms_body\"\r\n\r\ntrue\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"grace_window_days\"\r\n\r\n14\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"provider_ownership\"\r\n\r\nplatform\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"record_voice_calls\"\r\n\r\nfalse\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"max_masking_numbers\"\r\n\r\n100\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"voice_no_match_action\"\r\n\r\nvoicemail\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"backoffice_whisper_text\"\r\n\r\nIncoming call from {customer_name} for {tech_name} at {location_name}. Press {accept_key} to accept.\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"backoffice_whisper_enabled\"\r\n\r\ntrue\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"eager_provisioning_enabled\"\r\n\r\ntrue\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"masking_default_channels[]\"\r\n\r\nsms,voice\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"backoffice_whisper_accept_key\"\r\n\r\n1\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"smart_callback_window_minutes\"\r\n\r\n60\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"inbound_callback_route_in_hours\"\r\n\r\ntechnician\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"backoffice_whisper_require_accept\"\r\n\r\nfalse\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"backoffice_whisper_timeout_seconds\"\r\n\r\n10\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"inbound_callback_route_out_of_hours\"\r\n\r\nvoicemail\r\n-----011000010111000001101001--\r\n"

response = http.request(request)
puts response.read_body
```

```java
import com.mashape.unirest.http.HttpResponse;
import com.mashape.unirest.http.Unirest;

HttpResponse<String> response = Unirest.put("https://https/communications/settings")
  .header("{{tenant_key_name}}", "{{tenant_key_value1}}|{{tenant_key_value2}}")
  .body("-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"enabled\"\r\n\r\ntrue\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"masking_mode\"\r\n\r\nshared_location\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"cooldown_days\"\r\n\r\n30\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"masking_policy\"\r\n\r\nenforced\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"retention_days\"\r\n\r\n365\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"store_sms_body\"\r\n\r\ntrue\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"grace_window_days\"\r\n\r\n14\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"provider_ownership\"\r\n\r\nplatform\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"record_voice_calls\"\r\n\r\nfalse\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"max_masking_numbers\"\r\n\r\n100\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"voice_no_match_action\"\r\n\r\nvoicemail\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"backoffice_whisper_text\"\r\n\r\nIncoming call from {customer_name} for {tech_name} at {location_name}. Press {accept_key} to accept.\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"backoffice_whisper_enabled\"\r\n\r\ntrue\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"eager_provisioning_enabled\"\r\n\r\ntrue\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"masking_default_channels[]\"\r\n\r\nsms,voice\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"backoffice_whisper_accept_key\"\r\n\r\n1\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"smart_callback_window_minutes\"\r\n\r\n60\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"inbound_callback_route_in_hours\"\r\n\r\ntechnician\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"backoffice_whisper_require_accept\"\r\n\r\nfalse\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"backoffice_whisper_timeout_seconds\"\r\n\r\n10\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"inbound_callback_route_out_of_hours\"\r\n\r\nvoicemail\r\n-----011000010111000001101001--\r\n")
  .asString();
```

```php
<?php
require_once('vendor/autoload.php');

$client = new \GuzzleHttp\Client();

$response = $client->request('PUT', 'https://https/communications/settings', [
  'multipart' => [
    [
        'name' => 'enabled',
        'contents' => 'true'
    ],
    [
        'name' => 'masking_mode',
        'contents' => 'shared_location'
    ],
    [
        'name' => 'cooldown_days',
        'contents' => '30'
    ],
    [
        'name' => 'masking_policy',
        'contents' => 'enforced'
    ],
    [
        'name' => 'retention_days',
        'contents' => '365'
    ],
    [
        'name' => 'store_sms_body',
        'contents' => 'true'
    ],
    [
        'name' => 'grace_window_days',
        'contents' => '14'
    ],
    [
        'name' => 'provider_ownership',
        'contents' => 'platform'
    ],
    [
        'name' => 'record_voice_calls',
        'contents' => 'false'
    ],
    [
        'name' => 'max_masking_numbers',
        'contents' => '100'
    ],
    [
        'name' => 'voice_no_match_action',
        'contents' => 'voicemail'
    ],
    [
        'name' => 'backoffice_whisper_text',
        'contents' => 'Incoming call from {customer_name} for {tech_name} at {location_name}. Press {accept_key} to accept.'
    ],
    [
        'name' => 'backoffice_whisper_enabled',
        'contents' => 'true'
    ],
    [
        'name' => 'eager_provisioning_enabled',
        'contents' => 'true'
    ],
    [
        'name' => 'masking_default_channels[]',
        'contents' => 'sms,voice'
    ],
    [
        'name' => 'backoffice_whisper_accept_key',
        'contents' => '1'
    ],
    [
        'name' => 'smart_callback_window_minutes',
        'contents' => '60'
    ],
    [
        'name' => 'inbound_callback_route_in_hours',
        'contents' => 'technician'
    ],
    [
        'name' => 'backoffice_whisper_require_accept',
        'contents' => 'false'
    ],
    [
        'name' => 'backoffice_whisper_timeout_seconds',
        'contents' => '10'
    ],
    [
        'name' => 'inbound_callback_route_out_of_hours',
        'contents' => 'voicemail'
    ]
  ]
  'headers' => [
    '{{tenant_key_name}}' => '{{tenant_key_value1}}|{{tenant_key_value2}}',
  ],
]);

echo $response->getBody();
```

```csharp
using RestSharp;

var client = new RestClient("https://https/communications/settings");
var request = new RestRequest(Method.PUT);
request.AddHeader("{{tenant_key_name}}", "{{tenant_key_value1}}|{{tenant_key_value2}}");
request.AddParameter("undefined", "-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"enabled\"\r\n\r\ntrue\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"masking_mode\"\r\n\r\nshared_location\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"cooldown_days\"\r\n\r\n30\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"masking_policy\"\r\n\r\nenforced\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"retention_days\"\r\n\r\n365\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"store_sms_body\"\r\n\r\ntrue\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"grace_window_days\"\r\n\r\n14\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"provider_ownership\"\r\n\r\nplatform\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"record_voice_calls\"\r\n\r\nfalse\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"max_masking_numbers\"\r\n\r\n100\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"voice_no_match_action\"\r\n\r\nvoicemail\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"backoffice_whisper_text\"\r\n\r\nIncoming call from {customer_name} for {tech_name} at {location_name}. Press {accept_key} to accept.\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"backoffice_whisper_enabled\"\r\n\r\ntrue\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"eager_provisioning_enabled\"\r\n\r\ntrue\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"masking_default_channels[]\"\r\n\r\nsms,voice\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"backoffice_whisper_accept_key\"\r\n\r\n1\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"smart_callback_window_minutes\"\r\n\r\n60\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"inbound_callback_route_in_hours\"\r\n\r\ntechnician\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"backoffice_whisper_require_accept\"\r\n\r\nfalse\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"backoffice_whisper_timeout_seconds\"\r\n\r\n10\r\n-----011000010111000001101001\r\nContent-Disposition: form-data; name=\"inbound_callback_route_out_of_hours\"\r\n\r\nvoicemail\r\n-----011000010111000001101001--\r\n", ParameterType.RequestBody);
IRestResponse response = client.Execute(request);
```

```swift
import Foundation

let headers = ["{{tenant_key_name}}": "{{tenant_key_value1}}|{{tenant_key_value2}}"]
let parameters = [
  [
    "name": "enabled",
    "value": "true"
  ],
  [
    "name": "masking_mode",
    "value": "shared_location"
  ],
  [
    "name": "cooldown_days",
    "value": "30"
  ],
  [
    "name": "masking_policy",
    "value": "enforced"
  ],
  [
    "name": "retention_days",
    "value": "365"
  ],
  [
    "name": "store_sms_body",
    "value": "true"
  ],
  [
    "name": "grace_window_days",
    "value": "14"
  ],
  [
    "name": "provider_ownership",
    "value": "platform"
  ],
  [
    "name": "record_voice_calls",
    "value": "false"
  ],
  [
    "name": "max_masking_numbers",
    "value": "100"
  ],
  [
    "name": "voice_no_match_action",
    "value": "voicemail"
  ],
  [
    "name": "backoffice_whisper_text",
    "value": "Incoming call from {customer_name} for {tech_name} at {location_name}. Press {accept_key} to accept."
  ],
  [
    "name": "backoffice_whisper_enabled",
    "value": "true"
  ],
  [
    "name": "eager_provisioning_enabled",
    "value": "true"
  ],
  [
    "name": "masking_default_channels[]",
    "value": "sms,voice"
  ],
  [
    "name": "backoffice_whisper_accept_key",
    "value": "1"
  ],
  [
    "name": "smart_callback_window_minutes",
    "value": "60"
  ],
  [
    "name": "inbound_callback_route_in_hours",
    "value": "technician"
  ],
  [
    "name": "backoffice_whisper_require_accept",
    "value": "false"
  ],
  [
    "name": "backoffice_whisper_timeout_seconds",
    "value": "10"
  ],
  [
    "name": "inbound_callback_route_out_of_hours",
    "value": "voicemail"
  ]
]

let boundary = "---011000010111000001101001"

var body = ""
var error: NSError? = nil
for param in parameters {
  let paramName = param["name"]!
  body += "--\(boundary)\r\n"
  body += "Content-Disposition:form-data; name=\"\(paramName)\""
  if let filename = param["fileName"] {
    let contentType = param["content-type"]!
    let fileContent = String(contentsOfFile: filename, encoding: String.Encoding.utf8)
    if (error != nil) {
      print(error as Any)
    }
    body += "; filename=\"\(filename)\"\r\n"
    body += "Content-Type: \(contentType)\r\n\r\n"
    body += fileContent
  } else if let paramValue = param["value"] {
    body += "\r\n\r\n\(paramValue)"
  }
}

let request = NSMutableURLRequest(url: NSURL(string: "https://https/communications/settings")! as URL,
                                        cachePolicy: .useProtocolCachePolicy,
                                    timeoutInterval: 10.0)
request.httpMethod = "PUT"
request.allHTTPHeaderFields = headers
request.httpBody = postData as Data

let session = URLSession.shared
let dataTask = session.dataTask(with: request as URLRequest, completionHandler: { (data, response, error) -> Void in
  if (error != nil) {
    print(error as Any)
  } else {
    let httpResponse = response as? HTTPURLResponse
    print(httpResponse)
  }
})

dataTask.resume()
```