Сокетное соединение в контроллере маршрута API сохраняет данные предыдущего вызова - PullRequest
1 голос
/ 16 июня 2019

У меня есть конечная точка API в моем приложении Node / Express.Конечная точка отвечает за загрузку файлов.Есть несколько этапов процесса загрузки.например, преобразование изображений, отправка изображений в сторонние API и т. д. Я использую socket.io, чтобы сообщить клиенту о текущем этапе загрузки.

Проблема в том, что соединение с сокетом нормально работает при первом вызове., но во время моего второго вызова конечной точки соединение через сокет выполняется дважды и сохраняет данные, которые я отправил в предыдущем вызове.

Вот мой код:

server.js

import ClientsRouter from './api/routes/clients';
import express from 'express';
import http from 'http';
import io from 'socket.io';

const port  = process.env.PORT || 3000;

const app = express();
const server = http.Server(app);
const socket = io(server);

app.set('socket', socket);

app.use(bodyParser.urlencoded({ extended: false }));
app.use(bodyParser.json());
app.set('view engine', 'ejs');
app.use(express.static('dist'))
app.use('/uploads', express.static('uploads'));


app.use('/api/clients', ClientsRouter);

server.listen(port, () => console.log(`Server Listening on ${process.env.URL}`));

API / маршрутов / клиентов.js

import express from 'express';
import ClientsController from '../controllers/clients';

ClientsRouter.post('/uploadClientData/', clientDataUpload.array('client_data'), ClientsController.uploadClientData);

контроллеров / клиентов.js

const uploadClientData = async (req, res) => {
    try {
        const files = req.files
        const clientFolder = req.body.client_folder
        const { dbxUser } = req;
        const team_member_id = req.body.team_member_id;
        const data = req.files.map( i => ({team_member_id, destination: i.destination.substring(1), filename: i.filename, status: 1 } ))
        const io = req.app.get("socket");
        console.log("Outside Socket", data);  //This contains my currently passed data
        io.on('connection', async socket => {
            console.log("Socket Connection established");
            console.log("Inside Socket", data);  //But This contains my current data aling with the data that I passed in previous call
            await uploadQueue.collection.insertMany(data)
            socket.emit('upload stage', { upload_stage: 2, progress: 33 })
            await helpers.convertImagesToWebResolution(team_member_id, req.body.dpi, req.body.resolution);
            socket.emit('upload stage', { upload_stage: 3, progress: 66 })
            await helpers.uploadImagesToDropbox(team_member_id, dbxUser, clientFolder)
            socket.emit('upload stage', { upload_stage: 4, progress: 100 })
        })

        res.status(200).json({message: "Uploaded"});

    } catch (error) {
        console.log(error)
        res.status(500).json({
            error
        });
    }
}

И в моем внешнем компоненте реакции

componentDidMount(){
    const { currentFolder } = this.props;
    this.setState({ client_folder: currentFolder }, () => this.afterFileSelect())
}



componentDidUpdate(prevProps){
    const { selectedFiles } = this.props;
    if(prevProps.selectedFiles !== selectedFiles){
        this.afterFileSelect()
    }
}

afterFileSelect = async () => {
    const { selectedFiles, setSelectedFiles, currentFolder, user, uploadSettings} = this.props;
    let formData = new FormData()
    formData.append('client_folder', currentFolder)
    formData.append('team_member_id', user.team_member_id)
    formData.append('resolution', uploadSettings.resolution.split("x")[0])
    formData.append('dpi', uploadSettings.dpi)
    for(let selectedFile of selectedFiles){
        formData.append('client_data', selectedFile)
    }
    let uploadResp = uploadSettings.convert_web_res ? await uploadClientData(formData) : await dropboxDirectUpload(formData)
    const endpoint = uploadResp.config.url;
    const host = endpoint.substring(0, endpoint.indexOf("api"));
    const socket = socketIOClient(host);
    socket.on("upload stage", data => {
        this.setState({upload_stage: data.upload_stage, progress: data.progress})
        data.upload_stage === 4 && this.setState({client_folder: ""})
    })
}

Также я хочу знать, является ли это правильным способом для отслеживания прогресса загрузки?

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...