#pragma once #include #include #include #include #include class SetAttrMsgEx : public MirroredMessage> { public: typedef ErrorCodeResponseState ResponseState; virtual bool processIncoming(ResponseContext& ctx) override; std::tuple lock(EntryLockStore& store) override; bool isMirrored() override { return getEntryInfo()->getIsBuddyMirrored(); } private: std::unique_ptr executeLocally(ResponseContext& ctx, bool isSecondary) override; void forwardToSecondary(ResponseContext& ctx) override; FhgfsOpsErr setAttrRoot(); FhgfsOpsErr setChunkFileAttribs(FileInode& file, bool requestDynamicAttribs); FhgfsOpsErr setChunkFileAttribsSequential(FileInode& inode, bool requestDynamicAttribs); FhgfsOpsErr setChunkFileAttribsParallel(FileInode& inode, bool requestDynamicAttribs); FhgfsOpsErr processSecondaryResponse(NetMessage& resp) override { return (FhgfsOpsErr) static_cast(resp).getValue(); } const char* mirrorLogContext() const override { return "SetAttrMsgEx/forward"; } };