This repository has been archived by the owner on Apr 9, 2023. It is now read-only.
-
-
Notifications
You must be signed in to change notification settings - Fork 2
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
provide some documentation on interfaces
- Loading branch information
Showing
2 changed files
with
23 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -13,6 +13,7 @@ Contents: | |
applications | ||
addons | ||
services | ||
interfaces | ||
migrations | ||
behavior | ||
commands | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,22 @@ | ||
# Interfaces | ||
|
||
`plone.server` uses interfaces to abstract and define various things including | ||
content. Interfaces are useful when defining api contracts, using inheritance, | ||
defining schema/behaviors and being able to define which content your services | ||
are used for. | ||
|
||
In the services example, you'll notice the use of `context=ISite` for the service | ||
decorator configuration. In that case, it's to tell `plone.server` that the | ||
service is only defined for a site object. | ||
|
||
## Common interfaces | ||
|
||
Interfaces you will be interested in defining services for are: | ||
|
||
- `plone.server.interface.IDatabase`: A database contains the site objects | ||
- `plone.server.interface.ISite`: Site content object | ||
- `plone.server.interface.IResource`: Base interface for all content | ||
- `plone.server.interface.IContainer`: Base interface for content that can contain other content | ||
- `plone.server.interface.IRegistry`: Registry object interface | ||
- `plone.server.interface.IDefaultLayer`: Layers are an interface applied to the | ||
request object. IDefaultLayer is the base default layer applied to the request object. |