私はCFR21Part11などを必要とする環境で働いています。私はまだアプリを完全に準拠させていませんが、試行錯誤を繰り返してきたので、いくつかの場所で始めることができます。
1)Djangoの復帰もお勧めします。ただし、実行されたアクション(誰がいつ実行したかだけでなく)を使用して可変レベルの監査証跡を達成するには、提供されるものよりも少し多くが必要になります。このために、復帰シグナルの1つを使用して、コメントフィールドを評価可能なdictに変換し、行内の変数や実行されたアクションなどを呼び出しました。これは以下のとおりです。
https://github.com/etianen/django-reversion
@receiver(reversion.pre_revision_commit)
def it_worked(sender, **kwargs):
currentVersion = kwargs.pop('versions')[0].field_dict
fieldList = currentVersion.keys()
fieldList.remove('id')
commentDict = {}
try:
pastVersion = reversion.get_for_object(kwargs.pop('instances')[0])[0].field_dict
except IndexError:
for field in fieldList:
commentDict[field] = "Created"
except TypeError:
for field in fieldList:
commentDict[field] = "Deleted"
else:
for field in fieldList:
try:
pastTest = pastVersion[field]
except KeyError:
commentDict[field] = "Created"
else:
if currentVersion[field] != pastTest:
commentDict[field] = "Changed"
else:
commentDict[field] = "Unchanged"
comment = commentDict
revision = kwargs.pop('revision')
revision.comment = comment
revision.save()
kwargs['revision'] = revision
sender.save_revision
2/3)これには、オブジェクトレベルの権限システムを使用する必要があります。django-guardianを実装しました。実装できる複雑さのほとんど唯一の制限は、自分でまっすぐに保つことができるものの数です。実装する必要のあるアクセス許可の基本セットは、表示、編集、削除、およびある種のデータコントローラー/マネージャーの役割です。ただし、おそらくもっと複雑にしたいと思うでしょう。パーミッションチェックにはクラスベースのビューとミックスインを使用することを強くお勧めしますが、関数ベースでも機能します。これは、フィールドに何が起こるかを好きなように制御できるため、特定のアクションのパスワードの入力を求めるためにも使用できます。
https://github.com/lukaszb/django-guardian
4)有効期限が切れるパスワードは、必要に応じてDjango認証システムまたは任意のユーザーアカウント管理アプリでも実装できます。有効期限のカウントダウンを開始する日時を記録するには、フィールドを追加する必要があります。次に、ログイン時にカウントダウンからの時間を確認し、ウィンドウを超えていないかどうかを確認します。その場合は、パスワード変更の組み込みビューまたはアプリに適したメカニズムを使用して、新しいパスワードを作成するように要求します。
CFR 21 Part 11を実装する上で最も難しい部分は、要件を満たすためにプロジェクトが何をすべきかを適切な担当者に正確に教えてもらうことであり、コンプライアンスの検査を受けるには時間とコストがかかる可能性があります。
これがあなたが始めるのに役立つことを願っています。