NAME

WebService::Intercom - interact with the Intercom.io API

SYNOPSIS

 my $intercom = WebService::Intercom->new(app_id => '[APP ID]',
                                          api_key => '[API KEY]');

 # Create a user
 my $user = $intercom->user_create_or_update(
    email => 'test@example.com', 
    name => 'test user');
 
 # Retrieve an existing user.
 my $existing_user = $intercom->user_get(email => 'test2@example.com');

 # Add a tag to a user
 $user->tag('test tag');
 $intercom->tag_create_or_update(name => "test tag");
 $intercom->tag_items(name => "test tag", users => [{ email => 'test@example.com'}]);
 $user->untag('test tag');

 # Change the user's name
 $user->name = 'new name';
 $user->save();

 # Delete the user
 $user->delete();
 $intercom->user_delete(email => 'test@example.com');

 # Add a note
 $user->add_note(body => "This is a test note");
 $intercom->note_create(email => 'test@example.com',
                        body => "This is a test note");

 # Add an event
 $user->add_event(event_name => 'test event');
 $intercom->event_create(email => 'test@example.com',
                         event_name => 'test event',
                         metadata => {
                            "article" =>  {"url" =>  "https://example.org/",
                                           "value" => "link text"},
                         });

DESCRIPTION

Provides a nice API for Intercom.io rather than making raw requests.

IMPLEMENTATION PHILOSOPHY

This module attempts to stick as close to the API as possible.

Documentation for the v2 API:

http://doc.intercom.io/api/

For examples see the test cases, most functionality is well exercised via tests.

FUNCTIONS

user_get

Retrieves an existing user.

$intercom->user_get(Maybe[Str] :$user_id?,
                    Maybe[Str] :$email?,
                    Maybe[Str] :$id?);

Only one of user_id, email or id are required to retrieve a user.

Returns a WebService::Intercom::User.

user_create_or_update

Creates or updates a user.

# When you have an existing WebService::Intercom::User
$intercom->user_create_or_update(WebService::Intercom::User $user);

or

$intercom->user_create_or_update(Maybe[Str] :$user_id?,
                                 Maybe[Str] :$email?,
                                 Maybe[Str] :$id?,
                                 Maybe[Int] :$signed_up_at?,
                                 Str :$name?,
                                 Maybe[IPAddressType] :$last_seen_ip?,
                                 CustomAttributesType :$custom_attributes?,
                                 Maybe[Str] :$last_seen_user_agent?,
                                 HashRef :$companies?,
                                 Maybe[Int] :$last_request_at?,
                                 Maybe[Bool] :$unsubscribed_from_emails?,
                                 Maybe[Bool] :$update_last_request_at?,
                                 Maybe[Bool] :$new_session?);

Returns a WebService::Intercom::User that represents the new or updated user.

user_delete

Deletes a user

# When you have an existing WebService::Intercom::User
$intercom->user_delete(WebService::Intercom::User $user);

or

$intercom->user_delete(Maybe[Str] :$user_id?,
                       Maybe[Str] :$email?,
                       Maybe[Str] :$id?);

Only one of user_id, email or id is required.

Returns a WebService::Intercom::User that represents the deleted user.

tag_create_or_update

Creates or updates a tag.

# When you have an existing WebService::Intercom::User
$intercom->tag_create_or_update(WebService::Intercom::Tag $tag);

or

$intercom->tag_create_or_update(Str :$name,
                                Maybe[Str] :$id?);

Returns a WebService::Intercom::Tag that represents the tag.

tag_items

Applies or removes a tag to users or companies

# When you have an existing WebService::Intercom::User
$intercom->tag_items(Str :$name,
                     ArrayRef[TagUserIdentifierType] :$users?,
                     ArrayRef[TagCompanyIdentifierType] :$companies?);

tag_delete

Deletes a tag

# When you have an existing WebService::Intercom::User
$intercom->tag_delete(WebService::Intercom::Tag $tag);

or

$intercom->tag_delete(Str :$id);

Returns undef

note_create

Creates a note for a user

# When you have an existing WebService::Intercom::User
$intercom->note_create(Maybe[Str] :$user_id?,
                       Maybe[Str] :$email?,
                       Maybe[Str] :$id?,
                       Maybe[Str] :$admin_id?,
                       Str :$body);

Returns a WebService::Intercom::Note that represents the note.

event_create

Creates an event for a user

# When you have an existing WebService::Intercom::User
$intercom->event_create(Maybe[Str] :$user_id?,
                        Maybe[Str] :$email?,
                        EventNameType :$event_name,
                        Maybe[Int] :$created_at?,
                        Maybe[EventMetadataType] :$metadata?);

Returns undef.

SEE ALSO

See Moops and Kavorka to understand parameter signatures.

Also of course Intercom at http://www.intercom.io.

AUTHOR

Rusty Conover <rusty+cpan@luckydinosaur.com>

COPYRIGHT

This software is copyright (c) 2015 by Lucky Dinosaur LLC. http://www.luckydinosaur.com

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.

DISCLAIMER OF WARRANTIES

THIS PACKAGE IS PROVIDED "AS IS" AND WITHOUT ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE.