Just did a pass over the sale contract:
- Why is auctionData a function arg? Anyone can pass in an arbitrary limit, which would bypass the mint limit.
- To better stop bots you should've at least included a nonce with the signature.
Happy to chat more about ways to improve.