- 
        1. Re: S-RAMP: New extensibility contractseric.wittmann Nov 19, 2014 12:23 PM (in response to brmeyer)1 of 1 people found this helpfulMight also be a good time to re-think derivation. The reason s-ramp has the concept of an Expander at all is because we didn't want to derive content from a derived artifact. But perhaps that was the wrong decision. If a derived artifact could be further derived, then you only need to solve #1 and #3. And #3 is only applicable when an artifact is added without an artifact type explicitly set. 
- 
        2. Re: Re: S-RAMP: New extensibility contractsbrmeyer Nov 19, 2014 12:37 PM (in response to eric.wittmann)The reason s-ramp has the concept of an Expander at all is because we didn't want to derive content from a derived artifact. Really interesting thought. So, "expanding" could be seen as simply deriving a file, but the difference is the first level of "derived" artifacts are primary artifacts/files themselves. The ArtifactBuilder could simply be called iteratively w/ minimal extra logic. That would also give an "easy" opportunity for clients to define relationships amongst the entire set. 
- 
        3. Re: Re: S-RAMP: New extensibility contractseric.wittmann Nov 19, 2014 12:42 PM (in response to brmeyer)Yes exactly. It's unfortunate that the spec dictates that certain artifact types are always "derived" and others are not. If that weren't the case then I would say "derived" would just be a flag on the artifact. Sadly, if I remember the spec correctly, you're stuck. So you might have to stick with "Expanding" as a concept. 
- 
        4. Re: S-RAMP: New extensibility contractsobjectiser Nov 19, 2014 12:53 PM (in response to brmeyer)I liked your original thought about treating them individually, as they seemed to do different tasks - but also see the benefit of Eric's suggestion. My main question is how the distinction between primary and derived artifacts would be determined - would this be the responsibility of the ArtifactBuilder implementation? Or a property of the artifact being built? 
- 
        5. Re: Re: S-RAMP: New extensibility contractsbrmeyer Nov 19, 2014 1:16 PM (in response to objectiser)My main question is how the distinction between primary and derived artifacts would be determined - would this be the responsibility of the ArtifactBuilder implementation? Or a property of the artifact being built? Realistically, the ArtifactBuilder only needs to "generate additional artifacts from this given artifact", and that's it. The spec's concept of "derived" is really just a set of relationships and constraints pegged onto specific artifact types. So presumably, the needed logic would be fairly simple. I liked your original thought about treating them individually, as they seemed to do different tasks +1. Originally, my concern was that #2 and #3 will both need to open an archive, #2 to expand it and #3 to inspect it. Splitting into separate contracts may have meant duplication of efforts. But if I crack open the archive once and provide it to both contracts through abstraction, there may be no downside. 
- 
        6. Re: S-RAMP: New extensibility contractsbrmeyer Nov 20, 2014 1:54 PM (in response to brmeyer)Alright, here's what I had in mind. Pardon the really, really rough diagram, but hopefully it helps: https://www.dropbox.com/s/h8akmwpl83zqsxv/ArtifactExpander.pdf?dl=0 - A new REST endpoint would be created to accept a filename (slug), InputStream, and a Map<String, String> of "contextParameters" (client-specific "clues", such as the GAV from mvn:deploy). Note that the model and type would not be included. Explicitly identifying them would go through the existing endpoints.
- From #1, create an "ArtifactContext" and set the original archive and its exploded contents
- Give the original archive to the "ArtifactTypeDetector" chain. The most specific detector will set the archive artifact type in the ArtifactContext.
- Give the ArtifactContext to the "ArtifactExpander" chain. Again, the most specific detector wins (but inheritance should be used whenever applicable). This generates the full list of artifacts from the exploded archive contents, as well as expansion-specific relationships.
- Run the entire set through ArtifactBuilder, which will be left as is: build up all properties, generate derived artifacts, and set additional relationships. This step does not need the ArtifactContext, since all artifact types are already available.
 ArtifactExpander would pull in much of the current ZipToSrampArchive functionality, generating an SrampArchive and re-using the existing batch-upload endpoint. Any thoughts? 
- 
        7. Re: S-RAMP: New extensibility contractsobjectiser Nov 21, 2014 4:58 AM (in response to brmeyer)Sounds good to me. Just wanted to check how "most specific" would be determined in #3 and #4? 
- 
        8. Re: S-RAMP: New extensibility contractsbrmeyer Nov 21, 2014 9:48 AM (in response to objectiser)Presumably, the ArtifactTypeDetector and ArtifactExpander contracts would both provide an integer order value 
 
     
    