12
6

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

デヂエのデータをPleasanterに移行してみた。

Last updated at Posted at 2022-03-10

はじめに

この記事は、サイボウズデヂエのライブラリを、プリザンターに移行した際の手順をまとめたものです。
添付ファイルを含むデヂエのデータを、添付ファイルと共にプリザンターに移行します。

プリザンターについて

オープンソースソフトウェアのローコード開発プラットフォームです。マウス操作で素早く簡単に業務アプリを作成でき、最小限のコードで機能を拡張できるので様々な要件に合わせた業務アプリを開発できます。
https://pleasanter.net

環境

  • 移行元:サイボウズ デヂエ 8
  • 移行先:Pleasanter バージョン 1.3.0.0

準備

デヂエ

最初から登録されている、商談報告書を利用します。
mojikyo45_640-2.gif

Pleasanterへの登録バリエーションを確認したいので、添付ファイルと金額のフィールドを追加しました。
image.png

Pleasanter

デヂエの項目に対応するように用意します。
screenshot-localhost-2022.03.02-17_50_10.png

ポイント

いくつか、Pleasanterでは対応していない属性だったり、考慮が必要な項目があったので整理。

添付ファイル

以下フォルダに保存される模様。ただし、デヂエの仕様に従いフォルダ・ファイルが作られているようで考慮が必要。実現方法は後述します。
\cgi-bin\cbdb\dze\file\DB
image.png
フォルダ名、ファイル名がデヂエのライブラリ、レコード、フィールドと紐づいているようです。

ラジオボタン

これは、Pleasanterには無い項目属性。ですが、分類項目の選択肢設定に置き換えます。
image.png

方針

デヂエの機能で出力したxmlをインプットとし、Powershellを使ってAPI経由でPleasanterへ登録してみたいと思います。

補足:PleasanterのAPI仕様はマニュアルを参照ください。

XMLを見てみる

image.png

field-listタグの要素をPleasanterの項目と紐づけます。

項目名 デヂエのfield ID Pleasanterへ登録する項目ID 補足
日付 4 DateB
部署名 5 ClassA
名前 6 ClassB
お客様コード 117 ClassC
お客様名 7 ClassD
商談項目 8 ClassF
商談内容 9 DescriptionA
見込みランク 10 ClassE ラジオ項目はPleasanterには分類項目として設定
次回訪問日 11 DateA
上司のチェック 12 CheckA
添付ファイル 136 AttachmentsA 添付ファイルは別途考慮
金額 142 NumA

ラジオボタン項目は以下のように設定してみました。
screenshot-localhost-2022.03.03-11_32_57.png
xmlには、”A”、”B”、”C” と設定されているので、これで行けるはず。

実装

定義宣言等

# pleasanter登録用のUrlを指定します。
$url = 'http://localhost/api/items/99999/create'

# pleasanter登録用のApiKeyを指定します。
$ApiKey = 'xxxxxxxxxxxxxxxxxxxxxxx'

# デヂエから出力したxmlファイルのPATHを指定します。
$source = 'C:\temp\db65.xml'

# デヂエ資源のPATHを指定します。(添付ファイルを登録するため)
$deziePatch = 'C:\Program Files (x86)\Apache Software Foundation\Apache2.2\cgi-bin\cbdb\dze'

# AttachmentsのcontentType判定用
Add-Type -AssemblyName System.Web

連想配列のKeyにデヂエのフィールドID、ValueにPleasanterの項目IDを設定、お互いを紐づけます。

# デヂエのフィールドIDとpleasanterの項目IDの対応を指定します。
$ConvItemsId = @{

    '4' = 'DateB'
    '5' = 'ClassA'
    '6' = 'ClassB'
    '117' = 'ClassC'
    '7' = 'ClassD'
    '8' = 'ClassF'
    '9' = 'DescriptionA'
    '10' = 'ClassE'
    '11' = 'DateA'
    '12' = 'CheckA'
    '136' = 'AttachmentsA'
    '142' = 'NumA'

}

メイン処理


function main {
    write-host 'main start'

    # xmlオブジェクト作成
    $xmlObj = [System.Xml.XmlDocument](Get-Content $source)

    # ライブラリIDを取得
    $libraryId = $xmlObj.dezie.library.GetAttribute('id')

    # record単位でループ
    foreach ($record in $xmlObj.dezie.library.'record-list'.record) {

        # レコードIDを取得
        $recordId = $record.GetAttribute('id')    

        $Hash = @{}
        $AttachmentsHash = @{}
        $ClassHash = @{}
        $DateHash = @{}
        $CheckHash = @{}
        $NumHash = @{}
        $DescriptionHash = @{}

        Write-Host 'recordId = ' $recordId
        
        # xmlのvalue要素からPleasanterへ登録する情報を編集
        foreach($valueItem in $record.value){

            # フィールドIDを取得
            $fieldId = $valueItem.GetAttribute('id')

            # フィールドIDからPleasanterの項目IDを判断し、各項目分類ごとに編集
            switch -Wildcard ($ConvItemsId[$fieldId]) {

                'Attachments*' {

                    # ファイル名からcontentTypeを取得
                    $contentType = [System.Web.MimeMapping]::GetMimeMapping($valueItem.file.innerText)
                    
                    # 添付ファイルはライブラリID、フィールドID、レコードIDより対象ファイルを判断
                    $attachFile = EditAttach-Path $libraryId $fieldId $recordId                    

                    # base64に変換
                    $b64 = ConvertTo-Base64 $attachFile
                    
                    # リクエストjson編集
                    $attachments = New-Object System.Collections.ArrayList
                    $attachments.Add(@{
                        Name = $valueItem.file.innerText
                        ContentType =  $contentType
                        Base64 = $b64
                    })
                    $AttachmentsHash.Add($ConvItemsId[$fieldId],$attachments)

                }
                
                'Class*' {
                    
                    # リクエストjson編集
                    $ClassHash.Add($ConvItemsId[$fieldId],$valueItem.innerText)
                
                }

                'Num*' {
                    
                    # リクエストjson編集
                    $NumHash.Add($ConvItemsId[$fieldId],[int]$valueItem.innerText)
                
                }

                'Check*' {
                    
                    # リクエストjson用にbool値に変換
                    if($valueItem.innerText -eq '0'){

                        $CheckHash.Add($ConvItemsId[$fieldId],$false)

                    }else{

                        $CheckHash.Add($ConvItemsId[$fieldId],$true)

                    }
                }

                'Date*' {
                    
                    # リクエストjson用にdatetimeに変換
                    $date = [DateTime]::ParseExact($valueItem.date,'yyyy-MM-dd', $null);
                    $DateHash.Add($ConvItemsId[$fieldId],$date)
                }

                'Description*' {
                    $DescriptionHash.Add($ConvItemsId[$fieldId],$valueItem.innerText)

                }
            }
        }


        # リクエストjson編集
        $Hash.Add('ApiVersion',1.1)
        $Hash.Add('ApiKey',$ApiKey)
    
        if($AttachmentsHash.Count -gt 0) {
            $Hash.Add('AttachmentsHash',$AttachmentsHash)    
        }

        if($ClassHash.Count -gt 0) {
            $Hash.Add('ClassHash',$ClassHash)
        }

        if($NumHash.Count -gt 0) {
            $Hash.Add('NumHash',$NumHash)    
        }

        if($CheckHash.Count -gt 0) {
            $Hash.Add('CheckHash',$CheckHash)    
        }

        if($DateHash.Count -gt 0) {
            $Hash.Add('DateHash',$DateHash)    
        }

        if($DescriptionHash.Count -gt 0) {
            $Hash.Add('DescriptionHash',$DescriptionHash)    
        }

        $requestBody = $Hash | ConvertTo-Json -Depth 3

        #write-host $requestBody

        $Byte = [System.Text.Encoding]::UTF8.GetBytes($requestBody)
        
        # APIリクエスト発行
        $res = Invoke-RestMethod -Uri $url -ContentType 'application/json' -Method POST -Body ${Byte}

        Write-Host 'Reg to Pleasanter Comp' 
    }

    write-host 'main end'
}

添付ファイル用処理

ライブラリID+フィールドID+レコードIDで対象の添付ファイルを判断します。

function EditAttach-Path($libraryId, $fieldId, $recordId) {

    $path = $deziePatch + '\file\DB\' + $libraryId +'\' + $fieldId + '\' + $recordId
    return $path

}

API登録用にBase64に変換します。

function ConvertTo-Base64($filePath) {

    $file = Get-Item $filePath
    $b64 = [Convert]::ToBase64String([System.IO.File]::ReadAllBytes($file.FullName))
    return $b64

}

実行結果

登録できました。添付ファイルもちゃんと取得できます。

screenshot-localhost-2022.03.03-11_41_13.png

まとめ

デヂエから出力されるxmlが意外とわかりやすく、内容を確認してどういう移行仕様にするかを整理できれば、取り込みは割と簡単にできそうです。

サンプル

参考に、[こちら]に実装したpowershellのサンプルスクリプトと、pleasanterのサイトパッケージがあります。

  • transitionDezie.ps1
  • 商談報告書_2022_03_03 17_28_48.json
12
6
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
12
6

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?