diff --git a/.husky/pre-commit b/.husky/pre-commit index d24fdfc60..9d4f45ace 100755 --- a/.husky/pre-commit +++ b/.husky/pre-commit @@ -1,4 +1,5 @@ #!/usr/bin/env sh . "$(dirname -- "$0")/_/husky.sh" -npx lint-staged +# Disabling this hook for now because the BuildLintCommand has issues. If you have an error in a file that eslint catches the commit fails silently instead of explaining the error (Will 04/09/2023) +# npx lint-staged diff --git a/.lintstagedrc.js b/.lintstagedrc.js index 61152b6fb..d1b83dbc7 100644 --- a/.lintstagedrc.js +++ b/.lintstagedrc.js @@ -1,25 +1,38 @@ -const ignoredFiles = [ - 'package.json', - 'yarn.lock', - 'tsconfig.json', - '.lintstagedrc.js', - '.eslintrc.js', -]; - -const path = require('path'); - -const buildFormatCommand = filenames => { - const results = filenames - .map(f => path.relative(process.cwd(), f)) - .filter(f => !ignoredFiles.includes(f)); - - return results.length ? `prettier --list-different --write ${results.join(' ')}` : ''; +const { ESLint } = require('eslint'); + +const removeIgnoredFiles = async files => { + const eslint = new ESLint(); + const isIgnored = await Promise.all( + files.map(file => { + return eslint.isPathIgnored(file); + }) + ); + const filteredFiles = files.filter((_, i) => !isIgnored[i]); + return filteredFiles.join(' '); +}; + +const buildFormatCommand = async files => { + const filesToLint = await removeIgnoredFiles(files); + + if (!filesToLint || !filesToLint.length) { + return ''; + } + + const results = filesToLint.map(f => path.relative(process.cwd(), f)); + + return results.length + ? `prettier --ignore-unknown --list-different --write ${results.join(' ')}` + : ''; }; -const buildLintCommand = filenames => { - const results = filenames - .map(f => path.relative(process.cwd(), f)) - .filter(f => !ignoredFiles.includes(f)); +const buildLintCommand = async files => { + const filesToLint = await removeIgnoredFiles(files); + + if (!filesToLint || !filesToLint.length) { + return ''; + } + + const results = filesToLint.map(f => path.relative(process.cwd(), f)); return results.length ? `eslint --cache ${results.join(' ')}` : ''; }; diff --git a/README.md b/README.md index 3e2dd66d3..3c938cad6 100644 --- a/README.md +++ b/README.md @@ -12,6 +12,10 @@ Session integrates directly with [Oxen Service Nodes](https://docs.oxen.io/about Please search for any [existing issues](https://github.com/oxen-io/session-desktop/issues) that describe your bug in order to avoid duplicate submissions.

Submissions can be made by making a pull request to our development branch.If you don't know where to start contributing please read [Contributing.md](CONTRIBUTING.md) and refer to issues tagged with the [Good-first-issue](https://github.com/oxen-io/session-desktop/issues?q=is%3Aopen+is%3Aissue+label%3A%22good+first+issue%22) tag. +## Supported platforms + +Session requires Windows 10 or later, macOS Catalina (10.15) or later, or a linux distribution with glibc 2.28 or later like Debian 10 or Ubuntu 20.04. + ## Build instruction Build instructions can be found in [Contributing.md](CONTRIBUTING.md). diff --git a/ts/receiver/contentMessage.ts b/ts/receiver/contentMessage.ts index 1a1ff95cd..d7b7db7ca 100644 --- a/ts/receiver/contentMessage.ts +++ b/ts/receiver/contentMessage.ts @@ -35,6 +35,7 @@ import { getAllCachedECKeyPair, sentAtMoreRecentThanWrapper } from './closedGrou import { ConfigMessageHandler } from './configMessage'; import { ECKeyPair } from './keypairs'; import { ContactsWrapperActions } from '../webworker/workers/browser/libsession_worker_interface'; +import { isUsFromCache } from '../session/utils/User'; export async function handleSwarmContentMessage(envelope: EnvelopePlus, messageHash: string) { try { @@ -292,27 +293,42 @@ async function decrypt(envelope: EnvelopePlus): Promise { return plaintext; } -async function shouldDropIncomingPrivateMessage(sentAtTimestamp: number, envelope: EnvelopePlus) { +async function shouldDropIncomingPrivateMessage( + sentAtTimestamp: number, + envelope: EnvelopePlus, + content: SignalService.Content +) { // sentAtMoreRecentThanWrapper is going to be true, if the latest contact wrapper we processed was roughly more recent that this message timestamp const moreRecentOrNah = await sentAtMoreRecentThanWrapper(sentAtTimestamp, 'ContactsConfig'); + const isSyncedMessage = isUsFromCache(envelope.source); if (moreRecentOrNah === 'wrapper_more_recent') { - // we need to check if that conversation is already in the wrapper, and if yes + // we need to check if that conversation is already in the wrapper try { - const privateConvoInWrapper = await ContactsWrapperActions.get(envelope.source); + // let's check if the corresponding conversation is hidden in the contacts wrapper or not. + // the corresponding conversation is syncTarget when this is a synced message only, so we need to rely on it first, then the envelope.source. + const syncTargetOrSource = isSyncedMessage + ? content.dataMessage?.syncTarget || undefined + : envelope.source; + + if (!syncTargetOrSource) { + return false; + } + + const privateConvoInWrapper = await ContactsWrapperActions.get(syncTargetOrSource); if ( !privateConvoInWrapper || privateConvoInWrapper.priority <= CONVERSATION_PRIORITIES.hidden ) { // the wrapper is more recent that this message and there is no such private conversation. Just drop this incoming message. window.log.info( - `received message from contact ${envelope.source} which appears to be hidden/removed in our most recent libsession contactconfig, sentAt: ${sentAtTimestamp}. Dropping it` + `received message on conversation ${syncTargetOrSource} which appears to be hidden/removed in our most recent libsession contactconfig, sentAt: ${sentAtTimestamp}. Dropping it` ); return true; } window.log.info( - `received message from contact ${envelope.source} which appears to NOT be hidden/removed in our most recent libsession contactconfig, sentAt: ${sentAtTimestamp}. ` + `received message on conversation ${syncTargetOrSource} which appears to NOT be hidden/removed in our most recent libsession contactconfig, sentAt: ${sentAtTimestamp}. ` ); } catch (e) { window.log.warn( @@ -409,7 +425,7 @@ export async function innerHandleSwarmContentMessage( const isPrivateConversationMessage = !envelope.senderIdentity; if (isPrivateConversationMessage) { - if (await shouldDropIncomingPrivateMessage(sentAtTimestamp, envelope)) { + if (await shouldDropIncomingPrivateMessage(sentAtTimestamp, envelope, content)) { await removeFromCache(envelope); return; }