infopark_crm_connector 0.9.2 → 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/.yardopts +8 -0
- data/CHANGELOG.markdown +94 -0
- data/LICENSE +2 -0
- data/README.markdown +110 -0
- data/lib/crm_connector.rb +11 -15
- data/lib/crm_connector/account.rb +31 -2
- data/lib/crm_connector/activity.rb +61 -3
- data/lib/crm_connector/configuration.rb +2 -4
- data/lib/crm_connector/contact.rb +123 -3
- data/lib/crm_connector/core/continuation_support.rb +2 -1
- data/lib/crm_connector/core/enumerator.rb +20 -11
- data/lib/crm_connector/core/known_attributes.rb +3 -1
- data/lib/crm_connector/core/resource.rb +108 -16
- data/lib/crm_connector/core/search_support.rb +3 -1
- data/lib/crm_connector/custom_type.rb +20 -3
- data/lib/crm_connector/{default.rb → errors.rb} +1 -1
- data/lib/crm_connector/errors/authentication_failed.rb +10 -0
- data/lib/crm_connector/errors/base.rb +8 -0
- data/lib/crm_connector/event.rb +37 -2
- data/lib/crm_connector/event_contact.rb +38 -2
- data/lib/crm_connector/mailing.rb +35 -2
- data/lib/crm_connector/role.rb +7 -2
- data/lib/crm_connector/system.rb +14 -8
- metadata +22 -53
- data/CHANGELOG.rdoc +0 -87
- data/README.rdoc +0 -59
- data/lib/crm_connector/base.rb +0 -4
- data/lib/crm_connector/core/base.rb +0 -111
- data/lib/crm_connector/debugging.rb +0 -21
- data/lib/crm_connector/default/account.rb +0 -30
- data/lib/crm_connector/default/activity.rb +0 -54
- data/lib/crm_connector/default/contact.rb +0 -112
- data/lib/crm_connector/default/custom_type.rb +0 -24
- data/lib/crm_connector/default/event.rb +0 -23
- data/lib/crm_connector/default/event_contact.rb +0 -57
- data/lib/crm_connector/default/mailing.rb +0 -33
- data/lib/crm_connector/default/resource.rb +0 -10
- data/lib/crm_connector/default/role.rb +0 -9
- data/lib/crm_connector/inheriting_resource.rb +0 -30
- data/lib/crm_connector/resource.rb +0 -15
data/.yardopts
ADDED
data/CHANGELOG.markdown
ADDED
@@ -0,0 +1,94 @@
|
|
1
|
+
## Version 1.0.0 - 2012-09-14
|
2
|
+
* Enabled support for `event.custom_attributes`
|
3
|
+
* Removed deprecated functions `EventContact.find_by` and `EventContact.find_by_event_id_and_contact_id`. Please user `EventContact.search` instead.
|
4
|
+
* Removed `configuration.debug`.
|
5
|
+
* Renamed `Infopark::Crm::AuthenticationFailed` to `Infopark::Crm::Errors::AuthenticationFailed`.
|
6
|
+
* Merged `Infopark::Crm::Core::Base` and `Infopark::Crm::Resource` into `Infopark::Crm::Core:Resource`.
|
7
|
+
|
8
|
+
## Version 0.9.2 - 2012-03-19
|
9
|
+
* Security improvement for `Contact.authenticate`, `Contact.password_set` and `contact.password_request`
|
10
|
+
|
11
|
+
## Version 0.9.1 - 2012-02-28
|
12
|
+
* Removed `Diary`. Please use `Activity` instead.
|
13
|
+
* Added `Mailing`
|
14
|
+
* Added `appointment_*` and `task_*` fields to `Activity`
|
15
|
+
* Added `role_names` field to `Contact`
|
16
|
+
* Added `tags` field to `Activity`, `Account` and `Contact`
|
17
|
+
|
18
|
+
## Version 0.9 - 2012-01-27
|
19
|
+
Initial Release of Infopark CRM Connector
|
20
|
+
|
21
|
+
### Changes from OMC Connector to CRM Connector
|
22
|
+
* Namespace changed from `OmcConector::` to `Infopark::Crm::`
|
23
|
+
* Attribute names may have changed. For new attributes please refer to [Web Services API documentation](http://kb.infopark.de/crm-api).
|
24
|
+
* Works only with Infopark WebCRM.
|
25
|
+
|
26
|
+
#### Changed configuration
|
27
|
+
* `live_server_groups_callback` - replaces `contact_roles_callback`
|
28
|
+
|
29
|
+
#### New classes
|
30
|
+
* `CustomType`
|
31
|
+
* `Role`
|
32
|
+
* `System`
|
33
|
+
|
34
|
+
#### New methods
|
35
|
+
* `Account.search`
|
36
|
+
* `Activity.search`
|
37
|
+
* `Contact.search`
|
38
|
+
* `Event.search`
|
39
|
+
* `EventContact.search`
|
40
|
+
* `contact.live_server_groups` - replaces `contact.roles`
|
41
|
+
|
42
|
+
#### Removed classes
|
43
|
+
* `AccountCollection`
|
44
|
+
* `InquiryKind` - use `CustomType`
|
45
|
+
* `InquiryLink`
|
46
|
+
* `Inquiry` - use `Activity`
|
47
|
+
* `Location` - use `contact` and `account` properties
|
48
|
+
* `Mailing`
|
49
|
+
* `RegistrationInquiry`
|
50
|
+
* `Session`
|
51
|
+
|
52
|
+
|
53
|
+
#### Removed methods
|
54
|
+
* `account.contacts` - use `Contact.search(:params => {:acount_id => acount_id})`
|
55
|
+
* `Account.find_by_name` - use `Account.search`
|
56
|
+
* `account.inquiries` - use `Activity.search(:params => {:account_id => account_id})`
|
57
|
+
* `account.locations`
|
58
|
+
* `contact.account_activities` - use `Activity.search(:query => {:account_id => account_id})`
|
59
|
+
* `contact.activities` - use `Activity.search(:params => {:contact_id => contact_id})`
|
60
|
+
* `contact.create_activity`
|
61
|
+
* `contact.create_diary`
|
62
|
+
* `contact.create_location_with_account_association`
|
63
|
+
* `contact.create_location`
|
64
|
+
* `contact.create_registration_request`
|
65
|
+
* `contact.event_participation`
|
66
|
+
* `contact.find_activity`
|
67
|
+
* `Contact.find_by_email` - use `Contact.search(:params => {:email => email})`
|
68
|
+
* `Contact.find_by_login` - use `Contact.search(:params => {:login => login})`
|
69
|
+
* `Contact.languages`
|
70
|
+
* `contact.location`
|
71
|
+
* `Contact.lookup_uptions`
|
72
|
+
* `contact.move_location`
|
73
|
+
* `contact.roles` - use `contact.live_server_groups`
|
74
|
+
* `contact.serialized_attributes` - use `contact.attributes`
|
75
|
+
* `contact.subscriptions`
|
76
|
+
* `Contact.titles`
|
77
|
+
* `contact.update_location`
|
78
|
+
* `contact.update_subscriptions`
|
79
|
+
* `contact.validate_login` - use `Contact.search(:params => {:login => login})`
|
80
|
+
* `event.attend(!)`
|
81
|
+
* `event.contacts` - use `EventContact.search(:event_id => event_id)`
|
82
|
+
* `Event.find_by_name`
|
83
|
+
* `event.inquire(!)`
|
84
|
+
* `event.refuse(!)`
|
85
|
+
* `event.register(!)`
|
86
|
+
* `event_contact.attend` - use `event_contact.status = 'attended'`
|
87
|
+
* `event_contact.inquire` - use `event_contact.status = 'unregistered'`
|
88
|
+
* `event_contact.refuse` - use `event_contact.status = 'refused'`
|
89
|
+
* `event_contact.register` - use `event_contact.status = 'registered'`
|
90
|
+
* `event_contact.update_details`
|
91
|
+
* `inquiry.create_diary`
|
92
|
+
* `inquiry.create_link`
|
93
|
+
* `inquiry.diaries`
|
94
|
+
* `inquiry.links`
|
data/LICENSE
CHANGED
data/README.markdown
ADDED
@@ -0,0 +1,110 @@
|
|
1
|
+
<img alt="Infopark WebCRM Connector" src="" />
|
2
|
+
|
3
|
+
|
4
|
+
Infopark WebCRM Connector is the official Ruby SDK for [Infopark WebCRM](http://www.infopark.de/webcrm). It basically wraps the [WebCRM web services API](http://kb.infopark.de/crm-api) using [Active Resource](http://rubydoc.info/gems/activeresource/3.2.8/frames). Currently, Active Resource 3.0, 3.1 and 3.2 in combination with Ruby 1.8.7 and 1.9.x are tested and supported.
|
5
|
+
|
6
|
+
# Installation
|
7
|
+
|
8
|
+
Add `infopark_crm_connector` to your `gemfile`:
|
9
|
+
|
10
|
+
gem 'infopark_crm_connector'
|
11
|
+
|
12
|
+
Install the gem with [Bundler](http://gembundler.com/):
|
13
|
+
|
14
|
+
bundle install
|
15
|
+
|
16
|
+
# Configuration
|
17
|
+
|
18
|
+
require 'infopark_crm_connector'
|
19
|
+
|
20
|
+
Infopark::Crm.configure do |configuration|
|
21
|
+
configuration.url = "https://webcrm.server/url"
|
22
|
+
configuration.login = "webcrm_user"
|
23
|
+
configuration.api_key = "api_key_of_webcrm_user"
|
24
|
+
end
|
25
|
+
|
26
|
+
# See, if it is working
|
27
|
+
Infopark::Crm::Contact.first.last_name
|
28
|
+
|
29
|
+
See {Infopark::Crm.configure} for a complete list of configuration keys.
|
30
|
+
|
31
|
+
# Example Usage
|
32
|
+
|
33
|
+
This Ruby SDK provides the WebCRM's domain models {Infopark::Crm::Account Account}, {Infopark::Crm::Activity Activity}, {Infopark::Crm::Contact Contact}, {Infopark::Crm::Event Event}, {Infopark::Crm::Mailing Mailing}, among others. All domain models are subclasses of {Infopark::Crm::Core::Resource} which itself inherits from {ActiveResource::Base} and provides methods such as `find(id)`, `create(hash)`, `update(hash)`, `search(params)` and others.
|
34
|
+
|
35
|
+
## Contact
|
36
|
+
# Retrieve the contact identified by the login 'root'
|
37
|
+
contact = Infopark::Crm::Contact.search(:params => {:login => 'root'}).first
|
38
|
+
|
39
|
+
# Change this contact's mail address
|
40
|
+
contact.update_attribute(:email, 'root@example.com')
|
41
|
+
|
42
|
+
# Send a new password request mail to the contact's address
|
43
|
+
contact.password_request
|
44
|
+
|
45
|
+
## Activity
|
46
|
+
|
47
|
+
# Create a new activity kind
|
48
|
+
Infopark::Crm::CustomType.create(:name => 'support case', :kind => 'Activity',
|
49
|
+
:states => ['created'])
|
50
|
+
|
51
|
+
# Create a new activity
|
52
|
+
activity = Infopark::Crm::Activity.new(:kind => 'support case')
|
53
|
+
|
54
|
+
# Set properties of this activity
|
55
|
+
activity.title = 'Sprechen Sie Deutsch?'
|
56
|
+
|
57
|
+
# Switch to a different request locale
|
58
|
+
Infopark::Crm.configure {|c| c.locale = 'de'}
|
59
|
+
|
60
|
+
# Post the activity (which is going to fail)
|
61
|
+
activity.save
|
62
|
+
# => false
|
63
|
+
|
64
|
+
# Get to know what's missing
|
65
|
+
activity.errors.to_hash
|
66
|
+
# => {:state=>["ist kein gültiger Wert"]}
|
67
|
+
|
68
|
+
# Contributing
|
69
|
+
|
70
|
+
The source code is freely available at (https://github.com/infopark/crm_connector). Pull requests are welcome.
|
71
|
+
|
72
|
+
## Get started
|
73
|
+
|
74
|
+
git clone git@github.com:infopark/crm_connector.git
|
75
|
+
cd crm_connector/
|
76
|
+
bundle
|
77
|
+
|
78
|
+
## Run tests
|
79
|
+
|
80
|
+
Configure `test/config.json` with an empty WebCRM tenant (see `test/config_template.json`)
|
81
|
+
|
82
|
+
Run tests with the current version of Active Resource:
|
83
|
+
|
84
|
+
bundle exec rake test
|
85
|
+
|
86
|
+
|
87
|
+
Run tests with all supported versions of Active Resource:
|
88
|
+
|
89
|
+
bundle exec rake appraisal:install
|
90
|
+
bundle exec rake appraisal
|
91
|
+
|
92
|
+
## Build and install gem
|
93
|
+
|
94
|
+
bundle exec rake gem #build
|
95
|
+
bundle exec rake install #build and install
|
96
|
+
|
97
|
+
## Documentation
|
98
|
+
|
99
|
+
bundle exec rake yard
|
100
|
+
open doc/index.html
|
101
|
+
|
102
|
+
# Changelog
|
103
|
+
|
104
|
+
{include:file:CHANGELOG.markdown}
|
105
|
+
|
106
|
+
# License
|
107
|
+
|
108
|
+
Copyright (c) 2009 - 2012 Infopark AG (http://www.infopark.com)
|
109
|
+
|
110
|
+
This software can be used and modified under the LGPLv3. Please refer to http://www.gnu.org/licenses/lgpl-3.0.html for the license text.
|
data/lib/crm_connector.rb
CHANGED
@@ -2,6 +2,7 @@ require 'active_resource'
|
|
2
2
|
require 'active_support/core_ext/string/conversions'
|
3
3
|
|
4
4
|
module Infopark; module Crm
|
5
|
+
# @private
|
5
6
|
def self.setup_autoload(mod, mod_source)
|
6
7
|
dir = File.expand_path(".", mod_source)[0..-4] # - ".rb"
|
7
8
|
pattern = "#{dir}/*.rb"
|
@@ -13,24 +14,20 @@ module Infopark; module Crm
|
|
13
14
|
end
|
14
15
|
|
15
16
|
setup_autoload(self, __FILE__)
|
16
|
-
|
17
|
-
# exceptions (defined elsewhere)
|
18
|
-
autoload :AuthenticationFailed, File.expand_path('../crm_connector/core/base', __FILE__)
|
19
|
-
|
20
17
|
end; end
|
21
18
|
|
22
19
|
module Infopark; module Crm
|
23
20
|
|
24
|
-
# Configures the web
|
21
|
+
# Configures the web services connection
|
25
22
|
#
|
26
|
-
# View {README
|
23
|
+
# View {file:README.markdown README} for a usage example.
|
27
24
|
#
|
28
25
|
# Supported configuration keys are:
|
29
|
-
# [url]
|
26
|
+
# [url] The web services server url (schema, host, port, path (up to, but not including /api)).
|
30
27
|
#
|
31
|
-
# [login]
|
28
|
+
# [login] The user name (login) of the WebCRM contact person.
|
32
29
|
#
|
33
|
-
# [api_key]
|
30
|
+
# [api_key] The WebCRM user's valid API key (web services credential).
|
34
31
|
#
|
35
32
|
# [locale] The locale to use when sending requests to the server. Can be
|
36
33
|
# redefined at any time.
|
@@ -43,9 +40,9 @@ module Infopark; module Crm
|
|
43
40
|
#
|
44
41
|
# Infopark::Crm::Contact.create.errors.full_messages
|
45
42
|
#
|
46
|
-
# [live_server_groups_callback] A custom definition of what
|
47
|
-
#
|
48
|
-
#
|
43
|
+
# [live_server_groups_callback] A custom definition of what a contact's live_server_groups field
|
44
|
+
# returns. Provide a lambda that takes the contact instance as an
|
45
|
+
# argument and returns an array of live_server_groups (strings).
|
49
46
|
#
|
50
47
|
# Example:
|
51
48
|
#
|
@@ -60,13 +57,12 @@ module Infopark; module Crm
|
|
60
57
|
# }
|
61
58
|
# end
|
62
59
|
#
|
63
|
-
# [debug] When set to true, includes the module Debugging into every resource, which
|
64
|
-
# provides a logger method. Cannot be reverted by setting to +false+
|
65
60
|
#
|
61
|
+
# @return [void]
|
66
62
|
def self.configure(&block)
|
67
63
|
yield Configuration
|
68
64
|
|
69
|
-
Core::
|
65
|
+
Core::Resource.configure(Configuration)
|
70
66
|
end
|
71
67
|
|
72
68
|
end; end
|
@@ -1,4 +1,33 @@
|
|
1
1
|
module Infopark; module Crm
|
2
|
-
|
3
|
-
class Account <
|
2
|
+
|
3
|
+
class Account < Core::Resource
|
4
|
+
|
5
|
+
##
|
6
|
+
# @!method self.search(input)
|
7
|
+
# Searches for accounts
|
8
|
+
# @param input [Hash] A hash containing a +params+ key. The value of this key is a hash containing the actual search query.
|
9
|
+
# @return [Core::Enumerator<Infopark::Crm::Account>]
|
10
|
+
# @webcrm_rest_url <code>GET /api/accounts/search</code>
|
11
|
+
# @example
|
12
|
+
# results = Infopark::Crm::Account.search(:params => {:account_group => 'account_group_name'})
|
13
|
+
# results = Infopark::Crm::Account.search(:params => {:q => 'full-text search'})
|
14
|
+
has_search
|
15
|
+
|
16
|
+
self.schema = {
|
17
|
+
:account_group => :string,
|
18
|
+
:country => :string,
|
19
|
+
:extended_address => :string,
|
20
|
+
:home_page => :string,
|
21
|
+
:locality => :string,
|
22
|
+
:name => :string,
|
23
|
+
:org_name_address => :string,
|
24
|
+
:org_unit_address => :string,
|
25
|
+
:phone => :string,
|
26
|
+
:postalcode => :string,
|
27
|
+
:region => :string,
|
28
|
+
:street_address => :string,
|
29
|
+
:tags => :array,
|
30
|
+
:want_geo_location => :boolean,
|
31
|
+
}
|
32
|
+
end
|
4
33
|
end; end
|
@@ -1,5 +1,63 @@
|
|
1
|
+
require 'ostruct'
|
2
|
+
|
1
3
|
module Infopark; module Crm
|
2
|
-
|
3
|
-
|
4
|
-
|
4
|
+
class Activity < Core::Resource
|
5
|
+
|
6
|
+
##
|
7
|
+
# @!method self.search(input)
|
8
|
+
# Searches for activities
|
9
|
+
# @param input [Hash] A hash containing a +params+ key. The value of this key is a hash containing the actual search query.
|
10
|
+
# @return [Array<Infopark::Crm::Activity>]
|
11
|
+
# @webcrm_rest_url <code>GET /api/activities/search</code>
|
12
|
+
# @example
|
13
|
+
# results = Infopark::Crm::Activity.search(:params => {:state => 'created'})
|
14
|
+
# results = Infopark::Crm::Activity.search(:params => {:kind => 'support case'})
|
15
|
+
# results = Infopark::Crm::Activity.search(:params => {:contact_id => cid})
|
16
|
+
# results = Infopark::Crm::Activity.search(:params => {:account_id => aid})
|
17
|
+
# results = Infopark::Crm::Activity.search(:params => {:q => 'full-text search'})
|
18
|
+
has_search
|
19
|
+
|
20
|
+
self.schema = {
|
21
|
+
:account_id => :string,
|
22
|
+
:appointment_contact_id => :string,
|
23
|
+
:appointment_dtend_at => :time,
|
24
|
+
:appointment_dtstart_at => :time,
|
25
|
+
:appointment_location => :string,
|
26
|
+
:comment_notes => :string,
|
27
|
+
:comment_published => :boolean,
|
28
|
+
:contact_id => :string,
|
29
|
+
:email_cc => :string,
|
30
|
+
:kind => :string,
|
31
|
+
:state => :string,
|
32
|
+
:tags => :array,
|
33
|
+
:task_due_at => :time,
|
34
|
+
:task_owner_id => :string,
|
35
|
+
:title => :string,
|
36
|
+
}
|
5
37
|
|
38
|
+
##
|
39
|
+
# Queries the WebCRM for the Contact with the id +contact_id+.
|
40
|
+
# @return [Infopark::Crm::Contact] The contact associated with this activity, if +contact_id+ is present.
|
41
|
+
# @webcrm_rest_url <code>GET /api/contacts/_contact_id_</code>
|
42
|
+
def contact
|
43
|
+
Infopark::Crm::Contact.find(contact_id) if contact_id
|
44
|
+
end
|
45
|
+
|
46
|
+
##
|
47
|
+
# Queries the WebCRM for the Account with the id +account_id+.
|
48
|
+
# @return [Infopark::Crm::Account] The account associated with this activity, if +account_id+ is present.
|
49
|
+
# @webcrm_rest_url <code>GET /api/accounts/_account_id_</code>
|
50
|
+
def account
|
51
|
+
Infopark::Crm::Account.find(account_id) if account_id
|
52
|
+
end
|
53
|
+
|
54
|
+
##
|
55
|
+
# Queries the WebCRM for the CustomType with the id +kind+.
|
56
|
+
# @return [Infopark::Crm::CustomType] The custom type associated with this activity, if +kind+ is present.
|
57
|
+
# @webcrm_rest_url <code>GET /api/custom_types/_kind_</code>
|
58
|
+
def custom_type
|
59
|
+
Infopark::Crm::CustomType.find(kind) if kind
|
60
|
+
end
|
61
|
+
|
62
|
+
end
|
63
|
+
end; end
|
@@ -1,8 +1,8 @@
|
|
1
|
-
# :stopdoc:
|
2
|
-
|
3
1
|
require 'active_support/core_ext/class/attribute_accessors'
|
4
2
|
|
5
3
|
module Infopark; module Crm
|
4
|
+
|
5
|
+
# @private
|
6
6
|
class Configuration
|
7
7
|
|
8
8
|
cattr_accessor :api_key
|
@@ -17,8 +17,6 @@ module Infopark; module Crm
|
|
17
17
|
|
18
18
|
cattr_accessor :live_server_groups_callback
|
19
19
|
|
20
|
-
cattr_accessor :debug
|
21
|
-
|
22
20
|
self.login = "webservice"
|
23
21
|
|
24
22
|
self.live_server_groups_callback = lambda {|contact| []}
|
@@ -1,5 +1,125 @@
|
|
1
1
|
module Infopark; module Crm
|
2
|
-
|
3
|
-
|
4
|
-
|
2
|
+
class Contact < Core::Resource
|
3
|
+
|
4
|
+
##
|
5
|
+
# @!method self.search(input)
|
6
|
+
# Searches for contacts
|
7
|
+
# @param input [Hash] A hash containing a +params+ key. The value of this key is a hash containing the actual search query.
|
8
|
+
# @return [Array<Infopark::Crm::Contact>]
|
9
|
+
# @webcrm_rest_url <code>GET /api/contacts/search</code>
|
10
|
+
# @example
|
11
|
+
# results = Infopark::Crm::Contact.search(:params => {:login => 'the_login'})
|
12
|
+
# results = Infopark::Crm::Contact.search(:params => {:email => 'email@example.com'})
|
13
|
+
# results = Infopark::Crm::Contact.search(:params => {:q => 'full-text search'})
|
14
|
+
has_search
|
15
|
+
|
16
|
+
self.schema = {
|
17
|
+
:account_id => :string,
|
18
|
+
:country => :string,
|
19
|
+
:email => :string,
|
20
|
+
:extended_address => :string,
|
21
|
+
:fax => :string,
|
22
|
+
:first_name => :string,
|
23
|
+
:gender => :string,
|
24
|
+
:job_title => :string,
|
25
|
+
:language => :string,
|
26
|
+
:last_name => :string,
|
27
|
+
:locality => :string,
|
28
|
+
:login => :string,
|
29
|
+
:mobile_phone => :string,
|
30
|
+
:name_prefix => :string,
|
31
|
+
:org_name_address => :string,
|
32
|
+
:org_unit_address => :string,
|
33
|
+
:phone => :string,
|
34
|
+
:postalcode => :string,
|
35
|
+
:region => :string,
|
36
|
+
:role_names => :array,
|
37
|
+
:street_address => :string,
|
38
|
+
:tags => :array,
|
39
|
+
:want_email => :boolean,
|
40
|
+
:want_geo_location => :boolean,
|
41
|
+
:want_phonecall => :boolean,
|
42
|
+
:want_snailmail => :boolean,
|
43
|
+
}
|
44
|
+
|
45
|
+
##
|
46
|
+
# Queries the WebCRM for the Account with the id +account_id+.
|
47
|
+
# @return [Infopark::Crm::Account] The account associated with this contact, if +account_id+ is present.
|
48
|
+
# @webcrm_rest_url <code>GET /api/accounts/_account_id_</code>
|
49
|
+
def account
|
50
|
+
Infopark::Crm::Account.find(account_id) if account_id
|
51
|
+
end
|
52
|
+
|
53
|
+
##
|
54
|
+
# Looks for the user with the given +login+ and check whether the +password+ is correct.
|
55
|
+
# @param login [String]
|
56
|
+
# @param password [String]
|
57
|
+
# @return [Infopark::Crm::Contact] The found and authenticated contact.
|
58
|
+
# @raise [Infopark::Crm::Errors::AuthenticationFailed] if provided +password+ is not correct.
|
59
|
+
# @webcrm_rest_url <code>POST /api/contacts/authenticate</code>
|
60
|
+
def self.authenticate(login, password)
|
61
|
+
begin
|
62
|
+
response = post(:authenticate, {}, format.encode({:login => login, :password => password}))
|
63
|
+
result = format.decode(response.body)
|
64
|
+
return find(result['id']) if result.kind_of? Hash # ActiveResource 3.0
|
65
|
+
find(result)
|
66
|
+
rescue ActiveResource::ResourceInvalid
|
67
|
+
raise Errors::AuthenticationFailed
|
68
|
+
end
|
69
|
+
end
|
70
|
+
|
71
|
+
##
|
72
|
+
# Sets a new +password+ for the contact, which is associated with the given +token+.
|
73
|
+
# @param password [String] The new password.
|
74
|
+
# @param token [String] The token provided by +password_request+ which is associated with a contact.
|
75
|
+
# @return [String] The result message from the server.
|
76
|
+
# @webcrm_rest_url <code>POST /api/contacts/password_set</code>
|
77
|
+
def self.password_set(password, token)
|
78
|
+
response = post(:password_set, {}, format.encode({:password => password, :token => token}))
|
79
|
+
result = format.decode(response.body)
|
80
|
+
return result['message'] if result.kind_of? Hash # ActiveResource 3.0
|
81
|
+
result
|
82
|
+
end
|
5
83
|
|
84
|
+
##
|
85
|
+
# Sets the password of this contact to +password+.
|
86
|
+
# @param password [String] the new password
|
87
|
+
# @return [void]
|
88
|
+
def password_set(password)
|
89
|
+
token = password_request(:params => {:only_get_token => true})
|
90
|
+
self.class.password_set(password, token)
|
91
|
+
end
|
92
|
+
|
93
|
+
##
|
94
|
+
# Instructs the WebCRM to send the user an e-mail to let them set a new password.
|
95
|
+
# @param options [Hash]
|
96
|
+
# @webcrm_rest_url <code>GET /api/contacts/_id_/password_request</code>
|
97
|
+
# @webcrm_todo return nil instead of message for default parameters?
|
98
|
+
def password_request(options = {})
|
99
|
+
params = options[:params] || {}
|
100
|
+
response = post(:password_request, {}, self.class.format.encode(params))
|
101
|
+
result = self.class.format.decode(response.body)
|
102
|
+
return result.values.first if result.kind_of? Hash # ActiveResource 3.0
|
103
|
+
result
|
104
|
+
end
|
105
|
+
|
106
|
+
# Returns the live_server_groups of this contact as defined by +Configuration.live_server_groups_callback+
|
107
|
+
# @return [Array<String>] The calculated roles of this contact.
|
108
|
+
def live_server_groups
|
109
|
+
return @live_server_groups if defined?(@live_server_groups)
|
110
|
+
callback = Configuration.live_server_groups_callback
|
111
|
+
@live_server_groups = callback.call(self) if callback.respond_to?(:call)
|
112
|
+
raise "live_server_groups_callback: not defined or unexpected result!" unless @live_server_groups
|
113
|
+
|
114
|
+
@live_server_groups
|
115
|
+
end
|
116
|
+
|
117
|
+
##
|
118
|
+
# Overwrites +live_server_groups+, so live_server_groups_callback is not called for this object.
|
119
|
+
# @return [void]
|
120
|
+
def live_server_groups=(value)
|
121
|
+
@live_server_groups = value
|
122
|
+
end
|
123
|
+
|
124
|
+
end
|
125
|
+
end; end
|