import axios from 'axios'; const api = axios.create({ baseURL: import.meta.env.VITE_API_URL || 'http://localhost:8000/api', timeout: 8000, // 增加超时时间到 10秒 headers: { 'Content-Type': 'application/json', } }); // 请求拦截器:自动附加 Token api.interceptors.request.use((config) => { const token = localStorage.getItem('token'); if (token) { config.headers.Authorization = `Bearer ${token}`; } return config; }, (error) => { return Promise.reject(error); }); export const getConfigs = () => api.get('/configs/'); export const createOrder = (data) => api.post('/orders/', data); export const nativePay = (data) => api.post('/pay/', data); export const getOrder = (id) => api.get(`/orders/${id}/`); export const queryOrderStatus = (id) => api.get(`/orders/${id}/query_status/`); export const initiatePayment = (orderId) => api.post(`/orders/${orderId}/initiate_payment/`); export const confirmPayment = (orderId) => api.post(`/orders/${orderId}/confirm_payment/`); export const getServices = () => api.get('/services/'); export const getServiceDetail = (id) => api.get(`/services/${id}/`); export const createServiceOrder = (data) => api.post('/service-orders/', data); export const getVCCourses = () => api.get('/courses/'); export const getVCCourseDetail = (id) => api.get(`/courses/${id}/`); export const enrollCourse = (data) => api.post('/course-enrollments/', data); export const sendSms = (data) => api.post('/auth/send-sms/', data); export const queryMyOrders = (data) => api.post('/orders/my_orders/', data); export const phoneLogin = (data) => api.post('/auth/phone-login/', data); export const getUserInfo = () => { // 如果没有获取用户信息的接口,可以暂时从本地解析或依赖 update_user_info 的返回 // 但后端有 /wechat/update/ 可以返回用户信息,或者我们可以加一个 /auth/me/ // 目前 phone_login 返回了用户信息,前端可以保存。 // 如果需要刷新,可以复用 update_user_info(虽然名字叫update,但传空通常返回当前信息,需确认后端逻辑) // 查看后端逻辑:update_user_info 是 patch 更新,如果 data 为空,update 不会执行但会返回 serializer.data return api.post('/wechat/update/', {}); }; export const updateUserInfo = (data) => api.post('/wechat/update/', data); export const uploadUserAvatar = (data) => { // 使用 axios 直接请求外部接口,避免 base URL 和拦截器干扰 return axios.post('https://data.tangledup-ai.com/upload?folder=uploads/market/avator', data, { headers: { 'Content-Type': 'multipart/form-data', } }); }; // Community / Forum API export const getTopics = (params) => api.get('/community/topics/', { params }); export const getTopicDetail = (id) => api.get(`/community/topics/${id}/`); export const createTopic = (data) => api.post('/community/topics/', data); export const getReplies = (params) => api.get('/community/replies/', { params }); export const createReply = (data) => api.post('/community/replies/', data); export const uploadMedia = (data) => { return api.post('/community/media/', data, { headers: { 'Content-Type': 'multipart/form-data', } }); }; export const getStarUsers = () => api.get('/users/stars/'); export const getMyPaidItems = () => api.get('/users/paid-items/'); export const getAnnouncements = () => api.get('/community/announcements/'); export default api;