SN Pro Tips

View Original

What's New in Helsinki?

It seems like only yesterday that we upgraded to Geneva... Maybe that's because many ServiceNow customers still haven't done so. That won't stop us from exploring the new hotness that is Helsinki, though! As always we aim to provide you with the latest updates on the latest update

Get it?
That was a terrible pun.
I apologize. 

We've scoured the existing documentation, watched the available demos, and tried out the early-access dev instances. In this article, we're going to cover all of the most visible changes and new features in Helsinki so far on a product-by-product basis, and give you the low-down on what you can expect out of an upgrade. Let's get started! 

Note: This is part one of a two-part series on ServiceNow Helsinki. Subscribe to stay tuned for when part 2 comes out! 
See this content in the original post

Asset Management has always been closely linked with the CMDB, but a lot of that has involved manual work in the past. Now in Helsinki, it looks like we're getting a new feature called Asset-CI Mapping and Synchronization.

This new feature will allow you to synchronize asset and CI records by mapping their fields, states, and statuses to one another directly. Thus, changes made to a CI will trigger the asset record to be updated, and vice versa. This means that you get more consistent reports, more accurate records, and better accuracy overall. You can even create custom mapping synchronizations. 

Some examples of mappings you can create, include: 

  1. Mapping an Asset's State and Substate fields to Configuration Items' Hardware Status and Substatus fields (for hardware CIs)
  2. Mapping an Asset's State and Substate fields to the Configuration Items' Install Status field (for non-hardware CIs). 
    1. The Install Status field does not have a sub-field, but you can still map certain state conditions to it.
  3. Mapping various other Asset fields to particular CI fields. 

The synchronization can do in either direction, or both ways

See this content in the original post

Additionally in Helsinki, ServiceNow now allows you to set a Salvage Value and Expenditure Type for hardware models. Expenditure type can be either Capex (capital expenditure) or Opex (operational expenditure). 

Helsinki also introduces the Activity tracker for the Asset table, which is updated is the following fields are changed: Assigned to, Managed by, Reserved for, State, and Substate

The activity formatter also tracks if/when the asset is created or updated by a purchase order (if it's a hardware or software asset), or if it's associated with a transfer order that enters the initiated, cancelled, or received stage (if it's a hardware asset). 

See this content in the original post

But wait, there's more! Helsinki now (FINALLY!) adds the ability to mass update CIs through Change Management. To enable this functionality, enable to Change Management - Mass Update CI plugin (com.snc.change_management.mass_update_ci). This plugin is not enabled by default for either upgraded, OR for new instances. 

Note: Make sure that the Change management State Model plugin is already activated before enabling the Mass Update CI plugin. 

Mass updates to CIs are available only for normal and emergency changes. 

See this content in the original post

A few changes have come to the Incident module in Helsinki, as well as a whole new state model. Here are some of the changes: 

  1. Closed/cancelled incidents can't be reopened, but Resolved incidents can be, with a different incident number
  2. There are some minor tweaks to the incident notification emails templates.
    1. If you haven't customized these yourself (and thus they are upgraded with Helsinki), I recommend checking out the updated version to make sure you still like the formatting. 
  3. The Impact field is no longer on the Create Incident record producer by default. 
    1. This is mainly because, as many companies have already determined, it's not best practice to ask self-service users what the impact of their own incident is. Instead, users can specify their perceived "urgency" via that field. 
See this content in the original post

The Incident state model is changing just a little bit; we've now got the state values: NewIn Progress, On HoldResolvedClosed, and Canceled. However, when the state is set to On Hold, the following "reasons" can be associated with it: Awaiting CallerAwaiting EvidenceAwaiting Problem Resolution, and Awaiting Vendor

Unfortunately, this new state model is not available for upgraded instances. KB0564465 makes some explanation as to why. 

See this content in the original post

The Service Catalog has had a few tweaks to it as well, primarily allowing catalog management self-sufficiency, and diagnostics. 

See this content in the original post

Finally -- FINALLY, Catalog ownership has arrived. On the catalog definition page (Service Catalog > Catalog Definition > Maintain Catalogs), you can now assign a Manager to a given catalog.

The manager is able to edit and update the catalog, as well as the categories and catalog items within it. The manager can also assign editors, and a new manager if they like.

Only one Manager can be assigned to a catalog at one time, but it can have multiple editors. Managers must have the catalog_admin role, and editors must have the catalog_editor role. 

See this content in the original post

Helsinki adds some great catalog debugging functionality. A diagnostics related link has been added to catalog items, which allows you to quickly view "health" data. It checks for bad practice and performance or upgradeability-impacting factors, such as duplicate variables or DOM manipulation in catalog client scripts. It can be quite useful for narrowing down bugs or choke points, and will help you pick out synchronous AJAX calls in client scripts. 

See this content in the original post

The CMDB has been enhanced in Helsinki, and we know that a lot of ServiceNow customers will be happy about this one. The changes in CMDB Health will make reporting on CMDB accuracy and completeness a breeze, and the CMDB Extensions will take some of the manual work out of tracking certain asset types. Check out the details below. 

See this content in the original post

Helsinki gives us a really major upgrade here, which allows us to easily see the completeness, correctness, and compliance. To check out this new, fantastically useful Dashboard, navigate to Configuration > CMDB Dashboard

Completeness, in the context of these reports, means that CIs have the required and recommended fields populated. It does not refer to the completeness of discovery or anything like that, which is unfortunate because that would be awesome -- but I can't imagine how they'd determine that. 

Correctness means that CIs meet pre-defined data integrity rules which check for things like orphaned CIs.

Compliance validates that the CMDB data complies with pre-defined data certification rules. 

There is also a Relationships report, which checks the health of CI relationships, testing for indicators such as orphaned and duplicate relationships. 

More info on these reports, what they mean, and how to configure them can be found here

See this content in the original post

The CMDB has been updated with new table definitions to accommodate new extended CMDB tables in the following new plugins: 

  1. Mainframes (com.snc.cmdb.mainframe)
  2. Radio category (com.snc.cmdb.radio.category)
  3. Telecom category (com.snc.cmdb.telecom.category)
  4. Test equipment (com.snc.cmdb.test.equipment)
See this content in the original post

In this section, we'll go over some core platform changes, and stuff that is of particular interest to developers and administrators.

See this content in the original post

Have you ever tried to do something, only to have it spin ad-infinitum? It can be a real hassle to track down those transactions, especially if they're cancelled by the user. To help in troubleshooting, ServiceNow Helsinki now logs cancelled transactions (whether cancelled manually, or by quota rule) to a new table: syslog_cancellation.

This feature should come in really handy for debugging, but you can turn it off on a table-by-table basis, by changing the glide.quota.manager.log.cancellation table property. 

See this content in the original post

Wow, this has been a long time coming. We've been on ES3 for far too long in my opinion, but I'm glad that ES5 is finally here! 

If you're not too familiar with the different versions of JavaScript, there is a lot of stuff that was missing from ES3 (the version of JavaScript we've been using in ServiceNow since, it seems, forever). In fact, I wrote an article some time ago about how the Array.prototype.indexOf() method didn't work in ServiceNow, and how to get around it. The following code, for example, used to fail to run:

See this content in the original post

I am extremely happy to say that that article is now obsolete (if you upgrade to Helsinki), because the above code now works exactly as expected in a background script (which by the way, seems not to require security_admin elevation anymore), thanks to ECMAScript 5. This also enables you to use modern libraries, such as moment.js. Here's some info on what's new in ES5. And here's more

The new JS version support means we've also upgraded the underlying platform to Rhino version 1.7 R5.

See this content in the original post

JavaScript can now be run in two different "modes": Compatibility, and ES5 Standards mode. The JS engine automatically determines which mode to use on a script-by-script basis. 

Compatibility mode (ES3) is used for all scripts developed prior to the Helsinki release, and all global scripts. However, compatibility is not exactly the same as the old JS engine. For example, JSON.stringify() and JSON.parse() are now implemented using the ES5 native JSON object. The JSON .encode() and .decode() methods still exist, but should only be used when legacy behavior is desired. 

ES5 Standards Mode (ECMAScript 5 syntax) supports all the new hotness, including the use strict declaration, object extensibility control, getter and setter properties in objects, native JSON support (as mentioned above), and support for modern third-party libraries. 

See this content in the original post

User notification preferences have been thoroughly redesigned (see below) and users can opt in to or out of notifications on an individual basis if they like, and can see which notifications they're receiving for each of their devices, based on the table that the notification is generated from. 

Your users can access their notification preferences as usual, by going to their user icon at the top-right, clicking Profile, and then clicking the Notification Preferences UI action on the corresponding page. 

Note that these settings are different from the notification settings found in the sprocket menu at the top-right. 

That's not the only change to notifications, though. On the notification form (sysevent_email_action), in the Who will receive tab, there is now a Subscribable checkbox. If this box is ticked (which it is for some notifications by default), then users can manually choose to subscribe to that notification, and can define their own conditions. 

To do so, users should - from the Notification Preferences page above - click the Subscriptions tab at the top-right, and then click Add Personal Subscription + in the main body of the page. They will then be able to give their personal notification subscription a name, select an existing notification (that has the Subscribable checkbox ticked), and choose which devices to send it to. 

Once the notification is chosen, the user can then use a condition builder to set the conditions under which they should receive the notification. For example, a manager can choose to receive an email when an incident is assigned, but only if the incident is of a certain priority or higher. 

You can also use this to set up notifications specifically designed to be subscribed to, such as CI Affected. You can choose a specific CI for which you are responsible, and get a notification whenever an incident affects that record. 

See this content in the original post
Note: This is suspiciously missing from the documentation, but List v3 must be activated on upgraded instances. The plugin is com.glide.ui.list_v3. You'll then need to log out and back in, in order to see the changes. I've also noticed that split view is not available unless this plugin is activated. 

One of the first things you'll notice in List v3 if your users have complained about the lack of "List and Form View" in Geneva, is the "Split" view now available on lists. 

Just below the "split view" button, is the new list filter/query builder. Let me be frank... The new list filter/query builder UI is pretty awesome. I never realized what an annoying process it was to dot-walk when building a query until I used the Helsinki query builder. Check it out: 

ServiceNow Helsinki Query Builder List Filter UI

Wow; so much easier. A few clicks, and you've dot-walked over four levels; and that's not all. There's a Save/Load Filter button (with obvious functionality), a New Criteria button (which basically replaces the top-level Or button, but still seems cooler), and a Sort Filter button. This is a very nice improvement in my humble opinion, and I'm excited to use it in production. 

Speaking of conditions, List v3 now also supports multi-tiered list filtering. This allows you to build more complex queries, more easily.

Also in List v3, you'll find that UI Policies are now (finally) enforced during list editing! That's a fantastically useful enhancement, though it's been a long time coming. 

In List v3, the Personalize List Columns sprocket has lost its' icon, and moved to the "hamburger menu" at the top-right of the list view. 
There's actually a lot of options in that menu that used to be elsewhere, so if you're looking for something in the list view and can't find it where it used to be, check the hamburger menu

Also in List v3, the list footer is persistently at the bottom of the content view, so it's always within reach, meaning you can go to the next/previous page more easily.

There are a few minor things that were removed from List v3 as well. The seldom-used embedded and hierarchical lists that would show in List v2 are no longer possible in List v3. Detail rows for example, are no longer shown in List v3. 

The ability for Administrators to block access to list column personalization for end users has also been removed, making it easier to customize your experience. 

List v3 also applies to related lists as well - all related lists load asynchronously after the form loads, even if there are no v3 related lists on the form.

See this content in the original post

In this section, we'll point out some other more minor (or at least more succinct) changes in ServiceNow Helsinki. 

  1. XLSX support
    1. Import sets and export sets now support XLSX files. In fact, they're preferred for optimal performance! 
  2. Activity Stream Mentions
    1. Get someone's attention by mentioning them in the activity stream of a ticket, using the "@" character. By default, users receive an email notification when they are mentioned. 
  3. Remember List and Form View from Fuji and earlier? It was removed in Geneva, but in Helsinki they've brought it back. It's now called Split Mode
  4. On forms, the reference lookup icon (the magnifying glass) now opens the reference lookup list in a popover, rather than in a pop-up window. 

SN Pro Tips is owned and written by The SN Guys, ServiceNow consultants. Are you looking to upgrade your instance to Helsinki?
We humbly welcome you to schedule some time to chat and share your goals with us, so we can help your business Grow With Purpose


Did that article help you out? Check out some of our other articles below! 

See this content in the original post