|
<div style="padding:24px 16px;background:var(--background-color-interactive-subtle, #eaecf0);border:1px solid var(--border-color-subtle, #c8ccd1);border-radius:2px;margin-block:1em">
<div style="max-width:1200px; font-size: 1.15rem">
<div style="font-size:1.5rem;font-weight:600;line-height:1.25;color:var(--color-base, #202122);max-width:800px">NeoWiki turns wiki pages into queryable structured data</div>
Welcome to the NeoWiki demo wiki!
<div style="color:var(--color-subtle, #54595d);max-width:560px;margin-top:4px">Schemas, infoboxes, relations, and Cypher, native to MediaWiki.</div>
NeoWiki turns your wiki into a collaborative graph database by letting you store and query structured information.
Information is stored in versioned document form inside wiki pages. The latest version is also stored in
graph databases, via which it can be queried.
NeoWiki is in the experimental proof-of-concept phase. It is not production-ready, public interfaces will change,
big structural changes will happen, and key functionality is still missing.
This demo exists to gather feedback to inform further development.
You can find [https://github.com/ProfessionalWiki/NeoWiki/tree/master/docs technical documentation] in the
[https://github.com/ProfessionalWiki/NeoWiki NeoWiki git repository]. You can also
[https://github.com/ProfessionalWiki/NeoWiki/issues view the issue tracker] or
[https://professional.wiki/en/contact contact Professional Wiki] (the maintainer of NeoWiki).
</div>
== DiscoverExplore NeoWikiby Step byuse Stepcase ==
Terminology is explained in [https://github.com/ProfessionalWiki/NeoWiki/blob/master/docs/Glossary.md the glossary].
'''As a reader:'''
* View a Subject: [[Professional Wiki]]
* View a Schema: [[Schema:Company]]
'''As an editor:'''
* Edit a Subject: [[Professional Wiki]] (login required)
* Edit a Schema: either via a Subject using it, i.e. [[Professional Wiki]], or directly on the Schema page, i.e. [[Schema:Company]]
* Create a Subject: Create a new page with any content, then click "Create subject" in the NeoWiki section of the sidebar.
'''As a developer:'''
* View Subject JSON: [[Special:NeoJson/ACME_Inc]] (developer UI, normal users will not see JSON. [https://github.com/ProfessionalWiki/NeoWiki/blob/master/docs/SubjectFormat.md View docs])
* Query the graph database: [[Cypher|Cypher raw example]]
* Read values in wikitext: [[Value parser function]]
* Read values in Lua: [[Lua Data Access]]
* [[#REST_API_endpoints|Explore the REST API]]
== European Museums ==
A dataset of European museums, artists, and artworks showcasing cross-schema relations and rich property types.
'''Museums:''' [[Musee dOrsay|Musée d'Orsay]], [[Rijksmuseum]], [[Kunsthistorisches Museum]], [[Museo del Prado]]
'''Artists:''' [[Claude Monet]], [[Vincent van Gogh]], [[Johannes Vermeer]], [[Diego Velazquez|Diego Velázquez]], [[Gustav Klimt]]
'''Artworks:''' [[Water Lilies]], [[Starry Night Over the Rhone|Starry Night Over the Rhône]], [[The Milkmaid]], [[Las Meninas]], [[The Kiss]], [[The Art of Painting]]
'''Exhibitions:''' [[Impressionist Masters]], [[Dutch Golden Age Highlights]]
'''Cities:''' [[Paris]], [[Amsterdam]], [[Vienna]], [[Madrid]]
'''Overview:''' [[Museum Collection]]
== Demo Pages ==
* Simple page with automatic infobox and edit form: [[NeoWiki]], [[ProWiki]]
* Subject with relations: [[Professional Wiki]]
* Multiple subjects per page: [[ACME Inc]]
* Wikibase Statement emulation: [[Berlin]]
* Displaying data from other pages: [[Company Infoboxes]]
* [[Reactive UI example]]
== Schemas and Layouts ==
'''Schemas''' define the structure of your data. For instance, you can define that an Employee has a compensation
in EUR with a value between 0 and 1000000.
* [[Schema:Company]], [[Schema:Product]], [[Schema:Employee]]
* [[Schema:Museum]], [[Schema:Artist]], [[Schema:Artwork]], [[Schema:Exhibition]], [[Schema:Attendance]]
* [[Special:Schemas|View all schemas]]
'''Layouts''' customize how Subjects are displayed by selecting which properties to show and in what order.
{{#invoke:Card|cards|
* [[Layout:CompanyOverview]]
card1_title=Museum collection
* [[Special:Layouts|View all layouts]]
|card1_description=Connect institutions, artists, artworks, and exhibitions.
|card1_link=Museum collection
|card2_title=ACME Inc
== REST API Endpoints ==
|card2_description=Document a company's departments, products, and offices.
|card2_link=ACME Inc
|card3_title=Research catalog
An auto-generated OpenAPI 3.0 spec describes the REST API:
|card3_description=Track publications, authors, institutions, and projects.
|card3_link=Research catalog
}}
== See how it works ==
* [{{SERVER}}{{SCRIPTPATH}}/rest.php/specs/v0/module/- NeoWiki OpenAPI spec] — <code>/rest.php/specs/v0/module/-</code>
* [{{SERVER}}{{SCRIPTPATH}}/rest.php/specs/v0/discovery Module discovery] — <code>/rest.php/specs/v0/discovery</code>
* Subjects hold your structured data. A page can have multiple. See the Data tab. Example: [{{fullurl:Rijksmuseum|action=subjects}} Rijksmuseum]
Example endpoint URL: <code>{{SERVER}}{{SCRIPTPATH}}/rest.php/neowiki/v0/subject/s1demo4sssssss1</code>
* [[Special:Schemas]]. Every Subject is shaped by a Schema. View or manage Schemas via this list page.
* [[Special:Layouts]]. Customize the presentation of Subjects via Layouts. Example usage: [[Subject views]].
=== ReadBuild Endpointson it ===
* [[Developers|Developers hub]]: Cypher, parser functions, Lua, REST API.
* <code>GET /neowiki/v0/subject/{subjectId}</code> Gets the JSON definition of a subject
* [https://github.com/ProfessionalWiki/NeoWiki Source on GitHub]
* <code>GET /neowiki/v0/schema/{schemaName}</code> Gets the JSON definition of a schema
* [https://github.com/ProfessionalWiki/NeoWiki/tree/master/docs Technical documentation]
* [https://github.com/ProfessionalWiki/NeoWiki/issues Issue tracker]
=== WriteAbout Endpointsthis wiki ===
'''NeoWiki''' is a MediaWiki extension for queryable structured data. See [https://neowiki.ai neowiki.ai] for downloads, documentation, and updates.
These require a CSRF token, first obtained via <code>api.php?action=query&format=json&meta=tokens&type=csrf</code>
NeoWiki is under active development. Public interfaces and structure will continue to change. This demo wiki may be reset periodically, and edits may not persist.
* <code>POST /neowiki/v0/page/{pageId}/mainSubject</code> Creates a new main subject
* <code>POST /neowiki/v0/page/{pageId}/childSubjects</code> Creates a new child subject
* <code>PATCH /neowiki/v0/subject/{subjectId}</code> Updates a subject
* <code>DELETE /neowiki/v0/subject/{subjectId}</code> Deletes a subject
* [https://professional.wiki/en/contact Contact Professional Wiki] — the team behind NeoWiki
These endpoints are designed for the NeoWiki frontend. They are not a complete general purpose API yet.
* Follow NeoWiki: [https://mastodon.social/@NeoWiki Mastodon] · [https://bsky.app/profile/neowiki.bsky.social Bluesky] · [https://x.com/NeoWikiAI X]
|