[09:42:48 CDT(-0500)] <RickardAtWork> Quick question. Is it possible to include external CSS files in skin.xml? I've tried <css>http://www.example.com/test.css</css>, but that turns into /uPortal/media/skins/universality/lu/http://www.example.com/test.css
[09:43:57 CDT(-0500)] <RickardAtWork> I looked at the doctype, but there doesn't appear to be any provision for including an external stylesheet.
[09:45:58 CDT(-0500)] <EricDalquist> RickardAtWork: I don't think so
[09:46:02 CDT(-0500)] <EricDalquist> it supports absolute URLs
[09:46:09 CDT(-0500)] <EricDalquist> on the same domain
[09:46:12 CDT(-0500)] <EricDalquist> but not external domains
[09:46:15 CDT(-0500)] <RickardAtWork> Ok
[09:46:20 CDT(-0500)] <EricDalquist> seems like a really good improvement though
[09:46:28 CDT(-0500)] <RickardAtWork> Yea
[09:46:37 CDT(-0500)] <RickardAtWork> Not sure how it would work with aggregation though.
[09:46:39 CDT(-0500)] <EricDalquist> could you create a feature request here: https://issues.jasig.org/browse/UP
[09:46:44 CDT(-0500)] <RickardAtWork> Sure
[09:46:47 CDT(-0500)] <EricDalquist> well it would simply be passed through
[09:46:51 CDT(-0500)] <RickardAtWork> Ok
[09:46:55 CDT(-0500)] <RickardAtWork> I'll do that.
[09:46:57 CDT(-0500)] <EricDalquist> CSS files can't have their path changed at all
[09:47:09 CDT(-0500)] <EricDalquist> since they can do CSS file relative imports of other CSS, images, etc
[09:47:35 CDT(-0500)] <RickardAtWork> True
[09:48:17 CDT(-0500)] <EricDalquist> the aggregator currently combines CSS files that are in the same directory and listed next to each other
[09:48:46 CDT(-0500)] <EricDalquist> so you get different aggregation results for "foo/a.css, foo/b.css, bar/d.css" versus "foo/a.css, bar/d.css, foo/b.css"
[09:48:56 CDT(-0500)] <EricDalquist> the first example gets you 2 CSS files in the output
[09:48:56 CDT(-0500)] <RickardAtWork> Ah, ok.
[09:49:00 CDT(-0500)] <EricDalquist> the second gets your 3
[09:49:13 CDT(-0500)] <EricDalquist> if we didn't honor CSS file ordering styles could change because of overrides
[09:49:27 CDT(-0500)] <EricDalquist> so when you're modifying that file you want to group CSS files by path as much as possible
[09:49:33 CDT(-0500)] <EricDalquist> JS on the other hand doesn't matter
[09:49:40 CDT(-0500)] <EricDalquist> all the JS files are globed into a single file
[09:49:55 CDT(-0500)] <EricDalquist> since for JS all the paths are relative to the page's URL not the JS file's URL
[09:52:28 CDT(-0500)] <RickardAtWork> Which "component" do you suggest I pick for the feature request?
[09:52:37 CDT(-0500)] <EricDalquist> you can leave that blank
[09:52:43 CDT(-0500)] <RickardAtWork> Ok
[09:58:10 CDT(-0500)] <RickardAtWork> https://issues.jasig.org/browse/UP-2887
[09:58:14 CDT(-0500)] <RickardAtWork> Enjoy
[10:02:26 CDT(-0500)] <EricDalquist> thanks!
[10:02:31 CDT(-0500)] <EricDalquist> I'll get it scheduled for the next release
[10:28:21 CDT(-0500)] <RickardAtWork> Is it possible to get uPortal to output markup that is a bit more tidy? It's kind of difficult to read markup that's on 5 kilobyte long lines. I've changed intent to yes in the xsl:output tag, but it doesn't appear to have any effect.
[10:28:43 CDT(-0500)] <EricDalquist> I don't think it is in 3.2
[10:28:54 CDT(-0500)] <EricDalquist> we have that ability in trunk but that isn't much help :/
[10:29:51 CDT(-0500)] <RickardAtWork> Ok
[10:30:01 CDT(-0500)] <RickardAtWork> I'll run it through tidy manually.
[10:30:36 CDT(-0500)] <athena> EricDalquist: i got import/export working via vanilla servlets friday afternoon
[10:30:43 CDT(-0500)] <EricDalquist> wow
[10:30:45 CDT(-0500)] <EricDalquist> neat
[10:30:51 CDT(-0500)] <athena> yeah
[10:31:02 CDT(-0500)] <athena> so just need to know how we want things to work
[10:31:03 CDT(-0500)] <EricDalquist> do we have permissions defining who can do import/export/delete
[10:31:07 CDT(-0500)] <athena> no
[10:31:09 CDT(-0500)] <athena> so that's one issue
[10:31:36 CDT(-0500)] <athena> in the future we should really figure out a way to have import/export run as the user who's logged in
[10:31:41 CDT(-0500)] <athena> rather than doing everything as the session user
[10:31:56 CDT(-0500)] <EricDalquist> so are they under /api/?
[10:32:03 CDT(-0500)] <athena> yes
[10:32:08 CDT(-0500)] <athena> haven't checked anything in yet
[10:32:16 CDT(-0500)] <athena> (hm, did the last os x update change ant?)
[10:32:36 CDT(-0500)] <EricDalquist> not sure ...
[10:32:43 CDT(-0500)] <EricDalquist> I have my own ant/maven installed
[10:32:48 CDT(-0500)] <athena> yeah, i thought i did
[10:32:48 CDT(-0500)] <athena> weird
[10:32:51 CDT(-0500)] <athena> oh well.
[10:32:54 CDT(-0500)] <athena> anyway, so import/export
[10:33:17 CDT(-0500)] <athena> it seems like longterm what we'd really want is for that portlet to make use of a set of REST services
[10:33:56 CDT(-0500)] <EricDalquist> yup
[10:34:00 CDT(-0500)] <athena> import/export in a running portal could really just mean getting the output from a REST entity service that outputs as xml, or doing a PUT on an XML document
[10:34:03 CDT(-0500)] <athena> that seem reasonable?
[10:34:09 CDT(-0500)] <EricDalquist> yes
[10:34:12 CDT(-0500)] <athena> ok
[10:34:15 CDT(-0500)] <EricDalquist> that seems very reasonable
[10:34:22 CDT(-0500)] <EricDalquist> and all that stuff translates into rest URLs nicely{color}
[10:34:26 CDT(-0500)] <athena> yeah
[10:34:37 CDT(-0500)] <athena> maybe something like /api/channel/weather.xml?
[10:34:54 CDT(-0500)] <EricDalquist> yeah
[10:35:00 CDT(-0500)] <EricDalquist> do we want to have the file extension?
[10:35:04 CDT(-0500)] <athena> maybe
[10:35:25 CDT(-0500)] <athena> seems like maybe it makes things easier if we decide we want this stuff as JSON in the future? dunno
[10:35:37 CDT(-0500)] <EricDalquist> ah yeah
[10:35:40 CDT(-0500)] <EricDalquist> that makes sense
[10:35:49 CDT(-0500)] <EricDalquist> just pull off the extension in the URL mapping
[10:36:15 CDT(-0500)] <athena> the REST templates support paths like that, which makes it pretty convenient
[10:36:48 CDT(-0500)] Wiki Markup <athena> just do /api/channel/{fname}.xml and map fname as a @PathVariable
[10:36:55 CDT(-0500)] <EricDalquist> nice
[10:37:05 CDT(-0500)] Wiki Markup <EricDalquist> could you do /api/channel/{fname}.{format}
[10:37:17 CDT(-0500)] <EricDalquist> and then we just tweak that extension for different formats?
[10:37:45 CDT(-0500)] <athena> well
[10:37:54 CDT(-0500)] <athena> i think we'd want one of the following:
[10:38:19 CDT(-0500)] <athena> 1. if we have really separate logic or different object formats for xml vs. json just separately map the paths to different methods
[10:38:24 CDT(-0500)] <athena> or preferably
[10:38:58 CDT(-0500)] <athena> 2. we wind up having the same base object, which has appropriate XML annotations, and we just use spring's content negotiating view resolver to use the same returned model to output either JSON or XML
[10:39:06 CDT(-0500)] <athena> we don't have a use case for the JSON yet, I don't think
[10:39:07 CDT(-0500)] <EricDalquist> got it
[10:39:08 CDT(-0500)] <EricDalquist> ok
[10:39:23 CDT(-0500)] <athena> we have the JSON list of portlets, but that's that crazy custom thing
[10:39:31 CDT(-0500)] <EricDalquist> yeah{color}
[10:40:21 CDT(-0500)] <athena> any thoughts about what we want to do for permissions? just a single import/export permission or ?
[10:40:36 CDT(-0500)] <athena> guess we could have a permission that targets each entity type
[10:40:39 CDT(-0500)] <EricDalquist> hrm
[10:40:48 CDT(-0500)] <EricDalquist> yeah that would probably be the most useful
[10:41:01 CDT(-0500)] <athena> really wish we were just relying on normal portal permissions for this stuff
[10:41:08 CDT(-0500)] <EricDalquist> oh do we want to be specific about create vs update?
[10:41:12 CDT(-0500)] <EricDalquist> can't we?
[10:41:20 CDT(-0500)] <athena> from inside the portal, our crn stuff really obscures a lot
[10:41:23 CDT(-0500)] <athena> well, not really
[10:41:34 CDT(-0500)] <athena> the existing import/export portlet code just calls the crn scripts
[10:41:41 CDT(-0500)] <athena> which run everything as the system user
[10:41:51 CDT(-0500)] <EricDalquist>
[10:41:57 CDT(-0500)] <athena> and don't do any permissions checking anyway
[10:41:58 CDT(-0500)] <athena> yeah
[10:42:31 CDT(-0500)] <athena> i really think eventually we'd be better off dropping some of this stuff in favor of having XML-annotated classes, or XML mappers, or something like that
[10:43:01 CDT(-0500)] <athena> and then let command-line import be a crn wrapper or whatever around that stuff, and not use crn much from within the running portal
[10:43:04 CDT(-0500)] <EricDalquist> right
[10:43:14 CDT(-0500)] <EricDalquist> I'd like to get to the point where we have XML annotated objects
[10:43:19 CDT(-0500)] <athena> yeaah
[10:43:32 CDT(-0500)] <EricDalquist> and the import uses XSLT to migrate from old data formats to new data forms
[10:43:33 CDT(-0500)] <athena> we'd still need a way to handle outdated import formats, of course
[10:43:37 CDT(-0500)] <athena> yes
[10:43:44 CDT(-0500)] <athena> i think that'd be great
[10:43:49 CDT(-0500)] <EricDalquist> get the XML, read the version attribute then run an XSL
[10:43:58 CDT(-0500)] <athena> not that the current setup hasn't been a huge improvement over nothing at all
[10:44:02 CDT(-0500)] <EricDalquist> right
[10:44:12 CDT(-0500)] <athena> but it'd be great to be able to use some of the nice new XML annotations and such
[10:44:26 CDT(-0500)] <athena> maybe we can slowly start moving stuff over in the background
[10:44:38 CDT(-0500)] <athena> like when we write the new portlet class
[10:45:15 CDT(-0500)] <EricDalquist> I haven't really played with those
[10:45:18 CDT(-0500)] <EricDalquist> where are they from?
[10:45:44 CDT(-0500)] <athena> hmm
[10:45:54 CDT(-0500)] <athena> i think a lot of the ones i've used are JAXB?
[10:45:58 CDT(-0500)] <EricDalquist> ah ok
[10:46:06 CDT(-0500)] <EricDalquist> oh I went through and fixed our xml escaping issues in trunk ... that was a few hours of pain :/
[10:46:16 CDT(-0500)] <athena> i saw - thanks for doing that
[10:46:23 CDT(-0500)] <EricDalquist> I have a note to email the dev list to be careful about that in the future
[10:46:26 CDT(-0500)] <athena> yeah
[10:46:42 CDT(-0500)] <athena> i think we'd previously been most concerned about stuff visible to end users
[10:46:50 CDT(-0500)] <athena> but better to handle it properly for everyone
[10:46:56 CDT(-0500)] <athena> esp with our new delegated stuff
[10:47:18 CDT(-0500)] <EricDalquist> yaeh
[10:47:43 CDT(-0500)] <EricDalquist> really anything that gets written to the page needs to be escaped
[10:47:52 CDT(-0500)] <EricDalquist> unless there is a very explicit need otherwise
[10:47:54 CDT(-0500)] <athena> yeah
[10:48:03 CDT(-0500)] <EricDalquist> I even wrapped things that I knew were numbers
[10:48:06 CDT(-0500)] <EricDalquist> better to be consistent
[10:48:11 CDT(-0500)] <athena> and it's annoying that you can default xml escaping for the c:out tag and such, but not for ${}
[10:48:22 CDT(-0500)] <athena> shawn bayern was kind of horrified about that, by the way
[10:48:44 CDT(-0500)] <RickardAtWork> Tip for viewing messy markup: https://addons.mozilla.org/en-US/firefox/addon/249/
[10:48:46 CDT(-0500)] <athena> better to just wrap it i guess - never know if a data type might change
Page Comparison
General
Content
Integrations