NAME
WebService::Cmis::Client - Transport layer
DESCRIPTION
A CMIS client is used to communicate with the document manangement server by connecting to an exposed web service. It provides the initial access function to the repositories.
A client may use one of the user agents to authenticate against the CMIS backend, as specified by the =useragent= parameter during object construction. By default a user agent will be used performing HTTP basic auth as a fallback implemented by most CMIS servers.
Available user agents are:
WebService::Cmis::Agent::BasicAuth (default)
use Cache::FileCache ();
my $client = WebService::Cmis::getClient(
url => "http://cmis.alfresco.com/service/cmis",
cache => new Cache::FileCache({
cache_root => "/tmp/cmis_client"
},
useragent => new WebSercice::Cmis::Agent::BasicAuth(
user => "...",
password => "..."
)
)
)
my $repo = $client->getRepository;
Parent class: REST::Client
METHODS
- new(%params)
-
Create a new WebService::Cmis::Client. This requires a url of the webservice api, as well as a valid useragent handler.
See REST::Client for more options.
Parameters:
useragent - handler to be used for authentication
"WebService::Cmis::Agent::BasicAuth" (default)
url - repository url; example:
"http://localhost:8080/alfresco/service/cmis"
cache - a Cache::Cache object to be used for caching
overrideCacheContrib - boolean flag to ignore any http cache control for more aggressive caching
- setUseragent($userAgent)
-
setter to assert the user agent to be used in the REST::Client
- toString
-
return a string representation of this client
- clearCache
-
nukes all of the cache. calling this method is sometimes required to work around caching effects.
- purgeCache
-
purges outdated cache entries. call this method in case the cache backend is able to do a kind of house keeping.
- removeFromCache($path, %params)
-
removes an item from the cache associated with the given path and url parameters
- get($path, %params)
-
does a get against the CMIS service. More than likely, you will not need to call this method. Instead, let the other objects to it for you.
- request ( $method, $url, [$body_content, %$headers] )
-
add a cache layer on top of all network connections of the rest client
- responseContent
-
returns the full content of a response
- responseCode
-
returns the HTTP status code of the repsonse
- responseStatusLine
-
returns the "code message" of the response. (See HTTP::Status)
- responseBase -> $uri
-
returns the base uri for this response
- post($path, $payload, $contentType, %params)
-
does a post against the CMIS service. More than likely, you will not need to call this method. Instead, let the other objects to it for you.
- put($path, $payload, $contentType, %params)
-
does a put against the CMIS service. More than likely, you will not need to call this method. Instead, let the other objects to it for you.
- delete($url, %params)
-
does a delete against the CMIS service. More than likely, you will not need to call this method. Instead, let the other objects to it for you.
- processErrors
-
throws a client or a server exception based on the http error code of the last transaction.
- getRepositories() -> %repositories;
-
returns a hash of WebService::Cmis::Repository objects available at this service.
- getRepository($id) -> $repository
-
returns a WebService::Cmis::Repository of the given ID. if ID is undefined the default repository will be returned.
- getCacheHits() -> $num
-
returns the number of times a result has been fetched from the cache instead of accessing the CMIS backend. returns undefined when no cache is configured
- login(%params) -> $ticket
-
Logs in to the web service. returns an identifier for the internal state of the user agent that may be used to login again later on.
my $ticket = $client->login( user=> $user, password => $password ); $client->login( user => $user, ticket => $ticket );
- logout()
-
Logs out of the web service invalidating a stored state within the auth handler.
COPYRIGHT AND LICENSE
Copyright 2012-2013 Michael Daum
This module is free software; you can redistribute it and/or modify it under the same terms as Perl itself. See http://dev.perl.org/licenses/artistic.html.