- 
          
- 
                Notifications
    You must be signed in to change notification settings 
- Fork 177
Add "create project" docs for cookieplone #1714
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
          
     Merged
      
        
      
    
  
     Merged
                    Changes from 18 commits
      Commits
    
    
            Show all changes
          
          
            32 commits
          
        
        Select commit
          Hold shift + click to select a range
      
      badd795
              
                Add "create project" docs for cookieplone
              
              
                davisagli 2fabf07
              
                Add overlooked comma
              
              
                stevepiercy 3f264f6
              
                Rename file
              
              
                stevepiercy 0f6ef61
              
                Rename file
              
              
                stevepiercy 5115e86
              
                Remove "the" from Classic UI.
              
              
                stevepiercy a70b455
              
                Merge branch '6.0' into cookieplone
              
              
                stevepiercy c464ebf
              
                Apply suggestions from code review
              
              
                davisagli 51dad84
              
                Merge branch '6.0' into cookieplone
              
              
                stevepiercy 5619a1b
              
                Overhaul the Install index.
              
              
                stevepiercy 50246bc
              
                Simplify introductions for create-project*
              
              
                stevepiercy 5f28d42
              
                Update meta information
              
              
                stevepiercy 946a1c3
              
                Current version of Sphinx does not support replacements in includes, …
              
              
                stevepiercy 7d0a44f
              
                Hyphenate pre-requisite and tidy
              
              
                stevepiercy c524246
              
                Update meta information
              
              
                stevepiercy bf580c2
              
                Use narrow terminal to avoid horizontal scrolling of console.
              
              
                stevepiercy a99d74f
              
                Add next steps to view the site. Much excite!
              
              
                stevepiercy 477c496
              
                Update meta information and correct Volto version
              
              
                stevepiercy 1c0d53c
              
                Correct introduction
              
              
                stevepiercy bfc3698
              
                Add terms Cookieplone and cookieplone-templates to Glossary.
              
              
                stevepiercy 7badeea
              
                Use include for Python prerequisite
              
              
                stevepiercy 41de6eb
              
                Update docs/glossary.md
              
              
                stevepiercy 864e9cd
              
                Update docs/install/create-project-cookieplone.md
              
              
                stevepiercy e8fee7a
              
                Include corepack enable as an enumerated step, and use shell for syntax
              
              
                stevepiercy 0c4c79d
              
                Avoid horizontal scrolling and anonymize path to project
              
              
                stevepiercy 4f2e008
              
                Finalize tidy and update screenshots to 2024
              
              
                stevepiercy 94cd6f7
              
                Link to correct repo. See https://github.com/plone/cookieplone/pull/41
              
              
                stevepiercy f450915
              
                Add plone/generator-volto deprecation to Glossary
              
              
                stevepiercy 6d197a9
              
                Cannot use `@` at the start of a term in the Glossary
              
              
                stevepiercy 1013687
              
                Nope, `@` is fine, there was whitespace that broke the glossary.
              
              
                stevepiercy d67ac39
              
                Add note about installing Pillow requirements. See https://github.com…
              
              
                stevepiercy 11e46b9
              
                Merge branch '6.0' into cookieplone
              
              
                stevepiercy bc43d3a
              
                Update docs/glossary.md
              
              
                stevepiercy File filter
Filter by extension
Conversations
          Failed to load comments.   
        
        
          
      Loading
        
  Jump to
        
          Jump to file
        
      
      
          Failed to load files.   
        
        
          
      Loading
        
  Diff view
Diff view
There are no files selected for viewing
  
    
      This file contains hidden or 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,19 @@ | ||
| The hardware requirements below give a rough estimate of the minimum hardware setup needed for a Plone server. | ||
|  | ||
| A single Plone installation is able to run many Plone sites. | ||
|  | ||
| - Installation of the Plone backend and Classic UI frontend requires a minimum of 256 MB of RAM and 2GB of disk swap space. | ||
| - Installation of the Volto frontend requires a minimum of 2GB of RAM. | ||
| - After installation, running Plone requires a minimum of 256 MB RAM and 512 MB of disk swap space per Plone site. | ||
| 2 GB or more RAM per Plone site is recommended. | ||
| - Minimum 512 MB hard disk space is required. | ||
| 40 GB or more hard disk space is recommended. | ||
|  | ||
|  | ||
| ````{warning} | ||
| {term}`Add-on` products and caching solutions may also increase RAM and disk swap space requirements. | ||
| To avoid RAM and disk swap limitations, we recommend either temporarily resizing your remote machine to accommodate the build, or build your images locally and upload them to an image store, such as [Docker Hub](https://hub.docker.com/) or [GitHub Packages](https://github.com/features/packages). | ||
| ```{seealso} | ||
| [How much RAM is required to build a Volto front end?](https://community.plone.org/t/how-much-ram-is-required-to-build-a-volto-front-end/17949) and [Dealing with heap exhaustion while building Volto 17 on limited-RAM host](https://community.plone.org/t/dealing-with-heap-exhaustion-while-building-volto-17-on-limited-ram-host/18078). | ||
| ``` | ||
| ```` | 
  
    
      This file contains hidden or 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,6 @@ | ||
| Installing Python is beyond the scope of this documentation. | ||
| However, it is recommended to use a Python version manager, {term}`pyenv`, that allows you to install multiple versions of Python on your development environment without destroying your system's Python. | ||
| % TODO: uncomment this line after upgrading to plone-sphinx-theme and latest Sphinx which supports replacements inside includes. | ||
| % Plone requires Python version {SUPPORTED_PYTHON_VERSIONS}. | ||
|  | ||
| Plone requires Python version 3.8, 3.9, 3.10, 3.11, or 3.12. | 
      
      Loading
      
  Sorry, something went wrong. Reload?
      Sorry, we cannot display this file.
      Sorry, this file is invalid so it cannot be displayed.
      
    
      
      Loading
      
  Sorry, something went wrong. Reload?
      Sorry, we cannot display this file.
      Sorry, this file is invalid so it cannot be displayed.
      
    
  
    
      This file contains hidden or 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,224 @@ | ||
| --- | ||
| myst: | ||
| html_meta: | ||
| "description": "Create a Plone project with Classic UI (stable release)" | ||
| "property=og:description": "Create a Plone project with Classic UI (stable release)" | ||
| "property=og:title": "Create a Plone project with Classic UI (stable release)" | ||
| "keywords": "Plone, Plone 6, Classic UI, create, project, install, cookiecutter" | ||
| --- | ||
|  | ||
|  | ||
| (create-a-project-classic-ui-label)= | ||
|  | ||
| # Create a project with Classic UI (stable release) | ||
|  | ||
| This chapter describes how you can create a web application using the current **stable release** version of Plone with **Classic UI** for the frontend, while having full control over its development and deployment. | ||
|  | ||
| ```{seealso} | ||
| For other installation options, see {doc}`/install/index`. | ||
| ``` | ||
|  | ||
|  | ||
| ## System requirements | ||
|  | ||
| Plone 6 has both hardware requirements and software pre-requisites. | ||
|  | ||
|  | ||
| ### Hardware requirements | ||
|  | ||
| ```{include} /_inc/_hardware-requirements.md | ||
| ``` | ||
|  | ||
| ### Pre-requisites for installation | ||
|  | ||
| ```{include} ../volto/contributing/install-operating-system.md | ||
| ``` | ||
|  | ||
| - Python {SUPPORTED_PYTHON_VERSIONS} | ||
| - {term}`pipx` | ||
| - {term}`GNU make` | ||
| - {term}`Git` | ||
|  | ||
|  | ||
| #### Python | ||
|  | ||
| ```{include} /_inc/_install-python.md | ||
| ``` | ||
|  | ||
|  | ||
| #### pipx | ||
|  | ||
| Install {term}`pipx`. | ||
|  | ||
| ```shell | ||
| pip install pipx | ||
| ``` | ||
|  | ||
|  | ||
| #### Make | ||
|  | ||
| ```{include} ../volto/contributing/install-make.md | ||
| ``` | ||
|  | ||
|  | ||
| #### Git | ||
|  | ||
| ```{include} ../volto/contributing/install-git.md | ||
| ``` | ||
|  | ||
|  | ||
| ## Generate the project | ||
|  | ||
| After satisfying the pre-requisites, generate the project. | ||
|  | ||
| ```shell | ||
| pipx run cookieplone backend_addon | ||
| ``` | ||
|  | ||
| You will be presented with a series of prompts. | ||
| You can accept the default values in square brackets (`[default-option]`) by hitting the {kbd}`Enter` key, or enter your preferred values. | ||
| For ease of documentation, we will use the default values. | ||
|  | ||
| ```{tip} | ||
| See the cookiecutter's README for how to [Use options to avoid prompts](https://github.com/collective/cookiecutter-plone-starter/?tab=readme-ov-file#use-options-to-avoid-prompts). | ||
| ``` | ||
|  | ||
| ```{important} | ||
| For {guilabel}`Project Slug`, you must not use any of the Plone core package names listed in [`constraints.txt`](https://dist.plone.org/release/6.0-latest/constraints.txt). | ||
| Note that pip normalizes these names, so `plone.volto` and `plone-volto` are the same package. | ||
| ``` | ||
|  | ||
| ```console | ||
| % pipx run cookieplone backend_addon | ||
| ╭─────────────────────────────────── cookieplone ────────────────────────────────────╮ | ||
| │ │ | ||
| │ .xxxxxxxxxxxxxx. │ | ||
| │ ;xxxxxxxxxxxxxxxxxxxxxx; │ | ||
| │ ;xxxxxxxxxxxxxxxxxxxxxxxxxxxx; │ | ||
| │ xxxxxxxxxx xxxxxxxxxx │ | ||
| │ xxxxxxxx. .xxxxxxxx │ | ||
| │ xxxxxxx xxxxxxx: xxxxxxx │ | ||
| │ :xxxxxx xxxxxxxxxx xxxxxx: │ | ||
| │ :xxxxx+ xxxxxxxxxxx +xxxxx: │ | ||
| │ .xxxxx. :xxxxxxxxxx .xxxxx. │ | ||
| │ xxxxx+ ;xxxxxxxx +xxxxx │ | ||
| │ xxxxx +xx. xxxxx. │ | ||
| │ xxxxx: .xxxxxxxx :xxxxx │ | ||
| │ xxxxx .xxxxxxxxxx xxxxx │ | ||
| │ xxxxx xxxxxxxxxxx xxxxx │ | ||
| │ xxxxx .xxxxxxxxxx xxxxx │ | ||
| │ xxxxx: .xxxxxxxx :xxxxx │ | ||
| │ .xxxxx ;xx. ... xxxxx. │ | ||
| │ xxxxx+ :xxxxxxxx +xxxxx │ | ||
| │ .xxxxx. :xxxxxxxxxx .xxxxx. │ | ||
| │ :xxxxx+ xxxxxxxxxxx ;xxxxx: │ | ||
| │ :xxxxxx xxxxxxxxxx xxxxxx: │ | ||
| │ xxxxxxx xxxxxxx; xxxxxxx │ | ||
| │ xxxxxxxx. .xxxxxxxx │ | ||
| │ xxxxxxxxxx xxxxxxxxxx │ | ||
| │ ;xxxxxxxxxxxxxxxxxxxxxxxxxxxx+ │ | ||
| │ ;xxxxxxxxxxxxxxxxxxxxxx; │ | ||
| │ .xxxxxxxxxxxxxx. │ | ||
| │ │ | ||
| ╰────────────────────────────────────────────────────────────────────────────────────╯ | ||
| ╭─────────────────────────────────── Plone Addon ────────────────────────────────────╮ | ||
| │ Creating a new Plone Addon │ | ||
|         
                  stevepiercy marked this conversation as resolved.
              Show resolved
            Hide resolved | ||
| ╰────────────────────────────────────────────────────────────────────────────────────╯ | ||
| [1/7] Addon Title (Addon): | ||
| [2/7] A short description of your addon (A new addon for Plone): | ||
| [3/7] Author (Plone Community): | ||
| [4/7] Author E-mail ([email protected]): | ||
| [5/7] GitHub Username or Organization (collective): | ||
| [6/7] Python package name (collective.addon): | ||
| [7/7] Support headless Plone? | ||
| 1 - Yes | ||
| 2 - No | ||
| Choose from [1/2] (1): | ||
| -> Initialize Git repository | ||
| ╭───────────────────────────── New addon was generated ──────────────────────────────╮ | ||
| │ │ | ||
| │ Addon │ | ||
| │ │ | ||
| │ Now, enter the repository run the code formatter with: │ | ||
| │ │ | ||
| │ make format │ | ||
| │ │ | ||
| │ start coding, and push to your organization. │ | ||
| │ │ | ||
| │ Sorry for the convenience, │ | ||
| │ The Plone Community. │ | ||
| │ │ | ||
| │ https://plone.org/ │ | ||
| ╰────────────────────────────────────────────────────────────────────────────────────╯ | ||
| ``` | ||
|  | ||
|  | ||
| ## Install the project | ||
|  | ||
| Change to your project directory. | ||
|  | ||
| ```shell | ||
| cd collective.addon | ||
| ``` | ||
|  | ||
| To install the project's dependencies, use the following command. | ||
|  | ||
| ```shell | ||
| make install | ||
| ``` | ||
|  | ||
| This will take a few minutes. | ||
| When the process completes successfully, it will exit with no message. | ||
|  | ||
|  | ||
| ## Start Plone | ||
|  | ||
| To start Plone, issue the following command. | ||
|  | ||
| ```shell | ||
| make start | ||
| ``` | ||
|  | ||
| The Plone backend server starts up and emits messages to the console. | ||
|  | ||
| ```console | ||
| 2024-09-25 16:47:15,699 INFO [chameleon.config:39][MainThread] directory cache: /<path-to-project>/instance/var/cache. | ||
| 2024-09-25 16:47:16,387 WARNING [ZODB.FileStorage:412][MainThread] Ignoring index for /<path-to-project>/instance/var/filestorage/Data.fs | ||
| 2024-09-25 16:47:16,508 INFO [plone.restapi.patches:16][MainThread] PATCH: Disabled ZPublisher.HTTPRequest.ZopeFieldStorage.VALUE_LIMIT. This enables file uploads larger than 1MB. | ||
| 2024-09-25 16:47:17,018 INFO [plone.volto:23][MainThread] Aliasing collective.folderish classes to plone.volto classes. | ||
| 2024-09-25 16:47:17,760 INFO [Zope:42][MainThread] Ready to handle requests | ||
| Starting server in PID 20912. | ||
| 2024-09-25 16:47:17,772 INFO [waitress:486][MainThread] Serving on http://[::1]:8080 | ||
| 2024-09-25 16:47:17,772 INFO [waitress:486][MainThread] Serving on http://127.0.0.1:8080 | ||
| ``` | ||
|  | ||
| You can stop the site with {kbd}`ctrl-c`. | ||
|  | ||
|  | ||
| ## Create Classic UI Plone site | ||
|  | ||
| While the Plone backend server is running, open a browser and visit the following URL. | ||
|  | ||
| http://localhost:8080 | ||
|  | ||
| ```{image} /_static/plone-classic-ui-landing-page.png | ||
| :class: figure | ||
| :alt: Plone Classic UI landing page | ||
| ``` | ||
|  | ||
| Click the button {guilabel}`Create Classic UI Plone site` to do exactly that. | ||
|         
                  stevepiercy marked this conversation as resolved.
              Show resolved
            Hide resolved | ||
|  | ||
| Use the username and password of `admin` to authenticate. | ||
| You will be redirected to the Create a Plone site page. | ||
|  | ||
| ```{image} /_static/plone-classic-ui-site-page.png | ||
| :class: figure | ||
| :alt: Plone Classic UI site page | ||
| ``` | ||
|  | ||
| Enter values for {guilabel}`Path identifier`, {guilabel}`Title`, {guilabel}`Language`, and {guilabel}`Default timezone`. | ||
| The default values are usually good. | ||
|  | ||
| Click the button {guilabel}`Create Plone site`. | ||
|  | ||
| You will be redirected to the Plone site you just created. | ||
      
      Oops, something went wrong.
        
    
  
  Add this suggestion to a batch that can be applied as a single commit.
  This suggestion is invalid because no changes were made to the code.
  Suggestions cannot be applied while the pull request is closed.
  Suggestions cannot be applied while viewing a subset of changes.
  Only one suggestion per line can be applied in a batch.
  Add this suggestion to a batch that can be applied as a single commit.
  Applying suggestions on deleted lines is not supported.
  You must change the existing code in this line in order to create a valid suggestion.
  Outdated suggestions cannot be applied.
  This suggestion has been applied or marked resolved.
  Suggestions cannot be applied from pending reviews.
  Suggestions cannot be applied on multi-line comments.
  Suggestions cannot be applied while the pull request is queued to merge.
  Suggestion cannot be applied right now. Please check back later.
  
    
  
    
Uh oh!
There was an error while loading. Please reload this page.