mirror of
				https://github.com/zadam/trilium.git
				synced 2025-10-26 07:46:30 +01:00 
			
		
		
		
	bugfixes to sync
This commit is contained in:
		
							
								
								
									
										14
									
								
								db/migrations/0228__fix_blobIds.sql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								db/migrations/0228__fix_blobIds.sql
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | |||||||
|  | UPDATE blobs SET blobId = REPLACE(blobId, '+', 'X'); | ||||||
|  | UPDATE blobs SET blobId = REPLACE(blobId, '/', 'Y'); | ||||||
|  |  | ||||||
|  | UPDATE notes SET blobId = REPLACE(blobId, '+', 'X'); | ||||||
|  | UPDATE notes SET blobId = REPLACE(blobId, '/', 'Y'); | ||||||
|  |  | ||||||
|  | UPDATE attachments SET blobId = REPLACE(blobId, '+', 'X'); | ||||||
|  | UPDATE attachments SET blobId = REPLACE(blobId, '/', 'Y'); | ||||||
|  |  | ||||||
|  | UPDATE revisions SET blobId = REPLACE(blobId, '+', 'X'); | ||||||
|  | UPDATE revisions SET blobId = REPLACE(blobId, '/', 'Y'); | ||||||
|  |  | ||||||
|  | UPDATE entity_changes SET entityId = REPLACE(entityId, '+', 'X') WHERE entityName = 'blobs'; | ||||||
|  | UPDATE entity_changes SET entityId = REPLACE(entityId, '/', 'Y') WHERE entityName = 'blobs'; | ||||||
| @@ -4,8 +4,8 @@ const build = require('./build.js'); | |||||||
| const packageJson = require('../../package.json'); | const packageJson = require('../../package.json'); | ||||||
| const {TRILIUM_DATA_DIR} = require('./data_dir.js'); | const {TRILIUM_DATA_DIR} = require('./data_dir.js'); | ||||||
|  |  | ||||||
| const APP_DB_VERSION = 227; | const APP_DB_VERSION = 228; | ||||||
| const SYNC_VERSION = 31; | const SYNC_VERSION = 32; | ||||||
| const CLIPPER_PROTOCOL_VERSION = "1.0"; | const CLIPPER_PROTOCOL_VERSION = "1.0"; | ||||||
|  |  | ||||||
| module.exports = { | module.exports = { | ||||||
|   | |||||||
| @@ -5,12 +5,14 @@ const utils = require('./utils.js'); | |||||||
|  |  | ||||||
| function getBlobPojo(entityName, entityId) { | function getBlobPojo(entityName, entityId) { | ||||||
|     const entity = becca.getEntity(entityName, entityId); |     const entity = becca.getEntity(entityName, entityId); | ||||||
|  |  | ||||||
|     if (!entity) { |     if (!entity) { | ||||||
|         throw new NotFoundError(`Entity ${entityName} '${entityId}' was not found.`); |         throw new NotFoundError(`Entity ${entityName} '${entityId}' was not found.`); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     const blob = becca.getBlob(entity); |     const blob = becca.getBlob(entity); | ||||||
|  |     if (!blob) { | ||||||
|  |         throw new NotFoundError(`Blob ${entity.blobId} for ${entityName} '${entityId}' was not found.`); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     const pojo = blob.getPojo(); |     const pojo = blob.getPojo(); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -17,6 +17,9 @@ const {sanitizeAttributeName} = require('./sanitize_attribute_name.js'); | |||||||
| const noteTypes = require('../services/note_types.js').getNoteTypeNames(); | const noteTypes = require('../services/note_types.js').getNoteTypeNames(); | ||||||
|  |  | ||||||
| class ConsistencyChecks { | class ConsistencyChecks { | ||||||
|  |     /** | ||||||
|  |      * @param autoFix - automatically fix all encountered problems. False is only for debugging during development (fail fast) | ||||||
|  |      */ | ||||||
|     constructor(autoFix) { |     constructor(autoFix) { | ||||||
|         this.autoFix = autoFix; |         this.autoFix = autoFix; | ||||||
|         this.unrecoveredConsistencyErrors = false; |         this.unrecoveredConsistencyErrors = false; | ||||||
|   | |||||||
| @@ -37,6 +37,8 @@ function eraseNotes(noteIdsToErase) { | |||||||
| function setEntityChangesAsErased(entityChanges) { | function setEntityChangesAsErased(entityChanges) { | ||||||
|     for (const ec of entityChanges) { |     for (const ec of entityChanges) { | ||||||
|         ec.isErased = true; |         ec.isErased = true; | ||||||
|  |         // we're not changing hash here, not sure if good or not | ||||||
|  |         // content hash check takes isErased flag into account, though | ||||||
|         ec.utcDateChanged = dateUtils.utcNowDateTime(); |         ec.utcDateChanged = dateUtils.utcNowDateTime(); | ||||||
|  |  | ||||||
|         entityChangesService.putEntityChangeWithForcedChange(ec); |         entityChangesService.putEntityChangeWithForcedChange(ec); | ||||||
|   | |||||||
| @@ -73,8 +73,11 @@ async function migrate() { | |||||||
|         } |         } | ||||||
|     }); |     }); | ||||||
|  |  | ||||||
|     log.info("VACUUMing database, this might take a while ..."); |     if (currentDbVersion === 214) { | ||||||
|     sql.execute("VACUUM"); |         // special VACUUM after the big migration | ||||||
|  |         log.info("VACUUMing database, this might take a while ..."); | ||||||
|  |         sql.execute("VACUUM"); | ||||||
|  |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| function executeMigration(mig) { | function executeMigration(mig) { | ||||||
|   | |||||||
| @@ -91,12 +91,16 @@ function updateNormalEntity(remoteEC, remoteEntityRow, instanceId, updateContext | |||||||
|             updateContext.updated[remoteEC.entityName].push(remoteEC.entityId); |             updateContext.updated[remoteEC.entityName].push(remoteEC.entityId); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         if (!localEC || localEC.utcDateChanged < remoteEC.utcDateChanged || localEC.hash !== remoteEC.hash) { |         if (!localEC || localEC.utcDateChanged < remoteEC.utcDateChanged | ||||||
|  |             || localEC.hash !== remoteEC.hash | ||||||
|  |             || localEC.isErased !== remoteEC.isErased | ||||||
|  |         ) { | ||||||
|             entityChangesService.putEntityChangeWithInstanceId(remoteEC, instanceId); |             entityChangesService.putEntityChangeWithInstanceId(remoteEC, instanceId); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         return true; |         return true; | ||||||
|     } else if (localEC.hash !== remoteEC.hash && localEC.utcDateChanged > remoteEC.utcDateChanged) { |     } else if ((localEC.hash !== remoteEC.hash || localEC.isErased !== remoteEC.isErased) | ||||||
|  |                 && localEC.utcDateChanged > remoteEC.utcDateChanged) { | ||||||
|         // the change on our side is newer than on the other side, so the other side should update |         // the change on our side is newer than on the other side, so the other side should update | ||||||
|         entityChangesService.putEntityChangeForOtherInstances(localEC); |         entityChangesService.putEntityChangeForOtherInstances(localEC); | ||||||
|  |  | ||||||
| @@ -148,7 +152,7 @@ function eraseEntity(entityChange) { | |||||||
|     ]; |     ]; | ||||||
|  |  | ||||||
|     if (!entityNames.includes(entityName)) { |     if (!entityNames.includes(entityName)) { | ||||||
|         log.error(`Cannot erase entity '${entityName}', id '${entityId}'.`); |         log.error(`Cannot erase ${entityName} '${entityId}'.`); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -34,8 +34,8 @@ function hashedBlobId(content) { | |||||||
|  |  | ||||||
|     // we don't want such + and / in the IDs |     // we don't want such + and / in the IDs | ||||||
|     const kindaBase62Hash = base64Hash |     const kindaBase62Hash = base64Hash | ||||||
|         .replace('+', 'X') |         .replaceAll('+', 'X') | ||||||
|         .replace('/', 'Y'); |         .replaceAll('/', 'Y'); | ||||||
|  |  | ||||||
|     // 20 characters of base62 gives us ~120 bit of entropy which is plenty enough |     // 20 characters of base62 gives us ~120 bit of entropy which is plenty enough | ||||||
|     return kindaBase62Hash.substr(0, 20); |     return kindaBase62Hash.substr(0, 20); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user