Plone content export / import support
Project description
Plone Content Export and Import
Package supporting the export and import of content, principals, relations, translations, discussions, and redirects from and to a Plone site.
Introduction
This package is a slimmer version of the awesome collective.exportimport.
While collective.exportimport supports older Plone versions and Python 2, and also takes care of data conversion from Archetypes to Dexterity, this package focuses only on latest Plone and Python.
Documentation
plone.exportimport documentation
Installation
[!IMPORTANT] This package supports sites running Plone version 6.0 and above.
[!IMPORTANT] This package is now included with Plone 6.1 and above by default.
If plone.exportimport is not yet available in your Plone installation, add it using pip.
pip install plone.exportimport
Contributing
See Contributing to Plone and [Contribute to Plone 6 core](Contribute to Plone 6 core) for general contributing policies and guidance.
The following sections specifically describe how to develop and contribute to plone.exportimport.
Setup
You need a working Python environment version 3.8 or later.
Install the dependencies and a development instance using the following command.
make install
Local environment Plone server
Start Plone, on port 8080, with the following command.
make start
Format code base
Format the code base with the following command.
make format
Run tests
Testing of this package is done with pytest and tox.
Run all tests with the following command.
make test
Run all tests, but stop on the first error and open a pdb session.
./bin/tox -e test -- -x --pdb
Run tests named TestUtilsDiscussions.
./bin/tox -e test -- -k TestUtilsDiscussions
License
The project is licensed under the GPLv2.
Changelog
1.3.1 (2025-10-06)
New features:
- Implement regular commits to reduce memory usage in larger import processes. @ericof #55
Internal:
- Add a prefix to progress loggers. @ericof
- Fix type annotations. @ericof
- Import: Move plone.importer.principals to the top of the importers to be processed. @ericof
1.3.0 (2025-09-24)
New features:
- Support export/import of user
login_name@ewohnlich #69
Bug fixes:
- Fix import of ordering inside folderish components. @ericof #60
Internal:
- Update package metadata @ericof #78
1.2.1 (2025-09-05)
Bug fixes:
- Fix export of remoteUrl to an internal page keeping the site url in the exported data. @ericof #73
1.2.0 (2025-08-14)
New features:
- Support non-root PloneSite import/export [ewohnlich] #67
Bug fixes:
- Export all paths in Posix format to support export-import across platforms [ewohnlich] #66
1.1.1 (2025-06-26)
Bug fixes:
- Fix error getting parent object on Windows. @ewohnlich #64
1.1.0 (2025-03-11)
New features:
- Report object creation during import using the plone-importer cli. Use --quiet to disable it. @ericof #54
- Do not stop the import if an object parent is missing @ericof #56
Bug fixes:
- Set site during plone-importer transaction commit. @ericof #52
- Sort
relations.jsonandtranslations.jsonso their contents are stable. @mauritsvanrees #57
1.0.0 (2025-01-31)
Bug fixes:
- Export the raw value of rich text fields, instead of the transformed output. This fixes internal links in Classic UI based distributions. @mauritsvanrees #48
- Fix traceback when translation group does not have the default language. @mauritsvanrees #50
Documentation:
- Migrate documentation to README.md and https://6.docs.plone.org/admin-guide/export-import.html. @stevepiercy #46
1.0.0b1 (2025-01-23)
New features:
- Include revisions only when passing
--include-revisions. @mauritsvanrees #39
Bug fixes:
- Export principals: sort groups, roles, and members. @mauritsvanrees #39
- Import: update modification dates again at the end. The original modification dates may have changed. @mauritsvanrees #39
- Do not export parent info. This information is no longer needed: during import, parents are now always found by path and not by UID. From now on, the import ignores any parent info that is set. @mauritsvanrees #39
1.0.0a8 (2024-10-11)
Bug fixes:
- Use plone.app.discussion and plone.app.multilingual as optional dependencies. @davisagli #18
- Include 'isReferencing' relations in import. @ksuess #32
- Set constraints after setting local permissions on content [@ericof] #33
- Export adds a newline at the end of all files.
This matches the
.editorconfigsettings that we have in most Plone packages. [maurits] #35 - Do not export or import translations when
plone.app.multilingualis not available. [maurits] #35 - Disallowlisted portlets were not imported when there was no accompanying change in the actual portlet list. [maurits] #35
- Add a fixer for the
allow_discussionkey: this should only contain True or False when this is explicitly set on the object. [maurits] #35 - Do not export or import discussions/comments when
plone.app.discussionis not available. [maurits] #35 - Renamed
blacklisted_statuskey toblocked_statusto be sensitive. We still read the old key for backwards compatibility. [maurits] #35
1.0.0a7 (2024-06-13)
New features:
- Export / Import local permissions for each content [@ericof] #15
Bug fixes:
- Fix
plone.exportimport.utils.principals.members._run_as_managerfunction [@ericof] #29
1.0.0a6 (2024-06-10)
Bug fixes:
- Allow granting roles other than Manager and Member to principals [@ericof] #25
- Fix export of language for content [@sneridagh] #26
1.0.0a5 (2024-05-16)
Internal:
- Fix list of test dependencies [@ericof]
1.0.0a4 (2024-05-15)
New features:
- Add pre_deserialize_hooks to content import [@pbauer] #22
Bug fixes:
- Reindex members of relations in case that they contain preview_image_links [sneridagh] #13
- Avoid duplicating portlets registration during import [@ericof] #16
Internal:
- Update plone/meta [@ericof] #20
1.0.0a3 (2024-05-02)
Bug fixes:
- Fix importer by issuing a transaction commit [sneridagh] #9
- Account for use case language is empty string [sneridagh] #10
1.0.0a2 (2024-04-18)
New features:
- Support export/import of portlets if plone.app.portlets is installed. @davisagli #8
1.0.0a1 (2024-04-17)
New features:
- Implement exporter and importer for content [@ericof] #1
- Implement exporter and importer for members and groups [@ericof] #2
- Implement exporter and importer for redirects [@ericof] #3
- Implement exporter and importer for relations [@ericof] #4
- Implement exporter and importer for translations [@ericof] #5
- Implement exporter and importer for discussions [@ericof] #6
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file plone_exportimport-1.3.1.tar.gz.
File metadata
- Download URL: plone_exportimport-1.3.1.tar.gz
- Upload date:
- Size: 198.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.6
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
fc79e6686870d165b5f58cd98be2ddbf37481f82907c6c91b5c9fb685f08bb56
|
|
| MD5 |
470677eeef228a248d038f113677aa15
|
|
| BLAKE2b-256 |
97919ce87c4e1b490eb5092df27f801978246c4e6647126fece25b2a8af06d8a
|
File details
Details for the file plone_exportimport-1.3.1-py3-none-any.whl.
File metadata
- Download URL: plone_exportimport-1.3.1-py3-none-any.whl
- Upload date:
- Size: 66.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.6
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8b10164f9f34dd1cc1fd6102f229e1f4b8b9dfc3f50c7cb3594b2993aef5a948
|
|
| MD5 |
0cedb0b9ff62005f3cf80cd0be7acdf3
|
|
| BLAKE2b-256 |
cfd3022d6631428910dd13b5899bed1a5ba89699b83597eabe70ab55a4e181a6
|