Moved common functionality of the different list responses into a base class (ListBase<T>) that uses generics. Also made it so that AtomSerializer creates proper urn:uuid:s for it's atom id:s
git-svn-id: https://oai4j-client.svn.sourceforge.net/svnroot/oai4j-client/trunk@6 201c9376-5148-0410-b534-98494c770f31
This commit is contained in:
parent
dde8114c22
commit
0c4362c4fe
|
@ -17,6 +17,7 @@
|
||||||
package se.kb.oai.ore.impl;
|
package se.kb.oai.ore.impl;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
import org.dom4j.DocumentHelper;
|
import org.dom4j.DocumentHelper;
|
||||||
import org.dom4j.Element;
|
import org.dom4j.Element;
|
||||||
|
@ -138,6 +139,6 @@ public class AtomSerializer extends SerializerBase {
|
||||||
}
|
}
|
||||||
|
|
||||||
protected String createAtomId() {
|
protected String createAtomId() {
|
||||||
return "urn:uid:" + (int) (Math.random() * 1000);
|
return "urn:uuid:" + UUID.randomUUID().toString();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,21 +17,19 @@
|
||||||
package se.kb.oai.pmh;
|
package se.kb.oai.pmh;
|
||||||
|
|
||||||
import java.util.LinkedList;
|
import java.util.LinkedList;
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import org.dom4j.Document;
|
import org.dom4j.Document;
|
||||||
import org.dom4j.Node;
|
import org.dom4j.Node;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Class that represents the response from a <code>ListIdentifiers</code> request.
|
* Class that represents the response from a <code>ListIdentifiers</code> request.
|
||||||
*
|
* You can use it to get a list of <code>Headers</code> that holds identifiers.
|
||||||
|
*
|
||||||
* @author Oskar Grenholm, National Library of Sweden
|
* @author Oskar Grenholm, National Library of Sweden
|
||||||
*/
|
*/
|
||||||
public class IdentifiersList extends ResponseBase {
|
public class IdentifiersList extends ListBase<Header> {
|
||||||
|
|
||||||
private static final String HEADER_XPATH = "oai:ListIdentifiers/oai:header";
|
private static final String HEADER_XPATH = "oai:ListIdentifiers/oai:header";
|
||||||
|
|
||||||
private List<Header> headers;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates an <code>IdentifiersList</code> from the returned response.
|
* Creates an <code>IdentifiersList</code> from the returned response.
|
||||||
|
@ -42,42 +40,9 @@ public class IdentifiersList extends ResponseBase {
|
||||||
public IdentifiersList(Document document) throws ErrorResponseException {
|
public IdentifiersList(Document document) throws ErrorResponseException {
|
||||||
super(document);
|
super(document);
|
||||||
|
|
||||||
this.headers = new LinkedList<Header>();
|
super.list = new LinkedList<Header>();
|
||||||
for(Node node : xpath.selectNodes(HEADER_XPATH)) {
|
for(Node node : xpath.selectNodes(HEADER_XPATH)) {
|
||||||
headers.add(new Header(node));
|
list.add(new Header(node));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Get the size of the list.
|
|
||||||
*
|
|
||||||
* @return the size
|
|
||||||
*/
|
|
||||||
public int size() {
|
|
||||||
return headers.size();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get the identifiers as a list of <code>Headers</code>.
|
|
||||||
*
|
|
||||||
* @return a list of identifiers
|
|
||||||
*/
|
|
||||||
public List<Header> asList() {
|
|
||||||
return headers;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get the <code>ResumptionToken</code>, if any, for this response.
|
|
||||||
*
|
|
||||||
* @return the <code>ResumptionToken</code>, or <code>null</code>
|
|
||||||
* if none available
|
|
||||||
*/
|
|
||||||
public ResumptionToken getResumptionToken() {
|
|
||||||
if (super.resumptionToken == null
|
|
||||||
|| super.resumptionToken.getId() == null
|
|
||||||
|| super.resumptionToken.getId().length() == 0)
|
|
||||||
return null;
|
|
||||||
|
|
||||||
return super.resumptionToken;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,23 +17,20 @@
|
||||||
package se.kb.oai.pmh;
|
package se.kb.oai.pmh;
|
||||||
|
|
||||||
import java.util.LinkedList;
|
import java.util.LinkedList;
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import org.dom4j.Document;
|
import org.dom4j.Document;
|
||||||
import org.dom4j.Node;
|
import org.dom4j.Node;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This class represents the response from a <code>ListMetadataFormats</code> request
|
* This class represents the response from a <code>ListMetadataFormats</code> request
|
||||||
* to the OAI-PMH server.
|
* to the OAI-PMH server. You can use it to get a list of <code>MetadataFormats</code>.
|
||||||
*
|
*
|
||||||
* @author Oskar Grenholm, National Library of Sweden
|
* @author Oskar Grenholm, National Library of Sweden
|
||||||
*/
|
*/
|
||||||
public class MetadataFormatsList extends ResponseBase {
|
public class MetadataFormatsList extends ListBase<MetadataFormat> {
|
||||||
|
|
||||||
private static final String METADATAFORMAT_XPATH = "oai:ListMetadataFormats/oai:metadataFormat";
|
private static final String METADATAFORMAT_XPATH = "oai:ListMetadataFormats/oai:metadataFormat";
|
||||||
|
|
||||||
private List<MetadataFormat> metadataFormats;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a <code>MetadataFormatsList</code> from the returned response.
|
* Creates a <code>MetadataFormatsList</code> from the returned response.
|
||||||
*
|
*
|
||||||
|
@ -43,27 +40,20 @@ public class MetadataFormatsList extends ResponseBase {
|
||||||
public MetadataFormatsList(Document document) throws ErrorResponseException {
|
public MetadataFormatsList(Document document) throws ErrorResponseException {
|
||||||
super(document);
|
super(document);
|
||||||
|
|
||||||
this.metadataFormats = new LinkedList<MetadataFormat>();
|
super.list = new LinkedList<MetadataFormat>();
|
||||||
for(Node metadataFormat : xpath.selectNodes(METADATAFORMAT_XPATH)) {
|
for(Node metadataFormat : xpath.selectNodes(METADATAFORMAT_XPATH)) {
|
||||||
metadataFormats.add(new MetadataFormat(metadataFormat));
|
list.add(new MetadataFormat(metadataFormat));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the size of the list.
|
* The response from a <code>ListMetadataFormats</code> request will never
|
||||||
*
|
* have a resumption token, so this method will throw a <code>NoSuchMethodError</code>
|
||||||
* @return the size
|
* to prevent it from being used in that way.
|
||||||
*/
|
*/
|
||||||
public int size() {
|
@Override
|
||||||
return metadataFormats.size();
|
public ResumptionToken getResumptionToken() {
|
||||||
|
throw new NoSuchMethodError("The response from the verb 'ListMetadataFormats' " +
|
||||||
|
"can't have a ResumptionToken!");
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Get the metadata formats as a list of <code>MetadataFormats</code>.
|
|
||||||
*
|
|
||||||
* @return a list of metadata formats
|
|
||||||
*/
|
|
||||||
public List<MetadataFormat> asList() {
|
|
||||||
return metadataFormats;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,22 +17,21 @@
|
||||||
package se.kb.oai.pmh;
|
package se.kb.oai.pmh;
|
||||||
|
|
||||||
import java.util.LinkedList;
|
import java.util.LinkedList;
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import org.dom4j.Document;
|
import org.dom4j.Document;
|
||||||
import org.dom4j.Node;
|
import org.dom4j.Node;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Class that represents the response from a <code>ListRecords</code> request.
|
* Class that represents the response from a <code>ListRecords</code> request.
|
||||||
|
* You can use it to get the list of <code>Records</code> that made up the
|
||||||
|
* response.
|
||||||
*
|
*
|
||||||
* @author Oskar Grenholm, National Library of Sweden
|
* @author Oskar Grenholm, National Library of Sweden
|
||||||
*/
|
*/
|
||||||
public class RecordsList extends ResponseBase {
|
public class RecordsList extends ListBase<Record> {
|
||||||
|
|
||||||
private static final String RECORD_XPATH = "oai:ListRecords/oai:record";
|
private static final String RECORD_XPATH = "oai:ListRecords/oai:record";
|
||||||
|
|
||||||
private List<Record> records;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a <code>RecordsList</code> from the returned response.
|
* Creates a <code>RecordsList</code> from the returned response.
|
||||||
*
|
*
|
||||||
|
@ -42,42 +41,9 @@ public class RecordsList extends ResponseBase {
|
||||||
public RecordsList(Document document) throws ErrorResponseException {
|
public RecordsList(Document document) throws ErrorResponseException {
|
||||||
super(document);
|
super(document);
|
||||||
|
|
||||||
this.records = new LinkedList<Record>();
|
super.list = new LinkedList<Record>();
|
||||||
for (Node record : xpath.selectNodes(RECORD_XPATH)) {
|
for (Node record : xpath.selectNodes(RECORD_XPATH)) {
|
||||||
records.add(new Record(document, record));
|
list.add(new Record(document, record));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Get the size of the list.
|
|
||||||
*
|
|
||||||
* @return the size
|
|
||||||
*/
|
|
||||||
public int size() {
|
|
||||||
return records.size();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get the records as a list of <code>Records</code>.
|
|
||||||
*
|
|
||||||
* @return a list of records
|
|
||||||
*/
|
|
||||||
public List<Record> asList() {
|
|
||||||
return records;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get the <code>ResumptionToken</code>, if any, for this response.
|
|
||||||
*
|
|
||||||
* @return the <code>ResumptionToken</code>, or <code>null</code>
|
|
||||||
* if none available
|
|
||||||
*/
|
|
||||||
public ResumptionToken getResumptionToken() {
|
|
||||||
if (super.resumptionToken == null
|
|
||||||
|| super.resumptionToken.getId() == null
|
|
||||||
|| super.resumptionToken.getId().length() == 0)
|
|
||||||
return null;
|
|
||||||
|
|
||||||
return super.resumptionToken;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,22 +17,20 @@
|
||||||
package se.kb.oai.pmh;
|
package se.kb.oai.pmh;
|
||||||
|
|
||||||
import java.util.LinkedList;
|
import java.util.LinkedList;
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import org.dom4j.Document;
|
import org.dom4j.Document;
|
||||||
import org.dom4j.Node;
|
import org.dom4j.Node;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Class that represents the response from a <code>ListSets</code> request.
|
* Class that represents the response from a <code>ListSets</code> request.
|
||||||
|
* You can use it to get a list of <code>Sets</code>.
|
||||||
*
|
*
|
||||||
* @author Oskar Grenholm, National Library of Sweden
|
* @author Oskar Grenholm, National Library of Sweden
|
||||||
*/
|
*/
|
||||||
public class SetsList extends ResponseBase {
|
public class SetsList extends ListBase<Set> {
|
||||||
|
|
||||||
private static final String SET_XPATH = "oai:ListSets/oai:set";
|
private static final String SET_XPATH = "oai:ListSets/oai:set";
|
||||||
|
|
||||||
private List<Set> sets;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates an <code>SetsList</code> from the returned response.
|
* Creates an <code>SetsList</code> from the returned response.
|
||||||
*
|
*
|
||||||
|
@ -42,42 +40,9 @@ public class SetsList extends ResponseBase {
|
||||||
public SetsList(Document document) throws ErrorResponseException {
|
public SetsList(Document document) throws ErrorResponseException {
|
||||||
super(document);
|
super(document);
|
||||||
|
|
||||||
this.sets = new LinkedList<Set>();
|
super.list = new LinkedList<Set>();
|
||||||
for (Node set : xpath.selectNodes(SET_XPATH)) {
|
for (Node set : xpath.selectNodes(SET_XPATH)) {
|
||||||
sets.add(new Set(set));
|
list.add(new Set(set));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Get the size of the list.
|
|
||||||
*
|
|
||||||
* @return the size
|
|
||||||
*/
|
|
||||||
public int size() {
|
|
||||||
return sets.size();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get the sets as a list of <code>Sets</code>.
|
|
||||||
*
|
|
||||||
* @return a list of sets
|
|
||||||
*/
|
|
||||||
public List<Set> asList() {
|
|
||||||
return sets;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get the <code>ResumptionToken</code>, if any, for this response.
|
|
||||||
*
|
|
||||||
* @return the <code>ResumptionToken</code>, or <code>null</code>
|
|
||||||
* if none available
|
|
||||||
*/
|
|
||||||
public ResumptionToken getResumptionToken() {
|
|
||||||
if (super.resumptionToken == null
|
|
||||||
|| super.resumptionToken.getId() == null
|
|
||||||
|| super.resumptionToken.getId().length() == 0)
|
|
||||||
return null;
|
|
||||||
|
|
||||||
return super.resumptionToken;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue