Plone
This is here to serve as contents for the atom/rss feed for Plone, also read by planet.plone.org.
Permission problems for objects that have a non-existing owner
And show how to change ownership in Plone.
I had problems at a client site using Plone 3.3 and quintagroup.plonecomments 4.1.2. I do not think the problem is in that last package, but that is the spot where strange behaviour surfaced. The client reported that on some pages the comments were visible but the buttons to Remove or Edit them was not visible, not even for a Manager.
The comments and their buttons were shown by the plone.comments viewlet, which is customized by quintagroup.plonecomments. The Remove button was guarded by a permission 'Moderate Discussion'. The page template claimed that as Manager I did not have this permission. A simple Script Python added in the ZMI showed that this was non-sense: I did have that permission:
return context.portal_membership.checkPermission( 'Moderate Discussion', context)
In the end, what turned out to be the problem was that the object was owned by a user that no longer existed. Somehow that seems to have tricked Plone/Zope into thinking (at least in the template of this viewlet) that no one had the Moderate Discussion permission anymore. Other permissions seemed unaffected; for example you could still view the comments and reply to them.
Giving someone the local role Owner in the ZMI, or changing the Creator in the Ownership tab of the edit form did not have any effect. I had to add 'ownership_form' at the end of the url of the object to give ownership of this item (and its subobjects) to someone else. This fixed it, even when I myself was not the new owner.
So it looks like somewhere some code path was triggered that did not like the fact that the current owner did not exist anymore.
Now, maybe something weird was happening because the plone.comments viewlet was customized in the portal_view_customizations, but this worked without problems on a local older copy of the Data.fs. I still do not understand what the difference is between the live site and my local copy where I could remove comments everywhere just fine, even though the owner was gone there as well. Well, stranger things have happened in this particular Data.fs and I have come up with stranger solutions to tackle them. This one was quite clean. :-)
Python Users Netherlands meeting
Summary of the Python Users Nederland meeting in Arnhem, 3 november 2010.
Rob Gietema: Deco
I will talk about Deco and some more of Plone 4. I work for Four Digits, who organized this PUN. Originally four people, now seven. Since a few years we do only Plone. I myself do mostly front-end development, like integration of the TinyMCE visual editor in Plone.
Plone is a CMS. One of the current problems is creating composite pages. There are add-ons for that, but it is still crufty. Deco is meant to improve that a lot. In 2008 several people came with a proposal for that. Deco as front-end, Blocks as back-end.
Deco is a grid-based system. So you create multiple columns that you can style with CSS. The columns can be filled with tiles. We have structure tiles, like rich text. Also field tiles, like a title, description, list of tags. And application tiles, which can be anything: image, discussion forum, table of contents, multi-file upload.
The idea was good, but there were not a lot of people who wanted to write the javascript needed for that. But I do like to do that. :-)
We sprinted a few times on this. Four Digits hosted the Living Statues Sprint, there was a sprint at the Plone Conference in Bristol last week.
We created a demo website using Deco: http://decobrewery.com/. I will demo that now.
This is mostly for Plone 5, but parts will be available in upcoming Plone 4.x versions.
The parts involved in Deco are currently split over about 14 small python packages.
Create your own tile: an interface class with a schema, a class with a __call__ method that returns some html (can be in an html template), and some zcml to register this and glue everything together.
To do: create more templates for content types, fix bugs.
Want to code on it? Use https://svn.plone.org/svn/plone/plone.app.deco/buildouts/dev
It actually works in IE6 as well!
Reinout van Rees: checkoutmanager
checkoutmanager is a small tool to manage all your checkouts on your whole file system. You have 20 personal projects, 30 client projects, some dotfiles in your home dir. Just manage them all. I created checkoutmanager when I switched to a new laptop. Use it to checkout git, subversion, bazaard, mercurial. Every morning I do a checkoutmanager up to update all checkouts. I do checkoutmanager st to see which files in all my checkouts I forgot to commit. Also checkoutmanager out to see which local commits from git or mercurial I have not pushed to the central server yet. (To do: mention this in the docs.)
Roel Bruggink: Subversion pre-commit hooks for pyflakes, pep8
I installed pre-commit hooks on our subversion to disallow commits that go against pyflakes and pep8. I wrote some code that made it possible to add a comment in a file to ignore one or more PEP8 style checks. Hooked it up to TextMate to prevent you from saving a file with PEP8 problems, except when you explicitly specify it with that comment. Handy for those times where you really can't help it. If you want the code, mail me.
Lars van de Kerkhof: Hudson and Fabric
Hudson is a Java tool for continuous integration. It basically just runs a shell script for you and reports the results back. Usually those are test results. We use it for deployment as well, but of course only when the test requirements are met. We let it use Fabric for that. It is tricky to get Fabric to use the correct virtualenv, but we got that working. I also made a way to print a shell script that looks like what Fabric would do for real.
Rob Gietema: XDV/Diaza/Deliverance for theming
XDV uses XSLT to get html from for example Plone and transform and push it into an html template that your designer has created. Nice alternative way to do theming. You can also combine multiple sources, not just from Plone, but from other systems as well at the same time.
Varundev Kashimath: Why do certain products succeed?
Working at TU Delft. We did some research into how long it takes to do a project with Rails and with Django. Rails took longer in this case. Some discussion followed, hard to summarize.
Vincent Pretre (Zest Software): jquery.pyproxy
Lightning talk during the Dutch Plone User Day 2010 in the Euromast, Rotterdam. Also, cheap way of pointing Dutch readers to the Dutch summary of the whole day.
Vincent Pretre is lead developer at Zest Software for http://prettigpersoneel.nl, a hosted service for Human Resource Management for small to medium sized companies. The site uses Products.plonehrm, collective.sendaspdf and: jquery.pyproxy.
The idea is to replace KSS with jQuery for Ajax requests. Modify the DOM with python. We wanted it to be easy to use on client (browser) and server side. Keep jQuery syntax as close as possible. It should also be as extensible as jQuery, so existing plugins should work. It can be used as jQuery plugin.
pyproxy binds a call to an event. There is also pyproxy_call. In python: @jquery defines a view as callable by jquery.pyproxy. JQueryProxy: an object used to modify the DOM. extend_grammar: defines plugins syntax.
Current limitations: you cannot do a chained call, cannot save a query, cannot have functions as parameters (so no callbacks).
It is stable: used on production for months. Works with Plone and Django (can be extended to other frameworks), works with Firefox, Chrome, IE, WebKit.
The product is hosted on github. See the README there. Releases are available on PyPI (0.2 released on 22 October 2010).
See the slides.
More Dutch
But wait, there is more... if you are Dutch! I have a Dutch overview of all the lightning talks and a Dutch summary of all the talks.
Plone Gebruikersdag
Samenvatting van de Nederlandse Plone Gebruikersdag 2010 in Rotterdam.
In september werd de Nederlandse Plone Gebruikersdag 2010 gehouden in de Euromast, met prachtig uitzicht op het schitterende Rotterdam. Er waren ruim vijftig deelnemers op afgekomen. De dag was gevuld met lezingen van zo'n drie kwartier en een aantal 'lightning talks': bliksemsnelle praatjes van vijf tot zeven minuten. Natuurlijk was er ook een lunch, borrel en voor de nablijvers een diner, dus voldoende tijd om met elkaar te praten en kennis te maken. Hier volgt een korte samenvatting van de lezingen, met links naar wat uitgebreidere samenvattingen.
- Fabian Spaargaren (Exser): Naar web 2.0 met Plone
- Geir Bækholt (Jarn): Wat is er nieuw in Plone 4
- Jean-Paul Ladage (Zest Software): Plone voor uw mobiel
- Rob Gietema (Four Digits): Content bewerken in Plone met Deco
- Jeroen Vloothuis (KNMP) en Jan Murre (Pareto): Plone skinning met XDV
- Lightning Talks
Fabian Spaargaren (Exser): Naar web 2.0 met Plone
Exser is een samenwerkingsprogramma's van overheid, wetenschap en bedrijven met als doel diensteninnovatie. De website van Exser was statisch, maar Plone heeft daar dynamiek in gebracht. Op de website staat nu onder andere een nieuwsbrief, linked-in integratie, een twitter portlet, RSS feed.
Verder ging het praatje vooral communicatie tussen klant en webbouwer. Heb je aandacht voor je klant? Denk je mee? Doe je uurtje-factuurtje of spreek je vantevoren een vaste prijs af, misschien voor een deel van het werk?
Geir Bækholt (Jarn): Wat is er nieuw in Plone 4
Geir Bækholt, directeur bij Jarn en president van de Plone Foundation, geeft een overzicht van de stand van zaken van Plone en toekomstplannen voor Plone 4.1 en 5.
Plone 4.0 is begin september uitgebracht. Het was de bedoeling dat dit een kleine release zou worden, maar het is de grootste ooit geworden. Er zijn 27 grotere verbeteringen en nieuwe functionaliteit ('PLIPs'). Wat is er nieuw?
- Plone 4 is een stuk sneller. Plone 4 gebruikt Zope 2.12 en Python 2.6, wat helpt voor een kleiner geheugengebruik. Plone 4 is ongeveer 50 procent sneller dan Plone 3. Als je kijkt naar het aantal requests per seconde zijn we sneller dan Joomla, Drupal en Wordpress.
- BLOBs: Binary Large OBjects. Grote bestanden worden apart opgeslagen, wat het geheugengebruik terugbrengt.
- TinyMCE lost Kupu af als standaard visuele editor. Het is beter in het uploaden van afbeeldingen, bewerken van tabellen, invoegen van links, enzovoorts.
- Nieuwe uitstraling. Plone 4 komt met een vernieuwd, moderner thema.
- Beter gebruikersbeheer. Overal worden volledige namen gebruikt. Je kan inloggen met je e-mailadres, als je dit aanzet.
- Waarschijnlijk de eenvoudigste upgrade ooit. Natuurlijk verandert er een hoop tijdens de upgrade, dus houd backups bij de hand, maar een upgrade vanaf Plone 3 is niet spannend.
Wat zijn de toekomstplannen?
- Plone 4.1 komt waarschijnlijk begin 2011. Verwacht zijn onder
andere:
- rondleidingen door de gebruikersinterface met Amberjack
- verbeterd plaatsen van reacties
- verbeterde structuur van Verzamelingen (zoekmappen)
- nieuwe SiteAdmin rol, laten we zeggen een Manager zonder toegang tot de Zope Management Interface
- wachtwoordbeleid
- Plone 4.2: nog niet duidelijk wanneer dit gaat komen. Mogelijke
verbeteringen hier zijn:
- gebruiken van Chameleon om pagina's sneller te tonen (ongeveer 20 procent verbetering)
- voorbereiding architectuur voor Deco dat in Plone 5 komt
- betere batch-editing, tegelijk wijzigen van een aantal items
- Of Plone 4.3 er komt, weten we nog niet.
- Ergens aan de horizon is het magische Plone 5. Het zal de gebruikersinterface voor het bewerken flink verbeteren. Daar komen we aan de top te staan, met behulp van Deco en 'tiles' (tegels), geünificeerde contenttypes en een nieuwe interface voor het bewerken.
Lees meer... (Engels)
Jean-Paul Ladage (Zest Software): Plone voor uw mobiel
De enorme toename in het gebruik van smartphones maakt mobiele diensten lonend met de inzet van Plone GoMobile. Houd rekening met je doelgroep: welke mobieltjes worden gebruikt, welke schermresoluties horen daarbij?
Voor Plone is er Plone Go Mobile. Dit is een verzameling tools om binnen Plone nieuwe content voor mobiel te beheren of bestaande content te optimaliseren. Ook automatische doorsturing van bijvoorbeeld http://zestsoftware.nl naar http://m.zestsoftware.nl, de website en mobiele site van Zest Software.
Rob Gietema (Four Digits): Content bewerken in Plone met Deco
Met Deco wordt het onderhouden van een website echt leuk. Het geeft je alle vrijheid om pagina's op te maken. Deco zal standaard gebruikt worden in Plone 5 en je kan er in Plone 4 al mee experimenteren.
Deco werkt met een grid. Op dat grid kan je tiles (tegels) toevoegen met html; dat kan de weergave van de titel zijn, of een folder listing, of van alles en nog wat.
De tiles vervangen onder andere de viewlets en portlets, dus je hoeft weer wat minder technieken te weten.
Jeroen Vloothuis (KNMP) en Jan Murre (Pareto): Plone skinning met XDV
Een case studie van KNMP waarbij met Plone 4 en XDV de huisstijl is geïmplementeerd.
Het skinnen van een Plone site bestaat uit het aanpakken van CSS ('decorating the tree'), viewlets, portlets, main template. XDV gebruikt XSLT om die boom die Plone heeft opgezet te kortwieken. Met regels kan je zeggen: verplaats een deel van de html, of kopieer het, voeg wat toe aan de voor- of achterkant, haal wat weg. Dit is dus een nieuwe manier van het themen van een site. Zeker voor niet-programmeurs is dit potentieel een stuk sneller.
Hoe doe je deployment? Gebruik collective.xdv (nieuwe naam: Diazo) voor Plone.
Lightning Talks
Hierna volgden de 'lightning talks' of bliksempraatjes.
- Vincent Pretre (Zest Software): jquery.pyproxy
- Vervang KSS door jQuery voor Ajax requests. Zie http://pypi.python.org/pypi/jquery.pyproxy
- Roel Bruggink (Four Digits): Living Statues Sprint
- Met de Plone community een sprintje trekken voor de ontwikkeling van Deco. Zie http://blog.fourdigits.nl/living-statues-sprint-2010
- Fred van Dijk (Zest Software): pakketten die je (misschien) nog niet kent
- Kijk eens rond of je nog pakketten op de plank hebt liggen die je voor één klant hebt gemaakt maar die voor de Plone community ook interessant zijn. Voorbeelden van al dan niet gereleaste pakketten van Zest: collective.sendaspdf, zest.carouselitem, mr.inquisition, zest.portlet.contact, zest.teammember, zest.releaser. Zie de slides van Fred.
- Kees Hink (Goldmund, Wyldebeast and Wunderliebe): deurmat
- Binnen een jaar wilden twee van onze klanten een 'deurmat'. Een beetje zoals de homepage van http://plone.org. Maak linkjes aan, geef wat headers aan en je hebt een deurmat. Dat doet Products.Doormat.
- Thijs Jonkman (Pareto): XDV skinning
- Je kan XDV theming gebruiken om Collage in het Deco keurslijf te persen. De CSS positionering van Deco kan je namelijk ook al in Plone 3 of 4 gebruiken. De html code van Collage is lelijk, maar als je er een net zo lelijke xslt sheet tegenaan gooit, krijg je er wel wat schoons uit.
- Maurits van Rees (Zest Software): collective.watcherlist
- Ontwikkeld vanuit Products.Poi. Houd een lijstje bij van mensen die updates willen van een content item. Registreer een browser view. Stuur ze automatisch een mailtje. Zie http://plone.org/products/collective.watcherlist
Lightning talks
Bliksempraatjes tijdens de Nederlandse Plone Gebruikersdag 2010.
Snelle, vaak technische presentaties tijdens de Nederlandse Plone Gebruikersdag 2010 in de Euromast, Rotterdam.
- Vincent Pretre (Zest Software): jquery.pyproxy
- Roel Bruggink (Four Digits): Living Statues Sprint
- Fred van Dijk (Zest Software): pakketten die je (misschien) nog niet kent
- Kees Hink (Goldmund, Wyldebeast and Wunderliebe): deurmat
- Thijs Jonkman (Pareto): XDV skinning
- Maurits van Rees (Zest Software): collective.watcherlist
Vincent Pretre (Zest Software): jquery.pyproxy
Ik ben de hoofdontwikkelaar van Zest Software voor http://prettigpersoneel.nl, een online personeelsadministratie voor MKB'ers. De site gebruikt Products.plonehrm, collective.sendaspdf en: jquery.pyproxy.
Het idee is om KSS te vervangen door jQuery voor Ajax requests. De DOM aanpassen vanuit Python. We wilden dat het makkelijk te gebruiken was aan de client-kant (browser) en aan de server-kant. De python-syntax zo dicht mogelijk op de jQuery-syntax. Het zou net zo uitbreidbaar moeten zijn als jQuery, dus bestaande plugins zouden moeten worken. Het kan zelf als jQuery plugin gebruikt worden.
pyproxy bind een call aan een event. Er is ook pyproxy_call. In python code definieert @jquery een view als aanroepbaar door jquery.pyproxy. JQueryProxy: een object gebruikt om de DOM aan te passen. extend_grammar: definieer de syntax van plugins.
Huidige beperkingen: je kan geen chained call doen, kan geen query opslaan, kan geen functies als parameters gebruiken (dus geen callbacks).
Het is stabiel: al maanden in productie. Werkt met Plone en Django en kan uitgebreid worden naar andere frameworks. Werkt met Firefox, Chrome, IE, WebKit.
Het product wordt gehost op github. Zie de README daar. Releases zijn beschikbaar op PyPI (0.2 gereleased op 22 oktober 2010).
Zie de slides.
Roel Bruggink (Four Digits): Living Statues Sprint
De Plone community gebruikt sprints voor het ontwikkelen van nieuwe functionaliteit. Het idee is dat je met een aantal ontwikkelaars bij elkaar gaat zitten en een sprintje maakt in de ontwikkeling van een product. Eind augustus hebben wij van Four Digits de Living Statues Sprint in Arnhem georganiseerd. Twee keer per dag een stand-up meeting: kort overleg over wat je tot dan toe gedaan hebt en nu gaat doen. In dit geval hebben we vooral aan Deco gewerkt, zie het praatje van Rob. Ook aan Hudson, een continue integratieserver voor automatisch testen, vergelijkbaar met buildbot.
Fred van Dijk (Zest Software): pakketten die je (misschien) nog niet kent
We hebben bij Zest Software een aantal pakketten gemaakt die je waarschijnlijk nog niet kent. Het basis CMS Plone is open source. Veel add-on modules zijn ook open source. Worden door integrators vaak in eerste instantie voor één klant gebouwd. Soms kom je erachter dat het vrij makkelijk is om het voor algemeen gebruik te maken, bijvoorbeeld PloneFormGen. Wat komt er dan zoal uit Nederland, en hier specifiek bij Zest Software. Verkapte oproep: laat wat van je eigen modules zien.
- collective.sendaspdf: laat de server de pdf maken van een webpagina en email die. Heeft extra module nodig (wkhtmltopdf).
- zest.carouselitem: toevoeging voor collective.carousel. Speciaal contentitempje met plaatje en wat extra instellingen, zoals een ander kleurtje.
- mr.inquisition: voorafgaand aan migraties: toon onder andere overzicht van gebruikte content types.
- zest.portlet.contact: speciaal portlet voor contactgegevens
- zest.teammember: overzicht van teamleden/medewerkers, op een mooie manier vormgegeven met verschillende portretten.
- zest.releaser: maakt releasen makkelijk
Verder heb je bijvoorbeeld:
- TinyMCE (Four Digits)
- infrae.subversion (Infrae)
- Mlango (Goldmund)
- enz
Maar ja, releasen is soms iets teveel werk, dus niet alle genoemde pakketten hebben we al daadwerkelijk gereleased. Zet hem op! En maak reclame!
Zie de slides.
Kees Hink (Goldmund, Wyldebeast and Wunderliebe): deurmat
Binnen een jaar wilden twee van onze klanten een 'deurmat'. Een beetje zoals de homepage van http://plone.org. Maak linkjes aan, geef wat headers aan en je hebt een deurmat. Dat doet Products.Doormat.
Thijs Jonkman (Pareto): XDV skinning
Je kan XDV theming gebruiken om Collage in het Deco keurslijf te persen. De CSS positionering van Deco kan je namelijk ook al in Plone 3 of 4 gebruiken. De html code van Collage is lelijk, maar als je er een net zo lelijke xslt sheet tegenaan gooit, krijg je er wel wat schoons uit.
Maurits van Rees (Zest Software): collective.watcherlist
Poi is een issue tracker voor Plone. Hij wordt op plone.org gebruikt. Ik doe daar sinds een paar jaar de ontwikkeling van. In de loop der tijd heb ik daar een aantal problemen opgelost rond het versturen van e-mails met 'internationale' karakters, van Nederlandse accenten in de namen van ontvangers tot Japanse karakters in de tekst. Dat wilde ik het liefst maar één keer doen. Ik heb dus die code afgesplitst in een nieuw pakket collective.watcherlist. Poi 2.0 (voor Plone 4) gebruikt dit.
Met behulp van dit product kan je een lijstje bijhouden van mensen die geïnteresseerd zijn in updates van een item. In het geval van Poi zijn dat nieuwe issues of wijzigingen aan bestaande issues. Out-of-the-box doet watcherlist nog helemaal niets. Je moet zelf als programmeur dus integratiecode schrijven. Gelukkig is dat niet al te moeilijk naar mijn idee. De template die verstuurd wordt, registreer je gewoon als browser view. In de code van watcherlist zit een integratievoorbeeld.
Als ik ooit nog eens gek wordt van Singing & Dancing, maak ik een nieuwsbriefproduct met watcherlist als basis. :-)