Skip to content

Conversation

@pfefferle
Copy link
Member

@pfefferle pfefferle commented Oct 13, 2025

This PR refactors delete handling in the ActivityPub plugin by removing reader-specific custom post type (CPT) handling and simplifying the deletion logic. The changes improve the robustness of object comparison and add utility methods for deleting posts.

Proposed changes:

  • Simplified the delete handler logic by using object_to_uri() for consistent object comparison
  • Added new deletion utility methods to the Posts collection class
  • Removed redundant validation for minimal activities in the delete handler

Other information:

  • Have you written new tests for your changes, if applicable?

Testing instructions:

  • Go to '..'

Changelog entry

  • Automatically create a changelog entry from the details below.
Changelog Entry Details

Significance

  • Patch
  • Minor
  • Major

Type

  • Added - for new features
  • Changed - for changes in existing functionality
  • Deprecated - for soon-to-be removed features
  • Removed - for now removed features
  • Fixed - for any bug fixes
  • Security - in case of vulnerabilities

Message

pfefferle and others added 19 commits October 13, 2025 10:45
Introduces a new 'ap_object' post type and related taxonomies for handling ActivityPub objects, including registration, CRUD operations, and taxonomy management. Updates create and update handlers to process non-interaction objects using the new Objects collection. Enhances debug functionality to support the new post type and taxonomies.
Introduced Sanitize::content() to process and format content for ActivityPub, including block support and HTML sanitization. Updated Objects class to use the new sanitizer for post content.
Introduces a new Blocks::html_to_blocks() method to convert HTML content into block format using DOMDocument parsing and block mapping. Refactors Sanitize to use this new method, replacing the previous regex-based paragraph splitting logic for improved accuracy and maintainability.
The get_node_attributes private method was removed and the logic for setting the 'ordered' attribute on 'ol' nodes is now handled inline. This simplifies the code by reducing indirection and focusing only on the required attribute for ordered lists.
Refactored the Blocks class by renaming the html_to_blocks method to convert_from_html for improved clarity. Updated all references to use the new method name.
Introduces new PHPUnit tests for content sanitization in Sanitize::content, covering scenarios such as block support, malicious content, URLs, empty content, and safe HTML preservation. Also adds a test for Blocks::convert_from_html to verify HTML-to-block conversion when blocks are supported.
Introduces tests to verify content sanitization in Create handler, handling of private activities, and behavior with malformed object data. Also ensures required post types are registered during test setup.
Introduces a comprehensive PHPUnit test suite for the Activitypub\Collection\Objects class, covering object addition, updating, retrieval by GUID, and activity-to-post conversion, including edge cases and error handling. Mocks HTTP requests for remote actor fetching and ensures correct post type registration for test isolation.
Renamed update_actor and update_object to handle_actor_update and handle_object_update for improved clarity and consistency. Combined logic for handling object and interaction updates into handle_object_update. Updated corresponding test method names to match the new handler method names.
Changed the PHPUnit @Covers annotation from ::update_actor to ::handle_actor_update in Test_Update to accurately reflect the method being tested.
Changed the post type labels in the registration array from 'Posts'/'Post' to 'Objects'/'Object' to better reflect the content type.
Inserted a blank line after the use statements in class-update.php to improve code readability and adhere to coding standards.
Deleted the Blocks::convert_from_html method and its related test, and updated the Sanitize class to no longer convert HTML content to blocks. This simplifies content sanitization by removing automatic block conversion.
Introduces static delete and delete_by_guid methods to the Objects class for removing objects by ID or GUID. Updates the Delete handler to use object_to_uri for accurate actor/object comparison when processing delete activities.
Refactored the Objects collection to Posts, updating class names, constants, and references in all relevant files. Adjusted post type from 'ap_object' to 'ap_post' and updated related taxonomy registrations, handlers, and tests to reflect the new naming convention. This improves clarity and consistency in the codebase.
Renamed includes/collection/class-objects.php to class-posts.php and updated the import in class-delete.php to use the new Posts class. Also prefixed wp_delete_comment with a backslash for clarity.
@pfefferle pfefferle requested a review from Copilot October 13, 2025 15:22
Copy link

Copilot AI left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Pull Request Overview

This PR refactors delete handling in the ActivityPub plugin by removing reader-specific custom post type (CPT) handling and simplifying the deletion logic. The changes improve the robustness of object comparison and add utility methods for deleting posts.

  • Simplified the delete handler logic by using object_to_uri() for consistent object comparison
  • Added new deletion utility methods to the Posts collection class
  • Removed redundant validation for minimal activities in the delete handler

Reviewed Changes

Copilot reviewed 2 out of 2 changed files in this pull request and generated 3 comments.

File Description
includes/handler/class-delete.php Simplified actor-object comparison logic and removed minimal activity validation
includes/collection/class-posts.php Added delete() and delete_by_guid() utility methods for post deletion

Tip: Customize your code reviews with copilot-instructions.md. Create the file or learn how to get started.

pfefferle and others added 3 commits October 13, 2025 17:32
Refactored the Delete handler to separate logic for deleting objects and actors into distinct methods. Added handle_object_delete and handle_actor_delete methods, and introduced maybe_delete_posts for post deletion. Improved clarity and maintainability by removing redundant variables and streamlining the switch statement.
Refactored the method name from create_object to create_post to better reflect its purpose of handling post creation. Updated all relevant references and docblocks for clarity.
Adds explicit WP_Error objects when Create or Update operations fail, ensuring consistent error reporting. Also updates the docblock for the Create handler to reflect possible result types.
Moved the default WP_Error assignment to the start of handle_object_update, ensuring $result is always initialized. Removed redundant error assignment after update attempts.
Improves error handling in the update process by setting a WP_Error when actor data cannot be fetched, instead of returning early. This ensures the state variable reflects the failure, providing better feedback for downstream processes.
@pfefferle pfefferle added this to the Reader v1 milestone Oct 13, 2025
Standardizes return values in the Create handler by returning false instead of void in certain early exit cases, and returning nothing when creation fails. This improves consistency and clarity in function outcomes.
@pfefferle pfefferle self-assigned this Oct 15, 2025
@pfefferle pfefferle changed the title Delete reader cpt Delete Reader Item Oct 15, 2025
@pfefferle pfefferle added the Skip Changelog Disables the "Changelog Updated" action for PRs where changelog entries are not necessary. label Oct 15, 2025
@pfefferle pfefferle marked this pull request as ready for review October 15, 2025 13:39
Implements logic to delete all posts associated with a remote actor when the actor is deleted or becomes a tombstone. Adds a new Posts::get_by_remote_actor() method, schedules the 'activitypub_delete_actor_posts' event, and updates the Delete handler and tests to cover these scenarios.
Base automatically changed from cpt-ap-post to trunk October 16, 2025 16:01
@pfefferle pfefferle requested a review from obenland October 16, 2025 16:04
Renamed 'activitypub_delete_actor_interactions' and 'activitypub_delete_actor_posts' hooks to 'activitypub_delete_remote_actor_interactions' and 'activitypub_delete_remote_actor_posts' for better clarity. Also refactored handler method names from 'handle_actor_delete' and 'handle_object_delete' to 'delete_remote_actor' and 'delete_object' respectively. Updated all references and related tests to use the new hook and method names.
@pfefferle pfefferle requested a review from obenland October 20, 2025 07:47
@pfefferle pfefferle merged commit 7bc9606 into trunk Oct 20, 2025
13 checks passed
@pfefferle pfefferle deleted the delete-reader-cpt branch October 20, 2025 18:48
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

[Feature] Collections Skip Changelog Disables the "Changelog Updated" action for PRs where changelog entries are not necessary. [Tests] Includes Tests

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants