Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Secure backend socket.io from other applications that can access localhost i.e. browser #1940

Merged
merged 35 commits into from
Nov 9, 2023
Merged
Show file tree
Hide file tree
Changes from 18 commits
Commits
Show all changes
35 commits
Select commit Hold shift + click to select a range
3dbbae3
secure socket IO connection with token and origin, transform token fr…
Kacper-RF Oct 9, 2023
8913c3d
add JWT
Kacper-RF Oct 10, 2023
a02a23e
not throw error on missing auth token
Kacper-RF Oct 10, 2023
85f69b5
send 401 to unauthorized user
Kacper-RF Oct 10, 2023
7701605
generate random secret
Kacper-RF Oct 11, 2023
6ade751
use basic auth instead of JWT
Kacper-RF Oct 11, 2023
8276fef
auth tests
Kacper-RF Oct 11, 2023
7f0af19
WIP: secure sockets mobile
vinkabuki Oct 12, 2023
22cc0e8
fix:lint
Kacper-RF Oct 13, 2023
c0153f0
Pass socketioSecret to backend
vinkabuki Oct 16, 2023
4cb88c2
Add authorization headers to socketio android notifications client
vinkabuki Oct 16, 2023
32b564a
Merge branch 'bug/114' of github.com:TryQuiet/quiet into bug/114
vinkabuki Oct 16, 2023
8f476a2
Secure socketIO connection on iOS
vinkabuki Oct 17, 2023
140801b
Use random string for securing socketIO pn iOS
vinkabuki Oct 17, 2023
3eaf916
Extend lastKnownPort to lastKnownSocketIOData on android
vinkabuki Oct 18, 2023
f9fafbd
Handle socketIOSecret for iOS lifecycle event
vinkabuki Oct 18, 2023
bedc2e3
Code quality fixes
vinkabuki Oct 18, 2023
c1132ce
Create Utils class on iOS and move relevant methods there
vinkabuki Oct 19, 2023
47199f5
feat: getRandomValues and concept for validating options on backend
Kacper-RF Oct 26, 2023
2cba36d
fix: generating secret
Kacper-RF Oct 27, 2023
6d8131d
feat: use IPC and Redux store for transfering socketIOSecret
Kacper-RF Oct 27, 2023
130469a
test: add socketIOSecret selector test
Kacper-RF Oct 27, 2023
426c52b
test: add startConnectionSaga test
Kacper-RF Oct 27, 2023
d758341
Use secure random for socketio secret
vinkabuki Oct 30, 2023
96b97db
fix: use secure crypto for ios socketio secret
vinkabuki Oct 30, 2023
9caf372
fix: add Utils file to the project
siepra Oct 30, 2023
6107fd6
Merge branch 'master' into bug/114
Kacper-RF Oct 31, 2023
15885fe
Merge branch 'bug/114' of github.com:TryQuiet/quiet into bug/114
Kacper-RF Oct 31, 2023
23bf54d
fix: check pkijs
Kacper-RF Nov 2, 2023
7444d0a
fix: revert changes with pkijs
Kacper-RF Nov 2, 2023
cae556a
fix:change order
Kacper-RF Nov 2, 2023
dcfbeea
fix: generate secret after setEngine
Kacper-RF Nov 2, 2023
1c2bbd0
fix: backwards test for prod versions
Kacper-RF Nov 2, 2023
f0ccff7
fix: remove peculiar/webcrypto from common
Kacper-RF Nov 2, 2023
6b0e9d9
fix: file name
Kacper-RF Nov 8, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 5 additions & 1 deletion packages/backend/src/backendManager.ts
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@ program
.option('-a, --appDataPath <string>', 'Path of application data directory')
.option('-d, --socketIOPort <number>', 'Socket io data server port')
.option('-r, --resourcesPath <string>', 'Application resources path')
.option('-scrt, --socketIOSecret <string>', 'socketIO secret')

program.parse(process.argv)
const options = program.opts()
Expand All @@ -33,6 +34,7 @@ console.log('options', options)
interface OpenServices {
torControlPort?: any
socketIOPort?: any
socketIOSecret?: any
httpTunnelPort?: any
authCookie?: any
}
Expand All @@ -52,6 +54,7 @@ export const runBackendDesktop = async () => {
const app = await NestFactory.createApplicationContext(
AppModule.forOptions({
socketIOPort: options.socketIOPort,
socketIOSecret: options.socketIOSecret,
torBinaryPath: torBinForPlatform(resourcesPath),
torResourcesPath: torDirForPlatform(resourcesPath),
torControlPort: await getPort(),
Expand Down Expand Up @@ -97,6 +100,7 @@ export const runBackendMobile = async (): Promise<any> => {
app = await NestFactory.createApplicationContext(
AppModule.forOptions({
socketIOPort: options.dataPort,
socketIOSecret: options.socketIOSecret,
httpTunnelPort: options.httpTunnelPort ? options.httpTunnelPort : null,
torAuthCookie: options.authCookie ? options.authCookie : null,
torControlPort: options.controlPort ? options.controlPort : await getPort(),
Expand All @@ -120,6 +124,7 @@ export const runBackendMobile = async (): Promise<any> => {
app = await NestFactory.createApplicationContext(
AppModule.forOptions({
socketIOPort: msg.socketIOPort,
socketIOSecret: msg.socketIOSecret,
httpTunnelPort: msg.httpTunnelPort ? msg.httpTunnelPort : null,
torAuthCookie: msg.authCookie ? msg.authCookie : null,
torControlPort: msg.torControlPort ? msg.torControlPort : await getPort(),
Expand All @@ -133,7 +138,6 @@ export const runBackendMobile = async (): Promise<any> => {
}),
{ logger: ['warn', 'error', 'log', 'debug', 'verbose'] }
)
console.log('started backend wiktor little bastard ')
})
}

Expand Down
41 changes: 39 additions & 2 deletions packages/backend/src/nest/app.module.ts
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,7 @@ import { Server as SocketIO } from 'socket.io'
import { StorageModule } from './storage/storage.module'
import { IpfsModule } from './ipfs/ipfs.module'
import { Level } from 'level'
import { getCors } from './common/utils'
import { verifyToken } from '@quiet/common'

@Global()
@Module({
Expand Down Expand Up @@ -94,10 +94,47 @@ export class AppModule {
_app.use(cors())
const server = createServer(_app)
const io = new SocketIO(server, {
cors: getCors(),
cors: {
origin: '127.0.0.1',
allowedHeaders: ['authorization'],
credentials: true,
},
pingInterval: 1000_000,
pingTimeout: 1000_000,
})
io.engine.use((req, res, next) => {
const authHeader = req.headers['authorization']
if (!authHeader) {
console.error('No authorization header')
res.writeHead(401, 'No authorization header')
res.end()
return
}

const token = authHeader && authHeader.split(' ')[1]
if (!token) {
console.error('No auth token')
res.writeHead(401, 'No authorization token')
res.end()
return
}

if (!options.socketIOSecret) {
Kacper-RF marked this conversation as resolved.
Show resolved Hide resolved
console.error('No socketIoSecret')
res.writeHead(401, 'No socketIoSecret')
res.end()
return
}

if (verifyToken(options.socketIOSecret, token)) {
next()
} else {
console.error('Wrong basic token')
res.writeHead(401, 'Unauthorized')
res.end()
}
})

return { server, io }
},
inject: [EXPRESS_PROVIDER],
Expand Down
2 changes: 1 addition & 1 deletion packages/backend/src/nest/socket/socket.service.ts
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,6 @@ import {
Community,
DeleteFilesFromChannelSocketPayload,
} from '@quiet/types'
import cors, { CorsOptions } from 'cors'
import EventEmitter from 'events'
import { CONFIG_OPTIONS, SERVER_IO_PROVIDER } from '../const'
import { ConfigOptions, ServerIoProviderTypes } from '../types'
Expand Down Expand Up @@ -132,6 +131,7 @@ export class SocketService extends EventEmitter implements OnModuleInit {
this.logger(`Creating network for community ${community.id}`)
this.emit(SocketActionTypes.CREATE_NETWORK, community)
})

socket.on(SocketActionTypes.LEAVE_COMMUNITY, async () => {
this.logger('leaving community')
this.emit(SocketActionTypes.LEAVE_COMMUNITY)
Expand Down
1 change: 1 addition & 0 deletions packages/backend/src/nest/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@ import { Server as SocketIO } from 'socket.io'
export class ConnectionsManagerTypes {
options: Partial<ConnectionsManagerOptions>
socketIOPort: number
socketIOSecret?: string
httpTunnelPort?: number
torAuthCookie?: string
torControlPort?: number
Expand Down
Loading
Loading