Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

"internal" node properties in Fusion/UI #4208

Closed
kitsunet opened this issue Apr 23, 2023 · 14 comments · Fixed by #5015
Closed

"internal" node properties in Fusion/UI #4208

kitsunet opened this issue Apr 23, 2023 · 14 comments · Fixed by #5015
Assignees
Labels

Comments

@kitsunet
Copy link
Member

kitsunet commented Apr 23, 2023

Currently there is this in Neos.Neos/NodeTypes/Mixin/Node.yaml

  properties:
    #TODO: IS IT BREAKING TO DISABLE THESE NODE PROPERTIES BELOW WITH ES CR?
    #_creationDateTime:
    #  type: DateTime
    #_lastModificationDateTime:
    #  type: DateTime
    #_lastPublicationDateTime:
    #  type: DateTime
    #_path:
    #  type: string
    #_name:
    #  type: string

And yes unsurprisingly this is breaking in multiple ways. These are assumed ot be there at least in the NodeInfoView but probably in other places, also userland code might use those ala q(node).property('_path') which is perfectly "legal" at the moment. So we need to adapt internal usage and create migrations for userland code if we want to get rid of those (as well as create an accessor for them I guess?)

@kitsunet kitsunet converted this from a draft issue Apr 23, 2023
@kitsunet kitsunet self-assigned this Apr 23, 2023
@kitsunet
Copy link
Member Author

This is related to #3434 as that is using them. However I have a fix prepared for that.

@mhsdesign
Copy link
Member

mhsdesign commented Jun 2, 2023

in 7.3 for example these are the node properties which can be accessed via the internal property syntax:

properties which are declared in the original NodeInterface:

_accessRestrictions
_accessRoles
_accessible
_autoCreated
_childNodes
_contentObject
_context
_contextPath
_depth
_dimensions
_hidden
_hiddenAfterDateTime
_hiddenBeforeDateTime
_hiddenInIndex
_identifier
_index
_label
_name
_node
_nodeData
_nodeType
_nodeTypeAllowedAsChildNode
_otherNodeVariants
_parent
_parentPath
_path
_primaryChildNode
_properties
_property
_propertyNames
_removed
_visible
_workspace

for completion (unrelated but i just wanted to document it) these are the settable properties a la NodeInterface:

_accessRoles
_contentObject
_hidden
_hiddenAfterDateTime
_hiddenBeforeDateTime
_hiddenInIndex
_index
_name
_nodeType
_property
_removed
_workspace

additionally accessible properties because of the TraversableNodeInterface and Node.

_cacheEntryIdentifier
_contentStreamIdentifier
_creationDateTime
_dimensionSpacePoint
_lastModificationDateTime
_lastPublicationDateTime
_nodeAggregateIdentifier
_nodeName
_nodeTypeName
_numberOfChildNodes
_originDimensionSpacePoint
_root
_tethered

_path and _identifier are still supported in the new 9.0 cr:

https://github.com/neos/neos-development-collection/blob/8d7acb506d87c76b47bf9114dddd696bee15fdab/Neos.ContentRepository.NodeAccess/Classes/FlowQueryOperations/PropertyOperation.php#L93C1-L100

but since we kept the dynamic internal access in 9.0

if ($propertyName[0] === '_') {
    return ObjectAccess::getPropertyPath($element, substr($propertyName, 1));
}

we will also allow in the future some magic wizardry for these (new) 9.0 properties:

_subgraphIdentity
_nodeAggregateId
_originDimensionSpacePoint
_classification
_nodeTypeName
_nodeType
_properties
_nodeName
_timestamps

im against that. Keeping a legacy layer: Ok but i would refrain from allowing new magic accessors.

also there are futher cases like here:

return ObjectAccess::getPropertyPath($element, substr($propertyPath, 1));

@kitsunet
Copy link
Member Author

Suggestion mentioned in daily today is to actually fully abandon these as it will just lead to confusion with people when some still work. Lets rather migrate them and offer alternatives where it makes sense.

@mhsdesign
Copy link
Member

100% agree.

Additionally we should discuss if _hiddenInIndex - which in 8.3 was a magic property and now in 9.0 is a normal but untypical property due to the underscore - should be renamed to hiddenInIndex. Otherwise we could say this is the last core property which requires an underscore.

@dlubitz
Copy link
Contributor

dlubitz commented Jan 3, 2024

Please check also the already created rector migrations:
neos/rector#39

@mhsdesign
Copy link
Member

To avoid confusion, and since we have rector migrations in place, we decided in the weekly that we wanted to drop the legacy layer: https://github.com/neos/neos-development-collection/blob/8d7acb506d87c76b47bf9114dddd696bee15fdab/Neos.ContentRepository.NodeAccess/Classes/FlowQueryOperations/PropertyOperation.php#L93C1-L100 and not further support the underscore _ syntax anymore.

We should especially look at some node types as the underscore _ syntax is there still used for example to define an editor for the _nodeType but that should rather be either hardcoded in the ui or declared elsewhere. I think neos 9 doesnt need the concept of underscores for untypical properties anymore, and they are opened for consumer land to be used freely.

@kitsunet
Copy link
Member Author

Unfortunately we actually added _hidden and _hiddenInIndex into the property declaration and use them as regular properties now, they are just in the json like anything else. Seems a bit big break to change that still?

@dlubitz
Copy link
Contributor

dlubitz commented Jan 19, 2024

What about a NodeMigration to rename the property?

@kitsunet
Copy link
Member Author

But rename it to what? 😆 The thing is ... complicated, I can explain in the weekly... or write it out here later.

@mhsdesign
Copy link
Member

_hidden and _nodeType must go from the nodeType yaml imo.

@bwaidelich
Copy link
Member

As decided in our weekly today, the plan is to:

  • Rename _hiddenInIndex to hiddenInMenu
  • Remove _hidden
  • Replace all remaining underscore properties in the core
  • Remove special handling for underscores in properties

kitsunet added a commit to kitsunet/neos-development-collection that referenced this issue Mar 6, 2024
Provides a helper to access hidden status as well as renaming
`_hiddenInIndex` to `hiddenInMenu`.

Fixes: neos#4208
@mhsdesign
Copy link
Member

Todo: explicit eel ordering support via time stamp fields: https://neos-project.slack.com/archives/C050C8FEK/p1709887830143079?thread_ts=1709403062.357079&cid=C050C8FEK

currently in 9.0-dev its sort('_timestamps.originalCreated')

@kitsunet kitsunet moved this from In Progress 🚧 to Under Review 👀 in Neos 9.0 Release Board Apr 10, 2024
mhsdesign added a commit to mhsdesign/neos-development-collection that referenced this issue Apr 26, 2024
@github-project-automation github-project-automation bot moved this from Under Review 👀 to Done ✅ in Neos 9.0 Release Board May 14, 2024
@mhsdesign
Copy link
Member

Not yet -> #5015

@mhsdesign mhsdesign reopened this May 14, 2024
@mhsdesign mhsdesign moved this from Done ✅ to In Progress 🚧 in Neos 9.0 Release Board May 14, 2024
@mhsdesign
Copy link
Member

mhsdesign commented Sep 24, 2024

Update 2024 these are all the properties accessible in the Neos 8 Node (via ObjectAccess::getGettablePropertyNames)

  • accessRestrictions
  • accessRoles
  • accessible
  • autoCreated
  • cacheEntryIdentifier, not part of 8.3 API 👻
  • childNodes
  • contentObject
  • contentStreamIdentifier, not part of 8.3 API 👻, throws in 8.3 NodeMethodIsUnsupported 💥
  • context, marked as internal in 8.3 👻
  • contextPath
  • creationDateTime, not part of 8.3 API 👻
  • depth
  • dimensionSpacePoint, not part of 8.3 API 👻, available in 9.0 ✅, throws in 8.3 NodeMethodIsUnsupported 💥
  • dimensions
  • hidden
  • hiddenAfterDateTime
  • hiddenBeforeDateTime
  • hiddenInIndex
  • identifier
  • index
  • label
  • lastModificationDateTime, not part of 8.3 API 👻
  • lastPublicationDateTime, not part of 8.3 API 👻
  • name, available in 9.0
  • nodeAggregateIdentifier, not part of 8.3 API 👻
  • nodeData, marked as internal in 8.3 👻
  • nodeName, not part of 8.3 API 👻
  • nodeType
  • nodeTypeName, not part of 8.3 API 👻, available in 9.0
  • numberOfChildNodes, not part of 8.3 API 👻
  • originDimensionSpacePoint, not part of 8.3 API 👻, available in 9.0 ✅, throws in 8.3 NodeMethodIsUnsupported 💥
  • otherNodeVariants
  • parent
  • parentPath
  • path
  • primaryChildNode
  • properties, available in 9.0
  • propertyNames
  • removed
  • root, not part of 8.3 API 👻
  • tethered, not part of 8.3 API 👻
  • visible
  • workspace

new additional properties in 9.0

  • aggregateId, only 9.0
  • classification, only 9.0
  • contentRepositoryId, only 9.0
  • tags, only 9.0
  • timestamps, only 9.0
  • visibilityConstraints, only 9.0
  • workspaceName, only 9.0

Invalid gettable properties as they require arguments:

  • nodeTypeAllowedAsChildNode, throws in 8.3 ArgumentCountError 💥
  • property, available in 9.0 ✅, throws in 8.3 ArgumentCountError 💥
  • node, throws in 8.3 ArgumentCountError 💥

legend

  • not part of 8.3 API 👻, meaning not declared in the "original" node interface \Neos\ContentRepository\Domain\Model\NodeInterface
  • marked as internal in 8.3 👻, meaning it is explicitly declared as @internal

@github-project-automation github-project-automation bot moved this from In Progress 🚧 to Done ✅ in Neos 9.0 Release Board Oct 11, 2024
neos-bot pushed a commit to neos/contentrepository-nodeaccess that referenced this issue Oct 11, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
Archived in project
5 participants