投稿目的
この投稿は、ワークフローを実行し、プログラムで関連付けをリストする方法を示すことを目的としています。 ワークフローは標準でも、Visual Studioで作成してもかまいません。 ワークフローに関しては、標準のタスクリストとワークフロー履歴リストを使用します。
例
Web変数は、ワークフローに関連付ける必要があるリストを含むSPWebオブジェクトであることに同意します。
1.使用する変数を宣言します
SPList myList = null ; // workflow string myListName = null ; // SPList historyList = null ; // workflow SPList taskList = null ; // workflow string workflowTemplateGuid = null ; // Guid worklfow SPWorkflowTemplate workflowTemplate = null ; // Workflow SPWorkflowAssociation workflowAssociation = null ; // workflow string workflowAssocName = null ; // workflow
* This source code was highlighted with Source Code Highlighter .
SPList myList = null ; // workflow string myListName = null ; // SPList historyList = null ; // workflow SPList taskList = null ; // workflow string workflowTemplateGuid = null ; // Guid worklfow SPWorkflowTemplate workflowTemplate = null ; // Workflow SPWorkflowAssociation workflowAssociation = null ; // workflow string workflowAssocName = null ; // workflow
* This source code was highlighted with Source Code Highlighter .
SPList myList = null ; // workflow string myListName = null ; // SPList historyList = null ; // workflow SPList taskList = null ; // workflow string workflowTemplateGuid = null ; // Guid worklfow SPWorkflowTemplate workflowTemplate = null ; // Workflow SPWorkflowAssociation workflowAssociation = null ; // workflow string workflowAssocName = null ; // workflow
* This source code was highlighted with Source Code Highlighter .
SPList myList = null ; // workflow string myListName = null ; // SPList historyList = null ; // workflow SPList taskList = null ; // workflow string workflowTemplateGuid = null ; // Guid worklfow SPWorkflowTemplate workflowTemplate = null ; // Workflow SPWorkflowAssociation workflowAssociation = null ; // workflow string workflowAssocName = null ; // workflow
* This source code was highlighted with Source Code Highlighter .
SPList myList = null ; // workflow string myListName = null ; // SPList historyList = null ; // workflow SPList taskList = null ; // workflow string workflowTemplateGuid = null ; // Guid worklfow SPWorkflowTemplate workflowTemplate = null ; // Workflow SPWorkflowAssociation workflowAssociation = null ; // workflow string workflowAssocName = null ; // workflow
* This source code was highlighted with Source Code Highlighter .
SPList myList = null ; // workflow string myListName = null ; // SPList historyList = null ; // workflow SPList taskList = null ; // workflow string workflowTemplateGuid = null ; // Guid worklfow SPWorkflowTemplate workflowTemplate = null ; // Workflow SPWorkflowAssociation workflowAssociation = null ; // workflow string workflowAssocName = null ; // workflow
* This source code was highlighted with Source Code Highlighter .
SPList myList = null ; // workflow string myListName = null ; // SPList historyList = null ; // workflow SPList taskList = null ; // workflow string workflowTemplateGuid = null ; // Guid worklfow SPWorkflowTemplate workflowTemplate = null ; // Workflow SPWorkflowAssociation workflowAssociation = null ; // workflow string workflowAssocName = null ; // workflow
* This source code was highlighted with Source Code Highlighter .
SPList myList = null ; // workflow string myListName = null ; // SPList historyList = null ; // workflow SPList taskList = null ; // workflow string workflowTemplateGuid = null ; // Guid worklfow SPWorkflowTemplate workflowTemplate = null ; // Workflow SPWorkflowAssociation workflowAssociation = null ; // workflow string workflowAssocName = null ; // workflow
* This source code was highlighted with Source Code Highlighter .
SPList myList = null ; // workflow string myListName = null ; // SPList historyList = null ; // workflow SPList taskList = null ; // workflow string workflowTemplateGuid = null ; // Guid worklfow SPWorkflowTemplate workflowTemplate = null ; // Workflow SPWorkflowAssociation workflowAssociation = null ; // workflow string workflowAssocName = null ; // workflow
* This source code was highlighted with Source Code Highlighter .
SPList myList = null ; // workflow string myListName = null ; // SPList historyList = null ; // workflow SPList taskList = null ; // workflow string workflowTemplateGuid = null ; // Guid worklfow SPWorkflowTemplate workflowTemplate = null ; // Workflow SPWorkflowAssociation workflowAssociation = null ; // workflow string workflowAssocName = null ; // workflow
* This source code was highlighted with Source Code Highlighter .
2.初期化
リストの内部名を必ず使用してください。 ワークフローとの関連付けの名前を設定し、対応するワークフローの名前と一致させることができます。
- myListName = "マイリスト名" ;
- workflowAssocName = "My Workflow" ;
*このソースコードは、 ソースコードハイライターで強調表示されました。
3.ワークフローテンプレートを取得する
カスタムワークフローを使用し、そのテンプレートのGUIDを知りたい場合は、それを使用します。
- workflowTemplateGuid = "BAD855B1-32CE-4bf1-A29E-463678304E1A" ;
- workflowTemplate = web.WorkflowTemplates [ new Guid (workflowTemplateGuid)];
*このソースコードは、 ソースコードハイライターで強調表示されました。
GetTemplateByNameメソッドを使用してテンプレートGUIDを取得することもできます。
- //ワークフロー履歴のリストを取得しようとしています
- 試してみる
- {
- historyList = web.Lists [ "ワークフロー履歴" ];
- }
- catch (ArgumentException exc)
- {
- //ワークフロー履歴リストを作成します
- Guid listGuid = web.Lists.Add( "Workflow History" 、 "" 、SPListTemplateType.WorkflowHistory);
- historyList = web.Lists [listGuid];
- historyList.Hidden = true ;
- historyList.Update();
- }
*このソースコードは、 ソースコードハイライターで強調表示されました。
4.ワークフローの履歴とタスクのリストを取得または作成します。
ワークフローで使用される履歴リストは、WorkflowHistoryリストテンプレートから継承する必要があります。 ほとんどの場合、作成する必要はありません。
- workflowTemplate = web.WorkflowTemplates.GetTemplateByName( "テンプレート名" 、System.Globalization.CultureInfo.CurrentCulture);
*このソースコードは、 ソースコードハイライターで強調表示されました。
タスクリストは、タスクリストテンプレートから継承された通常のリストです。 ワークフロー用の特定のタスクリストを作成する場合は、「タスク」と呼ばないでください。 たとえば、「ワークフロータスク」と呼ぶことができます。
- //ワークフローのタスクのリストを取得しようとしています
- 試してみる
- {
- taskList = web.Lists [ "ワークフロータスク" ];
- }
- catch (ArgumentException exc)
- {
- //ワークフローのタスクリストを作成します
- Guid listGuid = web.Lists.Add( "Workflow Tasks" 、 "" 、SPListTemplateType.Tasks);
- taskList = web.Lists [listGuid];
- taskList.Hidden = true ;
- taskList.Update();
- }
*このソースコードは、 ソースコードハイライターで強調表示されました。
5.ワークフローとの関連付けを作成し、構成してリストに添付します。
- //サイト(Web)の安全でない更新を有効にします
- web.AllowUnsafeUpdates = true ;
- 試してみる
- {
- //ワークフローの関連付けを作成します
- workflowAssociation = SPWorkflowAssociation.CreateListAssociation(workflowTemplate、workflowAssocName、taskList、historyList);
- //ワークフローパラメータを設定します
- workflowAssociation.AllowManual = false ;
- workflowAssociation.AutoStartCreate = true ;
- workflowAssociation.AutoStartChange = false ;
- //ワークフローをリストにバインドします
- myList.AddWorkflowAssociation(workflowAssociation);
- //関連付けを有効にします
- workflowAssociation.Enabled = true ;
- }
- ついに
- {
- web.AllowUnsafeUpdates = false ;
- }
*このソースコードは、 ソースコードハイライターで強調表示されました。