Domino Upgrade

Search

About Me

I am the "Lotus Technology & Productivity Advisor" for IBM Asia Pacific. I'm based in Singapore.
Reach out to me via:
Follow notessensei on Twitter
Yahoo IM
Skype
Sametime
IBM

Ads by Google

Twitter

Languages

Other languages on request.

Visitors

30/07/2006

Before you call hotline the next time

Category
Watch this

25/07/2006

IBM's product names finally get a bite?

Category
IBM isn't famous for creating snappy product names and we had a lot of running Jokes on that topic. Would you consider a VPN solution with the name WECM (Sounds like "wack them")? But something is happening. After giving back Sametime and Quickplace their names somebody started thinking. Since WECM does connect you back to you enterprise, why not call it IBM Connect (just watch, it will happen)? Now I read on Jeff Eisen's blog in the Hannover 101 story, that the artist formerly known as "Websphere Everyplace Deployment" (a.k.a WED) will be known as (drum roll) Lotus Expeditor. Seems a lot of Websphere gets removed from the product names.
Now we need to finalize that push an cleanup some more. The Workplace Managed Client (WMC) would be the next candidate. We should call it Workplace Desktop. So we could have the Workplace Notes Desktop and the Workplace Forms Desktop or the Workplace Shared Desktop. Of course the Workplace brand has caused a lot of confusion too and might rather be on the list of endangered species. The Lotus ISV information blog has just been renamed back from The Workplace Channel into The Lotus Channel.

20/07/2006

What are you hiding from me?

QuickImage Category

By now you should be able to extract your database design as DXL. This opens a series of possibilities to run reports against your database to gain more insights into its design. Since Notes is around for so many years you will face the situation to inherit a database you haven't written. To understand its logic you need so see how Hide-when formulas have been used in the all over design. The following XSLT allows you to do this extraction.

Use it at a starting point and play with the layout. Ideas you could look at: Pack the whole report into a single table and load it into your favorite spreadsheet for sorting (a fancy Ajax lib could do that to).

<xsl:stylesheetversion="1.0" >
<xsl:outputmethod="xml"version="1.0"encoding="UTF-8"indent="yes" />
<xsl:templatematch="/" >
<html >
<head >
<title />
<styletype="text/css" />
</head>
<body >
<table >
<xsl:apply-templatesselect="//d:form" />
<xsl:apply-templatesselect="//d:subform" />
</table>
</body>
</html>
</xsl:template>
<xsl:templatematch="d:form" >
<tr >
<thcolspan="3" >
<h1 > Form
<xsl:value-ofselect="@name" />
</h1>
</th>
</tr>
<tr >
<th />
<th />
<th />
</tr>
<xsl:apply-templatesselect="//d:pardef[d:code/@event='hidewhen']" />
</xsl:template>
<xsl:templatematch="d:subform" >
<tr >
<thcolspan="3" >
<h1 > Subform
<xsl:value-ofselect="@name" />
</h1>
</th>
</tr>
<tr >
<th />
<th />
<th />
</tr>
<xsl:apply-templatesselect="//d:pardef[d:code/@event='hidewhen']" />
</xsl:template>
<xsl:templatematch="d:pardef" >
<tr >
<tdbgcolor="#EEEEFF" >
<xsl:value-ofselect="@id" />
</td>
<tdbgcolor="#EEFFEE" >
<xsl:value-ofselect="d:code/@enabled" />
</td>
<tdbgcolor="#FFEEEE" >
<xsl:value-ofselect="d:code[@event='hidewhen']/d:formula" />
</td>
</tr>
</xsl:template>
</xsl:stylesheet>

14/07/2006

Developing OpenSource Software is fun (allways) and paid for (sometime)

Category
Benno Stoll just published his master thesis at the University of Zurich in Switzerland. He researched the motivation of OpenSource developers. From the summary:
42% of the time spent for open source is financially compensated. However, we have to take into account that these figures may underestimate the amount of paid work. Paid open source developers are members of well-known open source projects. Such projects, however, can afford their own project infrastructure and are not dependent on platforms like SourceForge. Thus, the share of paid open source programmers may be rather underrepresented in the study's sample. (...)
In view of the importance of fun, the present study yielded the following results:
  • Fun matters: a simple model containing fun and spare time as independent variables can explain roughly 27% to 34% of the engagement for open source.
  • Spare Time matters: the amount of time spent by open source developers is significantly determined by the quantity of spare time the programmers have. However, the availability of spare time does not matter if the open source developers are asked for their willingness for future activities for open source.
  • The joy of programming does not wear off: each additional unit of fun is transferred linearly into additional commitment.

Go read the full report

09/07/2006

Getting hold of your replication formulas (SnTT Sunday edition)

QuickImage Category

Since R6 we are able to manipulate replication formulas using Lotus Script. You simply retrieve the entry and update or delete it. There is only one problem: If you don't know what custom replication pairs are in your database you can't do anything about it. Since "wild" custom replication formulas are a nightmare to track down I created the following script and XSLT stylesheet to extract this information using DXL. My script simply creates documents that document the settings. It will be easy to extend the script to include deletion of the entries. Or you could modifiy it to track replication formulas in multiple databases.

As usual: your mileage might vary!

Option Public Option Declare Sub Initialize Dim db As NotesDatabase Dim notecol As NotesNoteCollection Dim exporter As NotesDXLExporter Dim importer As NotesDXLImporter Dim transformer As NotesXSLTransformer Dim result As String Dim stream As NotesStream Dim s As New NotesSession 'Setup envionment Set db = s.CurrentDatabase 'Create the collection Set notecol = db.CreateNoteCollection(False) Call notecol.SelectAllAdminNotes(True) 'ACL, Replication Formulas Call notecol.BuildCollection Print "Build the collection ..." 'Get the transformation stylesheet Set stream = getRichTextSource("DocumentCustomReplicationFormulas") 'Create the import/export/transformer Set exporter = s.CreateDXLExporter Set transformer = s.CreateXSLTransformer Set importer = s.CreateDXLImporter 'Now we need to wire the exporter to the transformer to the importer Call exporter.SetInput(notecol) Call exporter.SetOutput(transformer) Call transformer.SetStylesheet(stream) Call transformer.setOutput(importer) Call importer.setOutput(db) 'Set the parameters for processing exporter.ExitOnFirstFatalError = False importer.ReplaceDBProperties = False importer.ReplicaRequiredForReplaceOrUpdate = False importer.ACLImportOption = DXLIMPORTOPTION_IGNORE importer.DesignImportOption = DXLIMPORTOPTION_IGNORE importer.DocumentImportOption = DXLIMPORTOPTION_CREATE Print "Processing" On Error Resume Next Call exporter.Process Print "Backup completed" result = exporter.log Call stream.Close Beep Msgbox result, 0, Cstr(importer.importednotecount) & " Documents created" End Sub Function getRichTextSource(SourceName As String) As NotesStream 'Retrieves a RichTextitem from the XSLTDefinitions view Dim db As NotesDatabase Dim doc As NotesDocument Dim v As NotesView Dim tmpStream As NotesStream Dim rt As NotesRichTextItem Dim s As New NotesSession Set db = s.CurrentDatabase Set v = db.GetView("XSLTDefinitions") Set doc = v.GetDocumentByKey(SourceName,True) If doc Is Nothing Then Msgbox "XSLT Definition " & SourceName & "not found" Exit Function End If Set rt = doc.GetFirstItem("Body") Set tmpStream = s.CreateStream tmpStream.WriteText(rt.GetUnformattedText) tmpStream.Position = 0 Set getRichTextSource = tmpStream End Function
This LotusScript was converted to HTML using the ls2html routine,
provided by Julian Robichaux at nsftools.com.

Disclaimer

This site is in no way affiliated, endorsed, sanctioned, supported, nor enlightened by Lotus Software nor IBM Corporation. I may be an employee, but the opinions, theories, facts, etc. presented here are my own and are in now way given in any official capacity. In short, these are my words and this is my site, not IBM's - and don't even begin to think otherwise. (Disclaimer shamelessly plugged from Rocky Oliver)

© 2003 - 2010 Stephan H. Wissel - all rights reserved as listed here: Creative Commons License
Unless otherwise labeled by its originating author, the content found on this site is made available under the terms of an Attribution/NonCommercial/ShareAlike Creative Commons License, with the exception that no rights are granted -- since they are not mine to grant -- in any logo, graphic design, trademarks or trade names of any type.

Get Firefox Use OpenDNS