-
Notifications
You must be signed in to change notification settings - Fork 13
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'develop' of github.com:Chia-Network/climate-warehouse i…
…nto develop
- Loading branch information
Showing
12 changed files
with
419 additions
and
3 deletions.
There are no files selected for viewing
This file contains 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
227 changes: 227 additions & 0 deletions
227
src/database/migrations/20220808192709-populate-units-fts.js
This file contains 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,227 @@ | ||
'use strict'; | ||
|
||
export default { | ||
async up(queryInterface) { | ||
if (queryInterface.sequelize.getDialect() === 'sqlite') { | ||
await queryInterface.dropTable('units_fts'); | ||
await queryInterface.sequelize.query(` | ||
CREATE VIRTUAL TABLE units_fts USING fts5( | ||
warehouseUnitId, | ||
issuanceId, | ||
projectLocationId, | ||
orgUid, | ||
unitOwner, | ||
countryJurisdictionOfOwner, | ||
inCountryJurisdictionOfOwner, | ||
serialNumberBlock, | ||
vintageYear, | ||
unitType, | ||
marketplace, | ||
marketplaceLink, | ||
marketplaceIdentifier, | ||
unitTags, | ||
unitStatus, | ||
unitStatusReason, | ||
unitRegistryLink, | ||
correspondingAdjustmentDeclaration, | ||
correspondingAdjustmentStatus, | ||
unitBlockStart, | ||
unitBlockEnd, | ||
unitCount, | ||
timeStaged | ||
); | ||
`); | ||
await queryInterface.sequelize.query( | ||
`INSERT INTO units_fts SELECT | ||
warehouseUnitId, | ||
issuanceId, | ||
projectLocationId, | ||
orgUid, | ||
unitOwner, | ||
countryJurisdictionOfOwner, | ||
inCountryJurisdictionOfOwner, | ||
serialNumberBlock, | ||
vintageYear, | ||
unitType, | ||
marketplace, | ||
marketplaceLink, | ||
marketplaceIdentifier, | ||
unitTags, | ||
unitStatus, | ||
unitStatusReason, | ||
unitRegistryLink, | ||
correspondingAdjustmentDeclaration, | ||
correspondingAdjustmentStatus, | ||
unitBlockStart, | ||
unitBlockEnd, | ||
unitCount, | ||
timeStaged | ||
FROM units`, | ||
); | ||
|
||
await queryInterface.sequelize.query(` | ||
CREATE TRIGGER unit_insert_fts AFTER INSERT ON units BEGIN | ||
INSERT INTO units_fts( | ||
warehouseUnitId, | ||
issuanceId, | ||
projectLocationId, | ||
orgUid, | ||
unitOwner, | ||
countryJurisdictionOfOwner, | ||
inCountryJurisdictionOfOwner, | ||
serialNumberBlock, | ||
vintageYear, | ||
unitType, | ||
marketplace, | ||
marketplaceLink, | ||
marketplaceIdentifier, | ||
unitTags, | ||
unitStatus, | ||
unitStatusReason, | ||
unitRegistryLink, | ||
correspondingAdjustmentDeclaration, | ||
correspondingAdjustmentStatus, | ||
unitBlockStart, | ||
unitBlockEnd, | ||
unitCount | ||
) VALUES ( | ||
new.warehouseUnitId, | ||
new.issuanceId, | ||
new.projectLocationId, | ||
new.orgUid, | ||
new.unitOwner, | ||
new.countryJurisdictionOfOwner, | ||
new.inCountryJurisdictionOfOwner, | ||
new.serialNumberBlock, | ||
new.vintageYear, | ||
new.unitType, | ||
new.marketplace, | ||
new.marketplaceLink, | ||
new.marketplaceIdentifier, | ||
new.unitTags, | ||
new.unitStatus, | ||
new.unitStatusReason, | ||
new.unitRegistryLink, | ||
new.correspondingAdjustmentDeclaration, | ||
new.correspondingAdjustmentStatus, | ||
new.unitBlockStart, | ||
new.unitBlockEnd, | ||
new.unitCount | ||
); | ||
END;`); | ||
|
||
await queryInterface.sequelize.query(` | ||
CREATE TRIGGER unit_delete_fts AFTER DELETE ON units BEGIN | ||
DELETE FROM units_fts WHERE warehouseUnitId = old.warehouseUnitId; | ||
END; | ||
`); | ||
|
||
await queryInterface.sequelize.query(` | ||
CREATE TRIGGER unit_update_fts AFTER UPDATE ON units BEGIN | ||
DELETE FROM units_fts WHERE warehouseUnitId = old.warehouseUnitId; | ||
INSERT INTO units_fts( | ||
warehouseUnitId, | ||
issuanceId, | ||
projectLocationId, | ||
orgUid, | ||
unitOwner, | ||
countryJurisdictionOfOwner, | ||
inCountryJurisdictionOfOwner, | ||
serialNumberBlock, | ||
vintageYear, | ||
unitType, | ||
marketplace, | ||
marketplaceLink, | ||
marketplaceIdentifier, | ||
unitTags, | ||
unitStatus, | ||
unitStatusReason, | ||
unitRegistryLink, | ||
correspondingAdjustmentDeclaration, | ||
correspondingAdjustmentStatus, | ||
unitBlockStart, | ||
unitBlockEnd, | ||
unitCount | ||
) VALUES ( | ||
new.warehouseUnitId, | ||
new.issuanceId, | ||
new.projectLocationId, | ||
new.orgUid, | ||
new.unitOwner, | ||
new.countryJurisdictionOfOwner, | ||
new.inCountryJurisdictionOfOwner, | ||
new.serialNumberBlock, | ||
new.vintageYear, | ||
new.unitType, | ||
new.marketplace, | ||
new.marketplaceLink, | ||
new.marketplaceIdentifier, | ||
new.unitTags, | ||
new.unitStatus, | ||
new.unitStatusReason, | ||
new.unitRegistryLink, | ||
new.correspondingAdjustmentDeclaration, | ||
new.correspondingAdjustmentStatus, | ||
new.unitBlockStart, | ||
new.unitBlockEnd, | ||
new.unitCount | ||
); | ||
END; | ||
`); | ||
} | ||
}, | ||
|
||
async down(queryInterface) { | ||
await queryInterface.dropTable('units_fts'); | ||
await queryInterface.sequelize.query(` | ||
CREATE VIRTUAL TABLE units_fts USING fts5( | ||
warehouseProjectId, | ||
orgUid, | ||
currentRegistry, | ||
projectId, | ||
registryOfOrigin, | ||
originProjectId, | ||
program, | ||
projectName, | ||
projectLink, | ||
projectDeveloper, | ||
sector, | ||
coveredByNDC, | ||
projectType, | ||
projectTags, | ||
ndcInformation, | ||
projectStatus, | ||
projectStatusDate, | ||
unitMetric, | ||
methodology, | ||
validationBody, | ||
validationDate, | ||
timeStaged | ||
); | ||
`); | ||
await queryInterface.sequelize.query( | ||
`INSERT INTO units_fts SELECT warehouseUnitId, | ||
orgUid, | ||
currentRegistry, | ||
projectId, | ||
registryOfOrigin, | ||
originProjectId, | ||
program, | ||
projectName, | ||
projectLink, | ||
projectDeveloper, | ||
sector, | ||
coveredByNDC, | ||
projectType, | ||
projectTags, | ||
ndcInformation, | ||
projectStatus, | ||
projectStatusDate, | ||
unitMetric, | ||
methodology, | ||
validationBody, | ||
validationDate, | ||
timeStaged FROM units`, | ||
); | ||
}, | ||
}; |
22 changes: 22 additions & 0 deletions
22
src/database/migrations/20220809182156-AddFileStoreSubscribedColumn.js
This file contains 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,22 @@ | ||
'use strict'; | ||
|
||
export default { | ||
async up(queryInterface, Sequelize) { | ||
await Promise.all( | ||
['organizations'].map((table) => { | ||
queryInterface.addColumn(table, 'fileStoreSubscribed', { | ||
type: Sequelize.STRING, | ||
allowNull: true, | ||
}); | ||
}), | ||
); | ||
}, | ||
|
||
async down(queryInterface) { | ||
await Promise.all( | ||
['organizations'].map((table) => { | ||
queryInterface.removeColumn(table, 'fileStoreSubscribed'); | ||
}), | ||
); | ||
}, | ||
}; |
This file contains 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
This file contains 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
This file contains 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
Oops, something went wrong.