https://ontology.unifiedcyberontology.org/uco/observable/WindowsHook
          A Windows hook is a mechanism by which an application can intercept events, such as messages, mouse actions, and keystrokes within the Windows operating system. A function that intercepts a particular type of event is known as a hook procedure. A hook procedure can act on each event it receives, and then modify or discard the event. [based on https://docs.microsoft.com/en-us/windows/win32/winmsg/about-hooks]
Instances of observable:WindowsHook can have the following properties:
| PROPERTY | TYPE | DESCRIPTION | RANGE | 
|---|---|---|---|
| From class core:UcoObject | |||
| investigation:wasDerivedFrom | owl:ObjectProperty | A re-implementation of the wasDerivedFrom property in W3C PROV-O. The definition of this property is 'A derivation is a transformation of an entity into another, an update of an entity resulting in a new one, or the construction of a new entity based on a pre-existing entity.' [Ref: https://www.w3.org/TR/prov-o/#wasDerivedFrom] | core:UcoObject | 
| From class owl:Thing | |||
| core:informalType | owl:DatatypeProperty | Informal Type serves as a parent property for string-valued properties meant to describe a type without implementing a class design. This property hierarchy supports a balancing point between semantic specificity and operational agility. The known benefits of describing types rather than implementing them include swift extensibility of some existing, or possibly non-existing, subclass hierarchy in UCO without requiring training in ontological development, taxonomic specification, or OWL, SHACL, or RDF maintenance logistics. The known detractions of using string-literals for type descriptions include that used vocabularies may require careful maintenance among data-sharing parties; that vocabularies require independent logistics (external to UCO) for providing definitions (i.e., dictionary-style semantics) to string-literals chosen; and that string-literals cannot by themselves encode hierarchical structure or entailments, such as the informal device type string 'ExamplePhone 8 P4321' entailing 'ExamplePhone 8', 'ExamplePhone', or 'ExamplePhone models discontinued in 2020'. Usage of Informal Type to house strings should be weighed against usage of classes when classes are available, and should periodically be reviewed for potential additions to UCO's class hierarchy or downstream extensions thereof. | owl:Thing | 
| types:threadNextItem | owl:ObjectProperty | The link to a next item in a thread. | owl:Thing | 
| types:threadPreviousItem | owl:ObjectProperty | A direct link to a previous item in a thread. | owl:Thing | 
By the associated SHACL property shapes, instances of observable:WindowsHook can have the following properties:
| PROPERTY | PROPERTY TYPE | DESCRIPTION | MIN COUNT | MAX COUNT | LOCAL RANGE | GLOBAL RANGE | |
|---|---|---|---|---|---|---|---|
| observable:ObservableObject | |||||||
| observable:hasChanged | owl:DatatypeProperty |  | 1 | xsd:boolean | xsd:boolean | ||
| observable:state | owl:DatatypeProperty |  | 1 | xsd:string | xsd:string | ||
| core:UcoObject | |||||||
| core:createdBy | owl:ObjectProperty | The identity that created a characterization of a concept. | 1 | core:IdentityAbstraction | core:IdentityAbstraction | ||
| core:description | owl:DatatypeProperty | A description of a particular concept characterization. | xsd:string | xsd:string | |||
| core:externalReference | owl:ObjectProperty | Specifies a reference to a resource outside of the UCO. | 0 | core:ExternalReference | core:ExternalReference | ||
| core:hasFacet | owl:InverseFunctionalProperty | Further sets of properties characterizing a concept based on the particular context of the class and of the particular instance of the concept being characterized. | core:Facet | core:Facet | |||
| core:modifiedTime | owl:DatatypeProperty | Specifies the time that this particular version of the object was modified. The object creator can use the time it deems most appropriate as the time this version of the object was modified. The value of the modified property for a given object version MUST be later than or equal to the value of the created property. Object creators MUST update the modified property when creating a new version of an object. The modified timestamp MUST be precise to the nearest millisecond (exactly three digits after the decimal place in seconds). | xsd:dateTime | xsd:dateTime | |||
| core:name | owl:DatatypeProperty | The name of a particular concept characterization. | 1 | xsd:string | xsd:string | ||
| core:objectCreatedTime | owl:DatatypeProperty | The time at which a characterization of a concept is created. This time pertains to the time of creating the record object, and is not an intrinsic characteristic of the concept. | 1 | xsd:dateTime | xsd:dateTime | ||
| core:objectMarking | owl:ObjectProperty | Marking definitions to be applied to a particular concept characterization in its entirety. | core:MarkingDefinitionAbstraction | core:MarkingDefinitionAbstraction | |||
| core:objectStatus | owl:AnnotationProperty | The current state of formality and acceptance for a UCO object. | 1 | xsd:string | core:ObjectStatusVocab | ||
| core:specVersion | owl:DatatypeProperty | The version of UCO ontology or subontology specification used to characterize a concept. | 1 | xsd:string | xsd:string | ||
| core:tag | owl:DatatypeProperty | A generic tag/label. | xsd:string | xsd:string | |||
@prefix observable: <https://ontology.unifiedcyberontology.org/uco/observable/> .
@prefix owl: <http://www.w3.org/2002/07/owl#> .
@prefix rdfs: <http://www.w3.org/2000/01/rdf-schema#> .
@prefix sh: <http://www.w3.org/ns/shacl#> .
observable:WindowsHook a owl:Class,
        sh:NodeShape ;
    rdfs:label "WindowsHook"@en ;
    rdfs:comment "A Windows hook is a mechanism by which an application can intercept events, such as messages, mouse actions, and keystrokes within the Windows operating system. A function that intercepts a particular type of event is known as a hook procedure. A hook procedure can act on each event it receives, and then modify or discard the event. [based on https://docs.microsoft.com/en-us/windows/win32/winmsg/about-hooks]"@en ;
    rdfs:subClassOf observable:ObservableObject ;
    sh:targetClass observable:WindowsHook .