-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathep3apidDocs.go
469 lines (377 loc) · 25.4 KB
/
ep3apidDocs.go
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
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
package eprinttools
import (
"fmt"
)
//
// End point documentation
//
func readmeDocument() string {
return `
USAGE
=====
ep3apid [OPTIONS] [SETTINGS_FILENAME]
SYNOPSIS
--------
Run an extended EPrints 3.x web API based on direct manipulation
of EPrint's MySQL database(s).
DETAIL
------
__ep3apid__ can be run from the command line and the will create an http web service. The web service provides a limitted number of end points providing eprint ids for content matched in EPrints's MySQL databases. You can configure it to provide read/write support to and from the MySQL databases used by EPrints.
The following URL end points are intended to take one unique identifier and map that to one or more EPrint IDs. This can be done because each unique ID targeted can be identified by querying a single table in EPrints. In addition the scan can return the complete results since all EPrint IDs are integers and returning all EPrint IDs in any of our repositories is sufficiently small to be returned in a single HTTP request.
Configuration information
-------------------------
There are two end points that give you information about what repositories are configured in for __ep3apid__ and what the database structure (tables and column names) for each configure repository.
- '/repositores' - returns a list of repositories configured for access by __ep3apid__
- '/repository/{REPO_ID}' returns the databases and columns of the repository indicated by "{REPO_ID}".
Unique ID to EPrint ID
----------------------
Unique ids maybe standards based (e.g. ORCID, DOI, ISSN, ISBN) or internal (e.g. group ids, funder ids)
- '/{REPO_ID}/doi/{DOI}' with the adoption of EPrints "doi" field in the EPrint table it makes sense to have a quick translation of DOI to EPrint id for a given EPrints repository.
- '/{REPO_ID}/pmid/{PMID}' with the "pmid" field in the EPrint table, it refers to PubMed is an index of the biomedical literature.
- '/{REPO_ID}/pmcid/{PMCID}' with the "pmcid" field in the EPrint table, PMCID an Identifier to each full-text paper in PubMed Central Archive
- '/{REPO_ID}/creator-id' returns a list of creaator-id available in the eprints repository
- '/{REPO_ID}/creator-id/{CREATOR_ID}' scans the name creator id field associated with creators and returns a list of EPrint ID
- '/{REPO_ID}/creator-name' returns a list of creator names (family, given) in repository
- '/{REPO_ID}/creator-name/{FAMILY}/{GIVEN}' returns a list of EPrint ID for the given creator using their family and given names
- '/{REPO_ID}/creator-orcid' return a list of "orcid" associated with creators in repository
- '/{REPO_ID}/creator-orcid/{ORCID}' scans the "orcid" field associated with creators and returns a list of EPrint ID
- '/{REPO_ID}/editor-id' returns a list of editor ids available in the EPrints repository
- '/{REPO_ID}/editor-id/{CREATOR_ID}' scans the name creator id field associated with editors and returns a list of EPrint ID
- '/{REPO_ID}/editor-name' returns a list of editor names (family, given) in repository
- '/{REPO_ID}/editor-name/{FAMILY}/{GIVEN}' returns a list of EPrint ID for the given editor using their family and given names
- '/{REPO_ID}/contributor-id' returns a list of contributor ids available in the eprints repository
- '/{REPO_ID}/contributor-id/{CONTRIBUTOR_ID}' scans the "id" field associated with a contributors and returns a list of EPrint ID
- '/{REPO_ID}/contributor-name' returns a list of contributor names (family, given) in repository
- '/{REPO_ID}/contributor-name/{FAMILY}/{GIVEN}' returns a list of EPrint ID for the given contributor using their family and given names
- '/{REPO_ID}/advisor-id' returns a list of advisor ids in the eprints repository
- '/{REPO_ID}/advisor-id/{ADVISOR_ID}' scans the name advisor id field associated with advisors and returns a list of EPrint ID
- '/{REPO_ID}/advisor-name' returns a list of advisor names (family, given) in repository
- '/{REPO_ID}/advisor-name/{FAMILY}/{GIVEN}' returns a list of EPrint ID for the given advisor using their family and given names
- '/{REPO_ID}/committee-id' returns a list of committee id in EPrints repository
- '/{REPO_ID}/committee-id/{COMMITTEE_ID}' scans the committee id field associated with committee members and returns a list of EPrint ID
- '/{REPO_ID}/committee-name' returns a list of committee members names (family, given) in repository
- '/{REPO_ID}/committee-name/{FAMILY}/{GIVEN}' returns a list of EPrint ID for the given committee member using their family and given names
- '/{REPO_ID}/corp-creator-id' returns a list of corp creator ids in the eprints repository
- '/{REPO_ID}/corp-creator-id/{CORP_CREATOR_ID}' returns the list of eprint id for the corporate creator id
- '/{REPO_ID}/corp-creator-uri' returns a list of corp creator uri in the eprints repository
- '/{REPO_ID}/corp-creator-uri/{CORP_CREATOR_URI}' returns the list of eprint id for the corporate creator's URI
- '/{REPO_ID}/group-id' returns a list of group ids in EPrints repository
- '/{REPO_ID}/group-id/{GROUP_ID}' this scans group ID and returns a list of EPrint IDs associated with the group
- '/{REPO_ID}/funder-id' returns a list of funders in the EPrints repository
- '/{REPO_ID}/funder-id/{FUNDER_ID}' returns a list of EPrint IDs associated with the funder
- '/{REPO_ID}/grant-number' returns a list of grant numbers in EPrints repository
- '/{REPO_ID}/grant-number/{GRANT_NUMBER}' returns a list of EPrint IDs associated with the grant number
- '/{REPO_ID}/issn' - returns a list of ISSN in repository
- '/{REPO_ID}/issn/{ISSN}' - returns a list eprint id for ISSN in repository
- '/{REPO_ID}/isbn' - returns a list of ISBN in repository
- '/{REPO_ID}/isbn/{ISBN}' - returns a list eprint id for ISBN in repository
- '/{REPO_ID}/patent-number' - return a list of patent numbers in repository
- '/{REPO_ID}/patent-number/{PATENT_NUMBER}' - return a list eprint ids for patent number in repository
- '/{REPO_ID}/patent-applicant' - return a list of patent applicants in repository
- '/{REPO_ID}/patent-applicant/{PATENT_APPLICANT}' - return a list eprint ids for patent applicant in repository
- '/{REPO_ID}/patent-classification' - return a list of patent classificatins in repository
- '/{REPO_ID}/patent-classification/{PATENT_CLASSIFICATION}' - return a list eprint ids for patent classification in repository
- '/{REPO_ID}/patent-assignee' - return a list of patent assignee in repository
- '/{REPO_ID}/patent-assignee/{PATENT_ASSIGNEE}' - return a list eprint ids for patent assignee in repository
- '/{REPO_ID}/year' - return a descending list of years containing record with a date type of "published".
- '/{REPO_ID}/year/{YEAR}' - return a list of eprintid for a given year contaning date type of "published".
Change Events
-------------
The follow API end points would facilitate faster updates to our feeds platform as well as allow us to create a separate public view of our EPrint repository content.
- '/{REPO_ID}/keys' returns complete list of EPrint ID in the repository
- '/{REPO_ID}/updated/{TIMESTAMP}/{TIMESTAMP}' returns a list of EPrint IDs updated starting at the first timestamp (timestamps should have a resolution to the minute, e.g. "YYYY-MM-DD HH:MM:SS") through inclusive of the second timestmap (if the second is omitted the timestamp is assumed to be "now")
- '/{REPO_ID}/deleted/{TIMESTAMP}/{TIMESTAMP}' through the returns a list of EPrint IDs deleted starting at first timestamp through inclusive of the second timestamp, if the second timestamp is omitted it is assumed to be "now"
- '/{REPO_ID}/pubdate/{APROX_DATESTAMP}/{APPOX_DATESTMP}' this query scans the EPrint table for records with publication starts starting with the first approximate date through inclusive of the second approximate date. If the second date is omitted it is assumed to be "today". Approximate dates my be expressed just the year (starting with Jan 1, ending with Dec 31), just the year and month (starting with first day of month ending with the last day) or year, month and day. The end returns zero or more EPrint IDs.
Read/Write API
--------------
As of __ep3apid__ version 1.0.3 a new set of end points exists for reading (retreiving EPrints XML) and writing (metadata import) of EPrints XML. The extended API only supports working with EPrints metadata not directly with the documents or files associated with individual records.
The metadata import functionality is enabled per repository. It only supports importing records at this time. Importing an EPrint XML document, which could containing multiple EPrint metadata records, is implemented purely using SQL statements and not the EPrints Perl API. This allows you (with the right MySQL configuration) to run the extended API on a different server without resorting to Perl.
- '/{REPO_ID}/eprint/{EPRINT_ID}' method GET with a content type of "application/json" (JSON of EPrint XML) or "application/xml" for EPrint XML
- '/{REPO_ID}/eprint-import/{USER_ID}' POST accepts EPrints XML with content type of "application/xml" or JSON of EPrints XML with content type "application/json". To enable this feature add the attribute '"write": true' to the repositories setting in settins.json. The {USER_ID} is required and this is used to assign the imported eprint to a specific buffer.
settings.json (configuration)
-----------------------------
To run the web service create a JSON file named settings.ini in the current directory where you're invoking __ep3apid__ from. The web service can be started with running
` + "```" + `
ep3apid
` + "```" + `
or to load "settings.json" from the current work directory.
` + "```" + `
ep3apid settings.json
` + "```" + `
The JSON settings.json file should look something like "REPO_ID" would
be the name used in the __ep3apid__ to access a specific repsitory. The
"dsn" value should be replaced with an appropriate data source name to
access the MySQL database for the repository you're supporting. You can have many repositories configured in a single __ep3apid__ instance.
` + "```" + `
{
"repositories": {
"REPO_ID": {
"dsn": "DB_USER:SECRET@/DB_NAME",
"base_url": "URL_TO_EPRINT_REPOSITORY",
"write": false,
"default_collection": "lemur-stuff",
"default_offical_url": "https://resolving-lemurs.example.edu",
"default_rights": "You are not allowed to use anything!",
"default_refereed": "TRUE",
"default_status": "inbox"
},
... /* Additional repositories configured here */ ...
}
}
` + "```" + `
Options
-------
` + "```" + `
-h Display this help message
-help
Display this help message
-license
Display software license
-version
Display software version
` + "```" + `
`
}
func repositoriesDocument() string {
return `
Repositories (end point)
========================
This end point lists the repositories known to the __ep3apid__ service.
- '/repositories' returns a JSON array of repository names defined in settings.json
- '/repositories/help' returns this documentation.
Example
-------
In this example we assume the __ep3apid__ services is running on "localhost:8484" and is configured to support two repositories "lemurprints" and "test3". We are using curl to retrieve the data.
` + "```" + `shell
curl -X GET http://localhost:8484/repositories
` + "```" + `
This should return a JSON array like
` + "```" + `json
[
"lemurprints",
"test3"
]
` + "```" + `
`
}
func repositoryDocument() string {
return `
Repository (end point)
----------------------
The end point executes a sequence of "SHOW" SQL statements to build a JSON object with table names as attributes pointing at an array of column names. This is suitable to determine on a per repository bases the related table and columnames representing an EPrint record.
- '/repository' return this documentation
- '/repository/{REPO_ID}' return the JSON representation
- '/repository/{REPO_ID/help' return this documentation
Example
-------
` + "```" + `shell
curl http://localhost:8485/lemurprints/tables
` + "```" + `
Would return a JSON expression similar to the expression below. The object has attributes that map to the EPrint talbles and for each table the attribute points at an array of column names.
The "eprint" table is the root of the object. Each other table is a sub object or array. Tables containing a "pos" field render as an array of objects (e.g. the "item" elements in the EPrint XML). If pos is missing then it is an object with attributes and values.
Each table is relatated by the "eprintid" column ("..." in the object below means the text was abbeviated). Sub tables are related by eprintid and pos columns. All metadata table names begin with "eprint%" or "document%".
` + "```" + `json
{
"eprint": [ "abstract", "alt_url", "book_title", "collection", "commentary", "completion_time", "composition_type", "contact_email", "coverage_dates", "data_type", "date_day", "date_month", "date_type", "date_year", "datestamp_day", "datestamp_hour", "datestamp_minute", ... ],
"eprint_accompaniment": [ "accompaniment", "eprintid", "pos" ],
"eprint_alt_title": [ "alt_title", "eprintid", "pos" ],
"eprint_conductors_id": [ "conductors_id", "eprintid", "pos" ],
"eprint_conductors_name": [ "conductors_name_family", "conductors_name_given", "conductors_name_honourific", "conductors_name_lineage", "eprintid", "pos" ],
"eprint_conductors_uri": [ "conductors_uri", "eprintid", "pos" ],
"eprint_conf_creators_id": [ "conf_creators_id", "eprintid", "pos" ],
"eprint_conf_creators_name": [ "conf_creators_name", "eprintid", "pos" ],
"eprint_conf_creators_uri": [ "conf_creators_uri", "eprintid", "pos" ],
"eprint_contributors_id": [ "contributors_id", "eprintid", "pos" ],
"eprint_contributors_name": [ "contributors_name_family", "contributors_name_given", "contributors_name_honourific", "contributors_name_lineage", "eprintid", "pos" ],
"eprint_contributors_type": [ "contributors_type", "eprintid", "pos" ], "eprint_contributors_uri": [ "contributors_uri", "eprintid", "pos" ],
"eprint_copyright_holders": [ "copyright_holders", "eprintid", "pos" ],
"eprint_corp_creators_id": [ "corp_creators_id", "eprintid", "pos" ],
"eprint_corp_creators_name": [ "corp_creators_name", "eprintid", "pos" ],
"eprint_corp_creators_uri": [ "corp_creators_uri", "eprintid", "pos" ],
"eprint_creators_id": [ "creators_id", "eprintid", "pos" ],
"eprint_creators_name": [ "creators_name_family", "creators_name_given", "creators_name_honourific", "creators_name_lineage", "eprintid", "pos" ],
"eprint_creators_uri": [ "creators_uri", "eprintid", "pos" ],
"eprint_divisions": [ "divisions", "eprintid", "pos" ],
"eprint_editors_id": [ "editors_id", "eprintid", "pos" ],
"eprint_editors_name": [ "editors_name_family", "editors_name_given", "editors_name_honourific", "editors_name_lineage", "eprintid", "pos" ],
"eprint_editors_uri": [ "editors_uri", "eprintid", "pos" ],
"eprint_exhibitors_id": [ "eprintid", "exhibitors_id", "pos" ],
"eprint_exhibitors_name": [ "eprintid", "exhibitors_name_family", "exhibitors_name_given", "exhibitors_name_honourific", "exhibitors_name_lineage", "pos" ],
"eprint_exhibitors_uri": [ "eprintid", "exhibitors_uri", "pos" ],
"eprint_funders_agency": [ "eprintid", "funders_agency", "pos" ],
"eprint_funders_grant_number": [ "eprintid", "funders_grant_number", "pos" ],
...
}
` + "```" + `
`
}
func isPublicDocument(repoID string) string {
return fmt.Sprintf(`'/%s/is-public/{EPRINT_ID}' returns returns true of the eprint id points at a public record or false otherwise`, repoID)
}
func keysDocument(repoID string) string {
return fmt.Sprintf(`'/%s/keys' returns a list of EPrint ID in the repository`, repoID)
}
func createdDocument(repoID string) string {
return fmt.Sprintf(`'/%s/created/{TIMESTAMP}/{TIMESTAMP}' returns a list of EPrint IDs created starting at the first timestamp (timestamps should have a resolution to the minute, e.g. "YYYY-MM-DD HH:MM:SS") through inclusive of the second timestmap (if the second is omitted the timestamp is assumed to be "now")`, repoID)
}
func updatedDocument(repoID string) string {
return fmt.Sprintf(`'/%s/updated/{TIMESTAMP}/{TIMESTAMP}' returns a list of EPrint IDs updated starting at the first timestamp (timestamps should have a resolution to the minute, e.g. "YYYY-MM-DD HH:MM:SS") through inclusive of the second timestmap (if the second is omitted the timestamp is assumed to be "now")`, repoID)
}
func deletedDocument(repoID string) string {
return fmt.Sprintf(`'/%s/deleted/{TIMESTAMP}/{TIMESTAMP}' through the returns a list of EPrint IDs deleted starting at first timestamp through inclusive of the second timestamp, if the second timestamp is omitted it is assumed to be "now"`, repoID)
}
func pubdateDocument(repoID string) string {
return fmt.Sprintf(`'/%s/pubdate/{APROX_DATESTAMP}/{APPOX_DATESTAMP}' this query scans the EPrint table for records with publication starts starting with the first approximate date through inclusive of the second approximate date. If the second date is omitted it is assumed to be "today". Approximate dates my be expressed just the year (starting with Jan 1, ending with Dec 31), just the year and month (starting with first day of month ending with the last day) or year, month and day. The end returns zero or more EPrint IDs.`, repoID)
}
func doiDocument(repoID string) string {
return fmt.Sprintf(`'/%s/doi/{DOI}' with the adoption of EPrints "doi" field in the EPrint table it makes sense to have a quick translation of DOI to EPrint id for a given EPrints repository.`, repoID)
}
func creatorDocument(repoID string) string {
return fmt.Sprintf(`
- '/%s/creator-id' returns a list of creaator-id available in the eprints repository
- '/%s/creator-id/{CREATOR_ID}' scans the name creator id field associated with creators and returns a list of EPrint ID
- '/%s/creator-name' returns a list of creator names (family, given) in repository
- '/%s/creator-name/{FAMILY}/{GIVEN}' returns a list of EPrint ID for the given creator using their family and given names
- '/%s/creator-orcid' return a list of "orcid" associated with creators in repository
- '/%s/creator-orcid/{ORCID}' scans the "orcid" field associated with creators and returns a list of EPrint ID
`, repoID, repoID, repoID, repoID, repoID, repoID)
}
func editorDocument(repoID string) string {
return fmt.Sprintf(`- '/%s/editor-id' returns a list of editor ids available in the EPrints repository
- '/%s/editor-id/{CREATOR_ID}' scans the name creator id field associated with editors and returns a list of EPrint ID
- '/%s/editor-name' returns a list of editor names (family, given) in repository
- '/%s/editor-name/{FAMILY}/{GIVEN}' returns a list of EPrint ID for the given editor using their family and given names
`, repoID, repoID, repoID, repoID)
}
func contributorDocument(repoID string) string {
return fmt.Sprintf(`
- '/%s/contributor-id' returns a list of contributor ids available in the eprints repository
- '/%s/contributor-id/{CONTRIBUTOR_ID}' scans the "id" field associated with a contributors and returns a list of EPrint ID
- '/%s/contributor-name' returns a list of contributor names (family, given) in repository
- '/%s/contributor-name/{FAMILY}/{GIVEN}' returns a list of EPrint ID for the given contributor using their family and given names
`, repoID, repoID, repoID, repoID)
}
func advisorDocument(repoID string) string {
return fmt.Sprintf(`
- '/%s/advisor-id' returns a list of advisor ids in the eprints repository
- '/%s/advisor-id/{ADVISOR_ID}' scans the name advisor id field associated with advisors and returns a list of EPrint ID
- '/%s/advisor-name' returns a list of advisor names (family, given) in repository
- '/%s/advisor-name/{FAMILY}/{GIVEN}' returns a list of EPrint ID for the given advisor using their family and given names
`, repoID, repoID, repoID, repoID)
}
func committeeDocument(repoID string) string {
return fmt.Sprintf(`
- '/%s/committee-id' returns a list of committee id in EPrints repository
- '/%s/committee-id/{COMMITTEE_ID}' scans the committee id field associated with committee members and returns a list of EPrint ID
- '/%s/committee-name' returns a list of committee members names (family, given) in repository
- '/%s/committee-name/{FAMILY}/{GIVEN}' returns a list of EPrint ID for the given committee member using their family and given names
`, repoID, repoID, repoID, repoID)
}
func corpCreatorDocument(repoID string) string {
return fmt.Sprintf(`
- '/%s/corp-creator-id' returns a list of corp creator ids in the eprints repository
- '/%s/corp-creator-id/{CORP_CREATOR_ID}' returns the list of eprint id for the corporate creator id
- '/%s/corp-ceator-uri' returns a list of corp creator uri in the eprints repository
- '/%s/corp-creator-uri/{CORP_CREATOR_URI}' returns the list of eprint id for the corporate creator's URI
`, repoID, repoID, repoID, repoID)
}
func groupDocument(repoID string) string {
return fmt.Sprintf(`
- '/%s/group-id' returns a list of group ids in EPrints repository
- '/%s/group-id/{GROUP_ID}' this scans group ID and returns a list of EPrint IDs associated with the group
`, repoID, repoID)
}
func funderDocument(repoID string) string {
return fmt.Sprintf(`
- '/%s/funder-id' returns a list of funders in the EPrints repository
- '/%s/funder-id/{FUNDER_ID}' returns a list of EPrint IDs associated with the funder
- '/%s/grant-number' returns a list of grant numbers in EPrints repository
- '/%s/grant-number/{GRANT_NUMBER}' returns a list of EPrint IDs associated with the grant number
`, repoID, repoID, repoID, repoID)
}
func pubmedIDDocument(repoID string) string {
return fmt.Sprintf(`
- '/%s/pmid/{PMID}' with the "pmid" field in the EPrint table, it refers to PubMed is an index of the biomedical literature.
`, repoID)
}
func pubmedCentralIDDocument(repoID string) string {
return fmt.Sprintf(`
- '/%s/pmcid/{PMCID}' with the "pmcid" field in the EPrint table, PMCID an Identifier to each full-text paper in PubMed Central Archive
`, repoID)
}
func issnDocument(repoID string) string {
return fmt.Sprintf(`
- '/%s/issn' - returns a list of ISSN in repository
- '/%s/issn/{ISSN}' - returns a list eprint id for ISSN in repository
`, repoID, repoID)
}
func isbnDocument(repoID string) string {
return fmt.Sprintf(`
- '/%s/isbn' - returns a list of ISBN in repository
- '/%s/isbn/{ISBN}' - returns a list eprint id for ISBN in repository
`, repoID, repoID)
}
func patentNumberDocument(repoID string) string {
return fmt.Sprintf(`
- '/%s/patent-number' - return a list of patent numbers in repository
- '/%s/patent-number/{PATENT_NUMBER}' - return a list eprint ids for patent number in repository
`, repoID, repoID)
}
func patentApplicantDocument(repoID string) string {
return fmt.Sprintf(`
- '/%s/patent-applicant' - return a list of patent applicants in repository
- '/%s/patent-applicant/{PATENT_APPLICANT}' - return a list eprint ids for patent applicant in repository
`, repoID, repoID)
}
func patentClassificationDocument(repoID string) string {
return fmt.Sprintf(`
- '/%s/patent-classification' - return a list of patent classificatins in repository
- '/%s/patent-classification/{PATENT_CLASSIFICATION}' - return a list eprint ids for patent classification in repository
`, repoID, repoID)
}
func patentAssigneeDocument(repoID string) string {
return fmt.Sprintf(`
- '/%s/patent-assignee' - return a list of patent assignee in repository
- '/%s/patent-assignee/{PATENT_ASSIGNEE}' - return a list eprint ids for patent assignee in repository
`, repoID, repoID)
}
func yearDocument(repoID string) string {
return fmt.Sprintf(`
- '/%s/year' - return a descending list of years containing record with a date type of "published".
- '/%s/year/{YEAR}' - return a list of eprintid for a given year contaning date type of "published".
`, repoID, repoID)
}
func recordDocument(repoID string) string {
return fmt.Sprintf(`Simplified Record
-----------------
This version of the API includes a simplified JSON record view. The
JSON represents the JSON model used in DataCite and InvenioRDMs.
- '/%s/record/{EPRINT_ID}' returns a complex JSON object representing the EPrint record identified by {EPRINT_ID}.
`, repoID)
}
func eprintReadWriteDocument(repoID string) string {
return fmt.Sprintf(`
Read/Write metadata API
-----------------------
As of 1.0.3 of the EPrints extended API support for reading (retrieving
EPrint XML) and write (importing EPrint XML) metadata has been added.
Reading is performed with a GET and writing with a POST to their
respective end points. The POST must be submitted with a
"applciation/xml" content type for EPrints XML or "application/json" for
the JSON version of EPrint XML. The EPrints extended API does NOT use
the Perl API, it talks directly to the MySQL database supporting your
EPrints repository.
GET:
- '/%s/eprint/{EPRINT_ID}' will retrieve an existing EPrint record as EPrint XML by building up an eprint record via SQL queries.
POST:
- '/%s/eprint-import/{USER_ID}' POST accepts EPrints XML with content type of "application/xml" or JSON of EPrints XML with content type "application/json". To enable this feature add the attribute '"write": true' to the repositories setting in settins.json. The {USER_ID} is required and this is used to assign the imported eprint to a specific buffer.
EPrints XML can contiain more than one EPrint record so multiple EPrint metadata records can be created with one post.
`, repoID, repoID)
}
func userDocument(repoID string) string {
return fmt.Sprintf(`
- '/%s/usernames' - return a list of usernames associated with repository
- '/%s/lookup-userid/{username}' - return a list of user id associated with usersname in repository
- '/%s/user/{userid|username}' - get a user object for user id or username in repository
`, repoID, repoID, repoID)
}