Package nl.knaw.dans.lib.dataverse
Class DatasetApi
java.lang.Object
nl.knaw.dans.lib.dataverse.DatasetApi
API end-points dealing with a single dataset.
- See Also:
-
Field Summary
-
Method Summary
Modifier and TypeMethodDescriptionassignRole
(String roleAssignment) assignRole
(RoleAssignment roleAssignment) void
The same asawaitLock(String, int, int)
but with defaults for number of tries and time between tries.void
Utility function that lets you wait until a specified lock type is set.void
awaitState
(String expectedState, long timeout, long pollingInterval) Waits for the dataset to reach the expected state.void
The samevoid
awaitUnlock
(int maxNumberOfRetries, int waitTimeInMilliseconds) Utility function that lets you wait until all locks are cleared before proceeding.protected Path
deleteMetadata
(String s, Map<String, String> metadataKeys) deleteMetadata
(FieldList fields, Map<String, String> metadataKeys) deleteRoleAssignment
(int roleAssignmentId) Edits the current draft's metadata, adding the fields that do not exist yet.editMetadata
(String s, Boolean replace) Edits the current draft's metadata, adding the fields that do not exist yet.Edits the current draft's metadata, adding the fields that do not exist yet.editMetadata
(String s, Map<String, String> metadataKeys) Edits the current draft's metadata, adding the fields that do not exist yet.editMetadata
(FieldList fields) Edits the current draft's metadata, adding the fields that do not exist yet.editMetadata
(FieldList fields, Boolean replace) Edits the current draft's metadata, adding the fields that do not exist yet.Edits the current draft's metadata, adding the fields that do not exist yet.editMetadata
(FieldList fields, Map<String, String> metadataKeys) Edits the current draft's metadata, adding the fields that do not exist yet.Deprecated.getLocks()
getQueryParamsFromMetadataKeys
(Map<String, String> metadataKeys) getState()
Returns the state of the latest version of the dataset that is visible to the user.Retrieves that latest version of a dataset that you can see with your permissions.getVersion
(@NonNull String version, boolean excludeFiles) getVersion
(String version) Retrieves a specific version of a dataset if you can see it with your permissions, otherwise returns a 401.publish()
publish
(UpdateType updateType, boolean assureIsIndexed) releaseMigrated
(String publicationDateJsonLd, boolean assureIsIndexed) setEmbargo
(String json) setEmbargo
(Embargo embargo) setRetentionPeriod
(String json) setRetentionPeriod
(RetentionPeriod retentionPeriod) protected Path
toString()
updateMetadata
(String s, Map<String, String> metadataKeys) updateMetadata
(DatasetVersion version) Note that not all the attributes of the DatasetVersion object are writable.updateMetadata
(DatasetVersion version, Map<String, String> metadataKeys) updateMetadataFromJsonLd
(String metadata, boolean replace) updateMetadataFromJsonLd
(String metadata, boolean replace, Map<String, String> metadataKeys) protected Path
versionedSubPath
(String endPoint, String version)
-
Field Details
-
persistendId
- See Also:
-
publish
- See Also:
-
invocationIdHeaderName
- See Also:
-
targetBase
-
id
-
isPersistentId
protected final boolean isPersistentId -
extraHeaders
-
MDKEY_PARAM_NAME_PREFIX
- See Also:
-
httpClientWrapper
protected final nl.knaw.dans.lib.dataverse.HttpClientWrapper httpClientWrapper
-
-
Method Details
-
toString
-
getLatestVersion
public DataverseHttpResponse<DatasetLatestVersion> getLatestVersion() throws IOException, DataverseExceptionDeprecated.usegetVersion()
insteadReturns metadata of the latest version of the dataset that you can see with your permissions. If there is a draft for a new version this is returned in the fieldlatestVersionPublishingState
. The use of this method is not recommended, as thegetVersion(String)
method is more explicit and you can retrieve the latest version by passing eitherVersion.LATEST
,Version.DRAFT
orVersion.LATEST_PUBLISHED
as the version parameter.- Returns:
- a JSON object that starts at the dataset level, most fields are replicated at the dataset version level.
- Throws:
IOException
- when I/O problems occur during the interaction with DataverseDataverseException
- when Dataverse fails to perform the request- See Also:
-
getVersion
Retrieves that latest version of a dataset that you can see with your permissions. The difference withgetLatestVersion()
is that the latter returns a different type of object. The use ofgetLatestVersion()
is not recommended, asgetVersion(String)
gives you more control over the version you want to retrieve.- Returns:
- object containing the dataset version metadata
- Throws:
IOException
- when I/O problems occur during the interaction with DataverseDataverseException
- when Dataverse fails to perform the request- See Also:
-
getVersion
public DataverseHttpResponse<DatasetVersion> getVersion(String version) throws IOException, DataverseException Retrieves a specific version of a dataset if you can see it with your permissions, otherwise returns a 401.- Parameters:
version
- version to retrieve- Returns:
- object containing the dataset version metadata
- Throws:
IOException
- when I/O problems occur during the interaction with DataverseDataverseException
- when Dataverse fails to perform the request- See Also:
-
getVersion
public DataverseHttpResponse<DatasetVersion> getVersion(@NonNull @NonNull String version, boolean excludeFiles) throws IOException, DataverseException - Parameters:
version
- version to retrieveexcludeFiles
- whether to exclude file metadata from the response- Returns:
- object containing the dataset version metadata
- Throws:
IOException
- when I/O problems occur during the interaction with DataverseDataverseException
- when Dataverse fails to perform the request
-
getAllVersions
public DataverseHttpResponse<List<DatasetVersion>> getAllVersions() throws IOException, DataverseException- Returns:
- list of objects containing dataset version metadata
- Throws:
IOException
- when I/O problems occur during the interaction with DataverseDataverseException
- when Dataverse fails to perform the request- See Also:
-
getFiles
public DataverseHttpResponse<List<FileMeta>> getFiles(String version) throws IOException, DataverseException - Parameters:
version
- version to get file metadata from- Returns:
- a list of file metas
- Throws:
IOException
- when I/O problems occur during the interaction with DataverseDataverseException
- when Dataverse fails to perform the request- See Also:
-
publish
public DataverseHttpResponse<DatasetPublicationResult> publish() throws IOException, DataverseException- Returns:
- dataset publication result
- Throws:
IOException
- when I/O problems occur during the interaction with DataverseDataverseException
- when Dataverse fails to perform the request- See Also:
-
publish
public DataverseHttpResponse<DataMessage> publish(UpdateType updateType, boolean assureIsIndexed) throws IOException, DataverseException - Parameters:
updateType
- major or minor version updateassureIsIndexed
- To make sure that indexing has already happened the `assureIsIndexed` is set to `true`, it will then cause Dataverse to fail fast if indexing is still pending. In this case the publish request will be retried a number of times.- Returns:
- dataset publication result
- Throws:
IOException
- when I/O problems occur during the interaction with DataverseDataverseException
- when Dataverse fails to perform the request- See Also:
-
releaseMigrated
public DataverseHttpResponse<DatasetPublicationResult> releaseMigrated(String publicationDateJsonLd, boolean assureIsIndexed) throws IOException, DataverseException - Throws:
IOException
DataverseException
-
editMetadata
public DataverseHttpResponse<DatasetVersion> editMetadata(String s) throws IOException, DataverseException Edits the current draft's metadata, adding the fields that do not exist yet. If `replace` is set to `false`, all specified fields must be either currently empty or allow multiple values.- Parameters:
s
- JSON document containing the edits to perform- Returns:
- DatasetVersion
- Throws:
IOException
- when I/O problems occur during the interaction with DataverseDataverseException
- when Dataverse fails to perform the request- See Also:
-
editMetadata
public DataverseHttpResponse<DatasetVersion> editMetadata(String s, Map<String, String> metadataKeys) throws IOException, DataverseExceptionEdits the current draft's metadata, adding the fields that do not exist yet. If `replace` is set to `false`, all specified fields must be either currently empty or allow multiple values.- Parameters:
s
- JSON document containing the edits to performmetadataKeys
- the HashMap maps the names of the metadata blocks to their 'secret' key values.- Returns:
- DatasetVersion
- Throws:
IOException
- when I/O problems occur during the interaction with DataverseDataverseException
- when Dataverse fails to perform the request- See Also:
-
editMetadata
public DataverseHttpResponse<DatasetVersion> editMetadata(String s, Boolean replace) throws IOException, DataverseException Edits the current draft's metadata, adding the fields that do not exist yet. If `replace` is set to `false`, all specified fields must be either currently empty or allow multiple values.- Parameters:
s
- JSON document containing the edits to performreplace
- whether to replace existing values- Returns:
- DatasetVersion
- Throws:
IOException
- when I/O problems occur during the interaction with DataverseDataverseException
- when Dataverse fails to perform the request- See Also:
-
editMetadata
public DataverseHttpResponse<DatasetVersion> editMetadata(String s, Boolean replace, Map<String, String> metadataKeys) throws IOException, DataverseExceptionEdits the current draft's metadata, adding the fields that do not exist yet. If `replace` is set to `false`, all specified fields must be either currently empty or allow multiple values. Whenever there are metadata field from a block that is protected by a 'key', the corresponding keys must be provided.- Parameters:
s
- JSON document containing the edits to performreplace
- whether to replace existing valuesmetadataKeys
- the HashMap maps the names of the metadata blocks to their 'secret' key values.- Returns:
- DatasetVersion
- Throws:
IOException
- when I/O problems occur during the interaction with DataverseDataverseException
- when Dataverse fails to perform the request- See Also:
-
editMetadata
public DataverseHttpResponse<DatasetVersion> editMetadata(FieldList fields, Boolean replace) throws IOException, DataverseException Edits the current draft's metadata, adding the fields that do not exist yet. If `replace` is set to `false`, all specified fields must be either currently empty or allow multiple values.- Parameters:
fields
- list of fields to editreplace
- whether to replace existing values- Returns:
- DatasetVersion
- Throws:
IOException
- when I/O problems occur during the interaction with DataverseDataverseException
- when Dataverse fails to perform the request- See Also:
-
editMetadata
public DataverseHttpResponse<DatasetVersion> editMetadata(FieldList fields, Boolean replace, Map<String, String> metadataKeys) throws IOException, DataverseExceptionEdits the current draft's metadata, adding the fields that do not exist yet. If `replace` is set to `false`, all specified fields must be either currently empty or allow multiple values.- Parameters:
fields
- list of fields to editreplace
- whether to replace existing valuesmetadataKeys
- the HashMap maps the names of the metadata blocks to their 'secret' key values.- Returns:
- DatasetVersion
- Throws:
IOException
- when I/O problems occur during the interaction with DataverseDataverseException
- when Dataverse fails to perform the request- See Also:
-
editMetadata
public DataverseHttpResponse<DatasetVersion> editMetadata(FieldList fields) throws IOException, DataverseException Edits the current draft's metadata, adding the fields that do not exist yet.- Parameters:
fields
- list of fields to edit- Returns:
- DatasetVersion
- Throws:
IOException
- when I/O problems occur during the interaction with DataverseDataverseException
- when Dataverse fails to perform the request- See Also:
-
editMetadata
public DataverseHttpResponse<DatasetVersion> editMetadata(FieldList fields, Map<String, String> metadataKeys) throws IOException, DataverseExceptionEdits the current draft's metadata, adding the fields that do not exist yet.- Parameters:
fields
- list of fields to editmetadataKeys
- the HashMap maps the names of the metadata blocks to their 'secret' key values.- Returns:
- DatasetVersion
- Throws:
IOException
- when I/O problems occur during the interaction with DataverseDataverseException
- when Dataverse fails to perform the request- See Also:
-
deleteMetadata
public DataverseHttpResponse<DatasetVersion> deleteMetadata(FieldList fields, Map<String, String> metadataKeys) throws IOException, DataverseException- Throws:
IOException
DataverseException
-
deleteMetadata
public DataverseHttpResponse<DatasetVersion> deleteMetadata(String s, Map<String, String> metadataKeys) throws IOException, DataverseException- Throws:
IOException
DataverseException
-
updateMetadataFromJsonLd
public DataverseHttpResponse<Object> updateMetadataFromJsonLd(String metadata, boolean replace) throws IOException, DataverseException - Parameters:
metadata
- JSON document describing the metadatareplace
- replace existing metadata- Returns:
- a generic DataverseHttpResponse
- Throws:
IOException
- when I/O problems occur during the interaction with DataverseDataverseException
- when Dataverse fails to perform the request- See Also:
-
updateMetadataFromJsonLd
public DataverseHttpResponse<Object> updateMetadataFromJsonLd(String metadata, boolean replace, Map<String, String> metadataKeys) throws IOException, DataverseException- Parameters:
metadata
- JSON document describing the metadatareplace
- replace existing metadatametadataKeys
- maps the names of the metadata blocks to their 'secret' key values- Returns:
- a generic DataverseResponse
- Throws:
IOException
- when I/O problems occur during the interaction with DataverseDataverseException
- when Dataverse fails to perform the request- See Also:
-
updateMetadata
public DataverseHttpResponse<DatasetVersion> updateMetadata(String s) throws IOException, DataverseException - Parameters:
s
- JSON document containing the new metadata- Returns:
- DatasetVersion
- Throws:
IOException
- when I/O problems occur during the interaction with DataverseDataverseException
- when Dataverse fails to perform the request- See Also:
-
updateMetadata
public DataverseHttpResponse<DatasetVersion> updateMetadata(String s, Map<String, String> metadataKeys) throws IOException, DataverseException- Parameters:
s
- JSON document containing the new metadatametadataKeys
- maps the names of the metadata blocks to their 'secret' key values- Returns:
- DatasetVersion
- Throws:
IOException
- when I/O problems occur during the interaction with DataverseDataverseException
- when Dataverse fails to perform the request- See Also:
-
updateMetadata
public DataverseHttpResponse<DatasetVersion> updateMetadata(DatasetVersion version) throws IOException, DataverseException Note that not all the attributes of the DatasetVersion object are writable. Dataverse may ignore some (e.g., license) or return an error if some are filled in (e.g., files). However, for a few attributes, such as fileAccessRequest and termsOfAccess, it is necessary to pass the whole version object instead of only the metadata blocks (as is done in the example of the API documentation).- Parameters:
version
- a version object containing the new metadata- Returns:
- DatasetVersion
- Throws:
IOException
- when I/O problems occur during the interaction with DataverseDataverseException
- when Dataverse fails to perform the request- See Also:
-
updateMetadata
public DataverseHttpResponse<DatasetVersion> updateMetadata(DatasetVersion version, Map<String, String> metadataKeys) throws IOException, DataverseException- Parameters:
version
- a version object containing the new metadatametadataKeys
- maps the names of the metadata blocks to their 'secret' key values- Returns:
- DatasetVersion
- Throws:
IOException
- when I/O problems occur during the interaction with DataverseDataverseException
- when Dataverse fails to perform the request- See Also:
-
deleteDraft
- Returns:
- a data message
- Throws:
IOException
- when I/O problems occur during the interaction with DataverseDataverseException
- when Dataverse fails to perform the request- See Also:
-
listRoleAssignments
public DataverseHttpResponse<List<RoleAssignmentReadOnly>> listRoleAssignments() throws IOException, DataverseException- Returns:
- role assignment information
- Throws:
IOException
- when I/O problems occur during the interaction with DataverseDataverseException
- when Dataverse fails to perform the request- See Also:
-
assignRole
public DataverseHttpResponse<RoleAssignmentReadOnly> assignRole(String roleAssignment) throws IOException, DataverseException - Parameters:
roleAssignment
- JSON document describing the assignment- Returns:
- role assignment information
- Throws:
IOException
- when I/O problems occur during the interaction with DataverseDataverseException
- when Dataverse fails to perform the request- See Also:
-
assignRole
public DataverseHttpResponse<RoleAssignmentReadOnly> assignRole(RoleAssignment roleAssignment) throws IOException, DataverseException - Throws:
IOException
DataverseException
-
deleteRoleAssignment
public DataverseHttpResponse<DataMessage> deleteRoleAssignment(int roleAssignmentId) throws IOException, DataverseException - Parameters:
roleAssignmentId
- Delete the assignment with this id- Returns:
- A data information message
- Throws:
IOException
- when I/O problems occur during the interaction with DataverseDataverseException
- when Dataverse fails to perform the request- See Also:
-
addFile
public DataverseHttpResponse<FileList> addFile(Path file, String metadata) throws IOException, DataverseException - Parameters:
file
- the file to addmetadata
- json document with the file metadata- Returns:
- a file list
- Throws:
IOException
- when I/O problems occur during the interaction with DataverseDataverseException
- when Dataverse fails to perform the request- See Also:
-
addFile
public DataverseHttpResponse<FileList> addFile(Path file, FileMeta fileMeta) throws IOException, DataverseException - Parameters:
file
- the file to addfileMeta
- json document with the file metadata- Returns:
- a file list
- Throws:
IOException
- when I/O problems occur during the interaction with DataverseDataverseException
- when Dataverse fails to perform the request- See Also:
-
submitForReview
public DataverseHttpResponse<SubmitForReviewResult> submitForReview() throws IOException, DataverseException- Returns:
- todo
- Throws:
IOException
- when I/O problems occur during the interaction with DataverseDataverseException
- when Dataverse fails to perform the request- See Also:
-
setEmbargo
public DataverseHttpResponse<HashMap> setEmbargo(Embargo embargo) throws IOException, DataverseException - Parameters:
embargo
- the embargo data- Returns:
- a hash map
- Throws:
IOException
- when I/O problems occur during the interaction with DataverseDataverseException
- when Dataverse fails to perform the request- See Also:
-
setEmbargo
public DataverseHttpResponse<HashMap> setEmbargo(String json) throws IOException, DataverseException - Throws:
IOException
DataverseException
-
setRetentionPeriod
public DataverseHttpResponse<HashMap> setRetentionPeriod(RetentionPeriod retentionPeriod) throws IOException, DataverseException - Parameters:
retentionPeriod
- the retention period data- Returns:
- a hash map
- Throws:
IOException
- when I/O problems occur during the interaction with DataverseDataverseException
- when Dataverse fails to perform the request
-
setRetentionPeriod
public DataverseHttpResponse<HashMap> setRetentionPeriod(String json) throws IOException, DataverseException - Throws:
IOException
DataverseException
-
getLocks
- Returns:
- a list of locks
- Throws:
IOException
- when I/O problems occur during the interaction with DataverseDataverseException
- when Dataverse fails to perform the request- See Also:
-
awaitUnlock
public void awaitUnlock(int maxNumberOfRetries, int waitTimeInMilliseconds) throws IOException, DataverseException Utility function that lets you wait until all locks are cleared before proceeding. Unlike most other functions in this library, this does not correspond directly with an API call. Rather thegetLocks()
call is done repeatedly to check if the locks have been cleared. Note that in scenarios where concurrent processes might access the same dataset it is not guaranteed that the locks, once cleared, stay that way.- Parameters:
maxNumberOfRetries
- the maximum number the check for unlock is made, defaults to [[awaitLockStateMaxNumberOfRetries]]waitTimeInMilliseconds
- the time between tries, defaults to [[awaitLockStateMillisecondsBetweenRetries]]- Throws:
IOException
- when I/O problems occur during the interaction with DataverseDataverseException
- when Dataverse fails to perform the request
-
awaitUnlock
The same- Throws:
IOException
- when I/O problems occur during the interaction with DataverseDataverseException
- when Dataverse fails to perform the request
-
awaitLock
public void awaitLock(String lockType, int maxNumberOfRetries, int waitTimeInMilliseconds) throws IOException, DataverseException Utility function that lets you wait until a specified lock type is set. Unlike most other functions in this library, this does not correspond directly with an API call. Rather thegetLocks()
call is done repeatedly to check if the locks has been set. A use case is when an http/sr workflow wants to make sure that a dataset has been locked on its behalf, so that it can be sure to have exclusive access via its invocation ID.- Parameters:
lockType
- the lock type to wait formaxNumberOfRetries
- the maximum number the check for unlock is made, defaults to #awawaitLockStateMaxNumberOfRetrieswaitTimeInMilliseconds
- the time between tries, defaults to [[awaitLockStateMillisecondsBetweenRetries]]- Throws:
IOException
- when I/O problems occur during the interaction with DataverseDataverseException
- when Dataverse fails to perform the request
-
awaitLock
The same asawaitLock(String, int, int)
but with defaults for number of tries and time between tries.- Parameters:
lockType
- the lock type to wait for- Throws:
IOException
- when I/O problems occur during the interaction with DataverseDataverseException
- when Dataverse fails to perform the request
-
awaitState
public void awaitState(String expectedState, long timeout, long pollingInterval) throws IOException, DataverseException Waits for the dataset to reach the expected state. This is useful when you want to wait for a dataset to be published, for example.- Parameters:
expectedState
- the state to wait for (e.g. "RELEASED")pollingInterval
- the time to wait between checkstimeout
- the maximum time to wait- Throws:
IOException
- if there is a problem with the HTTP requestDataverseException
- if Dataverse returns an error
-
getState
Returns the state of the latest version of the dataset that is visible to the user.- Returns:
- the state of the dataset
- Throws:
IOException
- if there is a problem with the HTTP requestDataverseException
- if Dataverse returns an error
-
params
-
subPath
-
versionedSubPath
-
buildPath
-
getQueryParamsFromMetadataKeys
-
getVersion()
instead