data:image/s3,"s3://crabby-images/42ece/42ece88231957aef5632321036bc0874fe0e1dfd" alt=""
| data:image/s3,"s3://crabby-images/42ece/42ece88231957aef5632321036bc0874fe0e1dfd" alt="" |
Declaration
Considering following Source Handler declaration in
cocoon.xconf :
<protocol
class="fr.paris5.shaman.spirit.insightsource.InsightSourceFactory"
name="insight-content"
/>
|
We want this protocol to be supported, in order to allow following
calls from Cocoon Sitemap:
<map:match type="publication-format" pattern="RAW" >
<map:read src="insight-content:/{1}" />
</map:match>
|
or:
<map:match type="publication-format" pattern="MY-FORMAT" >
<map:match pattern="**.html" >
<map:generate src="insight-content:/{1}.xml" />
<map:serialize type="html" />
</map:match>
</map:match>
|
Both forms access to Insight content, via the
insight-content: pseudo-protocol.
data:image/s3,"s3://crabby-images/dae97/dae97373aa60d08bc8f2e627421484d1878e9a0f" alt="Note" |
According to Spirit-tailored URLs,
transmitted URIs contain a prefix (like ~top-nn/
or ~pub-nn/ ) giving a mean to find the right
Publication.
|
Activity diagram
data:image/s3,"s3://crabby-images/0f6ba/0f6ba7ce302fce4bd2e69c4740134af32b95404d" alt="Insight Content access"
data:image/s3,"s3://crabby-images/dae97/dae97373aa60d08bc8f2e627421484d1878e9a0f" alt="Note" |
A Source object is able to deliver an
InputStream , plus some information about validity
(for cache update). It is used by Cocoon instead of URLs when
custom protocols are required, which is the case here.
|
| data:image/s3,"s3://crabby-images/42ece/42ece88231957aef5632321036bc0874fe0e1dfd" alt="" |