Entering the new era —We componentized sensenet ECM for version 7.0

Alright. Now, how to put it all back together.

It’s been a long one year, but we’re nearing the end of the componentization project for sensenet ECM. If you tried to keep up with the progress, what you could see, was a bunch of git repositories, NuGet and npm packages popping up now and again, but you may not be sure what each of them really does. You might be thinking “Okay, you tore the whole thing to pieces, but how the hell does it all fit together?” Fear not.

I’ll try and break down these components to you, so when you accidentally hop on to our github enterprise page, you won’t feel lost in the forest of repositories.

[[DISCLAIMER: I am not coming up with all this all by myself. People smarter than me, have already written a great description about this here. So if you don’t like my style, by all means, hop over there and read everything you can find.]]

If you’re still here, fasten your seatbelts. It’s going to be a long ride. So what’s lurking under the SenseNet enterprise in GitHub?

The Core

The essentials. The alpha, and the omega. What you need to have a powerful content management platform up and running on your premises.

SenseNet/sensenet
Current NuGet package

At the very core of sensenet ECM, there’s Sensenet Services. Services is the “Mother of All Components”: you’ll need it, if you want to do anything with sensenet ECM, for it is the heart of the platform.

It contains:

  • The main Content Repository and dynamic content type system
  • A set of built-in basic content types (File, Folder Workspace, ContentList/DocumentLibrary)
  • Indexing and Search
  • Security
  • SenseNet/sn-admin: This handy tool can be your best friend when developing on sensenet ECM. Be sure to get acquainted with each other.
  • SenseNet/sn-tools: When we face something more than once, it is nice to have a solution at hand the next time we encounter it. We collect our little tools in this repository.

But no UI, whatsoever. You can access the Content Repository inside Services through well defined — you guessed it — services/service entry points, such as the REST API, or WebDav. You can even use the javascript or the .NET client library, which are wrappers for the OData layer.

For detailed install steps please follow this link.

Extensions

Everything that makes your life better. Content types, we built for you. Prepackaged business logic in breadcrumbs, with mayo.

Tools make your life better. Use them.

SenseNet/WebPages
Current NuGet package

WebPages is our good old UI component. When you install it on top of Services, you get a login page and the Content Explorer out of the box. You can build your own pages using the app model and our built-in portlets. Everything you’ll find here is built with ASP.NET WebForms.

To summarize, when you install WebPages, you’ll have:

  • The Services component (it’s a requirement in the NuGet package)
  • The Content Explorer
  • A Login page
  • Our Built-in Portlets
For detailed install steps please follow this link.

SenseNet/Workspaces
Current NuGet package

Workspaces is a functional component for sensenet ECM, it contains predefined content types for workspaces, you can use for various scenarios. If you only have Services installed (because for whatever reason you don’t want to use WebPages or build your UI using ASP.NET WebForms), you’ll only get the workspace types. If, however, you have WebPages, you’ll also get the related content templates and the whole UI package for Workspaces — build entirely in ASP.NETWebForms.

For detailed install steps, please check this article.

SenseNet/Workflow
Current NuGet package

This component integrates the powerful Windows Workflow Foundation into your sensenet ECM. You can use it to build content driven workflows, such as the built-in Approval workflow.

If you want to build complex business scenarios and processes, Workflow is your go-to component.

SenseNet/sn-notification
Current NuGet package

Notifications lets your users subscribe to content changes in the Repository. The notifications are sent via e-mail either in bulk, or immediately.

SenseNet/sn-taskmanagement
Current NuGet package

Task manager is a component you need to install completely separately. It’s for managing long-running background tasks, such as preview generation. But don’t let us set limits for your creativity, the task manager is a powerful tool to run a bunch of tasks in the background on a seperate machine.

Make sure you read the documentation for Task Management and discover it’s full power.

Client libraries

Manipulate the Content Repository with the magic of client libraries. Build Single Page Applications, compelling UI’s, or WPF desktop apps, all powered with sensenet ECM! Take your pick.

Ask the server for some delicous content you can digest.

SenseNet/client-js
Current npm package

This Javascript (it’s really Typescript, “but who counts” nowadays) library lets you work with the Content Repository by providing a Javascript client API for the main content operations.

Since we’re talking about a Javascript library, instead of NuGet, you can install it from npm. Once you have a sensenet ECM Services running somewhere, set up CORS and you’re ready to start developing a Single Page Application for example.

There are several related packages that are in development and that will let you build applications in an even more productive fashion. These are:

The first library contains sensenet ECM UI controls implemented in Aurelia. The second does the same in React, with the exception that our React controls use Redux for a centralized state store, while our Aurelia controls don’t. All of these libraries have the prerequisite of installing sn-client-js.

SenseNet/sn-client-dotnet
Current NuGet package

If you fancy using the Content Repository from your .NET application, you can easily do that using the .NET Client for sensenet ECM. The library connects to the REST API and wraps it into a neat C# API. Use it any way you can think of (we think you could build nice WPF apps with it for example)!

If you have any questions, or feedback, talk to us. You can chat with us on Gitter, or send us e-mails, like in the medieval times.


One clap, two clap, three clap, forty?

By clapping more or less, you can signal to us which stories really stand out.