Oihana PHP System

ContactType extends Enumeration

Types of contact points for an Organization or Person.

Used for the contactPoint.contactType property in Schema.org.

Each constant represents a type of contact that can be used to describe the purpose or role of a contact point (phone, email, etc.) for an Organization or Person.

Constant Description Value
ASSISTANT Contact of an assistant or secretary. https://schema.oihana.xyz/ContactType#Assistant
BILLING Billing / invoice support contact. https://schema.oihana.xyz/ContactType#BillingSupport
CUSTOMER_COMPLAINTS_DEPARTMENT Customer Complaints Department. https://schema.oihana.xyz/ContactType#CCD
CUSTOMER_SERVICE Customer service / support for general inquiries. https://schema.oihana.xyz/ContactType#CustomerService
DEFAULT Default contact. https://schema.oihana.xyz/ContactType#Default
EMERGENCY Emergency contact. https://schema.oihana.xyz/ContactType#Emergency
FAX Fax contact. https://schema.oihana.xyz/ContactType#Fax
HOME Home / personal contact. https://schema.oihana.xyz/ContactType#Home
LANDLINE Landline phone contact. https://schema.oihana.xyz/ContactType#Landline
LEGAL Legal contact. https://schema.oihana.xyz/ContactType#Legal
MANAGER Contact of a manager or executive. https://schema.oihana.xyz/ContactType#Manager
MEDIA Media contact. https://schema.oihana.xyz/ContactType#Media
MOBILE Mobile phone contact. https://schema.oihana.xyz/ContactType#Mobile
MOBILE_PROFESSIONAL Professional Mobile contact. https://schema.oihana.xyz/ContactType#ProfessionalMobile
OTHER Other or miscellaneous contact. https://schema.oihana.xyz/ContactType#Other
PRESS Press / media inquiries. https://schema.oihana.xyz/ContactType#Press
PUBLIC_RELATIONS Public relations contact. https://schema.oihana.xyz/ContactType#PublicRelations
SALES Sales contact for commercial inquiries. https://schema.oihana.xyz/ContactType#Sales
SOCIAL_MEDIAS Social media contact. https://schema.oihana.xyz/ContactType#SocialMedias
SUPPORT Assistance / customer support / help desk contact (SAV). https://schema.oihana.xyz/ContactType#Support
TECHNICAL_SUPPORT Technical support contact, e.g., troubleshooting. https://schema.oihana.xyz/ContactType#TechnicalSupport
WORK Work / business contact. https://schema.oihana.xyz/ContactType#Work
Tags
see
ContactPoint

Table of Contents

Constants

ASSISTANT  = 'https://schema.oihana.xyz/ContactType#Assistant'
Assistant contact.
BILLING  = 'https://schema.oihana.xyz/ContactType#BillingSupport'
Billing / invoice support contact.
CONTEXT  = 'https://schema.org'
JSON-LD @context declaration for Schema.org.
CUSTOMER_COMPLAINTS_DEPARTMENT  = 'https://schema.oihana.xyz/ContactType#CCD'
Customer Complaints Department.
CUSTOMER_SERVICE  = 'https://schema.oihana.xyz/ContactType#CustomerService'
Customer service contact.
DEFAULT  = 'https://schema.oihana.xyz/ContactType#Default'
Default contact.
EMERGENCY  = 'https://schema.oihana.xyz/ContactType#Emergency'
Emergency contact.
FAX  = 'https://schema.oihana.xyz/ContactType#fax'
Fax contact.
HOME  = 'https://schema.oihana.xyz/ContactType#Home'
Home / personal contact.
JSON_PRIORITY_KEYS  = [\org\schema\constants\Schema::AT_TYPE, \org\schema\constants\Schema::AT_CONTEXT, \org\schema\constants\Schema::_KEY, \org\schema\constants\Schema::_FROM, \org\schema\constants\Schema::_TO, \org\schema\constants\Schema::ID, \org\schema\constants\Schema::NAME, \org\schema\constants\Schema::URL, \org\schema\constants\Schema::CREATED, \org\schema\constants\Schema::MODIFIED]
Defines the priority order of keys when serializing the object to JSON-LD.
LANDLINE  = 'https://schema.oihana.xyz/ContactType#landline'
Landline phone contact.
LEGAL  = 'https://schema.oihana.xyz/ContactType#Legal'
Legal contact.
MANAGER  = 'https://schema.oihana.xyz/ContactType#Manager'
Manager / executive contact.
MEDIA  = 'https://schema.oihana.xyz/ContactType#Media'
Media contact.
MOBILE  = 'https://schema.oihana.xyz/ContactType#mobile'
Mobile phone contact.
MOBILE_PROFESSIONAL  = 'https://schema.oihana.xyz/ContactType#ProfessionalMobile'
Professional / work mobile phone contact.
OTHER  = 'https://schema.oihana.xyz/ContactType#Other'
Other or miscellaneous contact.
PRESS  = 'https://schema.oihana.xyz/ContactType#Press'
Press contact.
PUBLIC_RELATIONS  = 'https://schema.oihana.xyz/ContactType#PublicRelations'
Public relations contact.
SALES  = 'https://schema.oihana.xyz/ContactType#Sales'
Sales contact.
SOCIAL_MEDIAS  = 'https://schema.oihana.xyz/ContactType#SocialMedias'
Social Medias contact.
SUPPORT  = 'https://schema.oihana.xyz/ContactType#Support'
Support contact.
TECHNICAL_SUPPORT  = 'https://schema.oihana.xyz/ContactType#TechnicalSupport'
Technical support contact.
WORK  = 'https://schema.oihana.xyz/ContactType#Work'
Work / business contact.

Properties

$_from  : string|null
The metadata to indicates the edge 'from' identifier.
$_id  : null|string
The metadata identifier of the item.
$_key  : null|string
The metadata unique key identifier of the thing.
$_rev  : null|string
The metadata revision value of the thing.
$_to  : string|null
The metadata to indicates the edge 'to' identifier.
$active  : bool|null
The active flag.
$additionalType  : array<string|int, mixed>|string|null|object
An additionalType for the item.
$alternateName  : string|object|array<string|int, mixed>|null
An alias for the item.
$created  : null|string
Date of creation of the resource.
$description  : string|object|array<string|int, mixed>|null
A short description of the item.
$disambiguatingDescription  : string|null
A sub property of description. A short description of the item used to disambiguate from other, similar items. Information from other properties (in particular, name) may be necessary for the description to be useful for disambiguation.
$hasPart  : string|Thing|array<string|int, Thing>|null
Indicates an item that this part of this item.
$id  : null|int|string
The unique identifier of the item.
$identifier  : string|null
The identifier of the item.
$image  : string|ImageObject|array<string|int, ImageObject|string>|null
The image reference of this resource.
$isPartOf  : string|Thing|array<string|int, Thing>|null
Indicates an item that this item is part of.
$license  : string|object|null
A legal document giving official permission to do something with the resource.
$mainEntityOfPage  : string|null
Indicates a page (or other CreativeWork) for which this thing is the main entity being described.
$modified  : null|string
Date on which the resource was changed.
$name  : int|string|null
The name of the item.
$owner  : null|string|Thing
The owner of this Thing.
$potentialAction  : array<string|int, mixed>|Action|null
Indicates a potential Action, which describes an idealized action in which this thing would play an 'object' role.
$publisher  : string|array<string|int, string|Person|Organization>|Person|Organization|null
The publisher of the resource.
$sameAs  : string|array<string|int, mixed>|null
URL of a reference Web page that unambiguously indicates the item's identity.
$subjectOf  : null|string|array<string|int, mixed>|CreativeWork|Event
A CreativeWork or Event about this Thing.
$supersededBy  : null|Type|Enumeration|Property
$url  : int|string|null
URL of the item.
$atContext  : string|null
The JSON-LD `@context` value.
$atType  : string|null
The JSON-LD `@type` value.

Methods

__construct()  : mixed
Constructor to hydrate public properties from an array or stdClass.
jsonSerialize()  : array<string|int, mixed>
Serializes the current object into a JSON-LD array.
withAtContext()  : $this
Sets the internal JSON-LD `@context` attribute.
withAtType()  : $this
Sets the internal JSON-LD `@type` attribute.
withJSONLDMeta()  : $this
Initializes both JSON-LD metadata: `@type` and `@context`.

Constants

ASSISTANT

Assistant contact.

public mixed ASSISTANT = 'https://schema.oihana.xyz/ContactType#Assistant'

BILLING

Billing / invoice support contact.

public mixed BILLING = 'https://schema.oihana.xyz/ContactType#BillingSupport'

CONTEXT

JSON-LD @context declaration for Schema.org.

public mixed CONTEXT = 'https://schema.org'

CUSTOMER_COMPLAINTS_DEPARTMENT

Customer Complaints Department.

public mixed CUSTOMER_COMPLAINTS_DEPARTMENT = 'https://schema.oihana.xyz/ContactType#CCD'

CUSTOMER_SERVICE

Customer service contact.

public mixed CUSTOMER_SERVICE = 'https://schema.oihana.xyz/ContactType#CustomerService'

DEFAULT

Default contact.

public mixed DEFAULT = 'https://schema.oihana.xyz/ContactType#Default'

EMERGENCY

Emergency contact.

public mixed EMERGENCY = 'https://schema.oihana.xyz/ContactType#Emergency'

FAX

Fax contact.

public mixed FAX = 'https://schema.oihana.xyz/ContactType#fax'

HOME

Home / personal contact.

public mixed HOME = 'https://schema.oihana.xyz/ContactType#Home'

JSON_PRIORITY_KEYS

Defines the priority order of keys when serializing the object to JSON-LD.

public array<string|int, string> JSON_PRIORITY_KEYS = [\org\schema\constants\Schema::AT_TYPE, \org\schema\constants\Schema::AT_CONTEXT, \org\schema\constants\Schema::_KEY, \org\schema\constants\Schema::_FROM, \org\schema\constants\Schema::_TO, \org\schema\constants\Schema::ID, \org\schema\constants\Schema::NAME, \org\schema\constants\Schema::URL, \org\schema\constants\Schema::CREATED, \org\schema\constants\Schema::MODIFIED]

Keys listed here will always appear first in the serialized array, in the order specified. All remaining public properties will be sorted alphabetically after these priority keys.

This ensures that important JSON-LD metadata and system fields (like @type, @context, _key, id, url, created, modified, etc.) appear at the top of the output for consistency and readability.

Usage:

$orderedKeys = self::JSON_PRIORITY_KEYS;

Notes:

  • Can be overridden in a subclass by redefining the constant.
  • Late static binding (static::JSON_PRIORITY_KEYS) allows child classes to modify the serialization order.

List of JSON-LD keys in priority order.

LANDLINE

Landline phone contact.

public mixed LANDLINE = 'https://schema.oihana.xyz/ContactType#landline'

Legal contact.

public mixed LEGAL = 'https://schema.oihana.xyz/ContactType#Legal'

MANAGER

Manager / executive contact.

public mixed MANAGER = 'https://schema.oihana.xyz/ContactType#Manager'

MEDIA

Media contact.

public mixed MEDIA = 'https://schema.oihana.xyz/ContactType#Media'

MOBILE

Mobile phone contact.

public mixed MOBILE = 'https://schema.oihana.xyz/ContactType#mobile'

MOBILE_PROFESSIONAL

Professional / work mobile phone contact.

public mixed MOBILE_PROFESSIONAL = 'https://schema.oihana.xyz/ContactType#ProfessionalMobile'

OTHER

Other or miscellaneous contact.

public mixed OTHER = 'https://schema.oihana.xyz/ContactType#Other'

PRESS

Press contact.

public mixed PRESS = 'https://schema.oihana.xyz/ContactType#Press'

PUBLIC_RELATIONS

Public relations contact.

public mixed PUBLIC_RELATIONS = 'https://schema.oihana.xyz/ContactType#PublicRelations'

SALES

Sales contact.

public mixed SALES = 'https://schema.oihana.xyz/ContactType#Sales'

SOCIAL_MEDIAS

Social Medias contact.

public mixed SOCIAL_MEDIAS = 'https://schema.oihana.xyz/ContactType#SocialMedias'

SUPPORT

Support contact.

public mixed SUPPORT = 'https://schema.oihana.xyz/ContactType#Support'

TECHNICAL_SUPPORT

Technical support contact.

public mixed TECHNICAL_SUPPORT = 'https://schema.oihana.xyz/ContactType#TechnicalSupport'

WORK

Work / business contact.

public mixed WORK = 'https://schema.oihana.xyz/ContactType#Work'

Properties

$_from

The metadata to indicates the edge 'from' identifier.

public string|null $_from

$_id

The metadata identifier of the item.

public null|string $_id

$_key

The metadata unique key identifier of the thing.

public null|string $_key

$_rev

The metadata revision value of the thing.

public null|string $_rev

$_to

The metadata to indicates the edge 'to' identifier.

public string|null $_to

$active

The active flag.

public bool|null $active

$additionalType

An additionalType for the item.

public array<string|int, mixed>|string|null|object $additionalType

$alternateName

An alias for the item.

public string|object|array<string|int, mixed>|null $alternateName

$created

Date of creation of the resource.

public null|string $created

$description

A short description of the item.

public string|object|array<string|int, mixed>|null $description

$disambiguatingDescription

A sub property of description. A short description of the item used to disambiguate from other, similar items. Information from other properties (in particular, name) may be necessary for the description to be useful for disambiguation.

public string|null $disambiguatingDescription

$hasPart

Indicates an item that this part of this item.

public string|Thing|array<string|int, Thing>|null $hasPart

$id

The unique identifier of the item.

public null|int|string $id

$identifier

The identifier of the item.

public string|null $identifier

$isPartOf

Indicates an item that this item is part of.

public string|Thing|array<string|int, Thing>|null $isPartOf

$license

A legal document giving official permission to do something with the resource.

public string|object|null $license

$mainEntityOfPage

Indicates a page (or other CreativeWork) for which this thing is the main entity being described.

public string|null $mainEntityOfPage

$modified

Date on which the resource was changed.

public null|string $modified

$name

The name of the item.

public int|string|null $name

$owner

The owner of this Thing.

public null|string|Thing $owner

Represents any entity (person, organization, system, or other object) that can be considered the possessor of this Thing.

$potentialAction

Indicates a potential Action, which describes an idealized action in which this thing would play an 'object' role.

public array<string|int, mixed>|Action|null $potentialAction

$sameAs

URL of a reference Web page that unambiguously indicates the item's identity.

public string|array<string|int, mixed>|null $sameAs

E.g. the URL of the item's Wikipedia page, Wikidata entry, or official website.

$subjectOf

A CreativeWork or Event about this Thing.

public null|string|array<string|int, mixed>|CreativeWork|Event $subjectOf

$url

URL of the item.

public int|string|null $url

$atContext

The JSON-LD `@context` value.

private string|null $atContext = null

Default is https://schema.org.

$atType

The JSON-LD `@type` value.

private string|null $atType = null

This can be manually set or automatically inferred from the class name.

Methods

__construct()

Constructor to hydrate public properties from an array or stdClass.

public __construct([array<string|int, mixed>|object|null $init = null ]) : mixed

This allows objects to be quickly populated with associative data without manually setting each property.

Parameters
$init : array<string|int, mixed>|object|null = null

A data array or object used to initialize the instance. Keys must match public property names.

Tags
throws
ReflectionException
example
use org\schema\Person;
use org\schema\constants\Prop;

$person = new Person
([
    Prop::NAME => 'Jane Doe',
    Prop::URL  => 'https://example.com/janedoe'
]);

echo $person->name; // Outputs: Jane Doe

jsonSerialize()

Serializes the current object into a JSON-LD array.

public jsonSerialize() : array<string|int, mixed>

Includes public properties, the JSON-LD @context and @type. Null values are automatically removed.

Tags
throws
ReflectionException

If reflection fails when accessing properties.

example
use org\schema\Person;
use org\schema\constants\Prop;

$person = new Person
([
    Prop::NAME => 'John Smith',
    Prop::ID   => 'jsmith-001'
]);

echo json_encode($person, JSON_PRETTY_PRINT);

Output:

{
   "@type": "Person",
   "@context": "https://schema.org",
   "id": "jsmith-001",
   "name": "John Smith"
}
Return values
array<string|int, mixed>

JSON-LD representation of the object.

withAtContext()

Sets the internal JSON-LD `@context` attribute.

public withAtContext(string $context) : $this

Useful if you need a custom JSON-LD context.

Parameters
$context : string

Optional JSON-LD context.

Return values
$this

withAtType()

Sets the internal JSON-LD `@type` attribute.

public withAtType(string $type) : $this

Allows overriding the default type inferred from the class.

Parameters
$type : string

Optional JSON-LD type

Return values
$this

withJSONLDMeta()

Initializes both JSON-LD metadata: `@type` and `@context`.

public withJSONLDMeta([string|null $atType = null ][, string|null $atContext = null ]) : $this

Can be called from constructor or later to override default values.

Parameters
$atType : string|null = null

Optional JSON-LD type

$atContext : string|null = null

Optional JSON-LD context

Return values
$this

        
On this page

Search results