Skip to main content

The microsite creation product for Plone

Project description

Introduction

Lineage is a Plone extension. It allows subfolders of a Plone site to appear as autonomous Plone sites to the everyday user. This hub and spoke structure allows site administrators to easily manage multiple, seemingly independent, sub-entity websites in one Plone. Furthermore, the “parent” site can access and view the content in all the “child” sites while the child sites only view their own content. The parent site can also syndicate chosen content to the selected child sites. Lineage is less complex and easier to manage than a cluster of nested Plone sites but gives users all the same benefits.

Lineage can be used within a large organization to manage multiple microsites, such as school district sites, university departments, corporate product sites, public library satellites, professional association events, and more.

Version information

  • 3.x: Plone 5.2, 6.0 - Python 3.8+

  • 2.x: Plone 5.0, 5.1, 5.2 - Python 2.7

  • 1.x: Plone 4.3

Detailed Documentation

Installation

Bootstrapped your buildout with all the dependencies. Install Lineage via Site Setup -> Add on Products. Now you are ready to go.

Add a Child Site:

  1. In Plone, go to the place where you want to add a new child site.

  2. Click Add New, and add a Folder.

  3. Enter the title and description for the Child site.

  4. Click Save.

  5. Click the Actions drop down and select Enable Subsite. This “activates” the child site behavior.

  6. The Plone site now has a child site. A drop down will appear at the top of the Plone to the left of the site actions area. A user can select the parent site or any child sites from this drop down.

Lineage extensions

There is a bunch of extensions available. They are helpful when there is the need of more special features within subites.

lineage.index

Adds an index and metadata that allows to search for content of a specific childsite only

collective.rooter

Force catalog queries to obey the current subsite

lineage.registry

Provides a plone.app.registry for Lineage subsites. It adds a local component with a layered-/proxy-registry

lineage.themeselection

Provides custom theme selection for Lineage subsites.

For more search Pypi

Upgrading to 2.X

Lineage 2.0 is a major upgrade to the software and will require you to have updated to the 1.1.2 version before you migrate any existing Lineage child sites to the new version. Lineage 2.0 removes all dependencies on p4a.subtyper and makes the product Plone 5 ready. The 1.1.2 release of Lineage is only used to migrate your existing Lineage 1.1 sites up to the needed state for the new 2.0 release.

Steps for upgrading:

  1. Install version 1.1.2 into your existing Lineage powered site

  2. Go to the Plone Site Setup and from the Add-Ons panel click the button to upgrade the Lineage product

  3. Install version 2.0 into your existing Lineage powered site

  4. Go to the Plone Site Setup and from the Add-Ons panel click the button to upgrade the Lineage product

  5. Enjoy Lineage 2.0

Changelog

3.0.0 (2023-11-20)

  • Drop Python 2.7 support and code cleanup. [petschki, thet]

2.3.1 (2023-11-20)

  • Add support for Plone 6 while keeping Plone 5 compatibility. [petschki, thet]

2.3 (2020-02-16)

  • Add support for Python 3 [cillianderoiste]

  • Fixed for Plone 5.2 [ajung]

  • Fix broken image link in README, fix project URL in setup.py [tkimnguyen]

  • Remove extraneous code that was causing a len() deprecation warning, #58 [tkimnguyen]

  • require plone.dexterity >= 2.9.3 for Python 3 (#55) [petri,tkimnguyen]

  • use pyflakes 2.1.0 to fix tests [tkimnguyen]

2.2 (2019-01-02)

  • Load the image traverser only if plone.app.imaging is installed. [thet]

  • Support registering browser layers for child sites for per-child-site theming. [rpatterson]

  • Simplify travis configuration and fix travis test run. [thet]

  • Depend on Products.CMFPlone instead of Plone to not fetch unnecessary dependencies. [thet]

  • Add descriptors.py back in with a placeholder so the site doesn’t complain about it missing. [abosio]

2.1 (2016-10-03)

  • Implement new utility method parent_site. [thet]

  • Setup related cleanups. [thet]

  • fix IImagingSchema traverser for Plone 4, disable in Plone 5 [jensens]

  • basic tests for enable/disable childsite [jensens]

  • household chores: make flake-8 happy (utf8-headers), some other minor pep8, add travis configuration and let tests run against 4.1 to 5.0 (and fixed them). [jensens]

  • Include get_image_traverser only when plone.app.imaging.interfaces.IImagingSchema is available, which is not the case in Plone 5. [thet]

  • Peel out enable_childsite and disable_childsite from the lineage_tool view, so that it can be easily used programmatically. [thet]

  • We don’t want to enable or disable a childsite on a default page. Traverse up, until a non-default page is found. [thet]

  • Add current_childsite method to @@lineageutils view, which returns the current lineage subsite object or None, if no lineage subsite is active. [thet]

  • Re-add the @@lineageutils browser page with it’s useful isChildSite method. Fix isChildSite to be called as a method on it’s view. [thet]

  • Added portuguese pt-br translation [lccruz]

2.0 - (2014-10-29)

  • Fix upgrade steps and migration for 1.x based versions. Please migrate your site to the latest 1.1.2 version before using 2.0. [calvinhp]

  • Content type framework agnostic: Compatible with Dexterity and Archetypes by allowing definitions of Subsites on plone.folder.interfaces.IFolder objects. [thet]

  • Remove dependency on p4a.subtyper. Enable and disable subsite menus are now in the object_buttons action menu. [thet]

  • Remove controlpanel. Use language translations for translating interface elements instead. [thet]

  • Remove deprecated ChildFolder content type. [thet]

  • Remove upgrade steps. Please upgrade to most recent 1.x version in the 1.x branch, deinstall collective.lineage and use the 2.x branch then and reinstall. [thet]

  • Make objectactions and site-switchter translateable and add German translations [fRiSi]

1.1.2 - (2014-10-29)

  • This is a migration step to 2.0 release only. Once installed, run the upgrade from the Plone Add-Ons control panel and then upgrade to 2.0 to re-enable management of child sites. [calvinhp]

  • Add upgrade step to remove p4a.subtyper interfaces and created a GenericSetup profile to remove the component from the component registry [calvinhp]

1.1.1 - (2014-06-26)

  • Add an adapter to allow the child site to use the portal image scales. Fixes https://github.com/collective/collective.lineage/issues/18 [ableeb]

  • In the uninstall profile, remove componentregistry collective.lineage.childsite utility from the component registry. [thet]

  • Add Chinese translations. [adam139]

1.1 - (2013-06-02)

  • Fixed imports to allow lineage to be compatible with Plone >= 4.1 [calvinhp]

  • Update dependencies and import locations and make collective.lineage compatible with Plone 4.3. [thet]

  • Add new events for WillBe created and removed. This will make add-ons like lineage.registry able to properly deal with the child site before the component registry is removed. [claytron]

  • Restored Plone 3.3 compatibility (if plone.app.registry is present) [keul]

  • i18n fixes and added italian translation [keul]

  • Uninstall step fixed (closed #8 and #11) but also removed other stuff left behind [keul]

1.0.1 - (2012-10-13)

  • Remove setup_site from the install function since this is no longer needed. Also bumped the metadata version so that the upgrade step actually runs. [claytron]

  • PEP8 [clayton]

1.0 - (2012-10-08)

  • PEP8 and pyflakes cleanup [claytron]

  • modernized tests, using layers now. [jensens]

  • fixed failing test with subscribers, subtype added event is not an object event! [jensens]

  • moved code to github and increased Plone version used in integrated buildout to 4.1-latest. [jensens]

  • The subscribers are now registered to the IChildSite interface so that custom child site types are still made into IObjectManagerSites. [rossp]

  • Added an isChildSite method to the LineageUtils view, to determine if the current context is part of a child site. [davidblewett]

  • Id attribute added to the lineage selection form to make Diazo/XDV theming easier. [timo]

  • German translation added. [timo]

  • added support for plone domain [macagua]

  • Added Spanish translation [macagua]

  • Changed the collective.lineage.childsite component to use the IFolderishContentTypeDescriptor interface instead of IPortalTypedFolderishDescriptor, allowing any folderish type to become a child site. [davidblewett]

  • Fixed issue where deactivating a Child Site wouldn’t remove it from the Lineage dropdown menu [calvinhp]

  • Format README so that it fits within 72 columns. [claytron]

0.6.1 - (2011-01-12)

  • Making sure that we copy the fact that the item inherits from its parent or not [lucielejard]

  • Updated the ignores [lucielejard]

  • Fixed the upgrade so that when we grab the layout of a folder, it does not get it using acquisition if it doesn’t have one, fixes #18 [lucielejard]

  • Copy over sharing settings from child folder to new folder, fixes #38 [anthonygerrard]

  • Fix by not renaming the child folder, instead create new folder with temp id and rename that to the child folder id after the child folder has been deleted, fixes #37 [anthonygerrard]

  • Adding a failing test case for #37 here as it is a serious bug but I have no idea how to fix it [anthonygerrard]

  • In lineage 0.1 child folders never inherited their parent’s portlets so always block parent portlets when migrating, fixes #34 [anthonygerrard]

  • Added a warning if portlet manager is not available on the new folder, fixes #35 [anthonygerrard]

  • Copy portlet assignments from and blocking settings across on migration, fixes #34 [anthonygerrard]

  • Refactor tests so that migration tests are in their own class and so can have common setup logic [anthonygerrard]

  • Read the default page of the child folder before conversion and then set it afterwards, fixes #18 [anthonygerrard]

0.6 - (2010-05-25)

  • used z3c.autoinclude and removed the zcml slug in buildout.cfg [tbesluau]

  • update the security settings at the end of the migration so that the workflow is applied correctly on the new migrated folders, fixes #20 [lucielejard]

  • updated the migration so it keeps the layout on the folder fixes #18 [lucielejard]

0.5.1 - (2010-05-12)

  • updated docs as per duffyd suggestions [lucielejard]

0.5 - (2010-05-11)

  • updated docs with links to the branches created by duffyd for the backports of the plip #234 mods to Plone 3.1.7 [lucielejard]

0.4 - (2010-04-30)

  • updated docs about PLIP

  • Update docs with information about “activation” behavior. [clayton]

0.3 - (2010-04-30)

  • getting the unit testing to work with plone4 and allowing childsite editing with plone4, refs #16 [tbesluau]

  • updated README.txt with useful links [lucielejard]

  • added tests for the uninstall of lineage [lucielejard]

  • updated the list of items todo, removed rolemap.xml since we don’t use it anymore, updated the history with the recent changes [lucielejard]

  • moved the registration of the utility in component registry so it gets registered locally, this fixes #5 [lucielejard]

  • added a deprecation warning on the Child Folder type [lucielejard]

  • put back some old zcml so the Child Folder migration can be tested [lucielejard]

  • added a test for the migration from 0.1 to >0.1 [lucielejard]

  • updated the version in metadata.xml for the upgrade step [lucielejard]

  • made the Child Folder type not globally addable [lucielejard]

  • added an upgrade step that will migrate the old Child Folder objects [lucielejard]

  • added an import various step so that the upgrade step gets run automatically on reinstall [lucielejard]

  • Set up for i18n translations [claytron]

  • Moving over to an ‘activation’ based system instead of having a ‘Child Folder’ type. Now a folder will have the option for a subtype named ‘Child Site’. http://plone.org/products/collective-lineage/issues/3 http://plone.org/products/collective-lineage/issues/1 [claytron]

  • Remove ‘Child Folder’ add/edit interfaces. The type still remains so that we can do a migration. [claytron]

  • Added uninstall profile and hooked it up to the Quickinstaller [claytron]

  • Added subtyper.xml to the uninstall profile that will deactivate all ‘Child Sites’ in the portal. This depends on p4a.subtyper code that has not yet been released. This also solves the export/import issue http://plone.org/products/collective-lineage/issues/2 [claytron]

  • Added a subscriber to create the local component site (this was in the ‘Child Folder’ type before) [claytron]

0.2 - (2010-04-08)

  • Doc clarifications [claytron]

0.1 - (2009-02-10)

  • Initial public release

Special Thanks

Six Feet Up would especially like to thank Martin Aspeli for his inspiration and the Duke Clinical Research Institute group for project funding.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

collective.lineage-3.0.0.tar.gz (31.5 kB view details)

Uploaded Source

Built Distribution

collective.lineage-3.0.0-py3-none-any.whl (26.5 kB view details)

Uploaded Python 3

File details

Details for the file collective.lineage-3.0.0.tar.gz.

File metadata

  • Download URL: collective.lineage-3.0.0.tar.gz
  • Upload date:
  • Size: 31.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.5

File hashes

Hashes for collective.lineage-3.0.0.tar.gz
Algorithm Hash digest
SHA256 9911fd040d34acc304d4f7be51795d8bc8d1ab5a8593617ce818ce730968f05e
MD5 20ad2d5fad293b516e990f58eba23f9b
BLAKE2b-256 5d2475d4aaf5fa400e6f04b20ed6d864c779509464f067ba4f36904c76569575

See more details on using hashes here.

File details

Details for the file collective.lineage-3.0.0-py3-none-any.whl.

File metadata

File hashes

Hashes for collective.lineage-3.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 7d09ad3543f5facbade1ce58f3a22e8c07dc8cddc4d485470738d2be41736014
MD5 34f754f636927b13987996f461c4e93d
BLAKE2b-256 9eef4c653eab12152d38b50868e9bbeccb8a6cae4d662b4f34eec8737c31c7c2

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page