Platform API

<back to all web services

ConnectContactsInRoles

Connect two contacts in the specified roles

Requires Authentication
The following routes are available for this service:
All Verbs/api/connections/{ContactId}/to/{ToContactId}
import 'package:servicestack/servicestack.dart';

// @ApiResponse(Description="List of roles available for connection from the specified contact for specified contact types")
class ConnectContactsInRolesResponse implements IConvertible
{
    ResponseStatus? ResponseStatus;

    ConnectContactsInRolesResponse({this.ResponseStatus});
    ConnectContactsInRolesResponse.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        ResponseStatus = JsonConverters.fromJson(json['ResponseStatus'],'ResponseStatus',context!);
        return this;
    }

    Map<String, dynamic> toJson() => {
        'ResponseStatus': JsonConverters.toJson(ResponseStatus,'ResponseStatus',context!)
    };

    getTypeName() => "ConnectContactsInRolesResponse";
    TypeContext? context = _ctx;
}

/**
* Connect two contacts in the specified roles
*/
// @Api(Description="Connect two contacts in the specified roles")
class ConnectContactsInRoles implements IConvertible
{
    /**
    * Create a connection from this contact to the specified to contact in the specified roles.
    */
    // @ApiMember(DataType="Guid", Description="Create a connection from this contact to the specified to contact in the specified roles.", IsRequired=true, Name="ContactId")
    String? ContactId;

    /**
    * Create a connection to this contact from the specified to contact in the specified roles.
    */
    // @ApiMember(DataType="Guid", Description="Create a connection to this contact from the specified to contact in the specified roles.", IsRequired=true, Name="ToContactId")
    String? ToContactId;

    /**
    * Type of contact being connected with. For e.g. Real Person, Virtual Person etc.
    */
    // @ApiMember(DataType="Guid", Description="Type of contact being connected with. For e.g. Real Person, Virtual Person etc.", IsRequired=true, Name="ContactTypeId")
    String? ContactTypeId;

    /**
    * List of roles to connect contacts in
    */
    // @ApiMember(DataType="List<Guid>", Description="List of roles to connect contacts in", IsRequired=true, Name="Roles")
    List<String>? Roles = [];

    /**
    * Send connection emails for auto - accept roles that are being assigned? Note: emails will always be sent if the role requires user acceptance
    */
    // @ApiMember(DataType="boolean", Description="Send connection emails for auto - accept roles that are being assigned? Note: emails will always be sent if the role requires user acceptance", IsRequired=true, Name="SendConnectionEmails")
    bool? SendConnectionEmails;

    ConnectContactsInRoles({this.ContactId,this.ToContactId,this.ContactTypeId,this.Roles,this.SendConnectionEmails});
    ConnectContactsInRoles.fromJson(Map<String, dynamic> json) { fromMap(json); }

    fromMap(Map<String, dynamic> json) {
        ContactId = json['ContactId'];
        ToContactId = json['ToContactId'];
        ContactTypeId = json['ContactTypeId'];
        Roles = JsonConverters.fromJson(json['Roles'],'List<String>',context!);
        SendConnectionEmails = json['SendConnectionEmails'];
        return this;
    }

    Map<String, dynamic> toJson() => {
        'ContactId': ContactId,
        'ToContactId': ToContactId,
        'ContactTypeId': ContactTypeId,
        'Roles': JsonConverters.toJson(Roles,'List<String>',context!),
        'SendConnectionEmails': SendConnectionEmails
    };

    getTypeName() => "ConnectContactsInRoles";
    TypeContext? context = _ctx;
}

TypeContext _ctx = TypeContext(library: 'pfapi.pstpf.com.au', types: <String, TypeInfo> {
    'ConnectContactsInRolesResponse': TypeInfo(TypeOf.Class, create:() => ConnectContactsInRolesResponse()),
    'ConnectContactsInRoles': TypeInfo(TypeOf.Class, create:() => ConnectContactsInRoles()),
});

Dart ConnectContactsInRoles DTOs

To override the Content-type in your clients, use the HTTP Accept Header, append the .json suffix or ?format=json

To embed the response in a jsonp callback, append ?callback=myCallback

HTTP + JSON

The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.

POST /api/connections/{ContactId}/to/{ToContactId} HTTP/1.1 
Host: pfapi.pstpf.com.au 
Accept: application/json
Content-Type: application/json
Content-Length: length

{"ContactId":"00000000-0000-0000-0000-000000000000","ToContactId":"00000000-0000-0000-0000-000000000000","ContactTypeId":"00000000-0000-0000-0000-000000000000","Roles":["00000000-0000-0000-0000-000000000000"],"SendConnectionEmails":false}
HTTP/1.1 200 OK
Content-Type: application/json
Content-Length: length

{"ResponseStatus":{"ErrorCode":"String","Message":"String","StackTrace":"String","Errors":[{"ErrorCode":"String","FieldName":"String","Message":"String","Meta":{"String":"String"}}],"Meta":{"String":"String"}}}