Refer.laaha.org. Formerly erefer.org
Local: https://refer-laaha.ddev.site Dev: https://refer-laaha.org Test/Stage: https://test-refer.laaha.org Live/Prod: https://refer.laaha.org
Prerequisites: Git and DDEV
git clone [email protected]:unicef/refer-laaha.git
cd refer-laaha
ddev start
ddev auth ssh
ddev composer update
If needed, mkdir backups
(an ignored directory) first.
The database can be retrieved from nightly backups, for example:
ddev export-db > backups/local-paranoia-backup-2022-09-07.sql.gz
scp [email protected]:/home/erpw/dev/backups/on-demand/backup-2022-10-17-17-05-erpw-146875152.sql.gz backups/
ddev import-db --src backups/backup-2022-10-17-17-05-erpw-146875152.sql.gz
ddev drush cr
Configuration overrides for the acquia_search_server are provided in settings.local-dev-shared.php, and included in a development environment by default. A solr instance is configured by ddev already, and is used by these overrides. The collection's configuration is not auto-configured however, so these commands will perform this action (which can also be done from https://laaha-org.ddev.site/en/admin/config/search/search-api/server/acquia_search_server if the search_api_solr_admin module is enabled).
ddev drush pm:enable search_api_solr_admin
ddev drush cr
ddev drush solr-upload-conf acquia_server_test_support --numShards=1
ddev drush pm:uninstall search_api_solr_admin # the admin module is not needed for normal use
ddev drush sapi-i acquia_live_search_index # rebuild the index (or just use UI)
Make local changes and export with:
ddev drush cex -y
Pull down changes made directly on an Acquia environment with, for dev:
ddev drush cpull @dev @self
Push a tag to the main branch, and GitHub will use blt artifact:deploy
. Acquia's approach is very slow; when that eventually finishes (visit https://github.com/unicef/laaha-org/actions/ to watch progress or https://cloud.acquia.com/a/applications/1453586a-0bf5-4dce-a39c-c53e788c86f7 to see the result in the Task Log) these additional steps are needed:
ddev drush @dev cr
ddev drush @dev -y updb
ddev drush @dev -y cim
From the hosted dev environment, further code deployments to test and prod are done through the cloud.acquia.com dashboard. After each code deployment through the UI, the database update and the configuration import are still needed.
For test:
ddev drush @test cr
ddev drush @test -y updb
ddev drush @test -y cim
And live:
ddev drush @live cr
ddev drush @live -y updb
ddev drush @live -y cim
Add to and follow the pattern for docroot/sites/default/settings.test.php
:
// Override domain hostnames. These need to be updated for each country added
// to production or else test/dev/local may send browsers to the live site.
$config['domain.record.bn_erefer_org']['hostname'] = 'bn-stage.erefer.org';
Edit the same section at docroot/sites/default/settings.local-dev-shared.php
.
And you must add the domain on Acquia to the Stage domains configuration.
(The dash in "ec-test" allows us to have a valid security sertificate while testing, but does require these subdomains be added manually to Acquia stage environment.)
- Add a new domain record at /admin/config/domain.
- Override the domain hostnames in settings.local-dev-shared.php , settings.test.php.
- Add the new domain hostname in .ddev/config.yml under additional_hostnames.
- Configure settings such as language detection and selection,languages and so on for the new domain from operations on /admin/config/domain.
- Re-arrange the detection methods under Content language detection from /admin/config/domain/language-detect-select/
- From /admin/content , enable the content of type homepage and basic page for the the new domain , and you can perform the same for the other required contents.
- From /admin/structure/block/manage/navigationheadermenu , configure the navigation menu block to appear on the new domain.
- Add new content under /admin/structure/taxonomy/manage/categories/overview for the hero categories to be displayed.
DELIMITER //
DROP FUNCTION IF EXISTS GetTopLevelParent //
CREATE FUNCTION GetTopLevelParent(eid INT) RETURNS INT
BEGIN
DECLARE parent INT;
DECLARE entityid INT;
SET parent = eid;
WHILE parent != 0 DO
SET entityid = parent;
SELECT ttp.parent_target_id INTO parent FROM taxonomy_term__parent AS ttp JOIN taxonomy_term_data AS ttd ON ttd.tid = ttp.entity_id WHERE ttp.entity_id = entityid && ttd.vid = 'country';
END
WHILE;
RETURN entityid;
END //
DELIMITER ;
The above function will returen the top most location id by given location id, directly executed this on Acquia database.
Copyright (c) 2021 UNICEF
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.