> ## Documentation Index
> Fetch the complete documentation index at: https://docs.alumio.com/llms.txt
> Use this file to discover all available pages before exploring further.

# Sendcloud

> Connect Alumio to Sendcloud.

## Extra information

System documentation: [Sendcloud API Reference](https://support.sendcloud.com/hc/en-us/articles/360024967012)

## Connector package documentation

### Table of Contents

* **1.** Setting up HTTP Client Sendcloud
  * **1.1** Steps
* **2.** Subscribing to entities from Sendcloud
  * **2.1** Steps
  * **2.2** General concept
* **3.** Publishing entity to Sendcloud
  * **3.1** Steps
  * **3.2** General concept

### 1. Setting up HTTP Client Sendcloud

**1.1 Steps**

1. In the Alumio Dashboard, go to Clients -> HTTP Clients. Create a new HTTP Client and select Sendcloud HTTP Client as the HTTP Client.
2. Fill in the Base URI and Authentication Type
   (For more information, see [Sendcloud API Reference](https://support.sendcloud.com/hc/en-us/articles/360024967012))
3. You can optionally enable logging of request to get the log of the authentication.
4. Save the HTTP Client for use.

### 2. Subscribing to Entities from Sendcloud

**2.1 Steps**

1. Go to Connections -> Incoming and create a new incoming configuration and select Sendcloud Subscriber as the subscriber.
2. Select the entity you want to subscribe to from Sendcloud.
3. Add any request parameters needed to subscribe to the entity.
4. You can optionally add a transformer to transform the request parameters into something you will request from Sendcloud.
5. Select the Sendcloud HTTP Client to use.
6. You can also optionally enable pagination to allow Alumio fetches paginated entities.

**2.2 General Concept**

We follow Sendcloud documentation on building this connector, so you can easily use the connector based on [Sendcloud API Reference](https://developer.Sendcloud.com/Sendcloud-api-docs/reference/introduction).

**HTTP Client**

The HTTP Client configuration you will use to access Sendcloud.

**Entity**

The entity you want to subscribe to Sendcloud. Please refer to the entities from [Sendcloud API Reference](https://support.sendcloud.com/hc/en-us/articles/360024967012) page.

**Request Parameters**

These are the parameters you can provide to get the needed entity based on the [Sendcloud API Reference](https://support.sendcloud.com/hc/en-us/articles/360024967012).

Please look at the example below on how to fill path field when subscribing "Get a spesific parcel" entity.

<img src="https://mintcdn.com/alumio/2XcHi1eVMdbU3dfQ/images/connectors/sendcloud-01.png?fit=max&auto=format&n=2XcHi1eVMdbU3dfQ&q=85&s=845f4e1749ba3de9f9cf0a30dda06665" alt="Sendcloud connector screenshot 1" width="690" height="489" data-path="images/connectors/sendcloud-01.png" />

<img src="https://mintcdn.com/alumio/2XcHi1eVMdbU3dfQ/images/connectors/sendcloud-02.png?fit=max&auto=format&n=2XcHi1eVMdbU3dfQ&q=85&s=8e84320a80f9e0240c3c1b7fbe591c1b" alt="Sendcloud connector screenshot 2" width="572" height="214" data-path="images/connectors/sendcloud-02.png" />

Based on the documentation, we can see that the end point require "id" as a path. That is why we set the "id" inside the path key in the Request Parameters.

* Path is the path parameter of the url. For example the \{id}.
* Query is defined set of parameters attached to the end of a url.\
  Example: [www.url.com?type=true\&start=0](http://www.url.com?type=true\&start=0)

Alumio will then make a request to Sendcloud with the URL /parcels/123

### 3. Publishing Entity to Sendcloud

**3.1 Steps**

1. Go to Connections -> Outgoing, create a new outgoing configuration and select Sendcloud Publisher as the publisher.
2. Select the Action that you want the publisher to perform with the data.
3. Select the Sendcloud entity you want the data to be published to.
4. You can optionally add any path data to the request on the key path.
5. You can optionally add any query data to the request on the key query.
6. You can optionally add any payload data to the request on the key payload.
7. Select the HTTP Client to use.

<img src="https://mintcdn.com/alumio/2XcHi1eVMdbU3dfQ/images/connectors/sendcloud-03.png?fit=max&auto=format&n=2XcHi1eVMdbU3dfQ&q=85&s=998affb2d7829506eb346524b4c8ff72" alt="Sendcloud connector screenshot 3" width="690" height="269" data-path="images/connectors/sendcloud-03.png" />

**3.2 General Concept**

Like the subscriber, the publisher has similar methods on how to use it. The difference is the payload that will be submitted by the publisher originating from the data (from routes, from transformers in outgoing configuration), though you can also add or modify payload using the Request Transformer.

**Action**

Currently, we support Create (HTTP POST method), Patch (HTTP PATCH method), and Delete (HTTP DELETE method) on submitting data to Sendcloud.

**Entity**

We support publishing to most Sendcloud endpoints.
Please refer to [Sendcloud API Reference](https://support.sendcloud.com/hc/en-us/articles/360024967012) page.

For example, we want to use "Create parcel (Single & Multiple)". Please select “Create” as the Action and "Create parcel (Single & Multiple)" as the entity of the publisher.

<img src="https://mintcdn.com/alumio/2XcHi1eVMdbU3dfQ/images/connectors/sendcloud-04.png?fit=max&auto=format&n=2XcHi1eVMdbU3dfQ&q=85&s=04b421bdab29d74b8dd234c73b647007" alt="Sendcloud connector screenshot 4" width="690" height="212" data-path="images/connectors/sendcloud-04.png" />

<img src="https://mintcdn.com/alumio/2XcHi1eVMdbU3dfQ/images/connectors/sendcloud-05.png?fit=max&auto=format&n=2XcHi1eVMdbU3dfQ&q=85&s=65952efa022393a4f369d37b58107578" alt="Sendcloud connector screenshot 5" width="809" height="447" data-path="images/connectors/sendcloud-05.png" />

Based on the documentation, it requires a "Request Body". That is why we set the "Request Body" inside the payload key in the data.

<img src="https://mintcdn.com/alumio/2XcHi1eVMdbU3dfQ/images/connectors/sendcloud-06.png?fit=max&auto=format&n=2XcHi1eVMdbU3dfQ&q=85&s=9e547224db2154b9ec2d8b4ddd0d4bfa" alt="Sendcloud connector screenshot 6" width="465" height="531" data-path="images/connectors/sendcloud-06.png" />

* Path is the path parameter of the url. For example the \{id}.
* Query is defined set of parameters attached to the end of a url.\
  Example: [www.url.com?type=true\&start=0](http://www.url.com?type=true\&start=0)
* Payload is the data contained within a request.

Alumio will send an API request to Sendcloud with URL /parcels

**HTTP Client**

The HTTP Client configuration you will use to access Sendcloud.
