-
Notifications
You must be signed in to change notification settings - Fork 3
/
README.Rmd
434 lines (358 loc) · 16.9 KB
/
README.Rmd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
---
title: "deposits"
output:
md_document:
variant: gfm
rmarkdown::html_vignette:
self_contained: no
---
# deposits
<!-- badges: start -->
[![R build status](https://github.com/ropenscilabs/deposits/workflows/R-CMD-check/badge.svg)](https://github.com/ropenscilabs/deposits/actions?query=workflow%3AR-CMD-check)
[![codecov](https://codecov.io/gh/ropenscilabs/deposits/branch/main/graph/badge.svg)](https://codecov.io/gh/ropenscilabs/deposits)
[![Project Status: Concept](https://www.repostatus.org/badges/latest/wip.svg)](https://www.repostatus.org/#wip)
<!-- badges: end -->
The deposits R package is a universal client for depositing and accessing
research data in a variety of online deposition services. Currently supported
services are [zenodo](https://zenodo.org) and [figshare](https://figshare.com).
These two systems have fundamentally different interfaces ("API"s, or
Application Programming Interfaces), and access to these and indeed all
deposition services has traditionally been enabled through individual software
clients. The deposits package aims to be a universal client offering access to
a variety of deposition services, without users having to know any specific
details of the APIs for each service.
The deposits package works seamlessly with [the "frictionless" data
workflow](https://frictionlessdata.io/), to enable unified documentation of all
aspects of datasets in one place. Instructions for installing and setting up
the package are in the [installation
vignette](https://docs.ropensci.org/deposits/articles/install-setup.html). This
README gives a brief overview of package usage, with more detail in the
[introductory
vignette](https://docs.ropensci.org/deposits/articles/deposits.html). For those
who prefer to jump straight in to a workflow, there is also a deposits
[workflow vignette](https://docs.ropensci.org/deposits/articles/workflow.html)
demonstrating a full workflow from data generation and documentation to
publication.
## Installation
The package can be installed by enabling the "ropenscilabs" repository from
[r-universe](https://ropenscilabs.r-universe.dev):
```{r}
options (repos = c (
ropenscilabs = "https://ropenscilabs.r-universe.dev",
CRAN = "https://cloud.r-project.org"
))
```
The `install.packages()` command will then install the development version.
Alternatively, the package can be installed with:
```{r gh-installation, eval = FALSE}
# install.packages("remotes")
remotes::install_github ("mpadge/deposits")
```
The package can then be loaded the usual way:
```{r load-fakey, eval = TRUE}
library (deposits)
```
## Data Repositories
The list of data repositories currently supported is accessible by the
`deposits_services()` function:
```{r services}
library (deposits)
deposits_services ()
```
The [`zenodo`](https://zenodo.org) "sandbox" environment offers an ideal
environment for testing the functionality of this package.
## The "frictionless" data workflow
Prior to describing the deposits workflow, it is useful to understand the
["frictionless" data workflow](https://frictionlessdata.io/), which provides a
standardised way to document the contents and structure of data files through a
separate metadata file. The deposits package links directly with [rOpenSci's
`frictionless` package](https://docs.ropensci.org/frictionless) for writing,
editing, and reading frictionless metadata files.
The deposits package nevertheless aims to make this integration as seamless
and painless as possible. No knowledge of the frictionless workflow is
necessary, and the deposits workflow should "just work" in many cases,
appropriately constructing frictionless metadata files and uploading them to
deposits services. It is of course also possible to use the deposits package
without frictionless metadata.
## The deposits workflow
We now provide a brief overview of the deposits workflow. A more complete
description is given in the [main package
vignette](https://docs.ropensci.org/deposits/articles/deposits.html), and
demonstrated step-by-step in [the workflow
vignette](https://docs.ropensci.org/deposits/articles/workflow.html). The
deposits package uses [the `R6` package](https://github.com/r-lib/R6) to
create [a
`depositsClient`](https://docs.ropensci.org/deposits/reference/depositsClient.html)
used to call all methods needed in a deposits workflow. A [separate
vignette](https://docs.ropensci.org/deposits/articles/deposits-R6.html)
describes the `R6` system for those unfamiliar with it.
A typical deposits workflow, and associated methods, involves the following
steps:
1. Create a new deposits client
2. Fill the client with metadata, either as part of Step 1 through using the
[`new()`
method](https://docs.ropensci.org/deposits/reference/depositsClient.html#method-new-),
or afterward by using the
[`deposit_fill_metadata()`](https://docs.ropensci.org/deposits/reference/depositsClient.html#method-depositsClient-deposit_fill_metadata)
method;
3. Create a new deposit on the nominated service using the
[`deposit_new()`](https://docs.ropensci.org/deposits/reference/depositsClient.html#method-deposit-new-)
method; and
4. Upload files for the deposit using the
[`deposit_upload_file()`](https://docs.ropensci.org/deposits/reference/depositsClient.html#method-deposit-upload-file-)
method.
The following sections describe each of these steps in more detail.
### Step 1: Create a new client
All deposits operations start with a client constructed with the `new()`
function:
```{r client-new, eval = FALSE}
cli <- depositsClient$new (service = "zenodo", sandbox = TRUE)
print (cli)
#> <deposits client>
#> deposits service : zenodo
#> sandbox: TRUE
#> url_base : https://sandbox.zenodo.org/api/
#> Current deposits : <none>
#>
#> hostdata : <none>
#> metadata : <none>
```
The upper section of information shown by calling `print (cli)` to print the
client describes general information, and aspects of the specified service, and
the profile of the user (identified through the locally-stored token, as
described in [the "Installation and Setup"
vignette](https://docs.ropensci.org/deposits/articles/install-setup.html#setup-api-tokens)).
The lower section contains information on the current deposit held within the
client. A new client initially contains no information on a deposit, and so
these lower sections are empty.
The code above demonstrates how `R6` objects work, through calling "methods" or
functions on the main "object" via the `$` symbol. The "new" method must be
called on [a `depositsClient`
object](https://docs.ropensci.org/deposits/reference/depositsClient.html). From
that point on, all other methods are called on that object itself. For example,
the following calls lists all methods implemented by the client:
```{r deposits-methods, eval = FALSE}
cli$deposits_methods ()
#> List of methods for a deposits client:
#>
#> - deposit_add_resource
#> - deposit_delete
#> - deposit_delete_file
#> - deposit_download_file
#> - deposit_embargo
#> - deposit_fill_metadata
#> - deposit_new
#> - deposit_prereserve_doi
#> - deposit_publish
#> - deposit_retrieve
#> - deposit_service
#> - deposit_update
#> - deposit_upload_file
#> - deposit_version
#> - deposits_list
#> - deposits_methods
#> - deposits_search
#>
#> see `?depositsClient` for full details of all methods.
```
All of the methods listed by
[`cli$deposits_methods()`](thos://docs.ropensci.org/deposits/reference/depositsClient.html#method-deposits-methods-)
then work similarly, by calling `cli$<method>(<parameters>)`. Note that R6
functions are called directly on the client, with the object itself (`cli`)
updated by the call. For example, [the `deposit_fill_metadata()`
method](https://docs.ropensci.org/deposits/reference/depositsClient.html#method-deposit-fill-metadata-)
described below can be used to specify metadata for a deposit. This works by
simply calling,
```{r client-fill-return, eval = FALSE}
cli$deposit_fill_metadata (metadata)
```
The `cli` object is then updated by this call, without needing to be assigned
to a return value (so there is no need to use `cli <- cli$<method>`).
### Step 2: Fill client with metadata
The *metadata* of a deposit describe the nature and properties of the data
being deposited. A deposit is first created by uploading metadata to a deposits
service; only then can actual data be uploaded and associated with the deposit
described by the metadata. The deposits package works with two main types of
metadata:
1. Metadata which describe a deposit and associated properties, such as author
names and affiliations, deposit titles and descriptions, dates, keywords,
links to other deposits or publications, and many other terms.
2. Frictionless metadata which describe the actual contents of the data to be
deposited. These kinds of metadata are (optionally) generated and (always)
handled here by [the `frictionless`
package](https://docs.ropensci.org/frictionless).
(Note that there are actually three main types of metadata, as described in the
[introductory
vignette](https://docs.ropensci.org/deposits/articles/deposits.html), but the
third may generally be ignored, and is intended as "read-only" metadata
provided by host services.) As explained at the outset, the deposits package
can be used without knowing or understanding anything about [the `frictionless`
package](https://docs.ropensci.org/frictionless) or [frictionless
workflows](https://frictionlessdata.io). Most of this present section therefore
concerns the first of these two kinds of metadata, referred to throughout all
package documentation as "metadata". Brief demonstrations are also given of the
second kind, to illustrate how the frictionless workflow integrates with the
general deposits workflow. These kinds of metadata are always referred to as
"frictionless metadata."
A separate vignette describes in detail [how to specify and include metadata in
a deposits
client](https://docs.ropensci.org/deposits/articles/metadata.html). This
section briefly demonstrates the process. An example of deposits metadata is:
```{r metadata}
metadata <- list (
title = "New Title",
abstract = "This is the abstract",
creator = list (list (name = "A. Person"), list (name = "B. Person"))
)
```
The "creator" field is a list-of-lists, to allow individual creator entries to
have multiple fields in addition to "name". These data can be used in
construction of a new client by passing a `metadata` argument:
```{r client-new-metadata, eval = FALSE}
cli <- depositsClient$new (
service = "zenodo",
sandbox = TRUE,
metadata = metadata
)
print (cli)
#> <deposits client>
#> deposits service : zenodo
#> sandbox: TRUE
#> url_base : https://sandbox.zenodo.org/api/
#> Current deposits : <none>
#>
#> hostdata : <none>
#> metadata : 3 terms (see 'metadata' element for details)
```
The "metadata" component of the client now holds 3 terms. Equivalently,
metadata can be added to an existing client with [the `deposit_fill_metadata()`
function](https://docs.ropensci.org/deposits/reference/depositsClient.html#method-depositsClient-deposit_fill_metadata):
```{r client-fill-metadata, eval = FALSE}
cli <- depositsClient$new (service = "zenodo", sandbox = TRUE)
cli$deposit_fill_metadata (metadata)
```
At that stage, the metadata are only associated with the local client. The
following section describes how to use those metadata to initiate a deposit on
an external service.
### Step 3: Create a new deposit
The metadata filled with the above steps can then be used to initiate a new
deposit on the associated server using [the `deposit_new()`
method](https://docs.ropensci.org/deposits/reference/depositsClient.html#method-deposit-new-).
```{r deposit_new, eval = FALSE}
cli$deposit_new ()
#> ID of new deposit : 1065666
print (cli)
#> <deposits client>
#> deposits service : zenodo
#> sandbox: TRUE
#> url_base : https://sandbox.zenodo.org/api/
#> Current deposits : <none>
#>
#> url_service : https://sandbox.zenodo.org/deposit/1065666
#> deposit id : 1065666
#> hostdata : list with 14 elements
#> metadata : 4 terms (see 'metadata' element for details)
```
The client now includes several additional elements, notably a "deposit id"
(stored in `cli$id`) giving the unique identifier for the new deposit, and a
"hostdata" item with, in this case, 14 elements as specified by the host
service. The `url_service` is the URL for the newly-created deposit. (Viewing
in a web browser will require logging in for all private and sandbox deposits).
The "metadata" item also includes an additional "identifier" element containing
a pre-reserved DOI provided by the deposits service.
### Step 4: Upload (or download) files
A deposit is really about data, not just metadata. Data can be uploaded to a deposit
with [the `deposit_upload_file()`
method](https://docs.ropensci.org/deposits/reference/depositsClient.html#method-deposit-upload-file-):
```{r deposit_upload, eval = FALSE}
cli$deposit_upload_file (path = "<path>/<to>/my-data.dat")
```
Details of files associated with deposits are stored in a `data.frame` stored
as part of the "hostdata" of a deposits client, in the `cli$hostdata$files`
item. Prior to uploading, `cli$hostdata$files` will be empty, but after
uploading it will be a `data.frame` including one row with an item whose
"filename" will be "my-data.dat".
```{r uploaded-files, eval = FALSE}
cli$hostdata$files
#> checksum filename filesize
#> 1 5955bb96a8fee3bc89549bde9ef9b470 my-data.dat 829
#> id
#> 1 618ae9b9-af48-4b86-aa37-7b4e767dccb7
#> links.download
#> 1 https://sandbox.zenodo.org/api/files/<file-hash>/my-data.dat
#> links.self
#> 1 https://sandbox.zenodo.org/api/deposit/depositions/1065666/files/<hash>
```
The `deposit_download_file()` function does the reverse:
```{r deposit_download, eval = FALSE}
cli$deposit_download_file ("my-data.dat")
#> '/<loca>/<directory>/my-data.dat'
```
Files are by default downloaded to the current working directory, or elsewhere
specified by an additional `path` parameter. (Note that this method returns the
full local path to the downloaded file, unlike most methods for deposit
clients, which invisibly return an updated version of the client.)
## Code of Conduct
Please note that this package is released with a [Contributor Code of
Conduct](https://ropensci.org/code-of-conduct/). By contributing to this
project, you agree to abide by its terms.
## Contributors
<!-- ALL-CONTRIBUTORS-LIST:START - Do not remove or modify this section -->
<!-- prettier-ignore-start -->
<!-- markdownlint-disable -->
All contributions to this project are gratefully acknowledged using the [`allcontributors` package](https://github.com/ropenscilabs/allcontributors) following the [all-contributors](https://allcontributors.org) specification. Contributions of any kind are welcome!
### Code
<table>
<tr>
<td align="center">
<a href="https://github.com/mpadge">
<img src="https://avatars.githubusercontent.com/u/6697851?v=4" width="100px;" alt=""/>
</a><br>
<a href="https://github.com/ropenscilabs/deposits/commits?author=mpadge">mpadge</a>
</td>
</tr>
</table>
### Issues
<table>
<tr>
<td align="center">
<a href="https://github.com/collinschwantes">
<img src="https://avatars.githubusercontent.com/u/6107885?u=414bad1b3dd9499b3dc60180fc411f1fb18de24e&v=4" width="100px;" alt=""/>
</a><br>
<a href="https://github.com/ropenscilabs/deposits/issues?q=is%3Aissue+author%3Acollinschwantes">collinschwantes</a>
</td>
<td align="center">
<a href="https://github.com/Bisaloo">
<img src="https://avatars.githubusercontent.com/u/10783929?u=38e3754466eaa200e20f0609709467b6331cdfbe&v=4" width="100px;" alt=""/>
</a><br>
<a href="https://github.com/ropenscilabs/deposits/issues?q=is%3Aissue+author%3ABisaloo">Bisaloo</a>
</td>
<td align="center">
<a href="https://github.com/maelle">
<img src="https://avatars.githubusercontent.com/u/8360597?u=824f03caa87c92420352e3dd9a05470320a67412&v=4" width="100px;" alt=""/>
</a><br>
<a href="https://github.com/ropenscilabs/deposits/issues?q=is%3Aissue+author%3Amaelle">maelle</a>
</td>
<td align="center">
<a href="https://github.com/joelnitta">
<img src="https://avatars.githubusercontent.com/u/13459362?v=4" width="100px;" alt=""/>
</a><br>
<a href="https://github.com/ropenscilabs/deposits/issues?q=is%3Aissue+author%3Ajoelnitta">joelnitta</a>
</td>
<td align="center">
<a href="https://github.com/noamross">
<img src="https://avatars.githubusercontent.com/u/571752?v=4" width="100px;" alt=""/>
</a><br>
<a href="https://github.com/ropenscilabs/deposits/issues?q=is%3Aissue+author%3Anoamross">noamross</a>
</td>
<td align="center">
<a href="https://github.com/peterdesmet">
<img src="https://avatars.githubusercontent.com/u/600993?v=4" width="100px;" alt=""/>
</a><br>
<a href="https://github.com/ropenscilabs/deposits/issues?q=is%3Aissue+author%3Apeterdesmet">peterdesmet</a>
</td>
</tr>
</table>
<!-- markdownlint-enable -->
<!-- prettier-ignore-end -->
<!-- ALL-CONTRIBUTORS-LIST:END -->