# Populating the Database for the First Time - [Development Environments](#development-environments) - [Deployed Environments](#deployed-environments) - [Further Reading](#further-reading) This document contains information about importing Boost Versions (also called Releases), Libraries, and the data associated with those objects. It is concerned with importing data in **deployed environments**, but at the bottom of the page there is a section on importing data for **local development**. ## Development Environments Download the production data for the website and mailman/hyperkitty. ```bash just load_production_data ```` That script can be run regularly to update data from the live servers. You will lose all local data. ## Deployed Environments There are several steps to populating the database with historical Boost data, because we retrieve Boost data from multiple sources. You can run all of these steps in sequence in a single command with the command: ```bash ./manage.py boost_setup ``` The `boost_setup` command will run all of the processes listed here: ```bash # Import Boost releases ./manage.py import_versions # import_versions also runs import_artifactory_release_data # Import Boost libraries ./manage.py update_libraries # Save which Boost releases include which libraries ./manage.py import_library_versions # import_library_versions retrieves documentation urls, so boost_setup # doesn't run import_library_version_docs_urls # Save other data we need for Libraries and LibraryVersions ./manage.py update_maintainers ./manage.py update_authors ./manage.py import_commits # Get the most recent beta release, and delete old beta releases ./manage.py import_beta_release --delete-versions ./manage.py import_ml_counts ``` Read more aboout these [management commands](./commands.md). Collectively, this is what these management commands accomplish: 1. `import_versions`: Imports Boost releases as `Version` objects, and imports links to Boost downloads hosted on Artifactory. 2. `update_libraries`: Imports Boost libraries and categories as `Library` and `Category` objects. 3. `import_library_versions`: Establishes which Boost libraries are included in which Boost versions. That information is stored in `LibraryVersion` objects. This process also stores the link to the version-specific Boost documentation for this library. 4. `update_maintainers`: For each `LibraryVersion`, saves the maintainers as `User` objects and makes sure they are associated with the `LibraryVersion`. 5. `update_authors`: For each `Library`, saves the authors as `User` objects and makes sure they are associated with the `Library`. 6. `import_commits`: For each `Library`, iterate through the `LibraryVersion`s and create `Commit`, `CommitAuthor`, and `CommitAuthorEmail` objects. Also attempts to update `CommitAuthor`s with their github profile URL and Avatar URL. 7. `import_beta_release`: Retrieves the most recent beta release from GitHub and imports it. If `--delete-versions` is passed, will delete the existing beta releases in the database. ## Further Reading - [Syncing Data about Boost Versions and Libraries with GitHub](./syncing_data_with_github.md) - Read more aboout the [management commands](./commands.md) you see here.