OpacApi.CancelResult, OpacApi.MultiStepResult, OpacApi.OpacErrorException, OpacApi.ProlongAllResult, OpacApi.ProlongResult, OpacApi.ReservationResult
Modifier and Type | Field and Description |
---|---|
protected org.json.JSONObject |
data |
protected static java.util.HashMap<java.lang.String,SearchResult.MediaType> |
defaulttypes |
protected java.lang.String |
opac_url |
protected java.util.List<java.util.List<org.apache.http.NameValuePair>> |
query |
protected static java.lang.String |
QUERY_TYPE_CONTAINS |
protected static java.lang.String |
QUERY_TYPE_EQUALS |
protected static java.lang.String |
QUERY_TYPE_FROM |
protected static java.lang.String |
QUERY_TYPE_STARTS_WITH |
protected static java.lang.String |
QUERY_TYPE_TO |
http_client, httpLoggingEnabled, initialised, KEY_SEARCH_QUERY_AUDIENCE, KEY_SEARCH_QUERY_AUTHOR, KEY_SEARCH_QUERY_AVAILABLE, KEY_SEARCH_QUERY_BARCODE, KEY_SEARCH_QUERY_BRANCH, KEY_SEARCH_QUERY_CATEGORY, KEY_SEARCH_QUERY_DIGITAL, KEY_SEARCH_QUERY_FREE, KEY_SEARCH_QUERY_HOME_BRANCH, KEY_SEARCH_QUERY_ISBN, KEY_SEARCH_QUERY_KEYWORDA, KEY_SEARCH_QUERY_KEYWORDB, KEY_SEARCH_QUERY_LOCATION, KEY_SEARCH_QUERY_ORDER, KEY_SEARCH_QUERY_PUBLISHER, KEY_SEARCH_QUERY_SYSTEM, KEY_SEARCH_QUERY_TITLE, KEY_SEARCH_QUERY_YEAR, KEY_SEARCH_QUERY_YEAR_RANGE_END, KEY_SEARCH_QUERY_YEAR_RANGE_START, library, stringProvider, supportedLanguages
SUPPORT_FLAG_ACCOUNT_PROLONG_ALL, SUPPORT_FLAG_CHANGE_ACCOUNT, SUPPORT_FLAG_ENDLESS_SCROLLING, SUPPORT_FLAG_QUICKLINKS, SUPPORT_FLAG_WARN_PROLONG_FEES, SUPPORT_FLAG_WARN_RESERVATION_FEES
Constructor and Description |
---|
WinBiap() |
Modifier and Type | Method and Description |
---|---|
AccountData |
account(Account account)
Load account view (borrowed and reserved items, see
AccountData )
This function is always called from a background thread, you can use blocking network
operations in it. |
protected int |
addParameters(java.util.Map<java.lang.String,java.lang.String> query,
java.lang.String key,
java.lang.String searchkey,
java.lang.String type,
java.util.List<java.util.List<org.apache.http.NameValuePair>> params,
int index)
For documentation of the parameters, @see
addParametersManual(String, String, String,
String, String, List, int) |
protected int |
addParametersManual(java.lang.String combination,
java.lang.String mode,
java.lang.String field,
java.lang.String operator,
java.lang.String value,
java.util.List<java.util.List<org.apache.http.NameValuePair>> params,
int index) |
OpacApi.CancelResult |
cancel(java.lang.String media,
Account account,
int useraction,
java.lang.String selection)
Cancel a media reservation/order identified by the given String (see AccountData
documentation) (see
AccountData )
This function is always called from a background thread, you can use blocking network
operations in it. |
void |
checkAccountData(Account account)
Check the validity of given account data.
|
SearchRequestResult |
filterResults(Filter filter,
Filter.Option option)
If your
OpacApi.search(List) implementation puts something different from null
into SearchRequestResult.setFilters(List) , this will be called to apply a filter to
the last search request. |
DetailledItem |
getResult(int position)
Get details for the item at
position from last OpacApi.search(java.util.List<de.geeksfactory.opacclient.searchfields.SearchQuery>) or OpacApi.searchGetPage(int) call. |
DetailledItem |
getResultById(java.lang.String id,
java.lang.String homebranch)
Get details for the item with unique ID id.
|
java.lang.String |
getShareUrl(java.lang.String id,
java.lang.String title)
Some library systems allow us to share search results.
|
java.util.Set<java.lang.String> |
getSupportedLanguages()
Get all languages supported by this library.
|
int |
getSupportFlags()
Return which optional features your API implementation supports.
|
void |
init(Library lib,
HttpClientFactory httpClientFactory)
Initializes HTTP client and String Provider
|
protected org.jsoup.nodes.Document |
login(Account account) |
java.util.List<SearchField> |
parseSearchFields() |
OpacApi.ProlongResult |
prolong(java.lang.String media,
Account account,
int useraction,
java.lang.String selection)
Extend the lending period of the item identified by the given String (see
AccountData )
This function is always called from a background thread, you can use blocking network
operations in it. |
OpacApi.ProlongAllResult |
prolongAll(Account account,
int useraction,
java.lang.String selection)
Extend the lending period of all lent items.
|
OpacApi.ReservationResult |
reservation(DetailledItem item,
Account account,
int useraction,
java.lang.String selection)
Perform a reservation on the item last fetched with
getResultById or
getResult for Account acc . |
SearchRequestResult |
search(java.util.List<SearchQuery> queries)
Performs a catalogue search.
|
SearchRequestResult |
searchGetPage(int page)
Get result page
page of the search performed last with OpacApi.search(java.util.List<de.geeksfactory.opacclient.searchfields.SearchQuery>) . |
void |
setLanguage(java.lang.String language)
Set the language to use.
|
boolean |
shouldUseMeaningDetector() |
buildHttpGetParams, cleanUrl, convertStreamToString, convertStreamToString, downloadCover, getDefaultEncoding, getQueryParams, getQueryParamsFirst, getSearchFields, httpGet, httpGet, httpGet, httpGet, httpPost, httpPost, httpPost, httpPost, logHttpError, searchQueryListToMap, setHttpLoggingEnabled, setStringProvider, start, volumeSearch
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
getSearchFields, setStringProvider, start, volumeSearch
protected static final java.lang.String QUERY_TYPE_CONTAINS
protected static final java.lang.String QUERY_TYPE_FROM
protected static final java.lang.String QUERY_TYPE_TO
protected static final java.lang.String QUERY_TYPE_STARTS_WITH
protected static final java.lang.String QUERY_TYPE_EQUALS
protected static java.util.HashMap<java.lang.String,SearchResult.MediaType> defaulttypes
protected java.lang.String opac_url
protected org.json.JSONObject data
protected java.util.List<java.util.List<org.apache.http.NameValuePair>> query
public void init(Library lib, HttpClientFactory httpClientFactory)
BaseApi
init
in interface OpacApi
init
in class BaseApi
lib
- The library the Api is initialized forhttpClientFactory
- A HttpClientFactory instance that will be used for instantiating
HTTP clients. This factory is pluggable because we want to use
platform-specific code on Android.protected int addParameters(java.util.Map<java.lang.String,java.lang.String> query, java.lang.String key, java.lang.String searchkey, java.lang.String type, java.util.List<java.util.List<org.apache.http.NameValuePair>> params, int index)
addParametersManual(String, String, String,
String, String, List, int)
protected int addParametersManual(java.lang.String combination, java.lang.String mode, java.lang.String field, java.lang.String operator, java.lang.String value, java.util.List<java.util.List<org.apache.http.NameValuePair>> params, int index)
combination
- "Combination" (probably And, Or, ...): Meaning unknown, seems to always be
"1" except in some mysterious queries the website adds every time that
don't change the resultmode
- "Mode": Meaning unknown, seems to always be "1" except in some mysterious
queries the website adds every time that don't change the resultfield
- "Field": The key for the property that is queried, for example "12" for
"title"operator
- "Operator": The type of search that is made (one of the QUERY_TYPE_
constants above), for example "8" for "contains"value
- "Value": The value that was input by the userpublic SearchRequestResult search(java.util.List<SearchQuery> queries) throws java.io.IOException, OpacApi.OpacErrorException
OpacApi
List<SearchQuery>
contains the
search criteria. See documentation on SearchResult
for details.
This function is always called from a background thread, you can use blocking network
operations in it. See documentation on DetailledItem for details.search
in interface OpacApi
queries
- see abovejava.io.IOException
OpacApi.OpacErrorException
SearchResult
public SearchRequestResult filterResults(Filter filter, Filter.Option option) throws java.io.IOException, OpacApi.OpacErrorException
OpacApi
OpacApi.search(List)
implementation puts something different from null
into SearchRequestResult.setFilters(List)
, this will be called to apply a filter to
the last search request.
If your OpacApi.search(List)
implementation does not set SearchRequestResult.setFilters(List)
, this wil never be called. Just return
null
.
This function is always called from a background thread, you can use blocking network
operations in it. See documentation on DetailledItem for details.filterResults
in interface OpacApi
filter
- The filter to be applied.option
- The filters option to be applied. If the option.isApplied()
returns true
, the filter is to be removed!java.io.IOException
OpacApi.OpacErrorException
SearchResult
,
Filter
public SearchRequestResult searchGetPage(int page) throws java.io.IOException, OpacApi.OpacErrorException
OpacApi
page
of the search performed last with OpacApi.search(java.util.List<de.geeksfactory.opacclient.searchfields.SearchQuery>)
.
This function is always called from a background thread, you can use blocking network
operations in it. See documentation on DetailledItem for details.searchGetPage
in interface OpacApi
page
- page number to fetchjava.io.IOException
OpacApi.OpacErrorException
OpacApi.search(List)
,
SearchResult
public DetailledItem getResultById(java.lang.String id, java.lang.String homebranch) throws java.io.IOException, OpacApi.OpacErrorException
OpacApi
getResultById
in interface OpacApi
id
- id of object to fetchhomebranch
- The users "home branch". "Home" library branch. Some library systems
require this information at search request time to determine where book
reservations should be placed. If in doubt, set to null
.java.io.IOException
OpacApi.OpacErrorException
DetailledItem
public DetailledItem getResult(int position) throws java.io.IOException, OpacApi.OpacErrorException
OpacApi
position
from last OpacApi.search(java.util.List<de.geeksfactory.opacclient.searchfields.SearchQuery>)
or OpacApi.searchGetPage(int)
call.
We generally prefer OpacApi.getResultById(String, String)
, so if you implement
getResultById
AND every search result of your driver
has an id set, you can omit this method (respectively, return null).
This function is always called from a background thread, you can use blocking network
operations in it.getResult
in interface OpacApi
position
- position of object in last searchjava.io.IOException
OpacApi.OpacErrorException
DetailledItem
public OpacApi.ReservationResult reservation(DetailledItem item, Account account, int useraction, java.lang.String selection) throws java.io.IOException
OpacApi
getResultById
or
getResult
for Account acc
. (if applicable)
This function is always called from a background thread, you can use blocking network
operations in it.reservation
in interface OpacApi
item
- The item to place a reservation for.account
- Account to be useduseraction
- Identifier for the selection made by the user in selection
, if
a selection was made (see OpacApi.MultiStepResult.getActionIdentifier()
)
or 0, if no selection was required. If your last method call returned
CONFIRMATION_NEEDED
, this is set to
ACTION_CONFIRMATION
if the user positively confirmed the action.selection
- When the method is called for the first time or if useraction is
ACTION_CONFIRMATION
, this parameter is null. If you return
SELECTION
in your OpacApi.MultiStepResult.getStatus()
, this
method will be called again with the user's selection present in
selection.ReservationResult
object which has to have the status set.java.io.IOException
public OpacApi.ProlongResult prolong(java.lang.String media, Account account, int useraction, java.lang.String selection) throws java.io.IOException
OpacApi
AccountData
)
This function is always called from a background thread, you can use blocking network
operations in it.prolong
in interface OpacApi
media
- Media identificationaccount
- Account to be useduseraction
- Identifier for the selection made by the user in selection
, if
a selection was made (see OpacApi.MultiStepResult.getActionIdentifier()
) or
0, if no selection was required. If your last method call returned
CONFIRMATION_NEEDED
, this is set to
ACTION_CONFIRMATION
if the user positively confirmed the action.selection
- When the method is called for the first time or if useraction is
ACTION_CONFIRMATION
, this parameter is null. If you return
SELECTION
in your OpacApi.MultiStepResult.getStatus()
, this
method will be called again with the user's selection present in
selection.ProlongResult
object which has to have the status set.java.io.IOException
public OpacApi.ProlongAllResult prolongAll(Account account, int useraction, java.lang.String selection) throws java.io.IOException
OpacApi
OpacApi.getSupportFlags()
implementation's return value contains the OpacApi.SUPPORT_FLAG_ACCOUNT_PROLONG_ALL
flag. If you don't support the feature, just implement a
stub method, like return false;
This function is always called from a background thread, you can use blocking network
operations in it.prolongAll
in interface OpacApi
ProlongAllResult
object which has to have the status set.java.io.IOException
OpacApi.prolong(String, Account, int, String)
,
AccountData
public OpacApi.CancelResult cancel(java.lang.String media, Account account, int useraction, java.lang.String selection) throws java.io.IOException, OpacApi.OpacErrorException
OpacApi
AccountData
)
This function is always called from a background thread, you can use blocking network
operations in it.cancel
in interface OpacApi
media
- Media identificationaccount
- Account to be useduseraction
- Identifier for the selection made by the user in selection
, if
a selection was made (see OpacApi.MultiStepResult.getActionIdentifier()
) or 0,
if no selection was required. If your last method call returned
CONFIRMATION_NEEDED
, this is set to
ACTION_CONFIRMATION
if the user positively confirmed the action.selection
- When the method is called for the first time or if useraction is
ACTION_CONFIRMATION
, this parameter is null. If you return
SELECTION
in your OpacApi.MultiStepResult.getStatus()
, this
method will be called again with the user's selection present in
selection.CancelResult
object which has to have the status set.java.io.IOException
OpacApi.OpacErrorException
public AccountData account(Account account) throws java.io.IOException, org.json.JSONException, OpacApi.OpacErrorException
OpacApi
AccountData
)
This function is always called from a background thread, you can use blocking network
operations in it.account
in interface OpacApi
account
- The account to displayjava.io.IOException
org.json.JSONException
OpacApi.OpacErrorException
AccountData
public java.util.List<SearchField> parseSearchFields() throws java.io.IOException
parseSearchFields
in class BaseApi
java.io.IOException
public boolean shouldUseMeaningDetector()
shouldUseMeaningDetector
in class BaseApi
public java.lang.String getShareUrl(java.lang.String id, java.lang.String title)
OpacApi
null
. If you
library only accepts direkt links when a session is open, get in touch with me
(mail@raphaelmichel.de) to get it integrated in the opacapp.de proxy.getShareUrl
in interface OpacApi
id
- Media id of the item to be sharedtitle
- Title of the item to be sharedpublic int getSupportFlags()
OpacApi
getSupportFlags
in interface OpacApi
SUPPORT_FLAG_*
constantspublic void checkAccountData(Account account) throws java.io.IOException, org.json.JSONException, OpacApi.OpacErrorException
OpacApi
OpacApi.account(Account)
function because just checking the login can be much faster than retrieving all the account
data.
This function is always called from a background thread, you can use blocking network
operations in it.checkAccountData
in interface OpacApi
account
- The account to checkOpacApi.OpacErrorException
- when the login data is invalid or there's another error message
from the OPAC systemjava.io.IOException
org.json.JSONException
protected org.jsoup.nodes.Document login(Account account) throws java.io.IOException, OpacApi.OpacErrorException
java.io.IOException
OpacApi.OpacErrorException
public void setLanguage(java.lang.String language)
OpacApi
setLanguage
in interface OpacApi
language
- the language to usepublic java.util.Set<java.lang.String> getSupportedLanguages() throws java.io.IOException
OpacApi
getSupportedLanguages
in interface OpacApi
java.io.IOException