メールでのインシデント起票
ServiceNowでのインシデント起票(ITSM)には、entry-point(起票起点)は3つ。
- Platform起票
- SP起票
- メール起票
1)Platform起票
incident.do でプラットフォーム上でインシデントを起票できる。
上記の入力フォームからsubmitをクリックすれば起票終了である。
2)SP起票(ServicePortal)
ServicePortalの問い合わせフォームから起票できる。
OOTB(初期状態)でのインシデント起票手順は、
1)ホーム画面の[Get Help]クリック
2)サービスカタログ画面の[create incident]クリック
サービスカタログは様々な顧客向けサービスのパッケージで、企業向け拡張として利用可能。いろいろ触ると楽しいですよ。
3)項目を入力して[submit]クリック
下記の入力フォームから入力すると、ビジネスルールとレコードプロデューサーが連動することによってインシデントが起票される。
下記、起票完了画面(ticket_conversation)
2.1)record producer
submitクリック時にrecord producer連動してチケットが起票されるが、その内部処理を見ていこう。
対象テーブル:record producer
対象レコード:create incident
レコードを開くと、さまざまな情報が出る。
基本情報は下記。
内部変数(質問項目とかカテゴライズ)はrelated linksのvariablesからできる。
受け渡しに使うデータなどの設定はスクリプトで行う。
var isMobile = GlideMobileExtensions.getDeviceType() == 'm';
var link = isMobile ? '#/!list/incident/q:active=true%5Ecaller_id=javascript:gs.user_id()%5EEQ' : 'home.do';
var linkLbl = isMobile ? "List" : "Homepage";
var br = '<br/>';
var linkURL = '<a href="' + link + '">' + gs.getMessage(linkLbl) + '</a>';
var msgArgs = [br, linkURL];
var info = gs.getMessage("This incident was opened on your behalf{0}The IT department will contact you if they need any further information{0}You can track status from this {1} {0}", msgArgs);
gs.addInfoMessage(info);
var caller = gs.getUserID();
var parent_table = RP.getParameterValue('sysparm_parent_table');
if (JSUtil.notNil(parent_table)) {
var parent_map = new GlideRecord('request_parent_mapping');
parent_map.addQuery('parent_table', parent_table);
parent_map.query();
if (parent_map.next())
var requested_for_field = parent_map.getValue('requested_for_field');
var parentGR = new GlideRecord(parent_table);
parentGR.addQuery('sys_id', RP.getParameterValue('sysparm_parent_sys_id'));
parentGR.query();
if (parentGR.next())
caller = parentGR.getValue(requested_for_field);
}
current.contact_type = 'self-service';
current.caller_id = caller;
if (producer.comments.length > 80)
current.short_description = producer.comments.substring(0, 79);
else
current.short_description = producer.comments;
current.description = producer.comments;
var incRPUtil = new LinkRecordProducerToIncident();
incRPUtil.linkRecordProducerToParentIncident(RP.getParameterValue('sysparm_parent_sys_id'), current);
currentObjectに設定値(short_description,description,urgency)を埋め込んで、
最後にLinkRecordProducerToIncident()で生成して、リダイレクトしています。
インシデントから要求を作成する
値が反映されて、インシデントレコードが生成されていることが確認できます。
3)メール起票設定
メール起票時の設定は、
下記の3つの手順が必要である。
- メールの送受信設定
- ユーザの設定
- ユーザにアドレスを設定
email propertiesにinbound,outboundのメール設定ができるので、メールでの調整はここ。
1)メール送受信設定
まず、ServiceNowからのin/outを可能とするには、
Email receiving enabled
Email sending enabled
ここのチェックボックスをYESにするだけ。
送信のSMTPと受信のPOP3サーバがこれでオンになる。カンタン。
メール設定で最初につまずく「SMTP」「POP」「IMAP」。その意味&設定方法は?
2)ユーザの設定
メール受信可能ユーザは、
**Send all email to this test email address (non-production testing)**のリストに値を入力することで追加できる。今はadminなので、追加でabel.tuterなどいろいろなユーザを加えることができる。
3)ユーザにアドレス設定
ユーザ(sys_user)レコードにはメールアドレスの入力項目があるので、
そこにメールアドレスを登録することではれてメールの送受信が可能となる。
appendix.TaskSLAについて
インシデントレコードのrelated linkにtask slaがくっついている。
これはSLAというITIL標準の概念。でService Level Agreementで、実務上ではインシデント起票から問題解決までの目標時間をインシデントの内容によって定義しよう、というもの。
SLA(えすえるえい)
インシデントレコードの、インパクト・緊急度から優先度を導出し、その優先度からSLAを生成している。
task_sla テーブルにレコードが定義されており、時間設定などが可能である。