30 May 2008
29 May 2008
The Fork in the Road for Social Media - ReadWriteWeb : Group buying has some possibilities. It at least fits the peer ethos, and it could be popular in a recession. To date, though, this is only a theory as far as I know. If I had to pick one sustainable revenue model, this would be the one. But the spark of innovation that turns this from a promising idea to a $100m plus revenue line is still missing.
OMGZ! It's 2000 all over again!
24 May 2008
Yay! I've got a shiny white Asus eeePC 900 Linux. It's so cute it should have a Hello Kitty sticker on the back. The eeeuser forum has been invaluable. Here's some things I've learned.
- The 900 with the 0502 bios upgrade does what the overclocking techniques did for the 700. It runs at 900Mhz on power and 650 on battery with speed stepping. So just ignore all those threads about overclocking.
- There's a repo at http://download.tuxfamily.org/xepcrepo p701 main
with a lot of packages specifically built for the eeepc. Add in the xandros repos and do pinning. pimpmyeee.sh does most of this for you but needs tweaking. Don't bother with the pure debian repos as there's very little that isn't already in those above and they'll just introduce dependency problems. pimpmyeee also makes it trivial to enable full desktop mode.
- Upgrade amarok to at least 1.4.8 (from xepcrepo) to avoid problems with the latest iPods and make lastfm streams work. It also seems to be more stable with large libs of tracks in samba shares that are not always there. check out dynamic collections and/or disable watch folders for changes to avoid Amarok just forgetting the whole collection.
- For some unknown reason, the eeepc xandros doesn't use the usual /etc/rc.d methods of auto-starting services based on runlevel. this is just weird! /etc/init.d entries exist but their not used. You have to create startup scripts in ~/.kde/Autostart with entries like
sudo /etc/init.d/autofs restart
[edited to add] There's an easier, better way. Near the end of the boot process it runs entries in /etc/fastservices where each entry is the name of a file in /etc/init.d So I added these two lines
- /etc/mtab keeps being recreated and grows like topsy with duplicate entries. Delete it and link it to /proc/mounts
- There are loads of forum threads about delaying network shares till after wireless connections come on line by putting netstart scripts into /etc/network/if-up.d/ They're all deluded! mountnfs in that directory is what the system uses anyway to remake samba and nfs shares. The problem is that wireless takes a little while to startup after networking comes online.
A better route is to use autofs.
1) build a mount command line for your samba share. Use cifs. add a noperm parameter so that a remote samba share that understands linux permissions doesn't override your local view of the permissions (like say a linksys Slug)
2) modify /etc/auto.master like this
/mnt/auto/ file:/etc/auto.mysamba --timeout=300 --ghost
3) create /etc/auto.mysamba
[mountname] -fstype=cifs,[mountoptions] [sharename]
where sharename is something like ://192.168.3.2/HDD_1_1_1
4) autostart autofs in your startup script in ~/.kde/Autostart
Now your share will be available as soon as you use it and will just return nothing when it's unavailable.
- Alt-click-drag let's you move the few dialogs that don't fit in the screen height.
- My internal microphone was crap and probably broken. I don't think I'm alone. I salvaged a mic capsule from an old portable home phone and soldered it in. Works a treat. You can get the screen surround off without opening the main case and voiding the warranty!
- Vodafone have a linux driver specially for the eeePC and 3G modems. It's got a couple of weird dependency problems that may or may not screw you up. Ignore them and it just works. Now I have to work out how to get it inside the case.
- It needs a bigger battery. Asus are screwing around with giving the UK a smaller capacity than the 700 or the 900 in other countries. There are aftermarket batteries that are more than double the capacity. but big.
16 May 2008
The Social Network Wars Begin In Earnest: Facebook Bans Google Friend Connect :
Why do all journalists have to frame issues as a war?
The first few widgets available on the Friends Connect OpenSocial hosted platform are from Google and in there is an OpenID Signin, and a Friends viewer. And also in there is a Facebook application. And it's this Facebook application that is calling Facebook's bluff.
Either Facebook's Connect API let's you use Facebook's auth and gives you access to your friends. Or not. And on the surface the answer is "Yes, as long as we like you". But even this isn't clear. FB appear to be saying that you can get and store ID numbers, but you can only display your contacts' data on the fly.
Which finally brings us down to a privacy debate that is central to the whole data portability drive as it relates to your list of friends. You have a claim on your own profile data. You have a claim on your list of friends. But you *don't* have a claim on your friend's profile data. And in that context Facebook looks like it's trying to do the right thing while also using it as a core part of their business model. Google is also trying to do the right thing from the public access point of view. Actually your friend's profile data is public information. And public information wants to be free.
14 May 2008
Prying Open the Social Graph - GigaOM :
I'm seeing an amazing number of articles that are criticising Google Friends Connect for not being about data portability and locking your data into Google.
So. Look at this in the context of Google promoting OpenSocial instead of in the context of Google opening up and providing data portability. OpenSocial is now 4 things.
1) An API for building widgets
2) An API for building a container for widgets for big web sites
3) A REST API for accessing the underlying data and mashing it up
05 May 2008
So nice to get a big win. There's been an ongoing, unanswered question in DataPortability. If we use XRDS-Simple as a way of listing services that the user provides, how do we know what URI to use for common service types? It felt like we needed a big list of service types that developers could agree on. Both those building XRDS files and those consuming them.
For some services, this seems relatively straight forwards. For instance a FOAF file in RDF-XML would have an entry in XRDS that looked like this.
http://xmlns.com/foaf/0.1/ is the xmlns for FOAF, it redirects to the FOAF specs and the FOAF community have committed to maintaining the URL indefinitely. The MediaType is shown as RDF-XML to distinguish from N3 although this is optional because it will be discovered when a consumer GETs the file.
But for some services this is going to be harder to identify and is going to require some buy in from the community developing the service type. For instance it's not immediately obvious what the Type should be for the page containing my Microformatted list of Profile pages marked up with rel="me". One possibility would be http://gmpg.org/xfn/11 But there's no guarantee that will be around for ever. And we'd want to break it down a little more. We really need 3 types for
- My profile page
- My list of external profiles
- My list of contacts
Anyway, we made contact with Gabe Wachob, one of the architects of XRDS-Simple and he announced last night http://xrdstype.net/ to be both a clearing house for the big list of types and if necessary to be a place to host a Type URI.
Until this gets going we'll probably start a list on the DataPotability wiki.
04 May 2008
I've been looking round a number of OpenID providers this morning. Almost all of them have kept up to date and are providing an XRDS file discovered though an http header when you GET the human memorable openid URL. I know I'm repeating myself but one way of looking at this is that they are all hosting a personal home page and then delegating from there to the actual openid server. This makes sense as it leaves their options open to add profile or other information to that page at some earlier or later date. So I'm still feeling the same way which is that the Service Catalogue should generally be the XRDS discovered at the home page. One of the entries will be the OpenID Server, either directly, or by a further redirection through the home page at the Service Provider. This makes it all a consistent method of finding it. And it allows us to attack the problem both at the OpenID Providers and via people's home blogs, or through their favourite Social Network.
Now say I have an XRDS at Voidstar which points through to the XRDS at MyOpenID which then points to the MyOpenID server. And say both I and MyOpenid have XRDS entries for other Services. The Relying party site really needs to aggregate all the XRDS entries into one list. It could get the profile service from MyOpenID and the Contact List service from Voidstar.
What we really need is for the JanRain Yadis library (and others) to return all this metadata to the calling program as part of OpenID discovery. The list of XRDS URLs found along the way and a list of the services in each one.
I like this. It then doesn't matter if the Service provider, the blog or some other site, hosts bits of the Service Catalogue. They can each contribute what they know. They can each choose whether to play Home Page Provider. It means we're not dependent on the OpenID provider but they can play along too.
As well as the parsing problem, I really need help on constructing appropriate entries for services within the XRDS file.
03 May 2008
The May DIY Project from the DataPortability project is to produce and markup blocks on people's websites and blogs with XFN rel="me".
Well firstly I've already done this some time ago. On the left you'll find a block giving every profile page where I've signed up for a service. Each link is marked up with the rel="me" microformat.
As a side effect of doing this I built a small test rig for navigating round these links and links like them. I started by using Google's Socialgraph API but that works on cached data and I needed something current.
That led me to trying to find libraries in PHP for parsing Microformats. Which in turn led me to an impassioned debate on the Microformats list. The gist is that you really, really don't want to write an HTML parser in any of the more common web programming languages. To me this means that Microformats are effectively write-only data when we're talking about App to App communication. That's not to say that they aren't useful. But App to App communication needs nice elegant standards with robust and formal definitions. Which is why most of them are based on XML. Burying the data within horrible, badly written HTML by marking up visible elements is just wrong. At least for App to App communications.
However, there is still merit in marking things up with microformats because firstly it's easy to do, and secondly you can use tools like the Firefox plugin Operator to grab them. Extracting a VCard from a web page you're looking at and dropping it into your local contacts store is a great use case.
So finally we get back to XFN and rel="me". Now it turns out that if you put the html through tidy so it's well formed XML and then query the nodes, it's relatively easy to extract all the XFN entries. Here's some sample PHP5 code which uses the loadHtml() function to do the HTML Tidy for you. The source HTML has to be really bad before this fails.
$url = 'http://voidstar.com/';
This gives us a route into querying something like my MyBlogLog page or my Plaxo Pulse page and finding all my profile pages so I don't have to type them all in yet again to the next service (FriendFeed, say) that wants the same data.
There's a side effect of putting your YASN-Roll (Yet Another Social Network Rollcall) on your weblog. It's great for self-publicists! Why wouldn't you want your blog readers to be able to find you on Twitter, Upcoming, Facebook, Plaxo and all the other places you hang out. Which finally brings us to the last part of the DataPortability DIY project. "Adopt an Alpha Blogger". This is where we go and hand hold a well known influential blogger, encourage them to "walk the walk" and get them to build an XFN enabled YASN-Roll on their blog.
And last but not least, if you run Wordpress, you don't have to do this by hand. Stephen Paul Weber has built a plug in for wordpress that does the hard part for you as part of the DiSo project.
I'm not sure why but I've been avoiding talking about Data Portability. It's time to change that.
Here's some thoughts on one of the primary Use Cases. This is aimed at initial population of a profile during signup to a service and the automatic finding of existing contacts already on the service.
* User U
* User's Home site/page H
* XRDS at the Home Page URL SC (For Service catalogue)
* New site where the user is signing up. N
* XRDS at the new site NX
* User's OpenID provider S (For Service Provider)
1) The User goes to the N Site's Signup page, where there's a field for OpenID.
2) The User puts their Home Page URL into the OpenID field.
3) The new site N uses XRDS discovery to retrieve the user's Service catalogue SC.
4) N reads and parses the SC looking for three things. Some of these may be combined.
* OpenID Service Provider and delegated ID
* Service providing Profile information SP
* Service providing Contact lists SCL
* Service providing a profile page URL list SCP
5) User is redirected to the OpenID Service Provider
6) The Service Provider looks up the N site's XRDS NX and confirms on screen that everything looks ok.
7) The User confirms that they want to sign in to the new site N
8) The user is redirected back to a profile form on the new site.
9) The new site N uses the Profile Service to retrieve the profile and populates the profile form with the data.
10) The User confirms that the profile data is correct
11) A new account is created with the profile data, the home site URL, the home site XRDS location and the OpenID key passed back from the service provider.
12) The new site N uses the Contacts list service SCL to retrieve the user's contacts.
13) The contact list is matched off against the existing member base. The new site can do whatever fits their business model. eg
* Make connections automatically
* Offer to follow all or some of them
* Send friend requests to all or some of them
14) The new site uses the profile page service SCP to retrieve the list of the user's other profile pages. Optionally it tells the SCP that there is a new entry for the user's new profile page on the New site. It can then do additional work on this eg - Store a link to the list that can be displayed dynamically on their new profile
* Store the profile pages locally
* Query them for RSS
Notes, Options and Issues
1) XRDS discovery should use that described in XRDS-Simple. Priority should be given to the http header method since this requires the minimum bandwidth.
2) The XRDS file should follow at least XRDS-Simple
3) This process requires that the user has a home page that can provide XRDS and has a simple enough URL to be used as the OpenID login. This may be a private blog, or a hosted service. This is a bottom up approach and the larger systems that provide hosted personal home pages should be encouraged to host an XRDS file for their member's profile pages.
4) The three services SP, SCL, SCP should be widely used, formal standards with libraries available for consuming them. Priority should be given to RDF-XML FOAF with additional namespaces. Not least because common usage of FOAF can handle all three services in a single file. However, there is a lack of a de facto standard in these areas. It is hoped that libraries appear to hide the complexity and to query and return common structured data from other systems such as the OpenSocial APIs, Google Contact APIs, MS Live Contacts and so on. hCard and XFN can be used providing ways can be found to parse them reliably and to encode all the required information.
5) The Contacts List service should provide at least one (and preferably more than one) common Inverse Functional Property such as mbox_sha1sum to aid matching with the existing members.
6) FOAF (like Atom and RSS) already has an auto-discovery method. This could be used in addition to XRDS. But work should be done to encourage moving to XRDS- Simple as a single auto-discovery method.
7) Standards, documentation and examples are needed to define how to code the three services in an XRDS file. And this has to allow for several possible service types for each entry. So a Profile Service entry might have several service entries of different protocols in a priority order
8) Properly parsing FOAF requires an RDF approach. It may be possible to recommend a structure that uses FOAF-XML and other preferred namespaces (such as vCard) into a form that is parsed by a simple XML parser.
9) It is assumed above in the process description that the three services do not require authentication. If they do then each should use their own authentication and discovery methods and work should be done to try and make this seamless to the user. It is recommended that oAuth is used by these services.
10) No attempt is made here to provide alternate personas through a single home page URL. The simplest solution is to use a different home page URL for the 2nd Persona.
11) It is also assumed that the OpenID provider concentrates on authentication and not profile/contact list management as well. OpenID Service providers may choose to do this. If they do then the service should be defined separately in the XRDS service catalogue. This goes against the development direction OpenID was taking with sReg and AX to combine this into a single service and so may cause some push back.
1) Work with the XRDS-Simple people to define, document and give examples of entries for common services.
2) Work with and encourage the DiSo (and others) people to develop plugins that create and manage an XRDS file for the common blog platforms. Work with them also to build plugins to create other related systems such as the microformatted list of the blogger's profile URLs. Help them to document these plugins as they are written, with examples.
3) Work with the OpenID people and JanRain to enhance and extend the Yadis auto- discovery libraries to parse XRDS and provide the service entries in an easily digestible form during the OpenID discovery process. Document recipes and examples that build on the Plaxo OpenID consumer guide on implementing a DP aware OpenID consumer
4) Work with the FOAF people to come up with a recommended set of namespaces, best practice and file layout-structure that is easy to create and read. Help and encourage the development of parsers that understand this best practice layout in all major languages. Work to define, document and give examples of putting private FOAF behind oAuth.
5) Work with the microformat people to define, document and give examples of best practice use of microformats. Help and encourage the development of parsers that understand this best practice in all major languages.
6) Work with the people developing the other major profile and contact list standards to make sure their standards work well with the "Profiles and Contacts population during initial signup" use case. include them in 1) above.
7) Develop and demonstrate prototypes of all of the above.
8) Encourage bloggers and the smaller hosted services and networks to implement the above. In particular, working one to one with the so called "Alpha-Bloggers".
02 May 2008
Hot: OpenID, oAuth, XRDS, XRDS-Simple, FOAF, OpenSocial Data APis
Cold: Microformats, hCard, XFN contact lists, OpenID AX
Indifferent: APML, OPML, MS Live Contacts
21 Apr 2008
The site maintenance over the last weekend went smoothly and I hope you're enjoying the much increased speed of the Ecademy website. We have two problems as a result.
Some people have been receiving email from the site that is dated December 2007. It seems we had a large queue of email that had been held. When that was copied across, the new email server finally delivered it. If you receive email notifications, particularly about subscription problems, that you weren't expecting then check the date. If the Sent date is very old, then simply discard it.
The main Contacts Search seems to have got out of step and some searches are not returning the data they should. This is currently being dealt with and should improve over the next day or so.
CTO Ecademy [from: JB Ecademy]
19 Apr 2008
We've now got Yahoo OpenID fully working to log into Ecademy.
1. Go to My Settings, Manage OpenIDs
2. Type in "yahoo.com" into the "Add a new OpenID" field and hit "Sign In"
3. After a moment and perhaps an intermediate screen, you'll be presented with a Yahoo screen asking if you want to log in to Ecademy.com. Click on the "Let Me In" button.
4. You're returned to Ecademy and your Yahoo OpenID is associated with your Ecademy account.
Now when you need to log in to Ecademy, the process is very similar.
1. Go to the login screen at Ecademy. Scroll down to the "Login with OpenID"
2. Type in Yahoo.com and click Sign in.
3. You're redirected to Yahoo asking if it's ok. Click "Let Me In"
4. You're back on the Ecademy home page and logged in. [from: JB Ecademy]
A second virus email has appeared with text about Ecademy, Subject: "ECADEMY will close work in April 2008". It appears to be from firstname.lastname@example.org
One copy we've seen was sent from a Korean home broadband PC using Outlook Express. This makes it look as though it's being sent by a botnet of infected PCs round the world.
Needless to say this is not from Ecademy, and is in no way connected with Ecademy servers, systems or people.
Ecademy never sends emails with attachments.
Ignore it. Don't open it. Delete it.
Chief Technology Officer
ps. Here's the text of the email
Dear email@example.com members, clients and guests of our portal,
Over the last few years our portal has helped you to organize your business, find new partners and increase sales.
However, all good things end. Many of you know that we have experienced legal problems over the last year. Our competitors from other social
networks are trying to take over our client base.
Our website has been hacked and our database was stolen. After that we were taken to court because of identity theft.
Unfortunately, legal expenses and unfavorable court verdict with following closure of our bank accounts will lead to closure of our website. All
paying members will receive refund starting from March 14th.
Please check attached file for legal information in regards to your account.
The Ecademy Team
Ecademy - The Social Network for Business People
Company Registration:7382702 VAT:718 0377 36
[from: JB Ecademy]
Over the last couple of days and again this evening we've had some problems with our database server.
It looks as though a request for an RSS feed was being made very frequently and this particular request was launching a database query that was inefficient and slow. The combination was overloading the database and leading to the site being extremely slow or unavailable.
This particular problem has now been dealt with and should not arise again.
Please accept our apologies for the outage.
Chief Technology Officer
Ecademy [from: JB Ecademy]
There's a virus email doing the rounds that appears to be a message from Ecademy support. It's a Virus or Trojan. At least one copy that we've seen appears to have come from an ADSL broadband line in Chile. The headers are forged and made to look as though it's from a fake Yahoo email address with a fake Yahoo message ID.
Needless to say this is not from Ecademy, and is in no way connected with Ecademy servers, systems or people.
At first glance the message could be taken to be designed to be a malicious attack on Ecademy but I'm inclined to think that it's actually just an example of clever social engineering. It wouldn't surprise me if there are or will be very similar emails apparently about other social networks just as there are already about all the banks.
Ignore it. Don't open it. Delete it.
Chief Technology Officer
Ecademy [from: JB Ecademy]
Some of you may have noticed that the Skype icons on Ecademy have changed and a lot of them now show a gray question mark. We made a change to the way Skype presence was displayed and these icons are now served direct by Skype's servers. This means that display of whether you're online should be more or less instant rather than delayed by an hour or not at all.
If you want your presence and status to be displayed, then you need to enable it in Skype. Within the Skype program the switch can be found in Tools, Options, Privacy, Privacy settings, and then check the box "Allow my status to be shown on the web". If you can't see the checkbox, click on "Advanced". The default is off, so if your Skype icon shows the gray question mark. you need to change it. [from: JB Ecademy]
This is a little tricky so pay attention!
Go and get yourself the following:-
- A Twitter Account
- A Facebook account
- An OpenID
- The URL for the RSS from your Ecademy status. This will be something like
Where 9999 is your Ecademy #ID number.
1) Sign in to Twitterfeed with your OpenID.
2) Create an entry in Twitterfeed for your Ecademy Status RSS. Route it to your Twitter account.
3) Add the Twitter application to your Facebook profile.
4) Click on the button at the top of the Twitter application setup where it says "Want Twitter to update your Facebook status? Click here!"
Now when you update your Ecademy status, it will flow though to Twitter and then on to Facebook automatically. [from: JB Ecademy]
I'm going to try to Skypecast the London Event tonight with Don Tapscott for people who cannot attend.
At around 7:30pm (UK time), go to this web address and follow the instructions. You will need your Skype ID and Password. [from: JB Ecademy]
Here's a challenge.
You're in Thailand.
You have your UK passport.
You have a UK bank account with internet banking and money in the account . You don't have your cheque book with you.
You can get to an Internet cafe.
The ATM has just swallowed your Bank card.
How do you get cash in your hand? [from: JB Ecademy]
- Twitterfeed Entries in an RSS feed copied to a Twitter account
- Twitter4Skype Twitter account updates copied to a Skype chat
- OpenID This page has a list of OpenID providers where you can get an OpenID
- RSS for your Ecademy status http://www.ecademy.com/module.php?mod=status&op=feed&uid=YourEcademyIDNumber
- RSS for your Ecademy contact's status http://www.ecademy.com/module.php?mod=status&op=feed&all=1&uid=YourEcademyIDNumber
Preparation. Get yourself an OpenID.
1. Copy your Ecademy status updates to your Twitter account
- Go to Twitterfeed.
- Log in with an OpenID
- Create a feed entry using your Ecademy status RSS
- Send it to your main Twitter account.
Every update on Ecademy also updates your Twitter
2. Copy your Ecademy Contact's status to a Twitter friend
- Create a dummy Twitter account (eg JBFeeds)
- Add this dummy account as a friend on your main Twitter account
- Go to Twitterfeed.
- Log in with an OpenID
- Create a feed entry using your Ecademy Contact's status RSS
- Send it to your dummy Twitter account. Prefix each tweet with: EC
Now you can see all your Twitter and Ecademy Friend's updates in one place.
3. Display your Ecademy Status on your Facebook profile
- Go to your Facebook profile.
- Add the Facebook Feeds RSS application http://apps.facebook.com/rssbook/
- Add the RSS for your Ecademy status as a feed
Your Ecademy status is now on your Facebook profile.
4. Add feeds from Facebook, Jaiku, Plazes, Ecademy to a Twitter Friend
- Follow on from 2. Seek out the RSS for all the other Status feeds for other services like Facebook, Jaiku, Plazes and add entries in Twitterfeed for them routed to your dummy Twitter user created in 2.
- Add a two letter prefix for each one like FB, EC, JK, PL
Now all your friend's on all your services can update their status and you'll see them all in one place.
5. Route all your Twitter updates to a Skype chat.
- Go here for a tutorial about Twitter to Skype.
1. Add twitter4skype as a contact.
2. Type the following as a single chat message to twitter4skype:
3. The system should return: twitter4skype Registration complete!
All the status updates you've gathered together in 4. appear in this Skype chat. Set Notifications to off for this chat so it doesn't popup every 5 minutes. [from: JB Ecademy]
1 to 20 of 3520