# Contract Geek API NAV
Shell Python JavaScript C#

Contract Geek

Authentication

Introduction

Welcome to the Contract Geek APIs.

Our APIs can be accessed from two separate environments:

How to Request an API Key

To request an API key, simply log in to the platform and navigate to the organization/API page. From this page, you can manage the API keys for the logged-in user.

What are API Users?

An API user is an internal user within the Organization who can operate exclusively via API. They have access to the web app solely for managing their own API Keys. They are not counted towards the maximum number of users in the Organization.

How To

Add an External User

If the user is part of an Organizaion

  1. Create a Controparte: Create a Controparte where you can add the new user using CreateControparte.

    • Have you already created the Controparte? Retrieve its ID using GetControparti
  2. Add the User: Use AddExternalUser to add the User. Remember to add the ID of the Controparte in the controparte_ids array.

If the user is a Natural person

  1. Create the User: Create the new user using AddExternalNaturalUser. This process will automatically create the associated Controparte.
    • Remember to retrive the ID of the new Controparte from the controparte_ids of the new User or using GetControparti

Create a Workflow

  1. Create a Draft: Create a Draft using CreateWorkflowDraft.

  2. Update the Draft: Modify your draft using UpdateWorkflowDraft.

    • Hint: We suggest using GetWorkflow to get the correct schema of the data to be passed via UpdateWorkflowDraft
    • Warning: Make sure to set the status to 2: Draft Ok before starting the Workflow.
  3. Start the Workflow: Call StartWorkflowDraft to start the Workflow.

Sign a Workflow

  1. Initiate a Signing Session: Start a signing session using SignOpenSession. Make sure to store the returned session_key for future steps.

  2. Send an OTP to the Current User: Depending on your preferred method of verification, send an OTP to the current user. Make sure to store the returned verify_id for future steps.

    • SMS Verification: If you need to sign using the SMS verification, call SignOTPSMSSend.
    • Email Verification: If you need to sign using the email verification, call SignOTPMailSend.
  3. Sign the Workflow: Use the previously stored session_key and verify_id, along with the received OTP, to sign the Workflow.

    • SMS Verification: If you need to sign using the SMS verification, call SignOTPSMS.
    • Email Verification: If you need to sign using the email verification, call SignOTPMail.

Controparte

GetControparti

Code samples

# You can also use wget
curl -X GET /Controparte \
  -H 'Accept: text/plain' \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'Accept': 'text/plain',
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.get('/Controparte', headers = headers)

print(r.json())


const headers = {
  'Accept':'text/plain',
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Controparte',
{
  method: 'GET',

  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }

    /// Make a dummy request
    public async Task MakeGetRequest()
    {
      string url = "/Controparte";
      var result = await GetAsync(url);
    }

    /// Performs a GET Request
    public async Task GetAsync(string url)
    {
        //Start the request
        HttpResponseMessage response = await Client.GetAsync(url);

        //Validate result
        response.EnsureSuccessStatusCode();

    }




    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

GET /Controparte

Retrieves a list of all Controparti within the Organization.

Example responses

200 Response

[{"controparte_id":0,"controparte_name":"string","controparte_nation":"string","controparte_city":"string","controparte_mail":"string","controparte_address":"string","controparte_last_edit":"2019-08-24T14:15:22Z","controparte_piva":"string","controparte_webpage":"string","controparte_type":0,"controparte_cf":"string"}]
[
  {
    "controparte_id": 0,
    "controparte_name": "string",
    "controparte_nation": "string",
    "controparte_city": "string",
    "controparte_mail": "string",
    "controparte_address": "string",
    "controparte_last_edit": "2019-08-24T14:15:22Z",
    "controparte_piva": "string",
    "controparte_webpage": "string",
    "controparte_type": 0,
    "controparte_cf": "string"
  }
]

Responses

Status Meaning Description Schema
200 OK A list of Controparti. Inline
403 Forbidden The user does not have permission to access the Controparti. ProblemDetails

Response Schema

Status Code 200

Name Type Nullable
Controparte [Controparte] false
» controparte_id integer(int32) false
» controparte_name string false
» controparte_nation string false
» controparte_city string false
» controparte_mail string false
» controparte_address string false
» controparte_last_edit string(date-time) false
» controparte_piva string false
» controparte_webpage string true
» controparte_type ControparteType(int32) false
» controparte_cf string true

Enumerated Values

Property Value
standard 0
natural person 1

CreateControparte

Code samples

# You can also use wget
curl -X POST /Controparte \
  -H 'Content-Type: application/json' \
  -H 'Accept: text/plain' \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'Content-Type': 'application/json',
  'Accept': 'text/plain',
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.post('/Controparte', headers = headers)

print(r.json())

const inputBody = '{
  "controparte_id": 0,
  "controparte_name": "string",
  "controparte_nation": "string",
  "controparte_city": "string",
  "controparte_mail": "string",
  "controparte_address": "string",
  "controparte_last_edit": "2019-08-24T14:15:22Z",
  "controparte_piva": "string",
  "controparte_webpage": "string",
  "controparte_type": 0,
  "controparte_cf": "string"
}';
const headers = {
  'Content-Type':'application/json',
  'Accept':'text/plain',
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Controparte',
{
  method: 'POST',
  body: inputBody,
  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }


    /// Make a dummy request
    public async Task MakePostRequest()
    {
      string url = "/Controparte";

      string json = @"{
  ""controparte_id"": 0,
  ""controparte_name"": ""string"",
  ""controparte_nation"": ""string"",
  ""controparte_city"": ""string"",
  ""controparte_mail"": ""string"",
  ""controparte_address"": ""string"",
  ""controparte_last_edit"": ""2019-08-24T14:15:22Z"",
  ""controparte_piva"": ""string"",
  ""controparte_webpage"": ""string"",
  ""controparte_type"": 0,
  ""controparte_cf"": ""string""
}";
      Controparte content = JsonConvert.DeserializeObject(json);
      await PostAsync(content, url);


    }

    /// Performs a POST Request
    public async Task PostAsync(Controparte content, string url)
    {
        //Serialize Object
        StringContent jsonContent = SerializeObject(content);

        //Execute POST request
        HttpResponseMessage response = await Client.PostAsync(url, jsonContent);
    }



    /// Serialize an object to Json
    private StringContent SerializeObject(Controparte content)
    {
        //Serialize Object
        string jsonObject = JsonConvert.SerializeObject(content);

        //Create Json UTF8 String Content
        return new StringContent(jsonObject, Encoding.UTF8, "application/json");
    }

    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

POST /Controparte

Creates a new Controparte within the Organization.

Body parameter

{
  "controparte_id": 0,
  "controparte_name": "string",
  "controparte_nation": "string",
  "controparte_city": "string",
  "controparte_mail": "string",
  "controparte_address": "string",
  "controparte_last_edit": "2019-08-24T14:15:22Z",
  "controparte_piva": "string",
  "controparte_webpage": "string",
  "controparte_type": 0,
  "controparte_cf": "string"
}

Parameters

Name In Type Required Description
body body Controparte true Controparte Object with the information of the new Controparte.

Example responses

201 Response

{"controparte_id":0,"controparte_name":"string","controparte_nation":"string","controparte_city":"string","controparte_mail":"string","controparte_address":"string","controparte_last_edit":"2019-08-24T14:15:22Z","controparte_piva":"string","controparte_webpage":"string","controparte_type":0,"controparte_cf":"string"}
{
  "controparte_id": 0,
  "controparte_name": "string",
  "controparte_nation": "string",
  "controparte_city": "string",
  "controparte_mail": "string",
  "controparte_address": "string",
  "controparte_last_edit": "2019-08-24T14:15:22Z",
  "controparte_piva": "string",
  "controparte_webpage": "string",
  "controparte_type": 0,
  "controparte_cf": "string"
}

Responses

Status Meaning Description Schema
201 Created The newly created Controparte. Controparte
400 Bad Request Something went wrong. Refer to the error message for more details. ProblemDetails
403 Forbidden The user does not have permission to create a new Controparte. ProblemDetails

EditControparte

Code samples

# You can also use wget
curl -X PUT /Controparte \
  -H 'Content-Type: application/json' \
  -H 'Accept: text/plain' \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'Content-Type': 'application/json',
  'Accept': 'text/plain',
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.put('/Controparte', headers = headers)

print(r.json())

const inputBody = '{
  "controparte_id": 0,
  "controparte_name": "string",
  "controparte_nation": "string",
  "controparte_city": "string",
  "controparte_mail": "string",
  "controparte_address": "string",
  "controparte_last_edit": "2019-08-24T14:15:22Z",
  "controparte_piva": "string",
  "controparte_webpage": "string",
  "controparte_type": 0,
  "controparte_cf": "string"
}';
const headers = {
  'Content-Type':'application/json',
  'Accept':'text/plain',
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Controparte',
{
  method: 'PUT',
  body: inputBody,
  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }



    /// Make a dummy request
    public async Task MakePutRequest()
    {
      int id = 1;
      string url = "/Controparte";


      string json = @"{
  ""controparte_id"": 0,
  ""controparte_name"": ""string"",
  ""controparte_nation"": ""string"",
  ""controparte_city"": ""string"",
  ""controparte_mail"": ""string"",
  ""controparte_address"": ""string"",
  ""controparte_last_edit"": ""2019-08-24T14:15:22Z"",
  ""controparte_piva"": ""string"",
  ""controparte_webpage"": ""string"",
  ""controparte_type"": 0,
  ""controparte_cf"": ""string""
}";
      Controparte content = JsonConvert.DeserializeObject(json);
      var result = await PutAsync(id, content, url);


    }

    /// Performs a PUT Request
    public async Task PutAsync(int id, Controparte content, string url)
    {
        //Serialize Object
        StringContent jsonContent = SerializeObject(content);

        //Execute PUT request
        HttpResponseMessage response = await Client.PutAsync(url + $"/{id}", jsonContent);

        //Return response
        return await DeserializeObject(response);
    }


    /// Serialize an object to Json
    private StringContent SerializeObject(Controparte content)
    {
        //Serialize Object
        string jsonObject = JsonConvert.SerializeObject(content);

        //Create Json UTF8 String Content
        return new StringContent(jsonObject, Encoding.UTF8, "application/json");
    }

    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

PUT /Controparte

Updates the information of an existing Controparte.

Body parameter

{
  "controparte_id": 0,
  "controparte_name": "string",
  "controparte_nation": "string",
  "controparte_city": "string",
  "controparte_mail": "string",
  "controparte_address": "string",
  "controparte_last_edit": "2019-08-24T14:15:22Z",
  "controparte_piva": "string",
  "controparte_webpage": "string",
  "controparte_type": 0,
  "controparte_cf": "string"
}

Parameters

Name In Type Required Description
body body Controparte true Controparte Object with the new information of the Controparte.

Example responses

403 Response

{"type":"string","title":"string","status":0,"detail":"string","instance":"string","property1":null,"property2":null}
{
  "type": "string",
  "title": "string",
  "status": 0,
  "detail": "string",
  "instance": "string",
  "property1": null,
  "property2": null
}

Responses

Status Meaning Description Schema
204 No Content The informations was updated successfully. None
403 Forbidden The user does not have permission to update the information. ProblemDetails

GetControparte

Code samples

# You can also use wget
curl -X GET /Controparte/{controparte_id} \
  -H 'Accept: text/plain' \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'Accept': 'text/plain',
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.get('/Controparte/{controparte_id}', headers = headers)

print(r.json())


const headers = {
  'Accept':'text/plain',
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Controparte/{controparte_id}',
{
  method: 'GET',

  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }

    /// Make a dummy request
    public async Task MakeGetRequest()
    {
      string url = "/Controparte/{controparte_id}";
      var result = await GetAsync(url);
    }

    /// Performs a GET Request
    public async Task GetAsync(string url)
    {
        //Start the request
        HttpResponseMessage response = await Client.GetAsync(url);

        //Validate result
        response.EnsureSuccessStatusCode();

    }




    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

GET /Controparte/{controparte_id}

Retrieves a Controparte within the Organization.

Parameters

Name In Type Required Description
controparte_id path integer(int32) true The ID of the Controparte to retrieve.

Example responses

200 Response

{"controparte_id":0,"controparte_name":"string","controparte_nation":"string","controparte_city":"string","controparte_mail":"string","controparte_address":"string","controparte_last_edit":"2019-08-24T14:15:22Z","controparte_piva":"string","controparte_webpage":"string","controparte_type":0,"controparte_cf":"string"}
{
  "controparte_id": 0,
  "controparte_name": "string",
  "controparte_nation": "string",
  "controparte_city": "string",
  "controparte_mail": "string",
  "controparte_address": "string",
  "controparte_last_edit": "2019-08-24T14:15:22Z",
  "controparte_piva": "string",
  "controparte_webpage": "string",
  "controparte_type": 0,
  "controparte_cf": "string"
}

Responses

Status Meaning Description Schema
200 OK Returns the requested Controparte Object. Controparte
403 Forbidden The user does not have permission to access the Controparti. ProblemDetails
404 Not Found A Controparte with the specified ID was not found. ProblemDetails

DeleteControparte

Code samples

# You can also use wget
curl -X DELETE /Controparte/{controparte_id} \
  -H 'Accept: text/plain' \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'Accept': 'text/plain',
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.delete('/Controparte/{controparte_id}', headers = headers)

print(r.json())


const headers = {
  'Accept':'text/plain',
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Controparte/{controparte_id}',
{
  method: 'DELETE',

  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }




    /// Make a dummy request
    public async Task MakeDeleteRequest()
    {
      int id = 1;
      string url = "/Controparte/{controparte_id}";

      await DeleteAsync(id, url);
    }

    /// Performs a DELETE Request
    public async Task DeleteAsync(int id, string url)
    {
        //Execute DELETE request
        HttpResponseMessage response = await Client.DeleteAsync(url + $"/{id}");

        //Return response
        await DeserializeObject(response);
    }

    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

DELETE /Controparte/{controparte_id}

Deletes a specified Controparte from the Organization.

Parameters

Name In Type Required Description
controparte_id path integer(int32) true The ID of the Controparte to delete.

Example responses

403 Response

{"type":"string","title":"string","status":0,"detail":"string","instance":"string","property1":null,"property2":null}
{
  "type": "string",
  "title": "string",
  "status": 0,
  "detail": "string",
  "instance": "string",
  "property1": null,
  "property2": null
}

Responses

Status Meaning Description Schema
204 No Content The Controparte was deleted successfully. None
403 Forbidden The user does not have permission to delete a Controparte. ProblemDetails

GetExternalUsers

Code samples

# You can also use wget
curl -X GET /Controparte/User \
  -H 'Accept: text/plain' \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'Accept': 'text/plain',
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.get('/Controparte/User', headers = headers)

print(r.json())


const headers = {
  'Accept':'text/plain',
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Controparte/User',
{
  method: 'GET',

  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }

    /// Make a dummy request
    public async Task MakeGetRequest()
    {
      string url = "/Controparte/User";
      var result = await GetAsync(url);
    }

    /// Performs a GET Request
    public async Task GetAsync(string url)
    {
        //Start the request
        HttpResponseMessage response = await Client.GetAsync(url);

        //Validate result
        response.EnsureSuccessStatusCode();

    }




    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

GET /Controparte/User

Retrives a list of all External User within the Organization and the Workspace.

An External User is a user that does not have access to the webapp of the application but can approve and sign a Workflow.

Example responses

200 Response

[{"user_id":0,"mail":"string","name":"string","surname":"string","phone":"string","cf":"string","controparte_ids":[0]}]
[
  {
    "user_id": 0,
    "mail": "string",
    "name": "string",
    "surname": "string",

    "phone": "string",
    "cf": "string",
    "controparte_ids": [
      0
    ]
  }
]

Responses

Status Meaning Description Schema
200 OK A list of Users. Inline
403 Forbidden The user does not have permission to access the Users. ProblemDetails

Response Schema

Status Code 200

Name Type Nullable
User [User] false
» id integer(int32) false
» name string false
» surname string false
» mail string false
» phone string true
» cf string true
» controparte_ids [integer] false

AddExternalUser

Code samples

# You can also use wget
curl -X POST /Controparte/User \
  -H 'Content-Type: application/json' \
  -H 'Accept: text/plain' \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'Content-Type': 'application/json',
  'Accept': 'text/plain',
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.post('/Controparte/User', headers = headers)

print(r.json())

const inputBody = '{
  "user_id": 0,
  "mail": "string",
  "name": "string",
  "surname": "string",
  "phone": "string",
  "cf": "string",
  "controparte_ids": [
    0
  ]
}';
const headers = {
  'Content-Type':'application/json',
  'Accept':'text/plain',
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Controparte/User',
{
  method: 'POST',
  body: inputBody,
  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }


    /// Make a dummy request
    public async Task MakePostRequest()
    {
      string url = "/Controparte/User";

      string json = @"{
  ""user_id"": 0,
  ""mail"": ""string"",
  ""name"": ""string"",
  ""surname"": ""string"",
  ""phone"": ""string"",
  ""cf"": ""string"",
  ""controparte_ids"": [
    0
  ]
}";
      ControparteUser content = JsonConvert.DeserializeObject(json);
      await PostAsync(content, url);


    }

    /// Performs a POST Request
    public async Task PostAsync(ControparteUser content, string url)
    {
        //Serialize Object
        StringContent jsonContent = SerializeObject(content);

        //Execute POST request
        HttpResponseMessage response = await Client.PostAsync(url, jsonContent);
    }



    /// Serialize an object to Json
    private StringContent SerializeObject(ControparteUser content)
    {
        //Serialize Object
        string jsonObject = JsonConvert.SerializeObject(content);

        //Create Json UTF8 String Content
        return new StringContent(jsonObject, Encoding.UTF8, "application/json");
    }

    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

POST /Controparte/User

Creates a new Extenral user and associate it to the requested controparti.

The 202 response indicates that the User is already present in our system. In this case, the AddExistingUserToControparte method should be used to associate the existing User with the specified Controparte. This method can also be accessed via the POST /controparte/{controparte_id}/user/{user_id} endpoint.

The 409 response indicates that the User is already present in our system but it is not associated with another Organization. Write a mail to assistenza@contractgeek.it for more details.

Body parameter

{
  "user_id": 0,
  "mail": "string",
  "name": "string",
  "surname": "string",
  "phone": "string",
  "cf": "string",
  "controparte_ids": [
    0
  ]
}

Parameters

Name In Type Required Description
body body ControparteUser false User Object with the information of the new User.

Example responses

200 Response

{"user_id":0,"mail":"string","name":"string","surname":"string","phone":"string","cf":"string","controparte_ids":[0]}
{
  "user_id": 0,
  "mail": "string",
  "name": "string",
  "surname": "string",
  "phone": "string",
  "cf": "string",
  "controparte_ids": [
    0
  ]
}

Responses

Status Meaning Description Schema
200 OK OK ControparteUser
201 Created The newly created User. None
202 Accepted The User is already present in our system and it associated with your Organization. None
400 Bad Request Something went wrong. Refer to the error message for more details. None
403 Forbidden The user does not have permission to create a new User. None
409 Conflict The User is already present in our system but it is associated with another Organization. None

EditControparteUser

Code samples

# You can also use wget
curl -X PUT /Controparte/User \
  -H 'Content-Type: application/json' \
  -H 'Accept: text/plain' \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'Content-Type': 'application/json',
  'Accept': 'text/plain',
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.put('/Controparte/User', headers = headers)

print(r.json())

const inputBody = '{
  "id": 0,
  "name": "string",
  "surname": "string",
  "mail": "string",
  "phone": "string",
  "cf": "string"
}';
const headers = {
  'Content-Type':'application/json',
  'Accept':'text/plain',
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Controparte/User',
{
  method: 'PUT',
  body: inputBody,
  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }



    /// Make a dummy request
    public async Task MakePutRequest()
    {
      int id = 1;
      string url = "/Controparte/User";


      string json = @"{
  ""id"": 0,
  ""name"": ""string"",
  ""surname"": ""string"",
  ""mail"": ""string"",
  ""phone"": ""string"",
  ""cf"": ""string""
}";
      User content = JsonConvert.DeserializeObject(json);
      var result = await PutAsync(id, content, url);


    }

    /// Performs a PUT Request
    public async Task PutAsync(int id, User content, string url)
    {
        //Serialize Object
        StringContent jsonContent = SerializeObject(content);

        //Execute PUT request
        HttpResponseMessage response = await Client.PutAsync(url + $"/{id}", jsonContent);

        //Return response
        return await DeserializeObject(response);
    }


    /// Serialize an object to Json
    private StringContent SerializeObject(User content)
    {
        //Serialize Object
        string jsonObject = JsonConvert.SerializeObject(content);

        //Create Json UTF8 String Content
        return new StringContent(jsonObject, Encoding.UTF8, "application/json");
    }

    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

PUT /Controparte/User

Updates the information of an existing external User.

Please note that this method does not support modifying a user's email address. If you need to change the email address, please send an email to assistenza@contractgeek.it with the old and new addresses.

Body parameter

{
  "id": 0,
  "name": "string",
  "surname": "string",
  "mail": "string",
  "phone": "string",
  "cf": "string"
}

Parameters

Name In Type Required Description
body body User true User Object with the new information of the User.

Example responses

403 Response

{"type":"string","title":"string","status":0,"detail":"string","instance":"string","property1":null,"property2":null}
{
  "type": "string",
  "title": "string",
  "status": 0,
  "detail": "string",
  "instance": "string",
  "property1": null,
  "property2": null
}

Responses

Status Meaning Description Schema
204 No Content The informations was updated successfully. None
403 Forbidden The user does not have permission to update the information. ProblemDetails

GetContropartiAssociatedToUser

Code samples

# You can also use wget
curl -X GET /Controparte/User/{user_id} \
  -H 'Accept: text/plain' \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'Accept': 'text/plain',
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.get('/Controparte/User/{user_id}', headers = headers)

print(r.json())


const headers = {
  'Accept':'text/plain',
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Controparte/User/{user_id}',
{
  method: 'GET',

  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }

    /// Make a dummy request
    public async Task MakeGetRequest()
    {
      string url = "/Controparte/User/{user_id}";
      var result = await GetAsync(url);
    }

    /// Performs a GET Request
    public async Task GetAsync(string url)
    {
        //Start the request
        HttpResponseMessage response = await Client.GetAsync(url);

        //Validate result
        response.EnsureSuccessStatusCode();

    }




    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

GET /Controparte/User/{user_id}

Retrives a list of all Controparti associated with an External User.

Parameters

Name In Type Required Description
user_id path integer(int32) true The ID of the User.

Example responses

200 Response

[{"controparte_id":0,"controparte_name":"string","controparte_nation":"string","controparte_city":"string","controparte_mail":"string","controparte_address":"string","controparte_last_edit":"2019-08-24T14:15:22Z","controparte_piva":"string","controparte_webpage":"string"}]
[
  {
    "controparte_id": 0,
    "controparte_name": "string",
    "controparte_nation": "string",
    "controparte_city": "string",
    "controparte_mail": "string",
    "controparte_address": "string",
    "controparte_last_edit": "2019-08-24T14:15:22Z",
    "controparte_piva": "string",
    "controparte_webpage": "string",
    "controparte_type": 0,
    "controparte_cf": "string"                          
  }
]

Responses

Status Meaning Description Schema
200 OK A list of Controparti. Inline
403 Forbidden The user does not have permission to access the Controparti. ProblemDetails

Response Schema

Status Code 200

Name Type Nullable
Controparte [Controparte] false
» controparte_id integer(int32) false
» controparte_name string false
» controparte_nation string false
» controparte_city string false
» controparte_mail string false
» controparte_address string false
» controparte_last_edit string(date-time) false
» controparte_piva string false
» controparte_webpage string true
» controparte_type ControparteType(int32) false
» controparte_cf string true

Enumerated Values

Property Value
standard 0
natural person 1

GetControparteUsers

Code samples

# You can also use wget
curl -X GET /Controparte/{controparte_id}/User \
  -H 'Accept: text/plain' \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'Accept': 'text/plain',
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.get('/Controparte/{controparte_id}/User', headers = headers)

print(r.json())


const headers = {
  'Accept':'text/plain',
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Controparte/{controparte_id}/User',
{
  method: 'GET',

  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }

    /// Make a dummy request
    public async Task MakeGetRequest()
    {
      string url = "/Controparte/{controparte_id}/User";
      var result = await GetAsync(url);
    }

    /// Performs a GET Request
    public async Task GetAsync(string url)
    {
        //Start the request
        HttpResponseMessage response = await Client.GetAsync(url);

        //Validate result
        response.EnsureSuccessStatusCode();

    }




    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

GET /Controparte/{controparte_id}/User

Retrives a list of all External Users associated with Controparte.

Parameters

Name In Type Required Description
controparte_id path integer(int32) true The ID of the Controparte to retrieve.

Example responses

200 Response

[{"id":0,"name":"string","surname":"string","mail":"string","phone":"string","cf":"string"}]
[
  {
    "id": 0,
    "name": "string",
    "surname": "string",
    "mail": "string",
    "phone": "string",
    "cf": "string"
  }
]

Responses

Status Meaning Description Schema
200 OK A list of Users. Inline
403 Forbidden The user does not have permission to access the Users. ProblemDetails

Response Schema

Status Code 200

Name Type Nullable
User [User] false
» id integer(int32) false
» name string true
» surname string true
» mail string true
» phone string true
» cf string true

AddUserToControparte

Code samples

# You can also use wget
curl -X POST /Controparte/{controparte_id}/User \
  -H 'Content-Type: application/json' \
  -H 'Accept: text/plain' \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'Content-Type': 'application/json',
  'Accept': 'text/plain',
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.post('/Controparte/{controparte_id}/User', headers = headers)

print(r.json())

const inputBody = '{
  "id": 0,
  "name": "string",
  "surname": "string",
  "mail": "string",
  "phone": "string",
  "cf": "string"
}';
const headers = {
  'Content-Type':'application/json',
  'Accept':'text/plain',
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Controparte/{controparte_id}/User',
{
  method: 'POST',
  body: inputBody,
  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }


    /// Make a dummy request
    public async Task MakePostRequest()
    {
      string url = "/Controparte/{controparte_id}/User";

      string json = @"{
  ""id"": 0,
  ""name"": ""string"",
  ""surname"": ""string"",
  ""mail"": ""string"",
  ""phone"": ""string"",
  ""cf"": ""string""
}";
      User content = JsonConvert.DeserializeObject(json);
      await PostAsync(content, url);


    }

    /// Performs a POST Request
    public async Task PostAsync(User content, string url)
    {
        //Serialize Object
        StringContent jsonContent = SerializeObject(content);

        //Execute POST request
        HttpResponseMessage response = await Client.PostAsync(url, jsonContent);
    }



    /// Serialize an object to Json
    private StringContent SerializeObject(User content)
    {
        //Serialize Object
        string jsonObject = JsonConvert.SerializeObject(content);

        //Create Json UTF8 String Content
        return new StringContent(jsonObject, Encoding.UTF8, "application/json");
    }

    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

POST /Controparte/{controparte_id}/User

Creates a new User and associates it with the specified Controparte.

The 202 response indicates that the User is already present in our system. In this case, the AddExistingUserToControparte method should be used to associate the existing User with the specified Controparte

The 409 response indicates that the User is already present in our system but it is not associated with another Organization. Write a mail to assistenza@contractgeek.it for more details.

Body parameter

{
  "id": 0,
  "name": "string",
  "surname": "string",
  "mail": "string",
  "phone": "string",
  "cf": "string"
}

Parameters

Name In Type Required Description
controparte_id path integer(int32) true ID of the Controparte to which the new User will be associated.
body body User false User Object with the information of the new User.

Example responses

201 Response

{"id":0,"name":"string","surname":"string","mail":"string","phone":"string","cf":"string"}
{
  "id": 0,
  "name": "string",
  "surname": "string",
  "mail": "string",
  "phone": "string",
  "cf": "string"
}

Responses

Status Meaning Description Schema
201 Created The newly created User. User
202 Accepted The User is already present in our system and it associated with your Organization. None
400 Bad Request Something went wrong. Refer to the error message for more details. ProblemDetails
403 Forbidden The user does not have permission to create a new User. ProblemDetails
409 Conflict The User is already present in our system but it is associated with another Organization. ProblemDetails

AddExternalNaturalUser

Code samples

# You can also use wget
curl -X POST /Controparte/naturalUser \
  -H 'Content-Type: application/json' \
  -H 'Accept: text/plain' \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'Content-Type': 'application/json',
  'Accept': 'text/plain',
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.post('/Controparte/naturalUser', headers = headers)

print(r.json())

const inputBody = '{
  "user_id": 0,
  "mail": "string",
  "name": "string",
  "surname": "string",
  "phone": "string",
  "cf": "string",
  "controparte_ids": [
    0
  ]
}';
const headers = {
  'Content-Type':'application/json',
  'Accept':'text/plain',
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Controparte/naturalUser',
{
  method: 'POST',
  body: inputBody,
  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }


    /// Make a dummy request
    public async Task MakePostRequest()
    {
      string url = "/Controparte/naturalUser";

      string json = @"{
  ""user_id"": 0,
  ""mail"": ""string"",
  ""name"": ""string"",
  ""surname"": ""string"",
  ""phone"": ""string"",
  ""cf"": ""string"",
  ""controparte_ids"": [
    0
  ]
}";
      ControparteUser content = JsonConvert.DeserializeObject(json);
      await PostAsync(content, url);


    }

    /// Performs a POST Request
    public async Task PostAsync(ControparteUser content, string url)
    {
        //Serialize Object
        StringContent jsonContent = SerializeObject(content);

        //Execute POST request
        HttpResponseMessage response = await Client.PostAsync(url, jsonContent);
    }



    /// Serialize an object to Json
    private StringContent SerializeObject(ControparteUser content)
    {
        //Serialize Object
        string jsonObject = JsonConvert.SerializeObject(content);

        //Create Json UTF8 String Content
        return new StringContent(jsonObject, Encoding.UTF8, "application/json");
    }

    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

POST /Controparte/naturalUser

Creates a new Natural User and their Controparte.

The 202 response indicates that the User is already present in our system. In this case, the AddExistingUserToControparte method should be used to associate the existing User with the specified Controparte. This method can also be accessed via the POST /controparte/{controparte_id}/user/{user_id} endpoint.

The 409 response indicates that the User is already present in our system but it is not associated with another Organization. Write a mail to assistenza@contractgeek.it for more details.

Body parameter

{
  "user_id": 0,
  "mail": "string",
  "name": "string",
  "surname": "string",
  "phone": "string",
  "cf": "string",
  "controparte_ids": [
    0
  ]
}

Parameters

Name In Type Required Description
body body ControparteUser false User Object with the information of the new User.

Example responses

200 Response

{"user_id":0,"mail":"string","name":"string","surname":"string","phone":"string","cf":"string","controparte_ids":[0]}
{
  "user_id": 0,
  "mail": "string",
  "name": "string",
  "surname": "string",
  "phone": "string",
  "cf": "string",
  "controparte_ids": [
    0
  ]
}

Responses

Status Meaning Description Schema
200 OK OK ControparteUser
201 Created The newly created User. None
202 Accepted The User is already present in our system and it associated with your Organization. None
400 Bad Request Something went wrong. Refer to the error message for more details. None
403 Forbidden The user does not have permission to create a new User. None
409 Conflict The User is already present in our system but it is associated with another Organization. None

AddExistingUserToControparte

Code samples

# You can also use wget
curl -X POST /Controparte/{controparte_id}/User/{user_id} \
  -H 'Accept: text/plain' \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'Accept': 'text/plain',
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.post('/Controparte/{controparte_id}/User/{user_id}', headers = headers)

print(r.json())


const headers = {
  'Accept':'text/plain',
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Controparte/{controparte_id}/User/{user_id}',
{
  method: 'POST',

  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }


    /// Make a dummy request
    public async Task MakePostRequest()
    {
      string url = "/Controparte/{controparte_id}/User/{user_id}";


      await PostAsync(null, url);

    }

    /// Performs a POST Request
    public async Task PostAsync(undefined content, string url)
    {
        //Serialize Object
        StringContent jsonContent = SerializeObject(content);

        //Execute POST request
        HttpResponseMessage response = await Client.PostAsync(url, jsonContent);
    }



    /// Serialize an object to Json
    private StringContent SerializeObject(undefined content)
    {
        //Serialize Object
        string jsonObject = JsonConvert.SerializeObject(content);

        //Create Json UTF8 String Content
        return new StringContent(jsonObject, Encoding.UTF8, "application/json");
    }

    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

POST /Controparte/{controparte_id}/User/{user_id}

Associates an existing User with the specified Controparte.

Parameters

Name In Type Required Description
controparte_id path integer(int32) true ID of the Controparte to which the existing User will be associated.
user_id path integer(int32) true ID of the User to associate

Example responses

403 Response

{"type":"string","title":"string","status":0,"detail":"string","instance":"string","property1":null,"property2":null}
{
  "type": "string",
  "title": "string",
  "status": 0,
  "detail": "string",
  "instance": "string",
  "property1": null,
  "property2": null
}

Responses

Status Meaning Description Schema
204 No Content The association was created successfully. None
403 Forbidden The user does not have permission to update the specified Controparte. ProblemDetails
409 Conflict The User is already associated with the specified Controparte. ProblemDetails

DeleteControparteUser

Code samples

# You can also use wget
curl -X DELETE /Controparte/{controparte_id}/User/{user_id} \
  -H 'Accept: text/plain' \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'Accept': 'text/plain',
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.delete('/Controparte/{controparte_id}/User/{user_id}', headers = headers)

print(r.json())


const headers = {
  'Accept':'text/plain',
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Controparte/{controparte_id}/User/{user_id}',
{
  method: 'DELETE',

  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }




    /// Make a dummy request
    public async Task MakeDeleteRequest()
    {
      int id = 1;
      string url = "/Controparte/{controparte_id}/User/{user_id}";

      await DeleteAsync(id, url);
    }

    /// Performs a DELETE Request
    public async Task DeleteAsync(int id, string url)
    {
        //Execute DELETE request
        HttpResponseMessage response = await Client.DeleteAsync(url + $"/{id}");

        //Return response
        await DeserializeObject(response);
    }

    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

DELETE /Controparte/{controparte_id}/User/{user_id}

Deletes a specified User from a Controparte.

This method allows for the removal of a User from a specific Controparte. If the controparte_id param is set to 0 delete the User from every Controparte.

Parameters

Name In Type Required Description
user_id path integer(int32) true The ID of the User to delete.
controparte_id path integer(int32) true The ID of the Controparte from which the User will be deleted. If set to 0 it will delete the user from every Controparte.

Example responses

403 Response

{"type":"string","title":"string","status":0,"detail":"string","instance":"string","property1":null,"property2":null}
{
  "type": "string",
  "title": "string",
  "status": 0,
  "detail": "string",
  "instance": "string",
  "property1": null,
  "property2": null
}

Responses

Status Meaning Description Schema
204 No Content The User was deleted successfully. None
403 Forbidden The user does not have permission to delete an User. ProblemDetails

Document

CreateArchive

Code samples

# You can also use wget
curl -X POST /Archive \
  -H 'Content-Type: multipart/form-data' \
  -H 'Accept: text/plain' \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'Content-Type': 'multipart/form-data',
  'Accept': 'text/plain',
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.post('/Archive', headers = headers)

print(r.json())

const inputBody = '{
  "file": "string"
}';
const headers = {
  'Content-Type':'multipart/form-data',
  'Accept':'text/plain',
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Archive',
{
  method: 'POST',
  body: inputBody,
  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }


    /// Make a dummy request
    public async Task MakePostRequest()
    {
      string url = "/Archive";


      await PostAsync(null, url);

    }

    /// Performs a POST Request
    public async Task PostAsync(undefined content, string url)
    {
        //Serialize Object
        StringContent jsonContent = SerializeObject(content);

        //Execute POST request
        HttpResponseMessage response = await Client.PostAsync(url, jsonContent);
    }



    /// Serialize an object to Json
    private StringContent SerializeObject(undefined content)
    {
        //Serialize Object
        string jsonObject = JsonConvert.SerializeObject(content);

        //Create Json UTF8 String Content
        return new StringContent(jsonObject, Encoding.UTF8, "application/json");
    }

    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

POST /Archive

Create a new Archive

Body parameter

file: string

Parameters

Name In Type Required Description
body body object false none
» file body string(binary) false A FormFile containing the new "Principale" document to be added to the Archive.

Example responses

201 Response

{"archive_id":0,"folder_id":0,"document_id":0}
{
  "archive_id": 0,
  "folder_id": 0,
  "document_id": 0
}

Responses

Status Meaning Description Schema
201 Created Information of the new Archive. ArchiveSmallDTO
403 Forbidden The user does not have permission to create am Archive. ProblemDetails

Information

whoami

Code samples

# You can also use wget
curl -X GET /whoami \
  -H 'Accept: text/plain' \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'Accept': 'text/plain',
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.get('/whoami', headers = headers)

print(r.json())


const headers = {
  'Accept':'text/plain',
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/whoami',
{
  method: 'GET',

  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }

    /// Make a dummy request
    public async Task MakeGetRequest()
    {
      string url = "/whoami";
      var result = await GetAsync(url);
    }

    /// Performs a GET Request
    public async Task GetAsync(string url)
    {
        //Start the request
        HttpResponseMessage response = await Client.GetAsync(url);

        //Validate result
        response.EnsureSuccessStatusCode();

    }




    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

GET /whoami

Validates the current user's API key and retrieves associated user information.

This method performs two primary checks:

Example responses

200 Response

{"id":0,"name":"string","surname":"string","mail":"string","phone":"string","cf":"string"}
{
  "id": 0,
  "name": "string",
  "surname": "string",
  "mail": "string",
  "phone": "string",
  "cf": "string"
}

Responses

Status Meaning Description Schema
200 OK A User object containing the details of the associated user if the API key is valid. User
400 Bad Request An error message detailing the issue. ProblemDetails

GetRole

Code samples

# You can also use wget
curl -X GET /Information/Role \
  -H 'Accept: text/plain' \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'Accept': 'text/plain',
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.get('/Information/Role', headers = headers)

print(r.json())


const headers = {
  'Accept':'text/plain',
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Information/Role',
{
  method: 'GET',

  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }

    /// Make a dummy request
    public async Task MakeGetRequest()
    {
      string url = "/Information/Role";
      var result = await GetAsync(url);
    }

    /// Performs a GET Request
    public async Task GetAsync(string url)
    {
        //Start the request
        HttpResponseMessage response = await Client.GetAsync(url);

        //Validate result
        response.EnsureSuccessStatusCode();

    }




    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

GET /Information/Role

Retrieves a collection of all defined user roles.

Example responses

200 Response

[{"role_id":0,"role_name_primary":"string","role_name_secondary":"string","description":"string","ws_can_create":true,"ws_can_invite":true,"doc_can_upload":true,"doc_can_edit":true,"doc_can_share":true}]
[
  {
    "role_id": 0,
    "role_name_primary": "string",
    "role_name_secondary": "string",
    "description": "string",
    "ws_can_create": true,
    "ws_can_invite": true,
    "doc_can_upload": true,
    "doc_can_edit": true,
    "doc_can_share": true
  }
]

Responses

Status Meaning Description Schema
200 OK Returns the collection of user roles. Inline

Response Schema

Status Code 200

Name Type Nullable
Role [Role] false
» role_id integer(int32) false
» role_name_primary string false
» role_name_secondary string true
» description string true
» ws_can_create boolean false
» ws_can_invite boolean false
» doc_can_upload boolean false
» doc_can_edit boolean false
» doc_can_share boolean false

GetStatus

Code samples

# You can also use wget
curl -X GET /Information/Status \
  -H 'Accept: text/plain' \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'Accept': 'text/plain',
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.get('/Information/Status', headers = headers)

print(r.json())


const headers = {
  'Accept':'text/plain',
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Information/Status',
{
  method: 'GET',

  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }

    /// Make a dummy request
    public async Task MakeGetRequest()
    {
      string url = "/Information/Status";
      var result = await GetAsync(url);
    }

    /// Performs a GET Request
    public async Task GetAsync(string url)
    {
        //Start the request
        HttpResponseMessage response = await Client.GetAsync(url);

        //Validate result
        response.EnsureSuccessStatusCode();

    }




    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

GET /Information/Status

Retrieves a collection of all possible workflow statuses.

Example responses

200 Response

[{"status_id":0,"title":"string","color":"string"}]
[
  {
    "status_id": 0,
    "title": "string",
    "color": "string"
  }
]

Responses

Status Meaning Description Schema
200 OK Returns the collection of workflow statuses. Inline

Response Schema

Status Code 200

Name Type Nullable
Status [Status] false
» status_id integer(int32) false
» title string true
» color string true

GetCategory

Code samples

# You can also use wget
curl -X GET /Information/Category \
  -H 'Accept: text/plain' \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'Accept': 'text/plain',
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.get('/Information/Category', headers = headers)

print(r.json())


const headers = {
  'Accept':'text/plain',
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Information/Category',
{
  method: 'GET',

  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }

    /// Make a dummy request
    public async Task MakeGetRequest()
    {
      string url = "/Information/Category";
      var result = await GetAsync(url);
    }

    /// Performs a GET Request
    public async Task GetAsync(string url)
    {
        //Start the request
        HttpResponseMessage response = await Client.GetAsync(url);

        //Validate result
        response.EnsureSuccessStatusCode();

    }




    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

GET /Information/Category

Retrieves a collection of all document categories.

Example responses

200 Response

[{"category_id":0,"category_name":"string"}]
[
  {
    "category_id": 0,
    "category_name": "string"
  }
]

Responses

Status Meaning Description Schema
200 OK Returns the collection of document categories. Inline

Response Schema

Status Code 200

Name Type Nullable
DocumentCategory [DocumentCategory] false
» category_id integer(int32) false
» category_name string false

GetSignOption

Code samples

# You can also use wget
curl -X GET /Information/SignOption \
  -H 'Accept: text/plain' \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'Accept': 'text/plain',
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.get('/Information/SignOption', headers = headers)

print(r.json())


const headers = {
  'Accept':'text/plain',
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Information/SignOption',
{
  method: 'GET',

  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }

    /// Make a dummy request
    public async Task MakeGetRequest()
    {
      string url = "/Information/SignOption";
      var result = await GetAsync(url);
    }

    /// Performs a GET Request
    public async Task GetAsync(string url)
    {
        //Start the request
        HttpResponseMessage response = await Client.GetAsync(url);

        //Validate result
        response.EnsureSuccessStatusCode();

    }




    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

GET /Information/SignOption

Retrieves a collection of all sign options.

Example responses

200 Response

[{"sign_option_id":0,"sign_name":"string","required_data":"string"}]
[
  {
    "sign_option_id": 0,
    "sign_name": "string",
    "required_data": "string"
  }
]

Responses

Status Meaning Description Schema
200 OK Returns the collection of sign options. Inline

Response Schema

Status Code 200

Name Type Nullable
SignOption [SignOption] false
» sign_option_id integer(int32) false
» sign_name string false
» required_data string true

Organization

GetOrganization

Code samples

# You can also use wget
curl -X GET /Organization \
  -H 'Accept: text/plain' \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'Accept': 'text/plain',
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.get('/Organization', headers = headers)

print(r.json())


const headers = {
  'Accept':'text/plain',
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Organization',
{
  method: 'GET',

  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }

    /// Make a dummy request
    public async Task MakeGetRequest()
    {
      string url = "/Organization";
      var result = await GetAsync(url);
    }

    /// Performs a GET Request
    public async Task GetAsync(string url)
    {
        //Start the request
        HttpResponseMessage response = await Client.GetAsync(url);

        //Validate result
        response.EnsureSuccessStatusCode();

    }




    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

GET /Organization

Retrieves detailed information about current Organization.

Example responses

200 Response

{"organization_id":0,"organization_name":"string","master_account_id":0,"workspaces":[0],"workspace_max_number":0,"organization_logo":"string","accesses":{"property1":true,"property2":true}}
{
  "organization_id": 0,
  "organization_name": "string",
  "master_account_id": 0,
  "workspaces": [
    0
  ],
  "workspace_max_number": 0,
  "organization_logo": "string",
  "accesses": {
    "property1": true,
    "property2": true
  }
}

Responses

Status Meaning Description Schema
200 OK An Organization Object with the information of the Organization. Organization

GetOrganizationWorkspace

Code samples

# You can also use wget
curl -X GET /Organization/Workspace \
  -H 'Accept: text/plain' \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'Accept': 'text/plain',
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.get('/Organization/Workspace', headers = headers)

print(r.json())


const headers = {
  'Accept':'text/plain',
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Organization/Workspace',
{
  method: 'GET',

  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }

    /// Make a dummy request
    public async Task MakeGetRequest()
    {
      string url = "/Organization/Workspace";
      var result = await GetAsync(url);
    }

    /// Performs a GET Request
    public async Task GetAsync(string url)
    {
        //Start the request
        HttpResponseMessage response = await Client.GetAsync(url);

        //Validate result
        response.EnsureSuccessStatusCode();

    }




    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

GET /Organization/Workspace

Retrieves a list of all Workspaces within the current Organization to which the User has access.

Example responses

200 Response

[{"workspace_id":0,"workspace_name":"string","logo":"string"}]
[
  {
    "workspace_id": 0,
    "workspace_name": "string",
    "logo": "string"
  }
]

Responses

Status Meaning Description Schema
200 OK A list of Workspaces. Inline

Response Schema

Status Code 200

Name Type Nullable
Workspace [Workspace] false
» workspace_id integer(int32) false
» workspace_name string false
» logo string(byte) true

GetOrganizationWorkspaceUser

Code samples

# You can also use wget
curl -X GET /Organization/User \
  -H 'Accept: text/plain' \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'Accept': 'text/plain',
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.get('/Organization/User', headers = headers)

print(r.json())


const headers = {
  'Accept':'text/plain',
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Organization/User',
{
  method: 'GET',

  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }

    /// Make a dummy request
    public async Task MakeGetRequest()
    {
      string url = "/Organization/User";
      var result = await GetAsync(url);
    }

    /// Performs a GET Request
    public async Task GetAsync(string url)
    {
        //Start the request
        HttpResponseMessage response = await Client.GetAsync(url);

        //Validate result
        response.EnsureSuccessStatusCode();

    }




    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

GET /Organization/User

Retrieves a list of all Users within the current Organization and Workspace.

If the Workspace-ID authentication header is set to 0, the method will retrieve all Users within the Organization.

Example responses

200 Response

[{"id":0,"name":"string","surname":"string","mail":"string","phone":"string","cf":"string","userRoles":[0],"userAuthorization":{"document":{"read":true,"write":{"property1":true,"property2":true}},"workflow":{"read":true,"write":{"property1":true,"property2":true}}},"deleted":true}]
[
  {
    "id": 0,
    "name": "string",
    "surname": "string",
    "mail": "string",
    "phone": "string",
    "cf": "string",
    "userRoles": [
      0
    ],
    "userAuthorization": {
      "document": {
        "read": true,
        "write": {
          "property1": true,
          "property2": true
        }
      },
      "workflow": {
        "read": true,
        "write": {
          "property1": true,
          "property2": true
        }
      }
    },
    "deleted": true
  }
]

Responses

Status Meaning Description Schema
200 OK A list of Users. Inline

Response Schema

Status Code 200

Name Type Nullable
WorkspaceUser [WorkspaceUser] false
» id integer(int32) false
» name string false
» surname string false
» mail string false
» phone string true
» cf string true
» userRoles [integer] true
» userAuthorization UserAuthorization false
»» document AuthObject false
»»» read boolean false
»»» write object true
»»»» additionalProperties boolean false
»» workflow AuthObject false
» deleted boolean false

UpdateInternalUser

Code samples

# You can also use wget
curl -X PUT /Organization/User \
  -H 'Content-Type: application/json' \
  -H 'Accept: text/plain' \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'Content-Type': 'application/json',
  'Accept': 'text/plain',
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.put('/Organization/User', headers = headers)

print(r.json())

const inputBody = '{
  "id": 0,
  "name": "string",
  "surname": "string",
  "mail": "string",
  "phone": "string",
  "cf": "string",
  "userRoles": [
    0
  ],
  "userAuthorization": {
    "document": {
      "read": true,
      "write": {
        "property1": true,
        "property2": true
      }
    },
    "workflow": {
      "read": true,
      "write": {
        "property1": true,
        "property2": true
      }
    }
  },
  "deleted": true
}';
const headers = {
  'Content-Type':'application/json',
  'Accept':'text/plain',
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Organization/User',
{
  method: 'PUT',
  body: inputBody,
  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }



    /// Make a dummy request
    public async Task MakePutRequest()
    {
      int id = 1;
      string url = "/Organization/User";


      string json = @"{
  ""id"": 0,
  ""name"": ""string"",
  ""surname"": ""string"",
  ""mail"": ""string"",
  ""phone"": ""string"",
  ""cf"": ""string"",
  ""userRoles"": [
    0
  ],
  ""userAuthorization"": {
    ""document"": {
      ""read"": true,
      ""write"": {
        ""property1"": true,
        ""property2"": true
      }
    },
    ""workflow"": {
      ""read"": true,
      ""write"": {
        ""property1"": true,
        ""property2"": true
      }
    }
  },
  ""deleted"": true
}";
      WorkspaceUser content = JsonConvert.DeserializeObject(json);
      var result = await PutAsync(id, content, url);


    }

    /// Performs a PUT Request
    public async Task PutAsync(int id, WorkspaceUser content, string url)
    {
        //Serialize Object
        StringContent jsonContent = SerializeObject(content);

        //Execute PUT request
        HttpResponseMessage response = await Client.PutAsync(url + $"/{id}", jsonContent);

        //Return response
        return await DeserializeObject(response);
    }


    /// Serialize an object to Json
    private StringContent SerializeObject(WorkspaceUser content)
    {
        //Serialize Object
        string jsonObject = JsonConvert.SerializeObject(content);

        //Create Json UTF8 String Content
        return new StringContent(jsonObject, Encoding.UTF8, "application/json");
    }

    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

PUT /Organization/User

Updates the information of an existing internal User.

To update the User's information at the Organization level, set the Workspace-ID authentication header to 0.

Please note that this method does not support modifying a user's email address. If you need to change the email address, please send an email to assistenza@contractgeek.it with the old and new addresses.

Body parameter

{
  "id": 0,
  "name": "string",
  "surname": "string",
  "mail": "string",
  "phone": "string",
  "cf": "string",
  "userRoles": [
    0
  ],
  "userAuthorization": {
    "document": {
      "read": true,
      "write": {
        "property1": true,
        "property2": true
      }
    },
    "workflow": {
      "read": true,
      "write": {
        "property1": true,
        "property2": true
      }
    }
  },
  "deleted": true
}

Parameters

Name In Type Required Description
body body WorkspaceUser false User Object with the new information of the User.

Example responses

403 Response

{"type":"string","title":"string","status":0,"detail":"string","instance":"string","property1":null,"property2":null}
{
  "type": "string",
  "title": "string",
  "status": 0,
  "detail": "string",
  "instance": "string",
  "property1": null,
  "property2": null
}

Responses

Status Meaning Description Schema
204 No Content The informations was updated successfully. None
403 Forbidden The user does not have permission to update the information. ProblemDetails

Ping

GetPing

Code samples

# You can also use wget
curl -X GET /Ping \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.get('/Ping', headers = headers)

print(r.json())


const headers = {
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Ping',
{
  method: 'GET',

  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }

    /// Make a dummy request
    public async Task MakeGetRequest()
    {
      string url = "/Ping";
      var result = await GetAsync(url);
    }

    /// Performs a GET Request
    public async Task GetAsync(string url)
    {
        //Start the request
        HttpResponseMessage response = await Client.GetAsync(url);

        //Validate result
        response.EnsureSuccessStatusCode();

    }




    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

GET /Ping

Executes a GET request to verify the server's ability to respond.

This function is typically used for health checks or ping operations.

Responses

Status Meaning Description Schema
200 OK The current UTC timestamp. string

PostPing

Code samples

# You can also use wget
curl -X POST /Ping \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.post('/Ping', headers = headers)

print(r.json())


const headers = {
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Ping',
{
  method: 'POST',

  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }


    /// Make a dummy request
    public async Task MakePostRequest()
    {
      string url = "/Ping";


      await PostAsync(null, url);

    }

    /// Performs a POST Request
    public async Task PostAsync(undefined content, string url)
    {
        //Serialize Object
        StringContent jsonContent = SerializeObject(content);

        //Execute POST request
        HttpResponseMessage response = await Client.PostAsync(url, jsonContent);
    }



    /// Serialize an object to Json
    private StringContent SerializeObject(undefined content)
    {
        //Serialize Object
        string jsonObject = JsonConvert.SerializeObject(content);

        //Create Json UTF8 String Content
        return new StringContent(jsonObject, Encoding.UTF8, "application/json");
    }

    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

POST /Ping

Executes a POST request to verify the server's ability to respond.

This function is typically used for health checks or ping operations.

Responses

Status Meaning Description Schema
200 OK The current UTC timestamp. string

PutPing

Code samples

# You can also use wget
curl -X PUT /Ping \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.put('/Ping', headers = headers)

print(r.json())


const headers = {
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Ping',
{
  method: 'PUT',

  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }



    /// Make a dummy request
    public async Task MakePutRequest()
    {
      int id = 1;
      string url = "/Ping";



      var result = await PutAsync(id, null, url);

    }

    /// Performs a PUT Request
    public async Task PutAsync(int id, undefined content, string url)
    {
        //Serialize Object
        StringContent jsonContent = SerializeObject(content);

        //Execute PUT request
        HttpResponseMessage response = await Client.PutAsync(url + $"/{id}", jsonContent);

        //Return response
        return await DeserializeObject(response);
    }


    /// Serialize an object to Json
    private StringContent SerializeObject(undefined content)
    {
        //Serialize Object
        string jsonObject = JsonConvert.SerializeObject(content);

        //Create Json UTF8 String Content
        return new StringContent(jsonObject, Encoding.UTF8, "application/json");
    }

    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

PUT /Ping

Executes a PUT request to verify the server's ability to respond.

This function is typically used for health checks or ping operations.

Responses

Status Meaning Description Schema
200 OK The current UTC timestamp. string

PatchPing

Code samples

# You can also use wget
curl -X PATCH /Ping \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.patch('/Ping', headers = headers)

print(r.json())


const headers = {
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Ping',
{
  method: 'PATCH',

  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }





    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

PATCH /Ping

Executes a PATCH request to verify the server's ability to respond.

This function is typically used for health checks or ping operations.

Responses

Status Meaning Description Schema
200 OK The current UTC timestamp. string

DeletePing

Code samples

# You can also use wget
curl -X DELETE /Ping \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.delete('/Ping', headers = headers)

print(r.json())


const headers = {
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Ping',
{
  method: 'DELETE',

  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }




    /// Make a dummy request
    public async Task MakeDeleteRequest()
    {
      int id = 1;
      string url = "/Ping";

      await DeleteAsync(id, url);
    }

    /// Performs a DELETE Request
    public async Task DeleteAsync(int id, string url)
    {
        //Execute DELETE request
        HttpResponseMessage response = await Client.DeleteAsync(url + $"/{id}");

        //Return response
        await DeserializeObject(response);
    }

    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

DELETE /Ping

Executes a DELETE request to verify the server's ability to respond.

This function is typically used for health checks or ping operations.

Responses

Status Meaning Description Schema
200 OK The current UTC timestamp. string

Sign

SignOpenSession

Code samples

# You can also use wget
curl -X GET /Workflow/{workflow_id}/Sign/OpenSession \
  -H 'Accept: text/plain' \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'Accept': 'text/plain',
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.get('/Workflow/{workflow_id}/Sign/OpenSession', headers = headers)

print(r.json())


const headers = {
  'Accept':'text/plain',
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Workflow/{workflow_id}/Sign/OpenSession',
{
  method: 'GET',

  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }

    /// Make a dummy request
    public async Task MakeGetRequest()
    {
      string url = "/Workflow/{workflow_id}/Sign/OpenSession";
      var result = await GetAsync(url);
    }

    /// Performs a GET Request
    public async Task GetAsync(string url)
    {
        //Start the request
        HttpResponseMessage response = await Client.GetAsync(url);

        //Validate result
        response.EnsureSuccessStatusCode();

    }




    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

GET /Workflow/{workflow_id}/Sign/OpenSession

Starts a Sign Session for the specified Workflow.

Parameters

Name In Type Required Description
workflow_id path integer(int32) true ID of the Workflow to Sign.

Example responses

200 Response

"string"

Responses

Status Meaning Description Schema
200 OK The session_key of the started session. string
400 Bad Request Something went wrong. Refer to the error message for more details. ProblemDetails

SignOTPSMSSend

Code samples

# You can also use wget
curl -X GET /Workflow/{workflow_id}/Sign/{session_key}/OTP/SMS/Send \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.get('/Workflow/{workflow_id}/Sign/{session_key}/OTP/SMS/Send', headers = headers)

print(r.json())


const headers = {
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Workflow/{workflow_id}/Sign/{session_key}/OTP/SMS/Send',
{
  method: 'GET',

  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }

    /// Make a dummy request
    public async Task MakeGetRequest()
    {
      string url = "/Workflow/{workflow_id}/Sign/{session_key}/OTP/SMS/Send";
      var result = await GetAsync(url);
    }

    /// Performs a GET Request
    public async Task GetAsync(string url)
    {
        //Start the request
        HttpResponseMessage response = await Client.GetAsync(url);

        //Validate result
        response.EnsureSuccessStatusCode();

    }




    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

GET /Workflow/{workflow_id}/Sign/{session_key}/OTP/SMS/Send

Sends an SMS to the current User with an OTP to Sign a Workflow.

Prior to using this method, ensure to call the SignOpenSession method to obtain a session_key for your Workflow.

Parameters

Name In Type Required Description
workflow_id path integer(int32) true ID of the Workflow to Sign.
session_key path string true Current session_key of the Workflow to Sign.

Responses

Status Meaning Description Schema
200 OK The verify_id associated with the OTP. string

SignOTPSMS

Code samples

# You can also use wget
curl -X POST /Workflow/{workflow_id}/Sign/{session_key}/OTP/SMS?verify_id=string&OTP=string \
  -H 'Accept: text/plain' \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'Accept': 'text/plain',
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.post('/Workflow/{workflow_id}/Sign/{session_key}/OTP/SMS', params={
  'verify_id': 'string',  'OTP': 'string'
}, headers = headers)

print(r.json())


const headers = {
  'Accept':'text/plain',
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Workflow/{workflow_id}/Sign/{session_key}/OTP/SMS?verify_id=string&OTP=string',
{
  method: 'POST',

  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }


    /// Make a dummy request
    public async Task MakePostRequest()
    {
      string url = "/Workflow/{workflow_id}/Sign/{session_key}/OTP/SMS";


      await PostAsync(null, url);

    }

    /// Performs a POST Request
    public async Task PostAsync(undefined content, string url)
    {
        //Serialize Object
        StringContent jsonContent = SerializeObject(content);

        //Execute POST request
        HttpResponseMessage response = await Client.PostAsync(url, jsonContent);
    }



    /// Serialize an object to Json
    private StringContent SerializeObject(undefined content)
    {
        //Serialize Object
        string jsonObject = JsonConvert.SerializeObject(content);

        //Create Json UTF8 String Content
        return new StringContent(jsonObject, Encoding.UTF8, "application/json");
    }

    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

POST /Workflow/{workflow_id}/Sign/{session_key}/OTP/SMS

Signs a Workflow using an OTP received via SMS.

Ensure to use the same session_key that was used to call the SignOTPSMSSend method.

Parameters

Name In Type Required Description
workflow_id path integer(int32) true ID of the Workflow to Sign.
session_key path string(uuid) true Current session_key of the Workflow to Sign.
verify_id query string true Security Code associated with the OTP, recevied after a successfull call to the SignOTPSMSSend method.
OTP query string true OTP received by the User via SMS.

Example responses

200 Response

{"user_id":0,"username":"string","is_internal":true,"document_id":0,"document_name":"string","sign_id":0,"workflow_id":0,"status_id":0,"retry_url":"string","donwload_guid":"aae2db4a-3557-4b6a-ad3d-15691ece8fd5"}
{
  "user_id": 0,
  "username": "string",
  "is_internal": true,
  "document_id": 0,
  "document_name": "string",
  "sign_id": 0,
  "workflow_id": 0,
  "status_id": 0,
  "retry_url": "string",
  "donwload_guid": "aae2db4a-3557-4b6a-ad3d-15691ece8fd5"
}

Responses

Status Meaning Description Schema
200 OK Information about the signed Workflow. WorkflowOKDTO
400 Bad Request Something went wrong. Refer to the error message for more details. ProblemDetails

SignOTPMailSend

Code samples

# You can also use wget
curl -X GET /Workflow/{workflow_id}/Sign/{session_key}/OTP/Mail/Send \
  -H 'Accept: text/plain' \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'Accept': 'text/plain',
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.get('/Workflow/{workflow_id}/Sign/{session_key}/OTP/Mail/Send', headers = headers)

print(r.json())


const headers = {
  'Accept':'text/plain',
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Workflow/{workflow_id}/Sign/{session_key}/OTP/Mail/Send',
{
  method: 'GET',

  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }

    /// Make a dummy request
    public async Task MakeGetRequest()
    {
      string url = "/Workflow/{workflow_id}/Sign/{session_key}/OTP/Mail/Send";
      var result = await GetAsync(url);
    }

    /// Performs a GET Request
    public async Task GetAsync(string url)
    {
        //Start the request
        HttpResponseMessage response = await Client.GetAsync(url);

        //Validate result
        response.EnsureSuccessStatusCode();

    }




    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

GET /Workflow/{workflow_id}/Sign/{session_key}/OTP/Mail/Send

Sends a Mail to the current User with an OTP to Sign a Workflow.

Prior to using this method, ensure to call the SignOpenSession method to obtain a session_key for your Workflow.

Parameters

Name In Type Required Description
workflow_id path integer(int32) true ID of the Workflow to Sign.
session_key path string true Current session_key of the Workflow to Sign.

Example responses

200 Response

"string"

Responses

Status Meaning Description Schema
200 OK The verify_id associated with the OTP. string

SignOTPMail

Code samples

# You can also use wget
curl -X POST /Workflow/{workflow_id}/Sign/{session_key}/OTP/Mail?verify_id=string&OTP=string \
  -H 'Accept: text/plain' \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'Accept': 'text/plain',
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.post('/Workflow/{workflow_id}/Sign/{session_key}/OTP/Mail', params={
  'verify_id': 'string',  'OTP': 'string'
}, headers = headers)

print(r.json())


const headers = {
  'Accept':'text/plain',
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Workflow/{workflow_id}/Sign/{session_key}/OTP/Mail?verify_id=string&OTP=string',
{
  method: 'POST',

  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }


    /// Make a dummy request
    public async Task MakePostRequest()
    {
      string url = "/Workflow/{workflow_id}/Sign/{session_key}/OTP/Mail";


      await PostAsync(null, url);

    }

    /// Performs a POST Request
    public async Task PostAsync(undefined content, string url)
    {
        //Serialize Object
        StringContent jsonContent = SerializeObject(content);

        //Execute POST request
        HttpResponseMessage response = await Client.PostAsync(url, jsonContent);
    }



    /// Serialize an object to Json
    private StringContent SerializeObject(undefined content)
    {
        //Serialize Object
        string jsonObject = JsonConvert.SerializeObject(content);

        //Create Json UTF8 String Content
        return new StringContent(jsonObject, Encoding.UTF8, "application/json");
    }

    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

POST /Workflow/{workflow_id}/Sign/{session_key}/OTP/Mail

Signs a Workflow using an OTP received via Mail.

Ensure to use the same session_key that was used to call the SignOTPMailSend method.

Parameters

Name In Type Required Description
workflow_id path integer(int32) true ID of the Workflow to Sign.
session_key path string(uuid) true Current session_key of the Workflow to Sign.
verify_id query string true Security Code associated with the OTP, recevied after a successfull call to the SignOTPMailSend method.
OTP query string true OTP received by the User via Mail.

Example responses

200 Response

{"user_id":0,"username":"string","is_internal":true,"document_id":0,"document_name":"string","sign_id":0,"workflow_id":0,"status_id":0,"retry_url":"string","donwload_guid":"aae2db4a-3557-4b6a-ad3d-15691ece8fd5"}
{
  "user_id": 0,
  "username": "string",
  "is_internal": true,
  "document_id": 0,
  "document_name": "string",
  "sign_id": 0,
  "workflow_id": 0,
  "status_id": 0,
  "retry_url": "string",
  "donwload_guid": "aae2db4a-3557-4b6a-ad3d-15691ece8fd5"
}

Responses

Status Meaning Description Schema
200 OK Information about the signed Workflow. WorkflowOKDTO
400 Bad Request Something went wrong. Refer to the error message for more details. ProblemDetails

Workflow

GetWorkflows

Code samples

# You can also use wget
curl -X GET /Workflow \
  -H 'Accept: text/plain' \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'Accept': 'text/plain',
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.get('/Workflow', headers = headers)

print(r.json())


const headers = {
  'Accept':'text/plain',
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Workflow',
{
  method: 'GET',

  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }

    /// Make a dummy request
    public async Task MakeGetRequest()
    {
      string url = "/Workflow";
      var result = await GetAsync(url);
    }

    /// Performs a GET Request
    public async Task GetAsync(string url)
    {
        //Start the request
        HttpResponseMessage response = await Client.GetAsync(url);

        //Validate result
        response.EnsureSuccessStatusCode();

    }




    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

GET /Workflow

Retrieves a List of Workflows that the current user can see.

Example responses

200 Response

[{"workflow_id":0,"status_id":0}]
[
  {
    "workflow_id": 0,
    "status_id": 0
  }
]

Responses

Status Meaning Description Schema
200 OK A list of Workflows. Inline
403 Forbidden The user does not have permission to access the requested Workflow. ProblemDetails

Response Schema

Status Code 200

Name Type Nullable
WorkflowGatewayDTO [WorkflowGatewayDTO] false
» workflow_id integer(int32) false
» status_id integer(int32) false

CreateWorkflowDraft

Code samples

# You can also use wget
curl -X POST /Workflow \
  -H 'Content-Type: multipart/form-data' \
  -H 'Accept: text/plain' \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'Content-Type': 'multipart/form-data',
  'Accept': 'text/plain',
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.post('/Workflow', headers = headers)

print(r.json())

const inputBody = '{
  "ContentType": "string",
  "ContentDisposition": "string",
  "Headers": {
    "property1": [
      "string"
    ],
    "property2": [
      "string"
    ]
  },
  "Length": 0,
  "Name": "string",
  "FileName": "string"
}';
const headers = {
  'Content-Type':'multipart/form-data',
  'Accept':'text/plain',
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Workflow',
{
  method: 'POST',
  body: inputBody,
  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }


    /// Make a dummy request
    public async Task MakePostRequest()
    {
      string url = "/Workflow";


      await PostAsync(null, url);

    }

    /// Performs a POST Request
    public async Task PostAsync(undefined content, string url)
    {
        //Serialize Object
        StringContent jsonContent = SerializeObject(content);

        //Execute POST request
        HttpResponseMessage response = await Client.PostAsync(url, jsonContent);
    }



    /// Serialize an object to Json
    private StringContent SerializeObject(undefined content)
    {
        //Serialize Object
        string jsonObject = JsonConvert.SerializeObject(content);

        //Create Json UTF8 String Content
        return new StringContent(jsonObject, Encoding.UTF8, "application/json");
    }

    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

POST /Workflow

Creates a Workflow with the "Draft" Status.

Ensure to select a Controparte as you will not have the opportunity to change this selection later in the process.

Body parameter

ContentType: string
ContentDisposition: string
Headers:
  property1:
    - string
  property2:
    - string
Length: 0
Name: string
FileName: string

Parameters

Name In Type Required Description
controparte_id query integer(int32) true ID of the to be associated with the Workflow. If set to 0, the Workflow will not be associated with any Controparte.
body body object true IFormFile with the Principale Document
» ContentType body string false none
» ContentDisposition body string false none
» Headers body object false none
»» additionalProperties body [string] false none
» Length body integer(int64) false none
» Name body string false none
» FileName body string false none

Example responses

201 Response

0
0

Responses

Status Meaning Description Schema
201 Created ID of the newly created Workflow. integer
403 Forbidden The user does not have permission to create a Workflow. ProblemDetails

UpdateWorkflowDraft

Code samples

# You can also use wget
curl -X PUT /Workflow \
  -H 'Content-Type: application/json' \
  -H 'Accept: text/plain' \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'Content-Type': 'application/json',
  'Accept': 'text/plain',
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.put('/Workflow', headers = headers)

print(r.json())

const inputBody = '{
  "workflow_id": 0,
  "controparte_id": 0,
  "status_id": 0,
  "approvers": [
    0
  ],
  "sequential_approval": true,
  "signers": [
    0
  ],
  "sequential_sign": true,
  "contributors": [
    {
      "contributor_uuid": "bf2ca53c-ce78-45ac-bea1-6846034f141a",
      "users": [
        0
      ],
      "doc_description": "string",
      "required": true
    }
  ],
  "sign_option_id": 0,
  "temp_link_delta_days_expire": 0,
  "workflow_documents": [
    {
      "document_id": 0,
      "filename": "string",
      "signBoxes": [
        {
          "field_id": "e68e30b1-d177-4632-b748-463bcd0eedc6",
          "user": 0,
          "page": 0,
          "x": 0,
          "y": 0,
          "width": 0,
          "height": 0,
          "rotation_degree": 0,
          "page_height": 0
        }
      ],
      "textAreas": [
        {
          "field_id": "e68e30b1-d177-4632-b748-463bcd0eedc6",
          "areaType": 0,
          "text": "string",
          "userId": 0,
          "question": "string",
          "fontFamily": 0,
          "fontSize": 0,
          "color": "string",
          "isBold": true,
          "isItalic": true,
          "required": true,
          "page": 0,
          "x": 0,
          "y": 0,
          "width": 0,
          "height": 0
        }
      ],
      "checkBoxes": [
        {
          "field_id": "e68e30b1-d177-4632-b748-463bcd0eedc6",
          "user": 0,
          "page": 0,
          "x": 0,
          "y": 0,
          "width": 0,
          "height": 0,
          "rotation_degree": 0,
          "is_checked": true,
          "required": true
        }
      ],
      "optionBoxes": [
        {
          "field_id": "e68e30b1-d177-4632-b748-463bcd0eedc6",
          "user": 0,
          "page": 0,
          "x": 0,
          "y": 0,
          "width": 0,
          "height": 0,
          "rotation_degree": 0,
          "is_checked": true,
          "required": true,
          "group_id": "306db4e0-7449-4501-b76f-075576fe2d8f"
        }
      ],
      "document_type": 0
    }
  ]
}';
const headers = {
  'Content-Type':'application/json',
  'Accept':'text/plain',
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Workflow',
{
  method: 'PUT',
  body: inputBody,
  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }



    /// Make a dummy request
    public async Task MakePutRequest()
    {
      int id = 1;
      string url = "/Workflow";


      string json = @"{
  ""workflow_id"": 0,
  ""controparte_id"": 0,
  ""status_id"": 0,
  ""approvers"": [
    0
  ],
  ""sequential_approval"": true,
  ""signers"": [
    0
  ],
  ""sequential_sign"": true,
  ""contributors"": [
    {
      ""contributor_uuid"": ""bf2ca53c-ce78-45ac-bea1-6846034f141a"",
      ""users"": [
        0
      ],
      ""doc_description"": ""string"",
      ""required"": true
    }
  ],
  ""sign_option_id"": 0,
  ""temp_link_delta_days_expire"": 0,
  ""workflow_documents"": [
    {
      ""document_id"": 0,
      ""filename"": ""string"",
      ""signBoxes"": [
        {
          ""field_id"": ""e68e30b1-d177-4632-b748-463bcd0eedc6"",
          ""user"": 0,
          ""page"": 0,
          ""x"": 0,
          ""y"": 0,
          ""width"": 0,
          ""height"": 0,
          ""rotation_degree"": 0,
          ""page_height"": 0
        }
      ],
      ""textAreas"": [
        {
          ""field_id"": ""e68e30b1-d177-4632-b748-463bcd0eedc6"",
          ""areaType"": 0,
          ""text"": ""string"",
          ""userId"": 0,
          ""question"": ""string"",
          ""fontFamily"": 0,
          ""fontSize"": 0,
          ""color"": ""string"",
          ""isBold"": true,
          ""isItalic"": true,
          ""required"": true,
          ""page"": 0,
          ""x"": 0,
          ""y"": 0,
          ""width"": 0,
          ""height"": 0
        }
      ],
      ""checkBoxes"": [
        {
          ""field_id"": ""e68e30b1-d177-4632-b748-463bcd0eedc6"",
          ""user"": 0,
          ""page"": 0,
          ""x"": 0,
          ""y"": 0,
          ""width"": 0,
          ""height"": 0,
          ""rotation_degree"": 0,
          ""is_checked"": true,
          ""required"": true
        }
      ],
      ""optionBoxes"": [
        {
          ""field_id"": ""e68e30b1-d177-4632-b748-463bcd0eedc6"",
          ""user"": 0,
          ""page"": 0,
          ""x"": 0,
          ""y"": 0,
          ""width"": 0,
          ""height"": 0,
          ""rotation_degree"": 0,
          ""is_checked"": true,
          ""required"": true,
          ""group_id"": ""306db4e0-7449-4501-b76f-075576fe2d8f""
        }
      ],
      ""document_type"": 0
    }
  ]
}";
      Workflow content = JsonConvert.DeserializeObject(json);
      var result = await PutAsync(id, content, url);


    }

    /// Performs a PUT Request
    public async Task PutAsync(int id, Workflow content, string url)
    {
        //Serialize Object
        StringContent jsonContent = SerializeObject(content);

        //Execute PUT request
        HttpResponseMessage response = await Client.PutAsync(url + $"/{id}", jsonContent);

        //Return response
        return await DeserializeObject(response);
    }


    /// Serialize an object to Json
    private StringContent SerializeObject(Workflow content)
    {
        //Serialize Object
        string jsonObject = JsonConvert.SerializeObject(content);

        //Create Json UTF8 String Content
        return new StringContent(jsonObject, Encoding.UTF8, "application/json");
    }

    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

PUT /Workflow

Updates the information of a Workflow in a Draft Status.

This method performs several formal checks with the Approvers/Signers array. It verifies if each Approver/Signer is an approver/signer in the Workspace or is an External User of the associated Controparte. It also checks if each signer has at least one signbox in at least one document of the Workflow and verifies if each user of a signbox is in the Signers array.

Body parameter

{
  "workflow_id": 0,
  "controparte_id": 0,
  "status_id": 0,
  "approvers": [
    0
  ],
  "sequential_approval": true,
  "signers": [
    0
  ],
  "sequential_sign": true,
  "contributors": [
    {
      "contributor_uuid": "bf2ca53c-ce78-45ac-bea1-6846034f141a",
      "users": [
        0
      ],
      "doc_description": "string",
      "required": true
    }
  ],
  "sign_option_id": 0,
  "temp_link_delta_days_expire": 0,
  "workflow_documents": [
    {
      "document_id": 0,
      "filename": "string",
      "signBoxes": [
        {
          "field_id": "e68e30b1-d177-4632-b748-463bcd0eedc6",
          "user": 0,
          "page": 0,
          "x": 0,
          "y": 0,
          "width": 0,
          "height": 0,
          "rotation_degree": 0,
          "page_height": 0
        }
      ],
      "textAreas": [
        {
          "field_id": "e68e30b1-d177-4632-b748-463bcd0eedc6",
          "areaType": 0,
          "text": "string",
          "userId": 0,
          "question": "string",
          "fontFamily": 0,
          "fontSize": 0,
          "color": "string",
          "isBold": true,
          "isItalic": true,
          "required": true,
          "page": 0,
          "x": 0,
          "y": 0,
          "width": 0,
          "height": 0
        }
      ],
      "checkBoxes": [
        {
          "field_id": "e68e30b1-d177-4632-b748-463bcd0eedc6",
          "user": 0,
          "page": 0,
          "x": 0,
          "y": 0,
          "width": 0,
          "height": 0,
          "rotation_degree": 0,
          "is_checked": true,
          "required": true
        }
      ],
      "optionBoxes": [
        {
          "field_id": "e68e30b1-d177-4632-b748-463bcd0eedc6",
          "user": 0,
          "page": 0,
          "x": 0,
          "y": 0,
          "width": 0,
          "height": 0,
          "rotation_degree": 0,
          "is_checked": true,
          "required": true,
          "group_id": "306db4e0-7449-4501-b76f-075576fe2d8f"
        }
      ],
      "document_type": 0
    }
  ]
}

Parameters

Name In Type Required Description
body body Workflow false Workflow Object with the new information of the Workflow.

Example responses

400 Response

{"type":"string","title":"string","status":0,"detail":"string","instance":"string","property1":null,"property2":null}
{
  "type": "string",
  "title": "string",
  "status": 0,
  "detail": "string",
  "instance": "string",
  "property1": null,
  "property2": null
}

Responses

Status Meaning Description Schema
204 No Content The information was updated successfully. None
400 Bad Request Something went wrong. Refer to the error message for more details. ProblemDetails
403 Forbidden The user does not have permission to update the requested Workflow. ProblemDetails

GetWorkflow

Code samples

# You can also use wget
curl -X GET /Workflow/{workflow_id} \
  -H 'Accept: text/plain' \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'Accept': 'text/plain',
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.get('/Workflow/{workflow_id}', headers = headers)

print(r.json())


const headers = {
  'Accept':'text/plain',
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Workflow/{workflow_id}',
{
  method: 'GET',

  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }

    /// Make a dummy request
    public async Task MakeGetRequest()
    {
      string url = "/Workflow/{workflow_id}";
      var result = await GetAsync(url);
    }

    /// Performs a GET Request
    public async Task GetAsync(string url)
    {
        //Start the request
        HttpResponseMessage response = await Client.GetAsync(url);

        //Validate result
        response.EnsureSuccessStatusCode();

    }




    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

GET /Workflow/{workflow_id}

Retrieves a Workflow within the Organization.

Parameters

Name In Type Required Description
workflow_id path integer(int32) true ID of the Workflow to retrieve.

Example responses

200 Response

{"workflow_id":0,"controparte_id":0,"status_id":0,"approvers":[0],"sequential_approval":true,"signers":[0],"sequential_sign":true,"sign_option_id":0,"temp_link_delta_days_expire":0,"workflow_documents":[{"document_id":0,"filename":"string","signBoxes":[{"user":0,"page":0,"page_height":0,"x":0,"y":0,"width":0,"height":0,"rotation_degree":0}],"document_type":0}]}
{
  "workflow_id": 0,
  "controparte_id": 0,
  "status_id": 0,
  "approvers": [
    0
  ],
  "sequential_approval": true,
  "signers": [
    0
  ],
  "sequential_sign": true,
  "contributors": [
    {
      "contributor_uuid": "bf2ca53c-ce78-45ac-bea1-6846034f141a",
      "users": [
        0
      ],
      "doc_description": "string",
      "required": true
    }
  ],
  "sign_option_id": 0,
  "temp_link_delta_days_expire": 0,
  "workflow_documents": [
    {
      "document_id": 0,
      "filename": "string",
      "signBoxes": [
        {
          "field_id": "e68e30b1-d177-4632-b748-463bcd0eedc6",
          "user": 0,
          "page": 0,
          "x": 0,
          "y": 0,
          "width": 0,
          "height": 0,
          "rotation_degree": 0,
          "page_height": 0
        }
      ],
      "textAreas": [
        {
          "field_id": "e68e30b1-d177-4632-b748-463bcd0eedc6",
          "areaType": 0,
          "text": "string",
          "userId": 0,
          "question": "string",
          "fontFamily": 0,
          "fontSize": 0,
          "color": "string",
          "isBold": true,
          "isItalic": true,
          "required": true,
          "page": 0,
          "x": 0,
          "y": 0,
          "width": 0,
          "height": 0
        }
      ],
      "checkBoxes": [
        {
          "field_id": "e68e30b1-d177-4632-b748-463bcd0eedc6",
          "user": 0,
          "page": 0,
          "x": 0,
          "y": 0,
          "width": 0,
          "height": 0,
          "rotation_degree": 0,
          "is_checked": true,
          "required": true
        }
      ],
      "optionBoxes": [
        {
          "field_id": "e68e30b1-d177-4632-b748-463bcd0eedc6",
          "user": 0,
          "page": 0,
          "x": 0,
          "y": 0,
          "width": 0,
          "height": 0,
          "rotation_degree": 0,
          "is_checked": true,
          "required": true,
          "group_id": "306db4e0-7449-4501-b76f-075576fe2d8f"
        }
      ],
      "document_type": 0
    }
  ]
}

Responses

Status Meaning Description Schema
200 OK The requested Workflow Object. Workflow
403 Forbidden The user does not have permission to access the requested Workflow. ProblemDetails
404 Not Found A Workflow with the specified ID was not found. ProblemDetails

DeleteWorkflow

Code samples

# You can also use wget
curl -X DELETE /Workflow/{workflow_id} \
  -H 'Accept: text/plain' \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'Accept': 'text/plain',
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.delete('/Workflow/{workflow_id}', headers = headers)

print(r.json())


const headers = {
  'Accept':'text/plain',
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Workflow/{workflow_id}',
{
  method: 'DELETE',

  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }




    /// Make a dummy request
    public async Task MakeDeleteRequest()
    {
      int id = 1;
      string url = "/Workflow/{workflow_id}";

      await DeleteAsync(id, url);
    }

    /// Performs a DELETE Request
    public async Task DeleteAsync(int id, string url)
    {
        //Execute DELETE request
        HttpResponseMessage response = await Client.DeleteAsync(url + $"/{id}");

        //Return response
        await DeserializeObject(response);
    }

    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

DELETE /Workflow/{workflow_id}

Deletes a Workflow that is in a Draft status.

Parameters

Name In Type Required Description
workflow_id path integer(int32) true ID of the Workflow to be deleted.

Example responses

403 Response

{"type":"string","title":"string","status":0,"detail":"string","instance":"string","property1":null,"property2":null}
{
  "type": "string",
  "title": "string",
  "status": 0,
  "detail": "string",
  "instance": "string",
  "property1": null,
  "property2": null
}

Responses

Status Meaning Description Schema
204 No Content The workflow was deleted successfully. None
403 Forbidden The user does not have permission to delete the Workflow. ProblemDetails

DownloadWorkflow

Code samples

# You can also use wget
curl -X GET /Workflow/{workflow_id}/Download \
  -H 'Accept: application/pdf' \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'Accept': 'application/pdf',
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.get('/Workflow/{workflow_id}/Download', headers = headers)

print(r.json())


const headers = {
  'Accept':'application/pdf',
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Workflow/{workflow_id}/Download',
{
  method: 'GET',

  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }

    /// Make a dummy request
    public async Task MakeGetRequest()
    {
      string url = "/Workflow/{workflow_id}/Download";
      var result = await GetAsync(url);
    }

    /// Performs a GET Request
    public async Task GetAsync(string url)
    {
        //Start the request
        HttpResponseMessage response = await Client.GetAsync(url);

        //Validate result
        response.EnsureSuccessStatusCode();

    }




    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

GET /Workflow/{workflow_id}/Download

Downloads a file containing all Documents of a specified Workflow.

The 200 response returns a .pdf file if a document_id is specified or there is only one file within the Workflow.

Otherwise, it returns a .zip folder containing all the documents.

Parameters

Name In Type Required Description
workflow_id path integer(int32) true ID of the Workflow where the file are located.
document_id query integer(int32) false If specified, only the requested Document will be downloaded.

Example responses

403 Response

Responses

Status Meaning Description Schema
200 OK A file containing all requested Documents. array(byte)
403 Forbidden The user does not have permission to access the requested Workflow. ProblemDetails
404 Not Found A Workflow or a Document with the specified ID was not found. ProblemDetails

DownloadWorkflowCertificate

Code samples

# You can also use wget
curl -X GET /Workflow/{workflow_id}/Download/Certificate \
  -H 'Accept: application/pdf' \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'Accept': 'application/pdf',
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.get('/Workflow/{workflow_id}/Download/Certificate', headers = headers)

print(r.json())


const headers = {
  'Accept':'application/pdf',
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Workflow/{workflow_id}/Download/Certificate',
{
  method: 'GET',

  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }

    /// Make a dummy request
    public async Task MakeGetRequest()
    {
      string url = "/Workflow/{workflow_id}/Download/Certificate";
      var result = await GetAsync(url);
    }

    /// Performs a GET Request
    public async Task GetAsync(string url)
    {
        //Start the request
        HttpResponseMessage response = await Client.GetAsync(url);

        //Validate result
        response.EnsureSuccessStatusCode();

    }




    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

GET /Workflow/{workflow_id}/Download/Certificate

Downloads the Certificate linked to a completed Workflow.

A workflow is considered completed if is in Status 5 Approvato or 8 Firmato.

Parameters

Name In Type Required Description
workflow_id path integer(int32) true ID of the completed Workflow.

Example responses

400 Response

Responses

Status Meaning Description Schema
200 OK The Certificate as a .pdf file. array(byte)
400 Bad Request Something went wrong. Refer to the error message for more details. ProblemDetails
403 Forbidden The user does not have permission to access the requested Workflow. ProblemDetails
404 Not Found A Workflow with the specified ID was not found. ProblemDetails

AddWorkflowAttachment

Code samples

# You can also use wget
curl -X POST /Workflow/{workflow_id}/Attachment \
  -H 'Content-Type: multipart/form-data' \
  -H 'Accept: text/plain' \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'Content-Type': 'multipart/form-data',
  'Accept': 'text/plain',
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.post('/Workflow/{workflow_id}/Attachment', headers = headers)

print(r.json())

const inputBody = '{
  "ContentType": "string",
  "ContentDisposition": "string",
  "Headers": {
    "property1": [
      "string"
    ],
    "property2": [
      "string"
    ]
  },
  "Length": 0,
  "Name": "string",
  "FileName": "string"
}';
const headers = {
  'Content-Type':'multipart/form-data',
  'Accept':'text/plain',
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Workflow/{workflow_id}/Attachment',
{
  method: 'POST',
  body: inputBody,
  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }


    /// Make a dummy request
    public async Task MakePostRequest()
    {
      string url = "/Workflow/{workflow_id}/Attachment";


      await PostAsync(null, url);

    }

    /// Performs a POST Request
    public async Task PostAsync(undefined content, string url)
    {
        //Serialize Object
        StringContent jsonContent = SerializeObject(content);

        //Execute POST request
        HttpResponseMessage response = await Client.PostAsync(url, jsonContent);
    }



    /// Serialize an object to Json
    private StringContent SerializeObject(undefined content)
    {
        //Serialize Object
        string jsonObject = JsonConvert.SerializeObject(content);

        //Create Json UTF8 String Content
        return new StringContent(jsonObject, Encoding.UTF8, "application/json");
    }

    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

POST /Workflow/{workflow_id}/Attachment

Adds an "Attachment" file to the selected Workflow.

Body parameter

ContentType: string
ContentDisposition: string
Headers:
  property1:
    - string
  property2:
    - string
Length: 0
Name: string
FileName: string

Parameters

Name In Type Required Description
workflow_id path integer(int32) true ID of the Workflow to which the Attachment will be added.
body body object false IFormFile with the Attachment Document
» ContentType body string false none
» ContentDisposition body string false none
» Headers body object false none
»» additionalProperties body [string] false none
» Length body integer(int64) false none
» Name body string false none
» FileName body string false none

Example responses

200 Response

0
0

Responses

Status Meaning Description Schema
201 Created ID of the newly added Document. None
403 Forbidden The user does not have permission to create a Workflow. None

StartWorkflowDraft

Code samples

# You can also use wget
curl -X POST /Workflow/Start/{workflow_id} \
  -H 'Accept: text/plain' \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'Accept': 'text/plain',
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.post('/Workflow/Start/{workflow_id}', headers = headers)

print(r.json())


const headers = {
  'Accept':'text/plain',
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Workflow/Start/{workflow_id}',
{
  method: 'POST',

  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }


    /// Make a dummy request
    public async Task MakePostRequest()
    {
      string url = "/Workflow/Start/{workflow_id}";


      await PostAsync(null, url);

    }

    /// Performs a POST Request
    public async Task PostAsync(undefined content, string url)
    {
        //Serialize Object
        StringContent jsonContent = SerializeObject(content);

        //Execute POST request
        HttpResponseMessage response = await Client.PostAsync(url, jsonContent);
    }



    /// Serialize an object to Json
    private StringContent SerializeObject(undefined content)
    {
        //Serialize Object
        string jsonObject = JsonConvert.SerializeObject(content);

        //Create Json UTF8 String Content
        return new StringContent(jsonObject, Encoding.UTF8, "application/json");
    }

    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

POST /Workflow/Start/{workflow_id}

Starts a Workflow that is currently in the "Bozza OK" status and allows for the addition of a reminder.

The Bozza Ok status corresponds to status_id = 2.

To add a reminder, specify the number of days between each reminder (days_between_reminders) and the total number of reminders to send (total_reminders_to_send). If the value of either of these parameters is less than or equal to 0, the reminder will not be set.

Parameters

Name In Type Required Description
workflow_id path integer(int32) true ID of the Workflow to be started.
days_between_reminders query integer(int32) false Number of days that should pass between each reminder. If this value is less than or equal to 0, the reminder is not set.
total_reminders_to_send query integer(int32) false Total number of reminders that should be sent. If this value is less than or equal to 0, the reminder is not set.

Example responses

400 Response

{"type":"string","title":"string","status":0,"detail":"string","instance":"string","property1":null,"property2":null}
{
  "type": "string",
  "title": "string",
  "status": 0,
  "detail": "string",
  "instance": "string",
  "property1": null,
  "property2": null
}

Responses

Status Meaning Description Schema
200 OK The new Status ID of the Workflow. integer(int32)
400 Bad Request Something went wrong. Refer to the error message for more details. ProblemDetails
403 Forbidden The user does not have permission to access the start the requested Workflow. ProblemDetails

ArchiveWorkflow

Code samples

# You can also use wget
curl -X POST /Workflow/Archive/{workflow_id} \
  -H 'Accept: text/plain' \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'Accept': 'text/plain',
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.post('/Workflow/Archive/{workflow_id}', headers = headers)

print(r.json())


const headers = {
  'Accept':'text/plain',
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Workflow/Archive/{workflow_id}',
{
  method: 'POST',

  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }


    /// Make a dummy request
    public async Task MakePostRequest()
    {
      string url = "/Workflow/Archive/{workflow_id}";


      await PostAsync(null, url);

    }

    /// Performs a POST Request
    public async Task PostAsync(undefined content, string url)
    {
        //Serialize Object
        StringContent jsonContent = SerializeObject(content);

        //Execute POST request
        HttpResponseMessage response = await Client.PostAsync(url, jsonContent);
    }



    /// Serialize an object to Json
    private StringContent SerializeObject(undefined content)
    {
        //Serialize Object
        string jsonObject = JsonConvert.SerializeObject(content);

        //Create Json UTF8 String Content
        return new StringContent(jsonObject, Encoding.UTF8, "application/json");
    }

    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

POST /Workflow/Archive/{workflow_id}

Archives a completed Workflow.

A workflow is considered completed if is in Status 5 Approvato or 8 Firmato.

Parameters

Name In Type Required Description
workflow_id path integer(int32) true ID of the Workflow to Archive.

Example responses

201 Response

{"archive_id":0,"folder_id":0,"document_id":0}
{
  "archive_id": 0,
  "folder_id": 0,
  "document_id": 0
}

Responses

Status Meaning Description Schema
201 Created Information about the newly created Archive. ArchiveSmallDTO
400 Bad Request Something went wrong. Refer to the error message for more details. ProblemDetails
403 Forbidden The user does not have permission to access the archive the requested Workflow. ProblemDetails

AddWorkflowContributorFile

Code samples

# You can also use wget
curl -X POST /Workflow/{workflow_id}/Contributor \
  -H 'Content-Type: multipart/form-data' \
  -H 'Accept: text/plain' \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'Content-Type': 'multipart/form-data',
  'Accept': 'text/plain',
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.post('/Workflow/{workflow_id}/Contributor', headers = headers)

print(r.json())

const inputBody = '{
  "form": [
    {
      "key": "string",
      "value": [
        "string"
      ]
    }
  ]
}';
const headers = {
  'Content-Type':'multipart/form-data',
  'Accept':'text/plain',
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Workflow/{workflow_id}/Contributor',
{
  method: 'POST',
  body: inputBody,
  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }


    /// Make a dummy request
    public async Task MakePostRequest()
    {
      string url = "/Workflow/{workflow_id}/Contributor";


      await PostAsync(null, url);

    }

    /// Performs a POST Request
    public async Task PostAsync(undefined content, string url)
    {
        //Serialize Object
        StringContent jsonContent = SerializeObject(content);

        //Execute POST request
        HttpResponseMessage response = await Client.PostAsync(url, jsonContent);
    }



    /// Serialize an object to Json
    private StringContent SerializeObject(undefined content)
    {
        //Serialize Object
        string jsonObject = JsonConvert.SerializeObject(content);

        //Create Json UTF8 String Content
        return new StringContent(jsonObject, Encoding.UTF8, "application/json");
    }

    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

POST /Workflow/{workflow_id}/Contributor

Adds a Contributor file to the selected Workflow.

Body parameter

form:
  - key: string
    value:
      - string

Parameters

Name In Type Required Description
workflow_id path integer(int32) true ID of the Workflow to which the File will be added.
body body object false none
» form form See below true none

Form Parameters

Name Type Required Description
contributor_uuid string(uuid) true uuid identifier of the Contributor
filename string false new name of the uploaded file
confidential bool true Determine whether the file should be marked as confidential

Example responses

200 Response

[{"contributor_uuid":"bf2ca53c-ce78-45ac-bea1-6846034f141a","users":[0],"doc_description":"string","required":true}]
[
  {
    "contributor_uuid": "bf2ca53c-ce78-45ac-bea1-6846034f141a",
    "users": [
      0
    ],
    "doc_description": "string",
    "required": true
  }
]

Responses

Status Meaning Description Schema
201 Created New contributors array None
404 Not Found The Workflow has an invalid status None

Response Schema

Status Code 200

Name Type Nullable
anonymous [Contributor] false
» contributor_uuid string(uuid) false
» users [integer] false
» doc_description string false
» required boolean false

DeleteWorkflowAttachment

Code samples

# You can also use wget
curl -X DELETE /Workflow/{workflow_id}/Attachment/{attachment_id} \
  -H 'X-api-key: API_KEY' \
  -H 'Organization-ID: API_KEY' \
  -H 'Workspace-ID: API_KEY'

import requests
headers = {
  'X-api-key': 'API_KEY',
  'Organization-ID': 'API_KEY',
  'Workspace-ID': 'API_KEY'
}

r = requests.delete('/Workflow/{workflow_id}/Attachment/{attachment_id}', headers = headers)

print(r.json())


const headers = {
  'X-api-key':'API_KEY',
  'Organization-ID':'API_KEY',
  'Workspace-ID':'API_KEY'
};

fetch('/Workflow/{workflow_id}/Attachment/{attachment_id}',
{
  method: 'DELETE',

  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});

using System;
using System.Collections.Generic;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Text;
using System.Threading.Tasks;
using Newtonsoft.Json;

/// <<summary>>
/// Example of Http Client
/// <</summary>>
public class HttpExample
{
    private HttpClient Client { get; set; }

    /// <<summary>>
    /// Setup http client
    /// <</summary>>
    public HttpExample()
    {
      Client = new HttpClient();
    }




    /// Make a dummy request
    public async Task MakeDeleteRequest()
    {
      int id = 1;
      string url = "/Workflow/{workflow_id}/Attachment/{attachment_id}";

      await DeleteAsync(id, url);
    }

    /// Performs a DELETE Request
    public async Task DeleteAsync(int id, string url)
    {
        //Execute DELETE request
        HttpResponseMessage response = await Client.DeleteAsync(url + $"/{id}");

        //Return response
        await DeserializeObject(response);
    }

    /// Deserialize object from request response
    private async Task DeserializeObject(HttpResponseMessage response)
    {
        //Read body 
        string responseBody = await response.Content.ReadAsStringAsync();

        //Deserialize Body to object
        var result = JsonConvert.DeserializeObject(responseBody);
    }
}

DELETE /Workflow/{workflow_id}/Attachment/{attachment_id}

Removes an Attachment from a Workflow.

Parameters

Name In Type Required Description
workflow_id path integer(int32) true ID of the Workflow from which the Attachment will be removed.
attachment_id path integer(int32) true The ID of the Attachment to be removed.

Responses

Status Meaning Description Schema
204 No Content The Attachment was removed successfully. None

Schemas

ArchiveSmallDTO

{
  "archive_id": 0,
  "folder_id": 0,
  "document_id": 0
}

Properties

Name Type Nullable Required
archive_id integer(int32) false
folder_id integer(int32) false
document_id integer(int32) false

AreaType

0

Properties

Name Type Required Restrictions Description
anonymous integer(int32) false none none

Enumerated Values

Property Value
ReadOnly 0
Question 1

AuthObject

{
  "read": true,
  "write": {
    "property1": true,
    "property2": true
  }
}

Properties

Name Type Nullable Required
read boolean false
write object true
» additionalProperties boolean false

Checkbox

{
  "field_id": "e68e30b1-d177-4632-b748-463bcd0eedc6",
  "user": 0,
  "page": 0,
  "x": 0,
  "y": 0,
  "width": 0,
  "height": 0,
  "rotation_degree": 0,
  "is_checked": true,
  "required": true
}

Properties

Name Type Nullable Description
field_id string(uuid) false
user integer(int32) false
page integer(int32) false
x integer(int32) false
y integer(int32) false
width integer(int32) false
height integer(int32) false
rotation_degree integer(int32) false
is_checked boolean false
required boolean false Specify whether the box must be checked to approve or sign the workflow.

Contributor

{
  "contributor_uuid": "bf2ca53c-ce78-45ac-bea1-6846034f141a",
  "users": [
    0
  ],
  "doc_description": "string",
  "required": true
}

Properties

Name Type Nullable Description
contributor_uuid string(uuid) false
users [integer] false
doc_description string false
required boolean false

Controparte

{
  "controparte_id": 0,
  "controparte_name": "string",
  "controparte_nation": "string",
  "controparte_city": "string",
  "controparte_mail": "string",
  "controparte_address": "string",
  "controparte_last_edit": "2019-08-24T14:15:22Z",
  "controparte_piva": "string",
  "controparte_webpage": "string"
}

Properties

Name Type Nullable
controparte_id integer(int32) false
controparte_name string true
controparte_nation string true
controparte_city string true
controparte_mail string true
controparte_address string true
controparte_last_edit string(date-time) false
controparte_piva string true
controparte_webpage string true
controparte_type ControparteType false
controparte_cf string true

ControparteType

0

Properties

Name Type Nullable
anonymous integer(int32) false

Enumerated Values

Property Value
standard 0
natural person 1

ControparteUser

{
  "user_id": 0,
  "mail": "string",
  "name": "string",
  "surname": "string",
  "phone": "string",
  "cf": "string",
  "controparte_ids": [
    0
  ]
}

Properties

Name Type Nullable
user_id integer(int32) false
mail string¦null false
name string¦null false
surname string¦null false
phone string¦null false
cf string¦null false
controparte_ids [integer] false

DocType

0

Properties

Name Type Nullable
anonymous integer(int32) false

Enumerated Values

Property Value
Principale 0
Allegato 1
Integrativo 2

Document

{
  "document_id": 0,
  "filename": "string",
  "signBoxes": [
    {
      "field_id": "e68e30b1-d177-4632-b748-463bcd0eedc6",
      "user": 0,
      "page": 0,
      "x": 0,
      "y": 0,
      "width": 0,
      "height": 0,
      "rotation_degree": 0,
      "page_height": 0
    }
  ],
  "textAreas": [
    {
      "field_id": "e68e30b1-d177-4632-b748-463bcd0eedc6",
      "areaType": 0,
      "text": "string",
      "userId": 0,
      "question": "string",
      "fontFamily": 0,
      "fontSize": 0,
      "color": "string",
      "isBold": true,
      "isItalic": true,
      "required": true,
      "page": 0,
      "x": 0,
      "y": 0,
      "width": 0,
      "height": 0
    }
  ],
  "checkBoxes": [
    {
      "field_id": "e68e30b1-d177-4632-b748-463bcd0eedc6",
      "user": 0,
      "page": 0,
      "x": 0,
      "y": 0,
      "width": 0,
      "height": 0,
      "rotation_degree": 0,
      "is_checked": true,
      "required": true
    }
  ],
  "optionBoxes": [
    {
      "field_id": "e68e30b1-d177-4632-b748-463bcd0eedc6",
      "user": 0,
      "page": 0,
      "x": 0,
      "y": 0,
      "width": 0,
      "height": 0,
      "rotation_degree": 0,
      "is_checked": true,
      "required": true,
      "group_id": "306db4e0-7449-4501-b76f-075576fe2d8f"
    }
  ],  
  "document_type": 0
}

Properties

Name Type Nullable
document_id integer(int32) false
filename string true
signBoxes [SignBox] true
textAreas [TextArea] true
checkBoxes [Checkbox] true
optionBoxes [Optionbox] true
document_type DocType false

DocumentCategory

{
  "category_id": 0,
  "category_name": "string"
}

Properties

Name Type Nullable
category_id integer(int32) false
category_name string true

FontFamily

0

Properties

Name Type Restrictions Description
anonymous integer(int32) none none

Enumerated Values

Property Value Example
Default 0
Helvetica 1 The quick brown fox jumps over the lazy dog
Courier 2 The quick brown fox jumps over the lazy dog
TimesRoman 3 The quick brown fox jumps over the lazy dog

Optionbox

Commonly known as Radio Button.

The group_id property is used to identify a group of radio buttons.

Please ensure the following rules are followed within a group:

  1. A group must contain at least two elements.
  2. The user property must be the same within a group.
  3. The required field value must be the same within a group.
{
  "field_id": "e68e30b1-d177-4632-b748-463bcd0eedc6",
  "user": 0,
  "page": 0,
  "x": 0,
  "y": 0,
  "width": 0,
  "height": 0,
  "rotation_degree": 0,
  "is_checked": true,
  "required": true,
  "group_id": "306db4e0-7449-4501-b76f-075576fe2d8f"
}

Properties

Name Type Nullable Consistent across group
field_id string(uuid) false false
user integer(int32) false true
page integer(int32) false false
x integer(int32) false false
y integer(int32) false false
width integer(int32) false false
height integer(int32) false false
rotation_degree integer(int32) false false
is_checked boolean false false
required boolean false true
group_id string(uuid) false true

Organization

{
  "organization_id": 0,
  "organization_name": "string",
  "master_account_id": 0,
  "workspaces": [
    0
  ],
  "workspace_max_number": 0,
  "organization_logo": "string",
  "accesses": {
    "property1": true,
    "property2": true
  }
}

Properties

Name Type Nullable
organization_id integer(int32) false
organization_name string true
master_account_id integer(int32) false
workspaces [integer] true
workspace_max_number integer(int32) false
organization_logo string(byte) true
accesses object true
» additionalProperties boolean false

ProblemDetails

{
  "type": "string",
  "title": "string",
  "status": 0,
  "detail": "string",
  "instance": "string",
  "property1": null,
  "property2": null
}

Properties

Name Type Nullable
additionalProperties any false
type string true
title string true
status integer(int32) true
detail string true
instance string true

Role

{
  "role_id": 0,
  "role_name_primary": "string",
  "role_name_secondary": "string",
  "description": "string",
  "ws_can_create": true,
  "ws_can_invite": true,
  "doc_can_upload": true,
  "doc_can_edit": true,
  "doc_can_share": true
}

Properties

Name Type Nullable
role_id integer(int32) false
role_name_primary string true
role_name_secondary string true
description string true
ws_can_create boolean false
ws_can_invite boolean false
doc_can_upload boolean false
doc_can_edit boolean false
doc_can_share boolean false

SignBox

{
  "field_id": "e68e30b1-d177-4632-b748-463bcd0eedc6",
  "user": 0,
  "page": 0,
  "x": 0,
  "y": 0,
  "width": 0,
  "height": 0,
  "rotation_degree": 0,
  "page_height": 0
}

Properties

Name Type Nullable
user integer(int32) false
page integer(int32) false
page_height integer(int32) false
x integer(int32) false
y integer(int32) false
width integer(int32) false
height integer(int32) false
rotation_degree integer(int32) true
page_height integer(int32) false

SignOption

{
  "sign_option_id": 0,
  "sign_name": "string",
  "required_data": "string"
}

Properties

Name Type Nullable
sign_option_id integer(int32) false
sign_name string true
required_data string true

Status

{
  "status_id": 0,
  "title": "string",
  "color": "string"
}

Properties

Name Type Nullable
status_id integer(int32) false
title string true
color string false

TextArea

{
  "field_id": "e68e30b1-d177-4632-b748-463bcd0eedc6",
  "areaType": 0,
  "text": "string",
  "userId": 0,
  "question": "string",
  "fontFamily": 0,
  "fontSize": 0,
  "color": "string",
  "isBold": true,
  "isItalic": true,
  "required": true,
  "page": 0,
  "x": 0,
  "y": 0,
  "width": 0,
  "height": 0
}

Properties

Name Type Nullable Restrictions Description
field_id string(uuid) false none none
areaType AreaType false none none
text string false none none
userId integer(int32) false none none
question string false none none
fontFamily FontFamily false none none
fontSize integer(int32) false none none
color string false An HTML color name (e.g., red) or a hex triplet (e.g., #ff0000) none
isBold boolean false none none
isItalic boolean false none none
required boolean false Only for 'Question' areaType Specify whether the question must be answered to approve or sign the workflow.
page integer(int32) false none none
x integer(int32) false none none
y integer(int32) false none none
width integer(int32) false none none
height integer(int32) false none none

User

{
  "id": 0,
  "name": "string",
  "surname": "string",
  "mail": "string",
  "phone": "string",
  "cf": "string"
}

Properties

Name Type Nullable
id integer(int32) false
name string true
surname string true
mail string true
phone string true
cf string true

UserAuthorization

{
  "document": {
    "read": true,
    "write": {
      "property1": true,
      "property2": true
    }
  },
  "workflow": {
    "read": true,
    "write": {
      "property1": true,
      "property2": true
    }
  }
}

Properties

Name Type Nullable
document AuthObject false
workflow AuthObject false

Workflow

{
  "workflow_id": 0,
  "controparte_id": 0,
  "status_id": 0,
  "approvers": [
    0
  ],
  "sequential_approval": true,
  "signers": [
    0
  ],
  "sequential_sign": true,
  "contributors": [
    {
      "contributor_uuid": "bf2ca53c-ce78-45ac-bea1-6846034f141a",
      "users": [
        0
      ],
      "doc_description": "string",
      "required": true
    }
  ],
  "sign_option_id": 0,
  "temp_link_delta_days_expire": 0,
  "workflow_documents": [
    {
      "document_id": 0,
      "filename": "string",
      "signBoxes": [
        {
          "field_id": "e68e30b1-d177-4632-b748-463bcd0eedc6",
          "user": 0,
          "page": 0,
          "x": 0,
          "y": 0,
          "width": 0,
          "height": 0,
          "rotation_degree": 0,
          "page_height": 0
        }
      ],
      "textAreas": [
        {
          "field_id": "e68e30b1-d177-4632-b748-463bcd0eedc6",
          "areaType": 0,
          "text": "string",
          "userId": 0,
          "question": "string",
          "fontFamily": 0,
          "fontSize": 0,
          "color": "string",
          "isBold": true,
          "isItalic": true,
          "required": true,
          "page": 0,
          "x": 0,
          "y": 0,
          "width": 0,
          "height": 0
        }
      ],
      "checkBoxes": [
        {
          "field_id": "e68e30b1-d177-4632-b748-463bcd0eedc6",
          "user": 0,
          "page": 0,
          "x": 0,
          "y": 0,
          "width": 0,
          "height": 0,
          "rotation_degree": 0,
          "is_checked": true,
          "required": true
        }
      ],
      "optionBoxes": [
        {
          "field_id": "e68e30b1-d177-4632-b748-463bcd0eedc6",
          "user": 0,
          "page": 0,
          "x": 0,
          "y": 0,
          "width": 0,
          "height": 0,
          "rotation_degree": 0,
          "is_checked": true,
          "required": true,
          "group_id": "306db4e0-7449-4501-b76f-075576fe2d8f"
        }
      ],
      "document_type": 0
    }
  ]
}

Properties

Name Type Nullable
workflow_id integer(int32) false
controparte_id integer(int32) false
status_id integer(int32) false
approvers [integer] true
sequential_approval boolean false
signers [integer] true
sequential_sign boolean false
sign_option_id integer(int32) false
temp_link_delta_days_expire integer(int32) false
workflow_documents [Document] true

WorkflowGatewayDTO

{
  "workflow_id": 0,
  "status_id": 0
}

Properties

Name Type Nullable
workflow_id integer(int32) false
status_id integer(int32) false

WorkflowOKDTO

{
  "user_id": 0,
  "username": "string",
  "is_internal": true,
  "document_id": 0,
  "document_name": "string",
  "sign_id": 0,
  "workflow_id": 0,
  "status_id": 0,
  "retry_url": "string",
  "donwload_guid": "aae2db4a-3557-4b6a-ad3d-15691ece8fd5"
}

Properties

Name Type Nullable
user_id integer(int32) false
username string true
is_internal boolean false
document_id integer(int32) false
document_name string true
sign_id integer(int32) false
workflow_id integer(int32) false
status_id integer(int32) false
retry_url string true
donwload_guid string(uuid) false

Workspace

{
  "workspace_id": 0,
  "workspace_name": "string",
  "logo": "string"
}

Properties

Name Type Nullable
workspace_id integer(int32) false
workspace_name string true
logo string(byte) true

WorkspaceUser

{
  "id": 0,
  "name": "string",
  "surname": "string",
  "mail": "string",
  "phone": "string",
  "cf": "string",
  "userRoles": [
    0
  ],
  "userAuthorization": {
    "document": {
      "read": true,
      "write": {
        "property1": true,
        "property2": true
      }
    },
    "workflow": {
      "read": true,
      "write": {
        "property1": true,
        "property2": true
      }
    }
  },
  "deleted": true
}

Properties

Name Type Nullable
id integer(int32) false
name string true
surname string true
mail string true
phone string true
cf string true
userRoles [integer] true
userAuthorization UserAuthorization false
deleted boolean false