I am considering implementing the EIP-5192 Minimal Soulbound NFTs standard, even though events can not be emitted by a subordinate contract, as the EIP-5192 makes the emission of events optional. I am not particularly fond of this approach, as I believe that such a simple interface should require the emission of events. In my opinion, it would be better to have two separate interfaces:
interface IERC5192 {
function locked(uint tokenId) external view returns(bool);
}
and
interface IERC5192Extended is IERC5192 {
// events MUST be emitted
event Locked(uint tokenId);
event Unlocked(uint tokenId);
}
This way, a subordinate contract could implement the first interface without being required to implement the second. However, I understand that a compromise solution is better than no solution at all, so I may proceed with implementing it.