- 
                Notifications
    You must be signed in to change notification settings 
- Fork 2
Standards Alignment Prototype
- Get data services working (project elements described below)
- Just get alignment data going
- All the features we discussed today...
 
- Get a trimmed down node running w/out slice -- ready for development. Install data services on it - show it works. (This is a question - I think this step make sense) (Lou, modify install should map services and associated view dependencies, so that if xyz services are installed, only xyz views are installed)
- Prove out test cases on this work (Joe, Susan, Aaron, Agilix)
- Get docs in shape for examples and code lib (Lou, Damon, Simulator)
- Get one more example data service going: maybe ratings
- Get replicate working better (including this stuff but also pull-replicate) (Get Lou smart on Jim's approach)
- Get publish signing on a node working (Austin, + version 2 of signing algorithm -- address data that can't be bencoded, switch to tagged-data? as a new spec, or use protocol buffers)
- Separate branch for standards alignment prototyping using pull request model
- Part of the asynchronous development process is writing tests and doing code reviews
Reducing size of data and cost/size of server
- Data results window size needs to be small
- Going to EBS for disk storage
- Design goal: Simplicity
- Every step can be done with curl
- Unit tests for components (may be language specific, using new or existing frameworks - should be callable from our overall test runner)
- Integration/functional tests (use our existing framework)
Provide these capabilities (maybe one per view or maybe integrated):
- Give me all standards aligned to URL/resource
- Give me all URLs associated with a standard
- Give me all alignment data
- Give me all aligned resources for a URL pattern / site
1a Story (Jim): What defines "alignment data"?
- Anything that starts with "http://purl.org/ASN/resources/*"
- XML with dct:conforms_to
- Criteria for relevant paradata (specific verbs for paradata)
- validate with Joe and Brian to identify rules of thumb
- define regex
- wiki article
1a Story (Jim): How do we organize (pattern) the data so it can be accessed in a consistent manner
- by date
- by sender
- by domain name (identity)
- by url
- by standard
- related to API format definition
1a Story (Jim): How to use the Java View Server to write the map functions?
- How to setup Maven
- Java
- not rich query interface
- source code repository for views?
- wiki article
1b Story: How to use the JavaScript to write the map functions?
- Javascript
- not rich query interface
- wiki article
Use restful-like interface but modified to support parameters
- Call it "obtain_view" (or suggest alt)
- Parameters include: Which map/extract to run, primary param (URL of resource or whatever), secondary params (provided after "?")
- Security / access
- Each map/extract design doc needs to hold an arbitrary parameter that describes if the map/extract is permitted to be accessed from the "obtain_view" interface (obtain_view must honor this)
- Possibly also enable access from "obtain_view" by convention of naming the map/extract view function with a particular prefix like "view-[name]" (e.g., "view-by-standards-url")
 
- Example:
1a Story (Walt/Jim): What is the API definition?
- related to organize (pattern) data story
- leverage CouchDB tools, but abstract the API to use them (e.g., how to use CouchDB List function/view/regex, so we may need abstract a way to pass arbitrary parameters (e.g., domain name regex) through API to a CouchDB List?)
- unrestricted, but obivously no access to internal views
6 Story (Austin, LM security): Define how to restrict access to the API
- Define security
- Each map/extract design doc needs to hold an arbitrary parameter that describes if the map/extract is permitted to be accessed from the "obtain_view" interface (obtain_view must honor this)
- Possibly also enable access from "obtain_view" by convention of naming the map/extract view function with a particular prefix like "view-[name]" (e.g., "view-by-standards-url")
- role-based access (single role initially as discriminator)?
 
- document in wiki
6 Story (Austin): How to restrict access to the API?
- Implement security
- Each map/extract design doc needs to hold an arbitrary parameter that describes if the map/extract is permitted to be accessed from the "obtain_view" interface (obtain_view must honor this)
- Possibly also enable access from "obtain_view" by convention of naming the map/extract view function with a particular prefix like "view-[name]" (e.g., "view-by-standards-url")
- role-based access
 
- Use obtain result format
- Relax certain LR envelope elements for output by creating a new envelope doc_type: "result_data"
- "result_data" doc_type would have compatibility with "resource_data" but used for returning data which are composites of inputs
 
- Design goals include:
- Ability to chain result sets together
- Optional/bonus: Ability to submit result_data docs back into LR network
 
1a Story (Walt, Dan): What is the result format for the service?
- model obtain
- wiki article
1a Story (Walt, Dan): What is the result format for the envelope?
- model after resource_data, but with relaxed element definitions
- doc_type="result_data"
- wiki article
- Examine whether performance requires some filters to be map/extractions.
- Filter by sender
- Filter by date
 
Addressed in above 1a story (organize data, API definition)
- Templates for view
- Helper functions and other templatizing tools
- How-to examples
 
- Java view server
- Performance: make sure >= javascript view server
 
- Maybe provide javascript view servers templates as learning examples
4 Story (Jim): Provide example map functions in simulator
4 Story (TBD): Host simulator
- Wizard for creating public/private keys and uploading to key servers
- Associate public/private keys to basic_auth login users
- Signing code on submission inside node
- Could sign all stuff with a single node public/private key and associate basic_auth credentials as "signed on behalf of"