/**
* 
*/
package com.product.admin.controller;

import javax.servlet.http.HttpServletRequest;

import com.product.common.lang.StringUtils;
import com.product.core.permission.PermissionService;
import com.product.core.spring.context.SpringMVCContextHolder;
import com.product.module.sys.config.SystemErrorCode;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;

import com.product.admin.config.SystemCode;
import com.product.admin.service.UserDefaultLanguageService;
import com.product.core.config.CoreConst;
import com.product.core.controller.support.AbstractBaseController;
import com.product.core.entity.FieldSetEntity;
import com.product.core.entity.RequestParameterEntity;
import com.product.core.exception.BaseException;

/**
 * Copyright LX-BASE
 * 
 * @Title: UserLanguageController
 * @Project: LX-BASE-SERVER
 * @Date: 2020骞�6鏈�12鏃� 涓嬪崍6:19:26
 * @Author: 閮戠洘
 * @Description: 鐢ㄦ埛榛樿鏃堕棿
 */
@RestController
@RequestMapping("/api/user/language")
public class UserDefaultLanguageController extends AbstractBaseController {

	@Autowired
	private UserDefaultLanguageService userLanguageService;
	/**
	 * 鏁版嵁鏉冮檺楠岃瘉
	 */
	@Autowired
	PermissionService permissionService;
	/**
	 * 淇敼鐢ㄦ埛榛樿璇█
	 * 
	 * @throws BaseException
	 */
	@RequestMapping(value = "/update-language/{version}", method = RequestMethod.POST)
	public String updateLanguage(HttpServletRequest request) throws BaseException {
		
		try {
			FieldSetEntity fse = null;
			Object bean = request.getAttribute(CoreConst.API_POST_REQUEST_DATA);
			if (bean != null) {
				RequestParameterEntity reqp = (RequestParameterEntity) bean;
				fse = reqp.getFormData();
			}
			if (bean == null || fse == null) {
				SpringMVCContextHolder.getSystemLogger().error(SystemCode.SYSTEM_FORM_NODATA.getValue(), SystemCode.SYSTEM_FORM_NODATA.getText());
				return this.error(SystemCode.SYSTEM_FORM_NODATA.getValue(), SystemCode.SYSTEM_FORM_NODATA.getText());
			}
			//鏁版嵁鎿嶄綔鐨勬潈闄愰獙璇�
			if(!permissionService.validDataPermission(fse,CoreConst.DATA_PERMISSION_VALID_TYPE_USER)) {
				SpringMVCContextHolder.getSystemLogger().error(SystemErrorCode.SYSTEM_NOT_OPER_PERMISSION.getValue(),
						SystemErrorCode.SYSTEM_NOT_OPER_PERMISSION.getText());
				return this.error(SystemErrorCode.SYSTEM_NOT_OPER_PERMISSION.getValue(), SystemErrorCode.SYSTEM_NOT_OPER_PERMISSION.getText());
			}
			if (StringUtils.isEmpty(fse.getString("language_code")) ) {
				SpringMVCContextHolder.getSystemLogger().error(SystemCode.SYSTEM_FORM_COUNT.getValue(), SystemCode.SYSTEM_FORM_COUNT.getText());
				return this.error(SystemCode.SYSTEM_FORM_COUNT.getValue(), SystemCode.SYSTEM_FORM_COUNT.getText());
			}
			return userLanguageService.updateLanguage(fse) ? OK()
					: error(SystemCode.SYSTEM_USERLANGUAGE_UPDATE_DELECT_FAIL.getValue(),
							SystemCode.SYSTEM_USERLANGUAGE_UPDATE_DELECT_FAIL.getText());
			
		}catch (BaseException e){
			SpringMVCContextHolder.getSystemLogger().error(e);
			e.printStackTrace();
			return this.error(e);
		}catch(Exception e) {
			SpringMVCContextHolder.getSystemLogger().error(e);
			e.printStackTrace();
            return error(SystemCode.SYSTEM_USERLANGUAGE_UPDATE_DELECT_FAIL.getValue(), SystemCode.SYSTEM_USERLANGUAGE_UPDATE_DELECT_FAIL.getText());
		}

	}

}