【FileMaker】ローカル環境でバックアップしたい


FileMaker Advent Calendar 2019 の23日目です。初参加になります。
カレンダーを作成してくださった Atsuko Sekiguchi (tyuma) さん、ありがとうございます

内容的には初級レベルのお話ですので、FileMakerガチ勢の人はつまらなくても怒らないでください。

はじめに

FileMakerServerを導入すれば、バックアップはとても簡単に行うことができますが、自分だけのシステムを作って運用している方もとても多いのではないでしょうか。しかもそういうシステムに限って、結構重要な情報を管理していたり。
バックアップを取ろうと思うと、ご自身で名前を付けて保存したり、一旦閉じてコピー&ペーストしたりという方法になるかと思います。OSのスケジューラで自動化している方もいらっしゃるかもしれませんが、起動中の場合は破損の恐れがある、全く更新がなくても無駄なバックアップが取られている、といった問題点があります。今回のTipsがそのような状況改善の糸口になれば幸いです。
※内容を理解して取り入れてほしいので、サンプルファイルのアップロードは行いません。悪しからず。

条件

  • ローカル環境(FileMakerServerを使っていない環境)で運用しているシステム
  • FileMaker14移行(ディレクトリ選択機能を使うため 不要なら13以下でもOK)
  • Windows環境(こちらもディレクトリ関連の処理があるため その部分をmac用に変更してもらえればOK)

システム概要

  • 予めバックアップ先のディレクトリを指定。
  • システム終了時に、自動で上記の場所に日付+時刻のフォルダを作成し、その中にファイルを保存。
  • 手動でもバックアップできるようにボタンを配置。

レシピ

材料

  • ファイル(.fmp12)1つ
  • テーブル1つ(フィールド2つ)
  • 値一覧1つ
  • スクリプト5つ
  • スクリプトトリガー1つ
  • レイアウト1つ
    • フィールド1つ
    • ボタン2つ
    • チェックボックス1つ

手順

1.テーブル定義

特に難しいところはありません。追加したのは2つのフィールドだけです。

フィールド名 タイプ オプション 説明
保存先 テキスト グローバル バックアップを保存するディレクトリ
終了時自動保存 テキスト グローバル システム終了時に自動でバックアップを保存する場合の設定

2.スクリプト作成

作るスクリプトは5つです。コメントを入れているので細かい説明は省きますが、分からない箇所があればコメントください。

ディレクトリ選択

バックアップの保存場所を、選択するためのスクリプトです。滅多に変更するものでもないので、直接入力するわ。っていう人は作らなくて良いです。

ディレクトリ作成

日付+時間のフォルダを作ります。そこにバックアップファイルを保存します。

バックアップ作成

バックアップ実行時のメインとなるスクリプトです。ここから他のスクリプトを呼び出します。

※システムが複数のファイルで構成されている場合は、後述の「名前を付けて保存」スクリプトをそれぞれのファイルに作成して、このスクリプトから呼び出してください。

15行面「変数を設定」ステップだけ、ちょっとややこしいので中身を抜き出しておきます。やっていることは、現在日時を「2020-01-05 0905」のような形式に整形しているだけです。

$directory &
Let([
ts=Get ( タイムスタンプ );
y=Year(ts);
m=Right("00" & Month(ts); 2);
d=Right("00" & Day(ts); 2);
h=Right("00" & Hour(ts); 2);
min=Right("00" & Minute(ts); 2)
];
y & "-" & m & "-" & d & " " & h & min & "/"
)

名前を付けて保存

「名前を付けて保存」を実行するためのスクリプトです。

OnLastWindowClose

システム終了時に自動でバックアップを保存するために、OnLastWindowCloseトリガーへ設定するためのスクリプトです。

3.レイアウト作成

いたってシンプルです。

①保存先を入力するためのテキスト 作成したフィールドをそのまま配置してください。
②保存先をディレクトリ選択画面で選ぶためのボタン
「ディレクトリ選択」スクリプトを割り当てます。

③終了時に自動で保存させたるためのチェックボックス
「終了時自動保存」のカスタム値一覧を追加して、インスペクタから割り当てます。

④今すぐにバックアップを実行する場合にクリックするボタン

「バックアップ実行」スクリプトを割り当てます。

4.システム終了時のスクリプト割り当て

ファイルオプションから「スクリプトトリガ」タブを選択。イベント「OnLastWindowClose」に、先ほど作成した「OnLastWindowClose」を割り当てます。これで、システム終了のタイミング(すべてのウインドウが閉じたタイミング)で、バックアップが実行されます。

5.完成(動かしてみる)

バックアップ実行ボタンをクリックするか、終了時自動保存にチェックを入れてシステムを終了してください。以下のように指定ディレクトリに日付+時刻のフォルダが生成され、その中にバックアップファイルが保存されていれば成功です。

おしまい

今回作成した機能はベース中のベースなので、ここから要件によっていろいろと機能強化しても良いと思います。

例)

  • バックアップファイルの世代数設定(要は古いものは消していく)。
  • 最終バックアップ日時を表示する。
  • バックアップログ用のテーブルを作成し、バックアップの成功可否や保存場所、ファイルサイズ等の履歴を保存。参照も可能にする。

一度作ってしまえば、いろいろなシステムに流用できますので、是非実装してみてください。
それではよいお年を!