Project

General

Profile

Actions

Bug #2442

closed

Create a "request new AccessionCode" function for VegBranch in VegBank

Added by Michael Lee over 18 years ago. Updated about 18 years ago.

Status:
Resolved
Priority:
Normal
Assignee:
Category:
vegbranch
Target version:
Start date:
05/22/2006
Due date:
% Done:

0%

Estimated time:
Bugzilla-Id:
2442

Description

This will allow users to request GUIDs from VegBank.org from ANYWHERE. This makes bug 1859 and bug 1828 unneeded, if we can do it. VegBranch will have to request new AccessionCodes from VegBank directly. Additionally, VegBank's downloader will have to recognize incoming accessionCodes as "requested new" and keep them instead of writing its own again. But this is difference from accessionCodes that are found in the database already.

Previously I was unable to download anything from the web directly into VegBranch. But it seems to work now with Application.importXML("http://..."). The format for the XML is:
<root>
<table>
<field>info</field>
<field2>info</field2>
</table>
</root>

It can be made to append to extant tables instead of creating new.


Files

VegbankRequestAccessionCodeTag.java (6.32 KB) VegbankRequestAccessionCodeTag.java Michael Lee, 06/02/2006 09:38 AM
Utility.java (28.2 KB) Utility.java Michael Lee, 06/02/2006 09:39 AM
getNewRequestID.jsp (1.67 KB) getNewRequestID.jsp Michael Lee, 06/02/2006 09:48 AM
Actions #1

Updated by Michael Lee over 18 years ago

I'd imagine this working on the VegBank side as a new table called "issuedAccessionCode"

A client would be able to request as many accessionCodes as they need for their application in a request (one request per table) like this:

http://vegbank.org/requestxml/{table}/{numberOfAccCodesNeeded}
--this would forward to the appropriate servlet/jsp page that would process the request, adding {numberOfAccCodesNeeded} records to the issuedAccessionCode table with the tableName field in that table set to {table} from the request.

then, VegBranch or whatever client would take those codes, write them as GUID accessionCode identifiers for the new data.

When the data are exported to VegBank-data-xml and uploaded to VegBank, the XML-Loader would use this logic with incoming accCodes:

1) is this accessionCode in the VegBank database already
1a) if so, reference that entitiy
1b) if not do #2
2) is this accessionCode in the stack of accCodes listed in "issuedAccessionCode"?
2a) if so, then use that accessionCode in the database, and delete it from the "issuedAccessionCode" stack.
2b) if not, then ignore the accessionCode and write a new VegBank accessionCode.

we might format the requested code differently. Currently we have "VB.Tbl.PK#.Confirm." Requested might be "VBReq.Tbl.PK#.Confirm" or something like that. This would ensure uniqueness between the two sets of codes.

Actions #2

Updated by Michael Lee over 18 years ago

Confirm for newly issues confirmation codes should be some random string, as we won't know "diddley" about the actual element until well after the AccessionCode is generated. Still useful in making sure typos didn't occur. If someone was only requesting one code, we could potentially issue a confirmation code. (I'm unsure about the wisdom even in that case...) Otherwise, it would be problematic as they'd be trying to match confirmation codes with their new entities... leads to possible mismatching.

Actions #3

Updated by Michael Lee over 18 years ago

this XML was successfully imported:
http://www.unc.edu/~mikelee/Misc/testImportXML2.xml

Actions #5

Updated by Michael Lee over 18 years ago

database.accession.key.preassign=VBAldoPre
is also added to build.properties in the /vegbank/ directory.

Actions #6

Updated by Michael Lee over 18 years ago

http://aldo.nceas.ucsb.edu/vegbank/views/getNewRequestID.jsp?tablename=observation&recordcount=4

creates 4 new observation accession codes as XML that can be downloaded by a client (VegBranch). VegBranch has successfully downloaded such accessionCodes to uniquely identify observations.

Actions #7

Updated by Michael Lee over 18 years ago

getPKFromAccessionCode() needs to be modified to look for the accessionCode in the "lookup table" if it isn't already found. It should only look for accessionCodes that are of the right prefix (set in .props file) to save time to avoid looking up VegBranch accessionCodes. If it finds the accessionCode there, it should somehow flag that code as acceptable, and this would stop removeAccessionCode() from doing what it does. I suppose that we don't have to enforce removal of that accessionCode then from the pre-request list, but it would be nice to. It could be done later, I think, or perhaps just flagged as removed (update seems safer than delete).

If it doesn't find the accessionCode there, then nothing different happens.

Actions #8

Updated by Michael Lee about 18 years ago

Works now. New data that are loaded into VegBank accept accessionCodes that are in the dba_preassignAccCode table. This means less work as we don't have to deal with multiple sets of accessionCodes (incoming codes and our unique codes).

Actions #9

Updated by Redmine Admin over 11 years ago

Original Bugzilla ID was 2442

Actions

Also available in: Atom PDF