Use sessionId cookie
This commit is contained in:
parent
eac76d417f
commit
d7d9748339
|
@ -18,4 +18,6 @@ RUN npm run prisma:generate
|
||||||
|
|
||||||
RUN npm run build
|
RUN npm run build
|
||||||
|
|
||||||
|
ENV NODE_TLS_REJECT_UNAUTHORIZED="0"
|
||||||
|
|
||||||
CMD npm run prisma:deploy && npm start
|
CMD npm run prisma:deploy && npm start
|
|
@ -6,16 +6,17 @@ import { logError } from './logger'
|
||||||
const TIMEOUT_IN_MS = 120000
|
const TIMEOUT_IN_MS = 120000
|
||||||
const REQUEST_TIMEOUT_IN_MS = 20000
|
const REQUEST_TIMEOUT_IN_MS = 20000
|
||||||
|
|
||||||
const getDevicesUri = (skip, page, take) =>
|
const getDevicesUri = (skip = 0, page = 1, take = 50) =>
|
||||||
`https://${process.env.CISCO_HOST}/data/client-table.html?columns=524287&take=${take}&skip=${skip}&page=${page}&pageSize=50&sort[0][field]=ST&sort[0][dir]=desc`
|
`data/client-table.html?columns=524287&take=${take}&skip=${skip}&page=${page}&pageSize=50&sort[0][field]=ST&sort[0][dir]=desc`
|
||||||
|
|
||||||
const httpsAgent = new https.Agent({
|
const httpsAgent = new https.Agent({
|
||||||
rejectUnauthorized: false,
|
rejectUnauthorized: false
|
||||||
ciphers: 'AES256-SHA' // That's necessary to connect to a TLS 1.0 server. Run node with --tls-min-v1.0
|
|
||||||
})
|
})
|
||||||
|
|
||||||
const ciscoAxios = create({
|
const ciscoAxios = create({
|
||||||
|
withCredentials: true,
|
||||||
httpsAgent: httpsAgent,
|
httpsAgent: httpsAgent,
|
||||||
|
baseURL: `https://${process.env.CISCO_HOST}/`,
|
||||||
timeout: REQUEST_TIMEOUT_IN_MS,
|
timeout: REQUEST_TIMEOUT_IN_MS,
|
||||||
auth: {
|
auth: {
|
||||||
username: process.env.CISCO_USER,
|
username: process.env.CISCO_USER,
|
||||||
|
@ -43,12 +44,21 @@ function getDevices() {
|
||||||
const responsesPromises = []
|
const responsesPromises = []
|
||||||
|
|
||||||
try {
|
try {
|
||||||
const firstResponse = await ciscoAxios.get(
|
await ciscoAxios.get(getDevicesUri())
|
||||||
getDevicesUri(skip, page, take),
|
} catch (e) {
|
||||||
{
|
if (e.response?.status === 401) {
|
||||||
cancelToken: source.token
|
const newSessionId = e.response.headers['set-cookie'][0]
|
||||||
|
.split(';')[0]
|
||||||
|
.split('=')[1]
|
||||||
|
|
||||||
|
ciscoAxios.defaults.headers.Cookie = `sessionId=${newSessionId}`
|
||||||
}
|
}
|
||||||
)
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
const firstResponse = await ciscoAxios.get(getDevicesUri(), {
|
||||||
|
cancelToken: source.token
|
||||||
|
})
|
||||||
|
|
||||||
const { total, data: page1devices } = firstResponse.data
|
const { total, data: page1devices } = firstResponse.data
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user