2.5 KiB
id | title | challengeType | forumTopicId | dashedName |
---|---|---|---|---|
589690e6f9fc0f352b528e6e | Limpar seu projeto com módulos | 2 | 301549 | clean-up-your-project-with-modules |
--description--
Nesse momento, tudo que você tem é o seu arquivo server.js
. Isso pode levar a dificuldades para gerenciar um código que não é muito expansível. Crie 2 arquivos novos: routes.js
e auth.js
Ambos devem começar com o seguinte código:
module.exports = function (app, myDataBase) {
}
Agora, no topo do arquivo do seu servidor, solicite estes arquivos assim: const routes = require('./routes.js');
Depois disso, estabeleça uma conexão com o banco de dados, instanciando cada um dos arquivos da seguinte forma: routes(app, myDataBase)
Por fim, pegue todas as rotas do servidor, cole-as em seus novos arquivos e remova-as do arquivo do arquivo do servidor. Leve também a função ensureAuthenticated
, já que ela foi especificamente criada para o roteamento. Agora, você precisará adicionar corretamente as dependências em que são usadas, tais como const passport = require('passport');
, no topo do arquivo, acima da linha de exportação do arquivo routes.js
.
Continue adicionando-os até que não existam mais erros e que o arquivo do servidor não tenha mais nenhuma rota (exceto a rota no bloco catch)!
Agora, faça a mesma coisa no arquivo auth.js. com tudo o que estiver relacionado à autenticação, como a serialização e a configuração da estratégia local, e apague-os do arquivo do servidor. Certifique-se de adicionar as dependências e de chamar auth(app, myDataBase)
no servidor no mesmo local.
Envie sua página quando você achar que ela está certa. Se você encontrar erros, pode conferir um exemplo do projeto concluído aqui.
--hints--
Os módulos devem estar presentes.
(getUserInput) =>
$.get(getUserInput('url') + '/_api/server.js').then(
(data) => {
assert.match(
data,
/require\s*\(('|")\.\/routes(\.js)?\1\)/gi,
'You should have required your new files'
);
assert.match(
data,
/client\s*\.db[^]*routes/gi,
'Your new modules should be called after your connection to the database'
);
},
(xhr) => {
throw new Error(xhr.statusText);
}
);
--solutions--
/**
Backend challenges don't need solutions,
because they would need to be tested against a full working project.
Please check our contributing guidelines to learn more.
*/