Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
T
traffic-front
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wangxiaoming
traffic-front
Commits
ba76c7eb
Commit
ba76c7eb
authored
Jul 09, 2018
by
frank.xa.zhang
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'dev' into dev_frank
parents
ac09da2d
d7aaf7ed
Show whitespace changes
Inline
Side-by-side
Showing
27 changed files
with
186 additions
and
363 deletions
+186
-363
pom.xml
atms-api/pom.xml
+6
-122
MyMailMapper.java
atms-api/src/main/java/pwc/taxtech/atms/MyMailMapper.java
+0
-5
MybatisConfig.java
atms-api/src/main/java/pwc/taxtech/atms/MybatisConfig.java
+0
-9
DataSourceFactory.java
...pwc/taxtech/atms/common/datasource/DataSourceFactory.java
+1
-1
Constant.java
...api/src/main/java/pwc/taxtech/atms/constant/Constant.java
+7
-5
CustomsInvoiceController.java
...pwc/taxtech/atms/controller/CustomsInvoiceController.java
+5
-3
FileUploadController.java
...ava/pwc/taxtech/atms/controller/FileUploadController.java
+1
-9
InputInvoiceImportController.java
...taxtech/atms/controller/InputInvoiceImportController.java
+5
-3
OutputInvoiceController.java
.../pwc/taxtech/atms/controller/OutputInvoiceController.java
+5
-3
TBDataImportController.java
...a/pwc/taxtech/atms/controller/TBDataImportController.java
+4
-4
MailQueueMapper.java
...i/src/main/java/pwc/taxtech/atms/dao/MailQueueMapper.java
+4
-3
CloseableFormulaDataSource.java
...c/taxtech/atms/dto/vatdto/CloseableFormulaDataSource.java
+1
-1
NotSupportedException.java
...ava/pwc/taxtech/atms/exception/NotSupportedException.java
+10
-0
ParameterException.java
...n/java/pwc/taxtech/atms/exception/ParameterException.java
+12
-0
DataSourcePoolService.java
.../pwc/taxtech/atms/service/impl/DataSourcePoolService.java
+1
-1
ProjectServiceImpl.java
...ava/pwc/taxtech/atms/service/impl/ProjectServiceImpl.java
+1
-1
FormulaAgent.java
.../java/pwc/taxtech/atms/vat/service/impl/FormulaAgent.java
+25
-19
ReportFormulaFactory.java
...c/taxtech/atms/vat/service/impl/ReportFormulaFactory.java
+0
-1
ReportGeneratorImpl.java
...wc/taxtech/atms/vat/service/impl/ReportGeneratorImpl.java
+46
-24
ReportServiceImpl.java
.../pwc/taxtech/atms/vat/service/impl/ReportServiceImpl.java
+9
-4
FormulaContext.java
...tms/vat/service/impl/report/functions/FormulaContext.java
+1
-0
applicationContext-datasource-mail.xml
...src/main/resources/applicationContext-datasource-mail.xml
+0
-46
applicationContext.xml
atms-api/src/main/resources/applicationContext.xml
+3
-17
MailServiceIT.java
...est/java/pwc/taxtech/atms/service/impl/MailServiceIT.java
+2
-8
pom.xml
atms-web/pom.xml
+15
-49
applicationContext-mvc.xml
atms-web/src/main/resources/applicationContext-mvc.xml
+15
-15
applicationContext.xml
atms-web/src/main/resources/applicationContext.xml
+7
-10
No files found.
atms-api/pom.xml
View file @
ba76c7eb
...
...
@@ -23,7 +23,9 @@
<maven.build.timestamp.format>
yyyy-MM-dd HH:mm:ss z
</maven.build.timestamp.format>
<timestamp>
${maven.build.timestamp}
</timestamp>
<sonar.exclusions>
**/*Mapper.*,**/*Example.*,**/*Test.java,**/*IT.java,**/*Dto.java,**/atms/entitiy/**/*.java,**/atms/thirdparty/**/*.java,**/atms/common/message/**/*.java,**/atms/dto/**/*.java,**/atms/constant/**/*.java
</sonar.exclusions>
<sonar.exclusions>
**/*Mapper.*,**/*Example.*,**/*Test.java,**/*IT.java,**/*Dto.java,**/atms/entitiy/**/*.java,**/atms/thirdparty/**/*.java,**/atms/common/message/**/*.java,**/atms/dto/**/*.java,**/atms/constant/**/*.java
</sonar.exclusions>
</properties>
<dependencyManagement>
...
...
@@ -161,12 +163,6 @@
<artifactId>
druid
</artifactId>
<version>
1.1.5
</version>
</dependency>
<dependency>
<groupId>
com.microsoft.sqlserver
</groupId>
<artifactId>
mssql-jdbc
</artifactId>
<version>
6.2.2.jre7
</version>
</dependency>
<dependency>
<groupId>
mysql
</groupId>
<artifactId>
mysql-connector-java
</artifactId>
...
...
@@ -204,7 +200,6 @@
</dependency>
<!-- https://mvnrepository.com/artifact/com.alibaba/fastjson -->
<dependency>
<groupId>
com.alibaba
</groupId>
...
...
@@ -255,6 +250,7 @@
<artifactId>
poi-ooxml
</artifactId>
<version>
3.17
</version>
</dependency>
<dependency>
<groupId>
org.apache.commons
</groupId>
<artifactId>
commons-text
</artifactId>
...
...
@@ -300,11 +296,13 @@
<groupId>
org.apache.tika
</groupId>
<artifactId>
tika-core
</artifactId>
<version>
1.17
</version>
<scope>
test
</scope>
</dependency>
<dependency>
<groupId>
org.apache.tika
</groupId>
<artifactId>
tika-parsers
</artifactId>
<version>
1.17
</version>
<scope>
test
</scope>
</dependency>
<dependency>
<groupId>
com.javaaxp
</groupId>
...
...
@@ -381,128 +379,14 @@
<resources>
<resource>
<directory>
src/main/resources
</directory>
<includes>
<include>
**/*.properties
</include>
<include>
**/*.xml
</include>
<include>
**/*.sql
</include>
</includes>
<filtering>
true
</filtering>
<!-- replace variable attribute or not -->
</resource>
<resource>
<directory>
src/main/resources/Document
</directory>
<includes>
<include>
**/*.xls
</include>
<include>
**/*.xlsx
</include>
</includes>
<targetPath>
${basedir}/target/classes/document
</targetPath>
</resource>
<resource>
<directory>
test/resources
</directory>
<includes>
<include>
**/*.properties
</include>
</includes>
</resource>
</resources>
<plugins>
<plugin>
<groupId>
org.apache.maven.plugins
</groupId>
<artifactId>
maven-war-plugin
</artifactId>
<version>
3.2.0
</version>
<configuration>
<archive>
<addMavenDescriptor>
false
</addMavenDescriptor>
</archive>
<webResources>
<resource>
<directory>
test
</directory>
<includes>
<include>
**
</include>
</includes>
<filtering>
true
</filtering>
</resource>
</webResources>
</configuration>
</plugin>
<plugin>
<groupId>
org.apache.maven.plugins
</groupId>
<artifactId>
maven-surefire-plugin
</artifactId>
<version>
2.20.1
</version>
<configuration>
<includes>
<include>
**/*IT.java
</include>
<include>
**/*Test.java
</include>
</includes>
</configuration>
</plugin>
<plugin>
<groupId>
org.codehaus.mojo
</groupId>
<artifactId>
cobertura-maven-plugin
</artifactId>
<version>
2.7
</version>
</plugin>
<!-- See: http://www.jacoco.org/jacoco/trunk/doc/maven.html -->
<!-- See: http://www.jacoco.org/jacoco/trunk/doc/examples/build/pom.xml -->
<plugin>
<groupId>
org.jacoco
</groupId>
<artifactId>
jacoco-maven-plugin
</artifactId>
<version>
0.8.0
</version>
<executions>
<execution>
<id>
default-prepare-agent
</id>
<goals>
<goal>
prepare-agent
</goal>
</goals>
</execution>
<execution>
<id>
default-report
</id>
<goals>
<goal>
report
</goal>
</goals>
</execution>
</executions>
</plugin>
<!-- See: https://docs.sonarqube.org/display/SCAN/Analyzing+with+SonarQube+Scanner+for+Maven -->
<plugin>
<groupId>
org.sonarsource.scanner.maven
</groupId>
<artifactId>
sonar-maven-plugin
</artifactId>
<version>
3.4.0.905
</version>
</plugin>
<plugin>
<groupId>
org.mybatis.generator
</groupId>
<artifactId>
mybatis-generator-maven-plugin
</artifactId>
<version>
1.3.2
</version>
<configuration>
<verbose>
true
</verbose>
<overwrite>
true
</overwrite>
</configuration>
</plugin>
<!-- 资源文件拷贝插件 -->
<plugin>
<groupId>
org.apache.maven.plugins
</groupId>
<artifactId>
maven-resources-plugin
</artifactId>
<version>
2.7
</version>
<dependencies>
<dependency>
<groupId>
org.apache.maven.shared
</groupId>
<artifactId>
maven-filtering
</artifactId>
<version>
1.3
</version>
</dependency>
</dependencies>
</plugin>
<!-- java编译插件 -->
<plugin>
<groupId>
org.apache.maven.plugins
</groupId>
<artifactId>
maven-compiler-plugin
</artifactId>
<version>
3.2
</version>
<dependencies>
<dependency>
<groupId>
org.apache.maven.shared
</groupId>
<artifactId>
maven-filtering
</artifactId>
<version>
3.1.1
</version>
</dependency>
</dependencies>
<configuration>
<source>
1.8
</source>
<target>
1.8
</target>
...
...
atms-api/src/main/java/pwc/taxtech/atms/MyMailMapper.java
deleted
100644 → 0
View file @
ac09da2d
package
pwc
.
taxtech
.
atms
;
public
interface
MyMailMapper
{
}
atms-api/src/main/java/pwc/taxtech/atms/MybatisConfig.java
View file @
ba76c7eb
...
...
@@ -36,13 +36,4 @@ public class MybatisConfig implements InitializingBean {
return
bean
;
}
@Bean
public
static
MapperScannerConfigurer
userMapperConfigurerMail
()
{
MapperScannerConfigurer
bean
=
new
MapperScannerConfigurer
();
bean
.
setMarkerInterface
(
MyMailMapper
.
class
);
bean
.
setBasePackage
(
BASE_PACKAGE
);
bean
.
setSqlSessionTemplateBeanName
(
"sqlSessionTemplateMail"
);
// bean.setSqlSessionFactoryBeanName("sqlSessionFactoryMail");
return
bean
;
}
}
atms-api/src/main/java/pwc/taxtech/atms/common/datasource/DataSourceFactory.java
View file @
ba76c7eb
package
pwc
.
taxtech
.
atms
.
common
.
datasource
;
import
com.alibaba.druid.pool.DruidDataSource
;
import
com.beust.jcommander.ParameterException
;
import
org.apache.commons.lang3.StringUtils
;
import
org.apache.commons.pool2.KeyedPooledObjectFactory
;
import
org.apache.commons.pool2.PooledObject
;
import
org.apache.commons.pool2.impl.DefaultPooledObject
;
import
org.slf4j.Logger
;
import
org.slf4j.LoggerFactory
;
import
pwc.taxtech.atms.exception.ParameterException
;
public
class
DataSourceFactory
implements
KeyedPooledObjectFactory
<
String
,
DruidDataSource
>
{
private
static
final
Logger
logger
=
LoggerFactory
.
getLogger
(
DataSourceFactory
.
class
);
...
...
atms-api/src/main/java/pwc/taxtech/atms/constant/Constant.java
View file @
ba76c7eb
...
...
@@ -26,11 +26,11 @@ public final class Constant {
public
static
final
String
UPLOAD_FOLDER_NAME
=
"Upload"
;
public
static
final
String
CURRENT_USER_HOME
=
"~"
;
public
static
final
String
CURRENT_USER_UPLOAD_FOLDER
=
CURRENT_USER_HOME
+
File
.
separator
+
UPLOAD_FOLDER_NAME
;
public
static
final
String
CURRENT_IMAGE_PATH
=
CURRENT_USER_HOME
+
File
.
separator
+
"Resource"
+
File
.
separator
+
"Images"
;
public
static
final
String
IMAGE_PATH_INFORMATION
=
CURRENT_IMAGE_PATH
+
File
.
separator
+
"information.png"
;
public
static
final
String
IMAGE_PATH_ERROR
=
CURRENT_IMAGE_PATH
+
File
.
separator
+
"error.png"
;
public
static
final
String
IMAGE_PATH_SUCCESS
=
CURRENT_IMAGE_PATH
+
File
.
separator
+
"success.png"
;
public
static
final
String
IMAGE_PATH_WARN
=
CURRENT_IMAGE_PATH
+
File
.
separator
+
"warning1.png"
;
public
static
final
String
CURRENT_IMAGE_PATH
=
CURRENT_USER_HOME
+
File
.
separator
+
"Resource"
+
File
.
separator
+
"Images"
;
public
static
final
String
IMAGE_PATH_INFORMATION
=
CURRENT_IMAGE_PATH
+
File
.
separator
+
"information.png"
;
public
static
final
String
IMAGE_PATH_ERROR
=
CURRENT_IMAGE_PATH
+
File
.
separator
+
"error.png"
;
public
static
final
String
IMAGE_PATH_SUCCESS
=
CURRENT_IMAGE_PATH
+
File
.
separator
+
"success.png"
;
public
static
final
String
IMAGE_PATH_WARN
=
CURRENT_IMAGE_PATH
+
File
.
separator
+
"warning1.png"
;
public
static
final
boolean
DEFAULT_RESULT
=
true
;
...
...
@@ -41,4 +41,5 @@ public final class Constant {
public
static
final
boolean
DEFAULT_HAS_HEADER
=
true
;
public
static
final
String
IMAGE_FORMART_
=
"png"
;
public
static
final
String
EMPTY
=
""
;
}
\ No newline at end of file
atms-api/src/main/java/pwc/taxtech/atms/controller/CustomsInvoiceController.java
View file @
ba76c7eb
...
...
@@ -2,7 +2,6 @@ package pwc.taxtech.atms.controller;
import
com.alibaba.fastjson.JSONObject
;
import
org.apache.commons.lang3.StringUtils
;
import
org.apache.http.HttpStatus
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.http.MediaType
;
import
org.springframework.http.ResponseEntity
;
...
...
@@ -31,6 +30,9 @@ import java.util.Map;
import
java.util.UUID
;
import
java.util.stream.Collectors
;
import
static
javax
.
servlet
.
http
.
HttpServletResponse
.
SC_NO_CONTENT
;
import
static
javax
.
servlet
.
http
.
HttpServletResponse
.
SC_OK
;
@RestController
@RequestMapping
(
value
=
"api/v1/CustomsInvoice"
)
public
class
CustomsInvoiceController
{
...
...
@@ -84,9 +86,9 @@ public class CustomsInvoiceController {
int
count
=
getDownloadFilePath
(
filter
,
os
);
if
(
count
==
0
)
{
response
.
setStatus
(
HttpStatus
.
SC_NO_CONTENT
);
response
.
setStatus
(
SC_NO_CONTENT
);
}
else
{
response
.
setStatus
(
HttpStatus
.
SC_OK
);
response
.
setStatus
(
SC_OK
);
}
}
catch
(
IOException
e
)
{
e
.
printStackTrace
();
...
...
atms-api/src/main/java/pwc/taxtech/atms/controller/FileUploadController.java
View file @
ba76c7eb
package
pwc
.
taxtech
.
atms
.
controller
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.beans.factory.annotation.Value
;
import
org.springframework.http.MediaType
;
import
org.springframework.http.ResponseEntity
;
import
org.springframework.web.bind.annotation.RequestMapping
;
import
org.springframework.web.bind.annotation.RequestMethod
;
import
org.springframework.web.bind.annotation.RestController
;
import
org.springframework.web.multipart.MultipartFile
;
import
org.springframework.web.multipart.MultipartHttpServletRequest
;
import
pwc.taxtech.atms.constant.enums.EnumModule
;
import
pwc.taxtech.atms.dto.PagingResultDto
;
import
pwc.taxtech.atms.dto.vatdto.InputVATInvoiceDto
;
import
pwc.taxtech.atms.vat.service.impl.FileUploadAdapter
;
import
javax.servlet.http.HttpServletRequest
;
import
javax.servlet.http.HttpServletResponse
;
import
javax.ws.rs.core.Response
;
import
static
pwc
.
taxtech
.
atms
.
constant
.
Constant
.
USER_ID_FOR_UPLOAD
;
@RestController
...
...
@@ -28,6 +20,6 @@ public class FileUploadController {
@RequestMapping
(
value
=
"NewFile"
,
method
=
RequestMethod
.
POST
,
produces
=
MediaType
.
MULTIPART_FORM_DATA_VALUE
)
public
ResponseEntity
getInputInvoiceTreeViewData
(
MultipartHttpServletRequest
request
)
{
return
fileUploadAdapter
.
upload
(
request
,
EnumModule
.
TrailBalance
,
USER_ID_FOR_UPLOAD
);
return
fileUploadAdapter
.
upload
(
request
,
EnumModule
.
TrailBalance
,
USER_ID_FOR_UPLOAD
);
}
}
atms-api/src/main/java/pwc/taxtech/atms/controller/InputInvoiceImportController.java
View file @
ba76c7eb
package
pwc
.
taxtech
.
atms
.
controller
;
import
org.apache.http.HttpStatus
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.http.MediaType
;
import
org.springframework.http.ResponseEntity
;
...
...
@@ -28,6 +27,9 @@ import java.util.List;
import
java.util.Map
;
import
java.util.UUID
;
import
static
javax
.
servlet
.
http
.
HttpServletResponse
.
SC_NO_CONTENT
;
import
static
javax
.
servlet
.
http
.
HttpServletResponse
.
SC_OK
;
@RestController
@RequestMapping
(
value
=
"api/v1/inputInvoiceImport"
)
public
class
InputInvoiceImportController
{
...
...
@@ -52,9 +54,9 @@ public class InputInvoiceImportController {
int
count
=
getDownloadFilePath
(
paras
,
os
);
if
(
count
==
0
)
{
response
.
setStatus
(
HttpStatus
.
SC_NO_CONTENT
);
response
.
setStatus
(
SC_NO_CONTENT
);
}
else
{
response
.
setStatus
(
HttpStatus
.
SC_OK
);
response
.
setStatus
(
SC_OK
);
}
}
catch
(
IOException
e
)
{
e
.
printStackTrace
();
...
...
atms-api/src/main/java/pwc/taxtech/atms/controller/OutputInvoiceController.java
View file @
ba76c7eb
package
pwc
.
taxtech
.
atms
.
controller
;
import
org.apache.http.HttpStatus
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.http.MediaType
;
import
org.springframework.http.ResponseEntity
;
...
...
@@ -24,6 +23,9 @@ import java.util.List;
import
java.util.Map
;
import
java.util.UUID
;
import
static
javax
.
servlet
.
http
.
HttpServletResponse
.
SC_NO_CONTENT
;
import
static
javax
.
servlet
.
http
.
HttpServletResponse
.
SC_OK
;
@RestController
@RequestMapping
(
value
=
"api/v1/outputInvoiceImport"
)
public
class
OutputInvoiceController
{
...
...
@@ -48,9 +50,9 @@ public class OutputInvoiceController {
int
count
=
getDownloadFilePath
(
paras
,
os
);
if
(
count
==
0
)
{
response
.
setStatus
(
HttpStatus
.
SC_NO_CONTENT
);
response
.
setStatus
(
SC_NO_CONTENT
);
}
else
{
response
.
setStatus
(
HttpStatus
.
SC_OK
);
response
.
setStatus
(
SC_OK
);
}
}
catch
(
IOException
e
)
{
e
.
printStackTrace
();
...
...
atms-api/src/main/java/pwc/taxtech/atms/controller/TBDataImportController.java
View file @
ba76c7eb
...
...
@@ -3,7 +3,6 @@ package pwc.taxtech.atms.controller;
import
com.alibaba.fastjson.JSONObject
;
import
io.swagger.annotations.ApiOperation
;
import
org.apache.commons.lang3.StringUtils
;
import
org.apache.http.HttpStatus
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.http.MediaType
;
import
org.springframework.http.ResponseEntity
;
...
...
@@ -14,6 +13,7 @@ import org.springframework.web.bind.annotation.RequestMethod;
import
org.springframework.web.bind.annotation.ResponseBody
;
import
org.springframework.web.bind.annotation.RestController
;
import
pwc.taxtech.atms.common.CommonUtils
;
import
pwc.taxtech.atms.common.util.NPOIHelper
;
import
pwc.taxtech.atms.dto.OperationResultDto
;
import
pwc.taxtech.atms.dto.vatdto.BalanceSubTotalDto
;
import
pwc.taxtech.atms.dto.vatdto.BalanceWithSubTotalsResultDto
;
...
...
@@ -27,7 +27,6 @@ import pwc.taxtech.atms.dto.vatdto.VatEnterpriseAccountDto;
import
pwc.taxtech.atms.service.ICitTBDataImportService
;
import
pwc.taxtech.atms.service.IdentityService
;
import
pwc.taxtech.atms.service.impl.DataImportServiceImpl
;
import
pwc.taxtech.atms.common.util.NPOIHelper
;
import
pwc.taxtech.atms.vat.dao.DataImportModel
;
import
pwc.taxtech.atms.vat.service.TBDataImportService
;
import
pwc.taxtech.atms.vat.service.impl.FileUploadAdapter
;
...
...
@@ -44,6 +43,7 @@ import java.util.List;
import
java.util.Objects
;
import
java.util.stream.Collectors
;
import
static
javax
.
servlet
.
http
.
HttpServletResponse
.
SC_INTERNAL_SERVER_ERROR
;
import
static
pwc
.
taxtech
.
atms
.
constant
.
Constant
.
DEFAULT_HAS_HEADER
;
import
static
pwc
.
taxtech
.
atms
.
constant
.
Constant
.
HEADER_ROW_INDEX
;
...
...
@@ -478,10 +478,10 @@ public class TBDataImportController {
return
ResponseEntity
.
ok
(
dataImportModel
);
}
catch
(
FileNotFoundException
e
)
{
//TODO: replace exception filter (neo)
e
.
printStackTrace
();
return
ResponseEntity
.
status
(
HttpStatus
.
SC_INTERNAL_SERVER_ERROR
).
build
();
return
ResponseEntity
.
status
(
SC_INTERNAL_SERVER_ERROR
).
build
();
}
catch
(
IOException
e
)
{
e
.
printStackTrace
();
return
ResponseEntity
.
status
(
HttpStatus
.
SC_INTERNAL_SERVER_ERROR
).
build
();
return
ResponseEntity
.
status
(
SC_INTERNAL_SERVER_ERROR
).
build
();
}
}
else
{
return
ResponseEntity
.
ok
().
build
();
...
...
atms-api/src/main/java/pwc/taxtech/atms/dao/MailQueueMapper.java
View file @
ba76c7eb
package
pwc
.
taxtech
.
atms
.
dao
;
import
java.util.List
;
import
org.apache.ibatis.annotations.Mapper
;
import
org.apache.ibatis.annotations.Param
;
import
org.apache.ibatis.session.RowBounds
;
import
pwc.taxtech.atms.MyMa
ilMa
pper
;
import
pwc.taxtech.atms.MyMapper
;
import
pwc.taxtech.atms.entitiy.MailQueue
;
import
pwc.taxtech.atms.entitiy.MailQueueExample
;
import
java.util.List
;
@Mapper
public
interface
MailQueueMapper
extends
MyMa
ilMa
pper
{
public
interface
MailQueueMapper
extends
MyMapper
{
/**
* This method was generated by MyBatis Generator.
* This method corresponds to the database table dbo.MAILQUEUE
...
...
atms-api/src/main/java/pwc/taxtech/atms/dto/vatdto/CloseableFormulaDataSource.java
View file @
ba76c7eb
package
pwc
.
taxtech
.
atms
.
dto
.
vatdto
;
import
pwc.taxtech.atms.vat.service.impl.
report.functions.
FormulaAgent
;
import
pwc.taxtech.atms.vat.service.impl.FormulaAgent
;
import
java.util.ArrayList
;
import
java.util.List
;
...
...
atms-api/src/main/java/pwc/taxtech/atms/exception/NotSupportedException.java
0 → 100644
View file @
ba76c7eb
package
pwc
.
taxtech
.
atms
.
exception
;
public
class
NotSupportedException
extends
ApplicationException
{
public
NotSupportedException
()
{
}
public
NotSupportedException
(
String
message
)
{
super
(
message
);
}
}
atms-api/src/main/java/pwc/taxtech/atms/exception/ParameterException.java
0 → 100644
View file @
ba76c7eb
package
pwc
.
taxtech
.
atms
.
exception
;
public
class
ParameterException
extends
ApplicationException
{
public
ParameterException
()
{
super
();
}
public
ParameterException
(
String
message
)
{
super
(
message
);
}
}
atms-api/src/main/java/pwc/taxtech/atms/service/impl/DataSourcePoolService.java
View file @
ba76c7eb
package
pwc
.
taxtech
.
atms
.
service
.
impl
;
import
com.alibaba.druid.pool.DruidDataSource
;
import
com.beust.jcommander.ParameterException
;
import
com.google.common.collect.Maps
;
import
org.apache.commons.lang3.StringUtils
;
import
org.apache.commons.pool2.impl.GenericKeyedObjectPool
;
...
...
@@ -19,6 +18,7 @@ import org.springframework.stereotype.Service;
import
pwc.taxtech.atms.common.datasource.DataSourceConfig
;
import
pwc.taxtech.atms.common.datasource.DataSourceFactory
;
import
pwc.taxtech.atms.common.datasource.ShardingContextHolder
;
import
pwc.taxtech.atms.exception.ParameterException
;
import
javax.annotation.PostConstruct
;
import
javax.sql.DataSource
;
...
...
atms-api/src/main/java/pwc/taxtech/atms/service/impl/ProjectServiceImpl.java
View file @
ba76c7eb
package
pwc
.
taxtech
.
atms
.
service
.
impl
;
import
com.beust.jcommander.internal.Lists
;
import
com.google.common.base.Predicate
;
import
com.google.common.collect.Lists
;
import
org.apache.ibatis.io.Resources
;
import
org.apache.ibatis.jdbc.ScriptRunner
;
import
org.apache.ibatis.session.SqlSession
;
...
...
atms-api/src/main/java/pwc/taxtech/atms/vat/service/impl/
report/functions/
FormulaAgent.java
→
atms-api/src/main/java/pwc/taxtech/atms/vat/service/impl/FormulaAgent.java
View file @
ba76c7eb
package
pwc
.
taxtech
.
atms
.
vat
.
service
.
impl
.
report
.
functions
;
package
pwc
.
taxtech
.
atms
.
vat
.
service
.
impl
;
import
org.springframework.
stereotype.Service
;
import
pwc.taxtech.atms.common.util.SpringContextUtil
;
import
org.springframework.
beans.factory.annotation.Autowired
;
import
org.springframework.stereotype.Repository
;
import
pwc.taxtech.atms.constant.enums.EnumServiceType
;
import
pwc.taxtech.atms.dao.FormulaAdminMapper
;
import
pwc.taxtech.atms.dto.GroupId
;
import
pwc.taxtech.atms.dto.vatdto.CellTemplatePerGroupDto
;
import
pwc.taxtech.atms.entitiy.ProjectServiceType
;
import
pwc.taxtech.atms.entitiy.ProjectServiceTypeExample
;
import
pwc.taxtech.atms.vat.dao.CellDataMapper
;
import
pwc.taxtech.atms.vat.dao.FormulaProjectMapper
;
import
pwc.taxtech.atms.vat.dao.ReportMapper
;
import
pwc.taxtech.atms.vat.entity.CellData
;
import
pwc.taxtech.atms.vat.entity.CellDataExample
;
import
pwc.taxtech.atms.vat.entity.Report
;
...
...
@@ -16,32 +20,33 @@ import java.util.List;
import
static
pwc
.
taxtech
.
atms
.
constant
.
Constant
.
FIRST_OR_DEFAULT
;
@Service
public
class
FormulaAgent
{
// @Autowired
// public FormulaAdminMapper formulaAdminMapper;
// @Autowired
// public FormulaProjectMapper projectMp;
// @Autowired
// public ReportMapper reportMapper;
// @Autowired
// public CellDataMapper cellDataMapper;
@Repository
public
class
FormulaAgent
extends
VatAbstractService
{
@Autowired
public
FormulaAdminMapper
adminMp
;
@Autowired
public
FormulaProjectMapper
projectMp
;
@Autowired
public
ReportMapper
reportMapper
;
@Autowired
public
CellDataMapper
cellDataMapper
;
public
List
<
CellTemplatePerGroupDto
>
getCellTemplateGroupDto
(
Long
templateGroupId
,
String
projectId
)
{
ProjectServiceTypeExample
pst
=
new
ProjectServiceTypeExample
();
pst
.
createCriteria
().
andTemplateGroupIDEqualTo
(
Long
.
valueOf
(
templateGroupId
))
.
andServiceTypeIDEqualTo
(
EnumServiceType
.
VAT
.
getCode
()
+
""
);
List
<
ProjectServiceType
>
pstReult
=
SpringContextUtil
.
projectServiceTypeMapper
.
selectByExample
(
pst
);
List
<
ProjectServiceType
>
pstReult
=
projectServiceTypeMapper
.
selectByExample
(
pst
);
List
<
CellTemplatePerGroupDto
>
cellTemplates
=
SpringContextUtil
.
formulaAdminMapper
.
getCellTemplatePerGroupDto
(
templateGroupId
);
List
<
CellTemplatePerGroupDto
>
cellTemplates
=
adminMp
.
getCellTemplatePerGroupDto
(
templateGroupId
);
if
(
pstReult
==
null
||
pstReult
.
isEmpty
())
{
List
<
GroupId
>
groupIds
=
SpringContextUtil
.
formulaAdminMapper
.
getTemplateGroupId
(
projectId
);
List
<
GroupId
>
groupIds
=
adminMp
.
getTemplateGroupId
(
projectId
);
GroupId
groupId
;
if
(
groupIds
.
size
()
>
0
)
{
groupId
=
groupIds
.
stream
().
filter
(
m
->
m
.
isDefault
!=
1
).
findFirst
().
get
();
if
(
groupId
==
null
)
groupId
=
groupIds
.
get
(
0
);
cellTemplates
.
addAll
(
SpringContextUtil
.
formulaAdminMapper
.
getCellTemplatePerGroupDto
(
groupId
.
groupId
));
cellTemplates
.
addAll
(
adminMp
.
getCellTemplatePerGroupDto
(
groupId
.
groupId
));
}
}
return
cellTemplates
;
...
...
@@ -51,7 +56,7 @@ public class FormulaAgent {
ReportExample
example
=
new
ReportExample
();
example
.
createCriteria
().
andTemplateIdEqualTo
(
Long
.
valueOf
(
templateId
))
.
andPeriodEqualTo
(
periodId
);
List
<
Report
>
reports
=
SpringContextUtil
.
reportMapper
.
selectByExample
(
example
);
List
<
Report
>
reports
=
reportMapper
.
selectByExample
(
example
);
if
(
reports
!=
null
||
!
reports
.
isEmpty
())
return
reports
.
get
(
FIRST_OR_DEFAULT
);
return
null
;
...
...
@@ -60,9 +65,10 @@ public class FormulaAgent {
public
CellData
getCellDataListByTemplate
(
String
templateId
,
Long
reportId
)
{
CellDataExample
dataExample
=
new
CellDataExample
();
dataExample
.
createCriteria
().
andCellTemplateIdEqualTo
(
Long
.
valueOf
(
templateId
));
List
<
CellData
>
cellDataList
=
SpringContextUtil
.
cellDataMapper
.
selectByExample
(
dataExample
);
List
<
CellData
>
cellDataList
=
cellDataMapper
.
selectByExample
(
dataExample
);
if
(
cellDataList
!=
null
||
!
cellDataList
.
isEmpty
())
return
cellDataList
.
get
(
FIRST_OR_DEFAULT
);
return
null
;
}
}
atms-api/src/main/java/pwc/taxtech/atms/vat/service/impl/ReportFormulaFactory.java
View file @
ba76c7eb
...
...
@@ -18,7 +18,6 @@ import pwc.taxtech.atms.dto.vatdto.ReportCellDataSourceDto;
import
pwc.taxtech.atms.exception.Exceptions
;
import
pwc.taxtech.atms.vat.entity.CellData
;
import
pwc.taxtech.atms.vat.entity.Report
;
import
pwc.taxtech.atms.vat.service.impl.report.functions.FormulaAgent
;
import
pwc.taxtech.atms.vat.service.impl.report.functions.FormulaContext
;
import
java.math.BigDecimal
;
...
...
atms-api/src/main/java/pwc/taxtech/atms/vat/service/impl/ReportGeneratorImpl.java
View file @
ba76c7eb
package
pwc
.
taxtech
.
atms
.
vat
.
service
.
impl
;
import
org.apache.commons.lang.StringUtils
;
import
org.apache.poi.openxml4j.exceptions.InvalidFormatException
;
import
org.apache.poi.ss.formula.functions.FreeRefFunction
;
import
org.apache.poi.ss.formula.udf.AggregatingUDFFinder
;
import
org.apache.poi.ss.formula.udf.DefaultUDFFinder
;
import
org.apache.poi.ss.formula.udf.UDFFinder
;
import
org.apache.poi.ss.usermodel.*
;
import
org.apache.poi.ss.usermodel.Cell
;
import
org.apache.poi.ss.usermodel.FormulaEvaluator
;
import
org.apache.poi.ss.usermodel.Row
;
import
org.apache.poi.ss.usermodel.Sheet
;
import
org.apache.poi.ss.usermodel.Workbook
;
import
org.apache.poi.ss.usermodel.WorkbookFactory
;
import
org.apache.poi.xssf.usermodel.XSSFWorkbook
;
import
org.slf4j.Logger
;
import
org.slf4j.LoggerFactory
;
...
...
@@ -15,17 +19,38 @@ import org.springframework.stereotype.Service;
import
pwc.taxtech.atms.common.POIUtil
;
import
pwc.taxtech.atms.constant.enums.CellDataSourceType
;
import
pwc.taxtech.atms.service.impl.DistributedIDService
;
import
pwc.taxtech.atms.vat.dao.*
;
import
pwc.taxtech.atms.vat.entity.*
;
import
pwc.taxtech.atms.vat.dao.CellDataMapper
;
import
pwc.taxtech.atms.vat.dao.PeriodCellTemplateConfigMapper
;
import
pwc.taxtech.atms.vat.dao.PeriodCellTemplateMapper
;
import
pwc.taxtech.atms.vat.dao.PeriodTemplateMapper
;
import
pwc.taxtech.atms.vat.dao.ReportMapper
;
import
pwc.taxtech.atms.vat.entity.CellData
;
import
pwc.taxtech.atms.vat.entity.PeriodCellTemplate
;
import
pwc.taxtech.atms.vat.entity.PeriodCellTemplateConfig
;
import
pwc.taxtech.atms.vat.entity.PeriodCellTemplateConfigExample
;
import
pwc.taxtech.atms.vat.entity.PeriodCellTemplateExample
;
import
pwc.taxtech.atms.vat.entity.PeriodTemplate
;
import
pwc.taxtech.atms.vat.entity.PeriodTemplateExample
;
import
pwc.taxtech.atms.vat.entity.Report
;
import
pwc.taxtech.atms.vat.service.ReportGenerator
;
import
pwc.taxtech.atms.vat.service.impl.report.functions.*
;
import
pwc.taxtech.atms.vat.service.impl.report.functions.FSJZ
;
import
pwc.taxtech.atms.vat.service.impl.report.functions.FormulaContext
;
import
pwc.taxtech.atms.vat.service.impl.report.functions.ND
;
import
pwc.taxtech.atms.vat.service.impl.report.functions.SGSR
;
import
java.io.File
;
import
java.io.FileNotFoundException
;
import
java.io.IOException
;
import
java.util.*
;
import
java.util.Date
;
import
java.util.HashMap
;
import
java.util.List
;
import
java.util.Map
;
import
java.util.Optional
;
import
java.util.stream.Collectors
;
import
static
pwc
.
taxtech
.
atms
.
constant
.
Constant
.
EMPTY
;
@Service
public
class
ReportGeneratorImpl
implements
ReportGenerator
{
@Autowired
...
...
@@ -55,7 +80,7 @@ public class ReportGeneratorImpl implements ReportGenerator {
List
<
PeriodTemplate
>
periodTemplateList
=
periodTemplateMapper
.
selectByExample
(
periodTemplateExample
);
List
<
Long
>
periodTemplateIDList
=
periodTemplateList
.
stream
().
map
(
PeriodTemplate:
:
getTemplateId
).
collect
(
Collectors
.
toList
());
Long
templateGroupID
=
periodTemplateList
.
size
()
>
0
?
periodTemplateList
.
get
(
0
).
getTemplateGroupId
():
0
;
Long
templateGroupID
=
periodTemplateList
.
size
()
>
0
?
periodTemplateList
.
get
(
0
).
getTemplateGroupId
()
:
0
;
PeriodCellTemplateExample
periodCellTemplateExample
=
new
PeriodCellTemplateExample
();
periodCellTemplateExample
.
createCriteria
().
andReportTemplateIdIn
(
periodTemplateIDList
);
...
...
@@ -74,10 +99,7 @@ public class ReportGeneratorImpl implements ReportGenerator {
Workbook
newWorkbook
=
workbook
.
get
();
addFunctionsToWorkbook
(
newWorkbook
,
templateGroupID
);
addFunctionsToWorkbook
(
newWorkbook
,
templateGroupID
);
int
sheetCount
=
newWorkbook
.
getNumberOfSheets
();
for
(
int
i
=
0
;
i
<
sheetCount
;
i
++)
{
Sheet
sheet
=
newWorkbook
.
getSheetAt
(
i
);
...
...
@@ -119,7 +141,7 @@ public class ReportGeneratorImpl implements ReportGenerator {
cell
=
row
.
getCell
(
k
.
getColumnIndex
());
//todo:后面单独处理kv的公式
if
(!
v
.
getFormula
().
contains
(
"@"
))
{
if
(!
v
.
getFormula
().
contains
(
"@"
))
{
cell
.
setCellFormula
(
v
.
getFormula
());
}
});
...
...
@@ -157,21 +179,20 @@ public class ReportGeneratorImpl implements ReportGenerator {
List
<
PeriodCellTemplateConfig
>
periodCellTemplateConfigs
=
periodCellTemplateConfigList
.
stream
().
filter
(
a
->
a
.
getReportTemplateId
().
equals
(
templateID
)).
collect
(
Collectors
.
toList
());
for
(
PeriodCellTemplateConfig
periodCellTemplateConfig
:
periodCellTemplateConfigs
)
{
Optional
<
PeriodCellTemplate
>
tempPeriodCellTemplate
=
periodCellTemplateList
.
stream
().
filter
(
a
->
a
.
getCellTemplateId
().
equals
(
periodCellTemplateConfig
.
getCellTemplateId
())).
findFirst
();
if
(
tempPeriodCellTemplate
!=
null
)
{
Optional
<
PeriodCellTemplate
>
tempPeriodCellTemplate
=
periodCellTemplateList
.
stream
().
filter
(
a
->
a
.
getCellTemplateId
().
equals
(
periodCellTemplateConfig
.
getCellTemplateId
())).
findFirst
();
if
(
tempPeriodCellTemplate
!=
null
)
{
CellData
cellData
=
new
CellData
();
cellData
.
setId
(
distributedIDService
.
nextId
());
cellData
.
setReportId
(
reportID
);
cellData
.
setCellTemplateId
(
tempPeriodCellTemplate
.
get
().
getCellTemplateId
());
String
data
;
if
(
sheet
.
getRow
(
tempPeriodCellTemplate
.
get
().
getRowIndex
())!=
null
&&
sheet
.
getRow
(
tempPeriodCellTemplate
.
get
().
getRowIndex
()).
getCell
(
tempPeriodCellTemplate
.
get
().
getColumnIndex
())!=
null
){
data
=
Double
.
toString
(
sheet
.
getRow
(
tempPeriodCellTemplate
.
get
().
getRowIndex
()).
getCell
(
tempPeriodCellTemplate
.
get
().
getColumnIndex
()).
getNumericCellValue
());
}
else
{
data
=
StringUtils
.
EMPTY
;
if
(
sheet
.
getRow
(
tempPeriodCellTemplate
.
get
().
getRowIndex
())
!=
null
&&
sheet
.
getRow
(
tempPeriodCellTemplate
.
get
().
getRowIndex
()).
getCell
(
tempPeriodCellTemplate
.
get
().
getColumnIndex
())
!=
null
)
{
data
=
Double
.
toString
(
sheet
.
getRow
(
tempPeriodCellTemplate
.
get
().
getRowIndex
()).
getCell
(
tempPeriodCellTemplate
.
get
().
getColumnIndex
()).
getNumericCellValue
());
}
else
{
data
=
EMPTY
;
}
cellData
.
setData
(
data
);
cellData
.
setFormulaExp
(
StringUtils
.
EMPTY
);
cellData
.
setFormulaExp
(
EMPTY
);
cellData
.
setCreateBy
(
"Admin"
);
cellData
.
setCreateTime
(
createTime
);
cellData
.
setUpdateBy
(
"Admin"
);
...
...
@@ -236,15 +257,16 @@ public class ReportGeneratorImpl implements ReportGenerator {
*
* @param workbook 工作簿
*/
private
void
addFunctionsToWorkbook
(
Workbook
workbook
,
Long
templateGroupID
)
{
String
[]
functionNames
=
{
"SGSR"
,
"FSJZ"
,
"ND
"
};
private
void
addFunctionsToWorkbook
(
Workbook
workbook
,
Long
templateGroupID
)
{
String
[]
functionNames
=
{
"SGSR"
,
"FSJZ"
,
"ND"
,
"BB
"
};
FormulaContext
formulaContext
=
new
FormulaContext
();
formulaContext
.
setFormulaAgent
(
formulaAgent
);
formulaContext
.
setPeriod
(
6
);
//todo: assign value later
formulaContext
.
setReportTemplateGroupID
(
templateGroupID
);
FreeRefFunction
[]
functionImpls
=
{
new
SGSR
(
formulaContext
),
new
FSJZ
(
formulaContext
),
new
ND
(
formulaContext
)};
FreeRefFunction
[]
functionImpls
=
{
new
SGSR
(
formulaContext
),
new
FSJZ
(
formulaContext
),
new
ND
(
formulaContext
),
new
ReportFormulaFactory
.
BB
(
formulaContext
)};
UDFFinder
udfs
=
new
DefaultUDFFinder
(
functionNames
,
functionImpls
);
UDFFinder
udfToolpack
=
new
AggregatingUDFFinder
(
udfs
);
workbook
.
addToolPack
(
udfToolpack
);
}
}
}
atms-api/src/main/java/pwc/taxtech/atms/vat/service/impl/ReportServiceImpl.java
View file @
ba76c7eb
...
...
@@ -8,14 +8,19 @@ import pwc.taxtech.atms.dto.OperationResultDto;
import
pwc.taxtech.atms.dto.vatdto.CellTemplateReferenceDto
;
import
pwc.taxtech.atms.dto.vatdto.ReportDto
;
import
pwc.taxtech.atms.entitiy.*
;
import
pwc.taxtech.atms.exception.NotSupportedException
;
import
pwc.taxtech.atms.vat.entity.PeriodCellTemplate
;
import
pwc.taxtech.atms.vat.entity.PeriodCellTemplateConfig
;
import
pwc.taxtech.atms.vat.entity.PeriodTemplate
;
import
pwc.taxtech.atms.vat.entity.PeriodTemplateExample
;
import
pwc.taxtech.atms.vat.service.ReportService
;
import
javax.ws.rs.NotSupportedException
;
import
java.util.*
;
import
java.util.ArrayList
;
import
java.util.Arrays
;
import
java.util.HashMap
;
import
java.util.List
;
import
java.util.Map
;
import
java.util.Optional
;
import
java.util.stream.Collectors
;
@Service
...
...
@@ -87,7 +92,7 @@ public class ReportServiceImpl extends VatAbstractService implements ReportServi
}
@Override
public
OperationResultDto
updateConfig
(
String
projectId
,
Integer
period
,
Boolean
ifDeleteManualDataSource
,
String
generator
)
{
public
OperationResultDto
updateConfig
(
String
projectId
,
Integer
period
,
Boolean
ifDeleteManualDataSource
,
String
generator
)
{
OperationResultDto
result
=
new
OperationResultDto
();
if
(
period
==
null
)
{
...
...
@@ -118,7 +123,7 @@ public class ReportServiceImpl extends VatAbstractService implements ReportServi
dataSourceMapper
.
clearTaxPayerReportWithPeriod
(
period
);
dataSourceMapper
.
clearDataSourceWithPeriod
(
period
);
dataSourceMapper
.
clearDataSourceDetailWithPeriod
(
period
);
dataSourceMapper
.
clearCellDataWithPeriod
(
strExceptTemplateIDs
);
dataSourceMapper
.
clearCellDataWithPeriod
(
strExceptTemplateIDs
);
// 根据templategroupid 把 template 插入到 periodTemplate
TemplateExample
example
=
new
TemplateExample
();
...
...
atms-api/src/main/java/pwc/taxtech/atms/vat/service/impl/report/functions/FormulaContext.java
View file @
ba76c7eb
...
...
@@ -2,6 +2,7 @@ package pwc.taxtech.atms.vat.service.impl.report.functions;
import
lombok.Getter
;
import
lombok.Setter
;
import
pwc.taxtech.atms.vat.service.impl.FormulaAgent
;
@Setter
@Getter
...
...
atms-api/src/main/resources/applicationContext-datasource-mail.xml
deleted
100644 → 0
View file @
ac09da2d
<?xml version="1.0" encoding="UTF-8"?>
<beans
xmlns=
"http://www.springframework.org/schema/beans"
xmlns:xsi=
"http://www.w3.org/2001/XMLSchema-instance"
xmlns:context=
"http://www.springframework.org/schema/context"
xmlns:mvc=
"http://www.springframework.org/schema/mvc"
xmlns:tx=
"http://www.springframework.org/schema/tx"
xsi:schemaLocation=
"http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.3.xsd
http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.3.xsd
http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.3.xsd"
>
<!-- DruidDataSource数据源配置) -->
<!-- See: https://github.com/alibaba/druid/wiki/%E9%85%8D%E7%BD%AE_DruidDataSource%E5%8F%82%E8%80%83%E9%85%8D%E7%BD%AE -->
<bean
id=
"dataSourceMail"
class=
"com.alibaba.druid.pool.DruidDataSource"
init-method=
"init"
destroy-method=
"close"
>
<!-- 基本属性 url、user、password -->
<property
name=
"url"
value=
"${mail_jdbc_url}"
/>
<property
name=
"username"
value=
"${mail_jdbc_user}"
/>
<property
name=
"password"
value=
"${mail_jdbc_password}"
/>
<!-- 配置初始化大小、最小、最大 -->
<property
name=
"initialSize"
value=
"${atms.config.druid.initialSize:0}"
/>
<property
name=
"minIdle"
value=
"${atms.config.druid.minIdle:1}"
/>
<property
name=
"maxActive"
value=
"${atms.config.druid.maxActive:20}"
/>
<!-- 配置获取连接等待超时的时间 -->
<property
name=
"maxWait"
value=
"${atms.config.druid.maxWait:60000}"
/>
<!-- 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒 -->
<property
name=
"timeBetweenEvictionRunsMillis"
value=
"${atms.config.druid.timeBetweenEvictionRunsMillis:60000}"
/>
<!-- 配置一个连接在池中最小生存的时间,单位是毫秒 -->
<property
name=
"minEvictableIdleTimeMillis"
value=
"${atms.config.druid.minEvictableIdleTimeMillis:300000}"
/>
<property
name=
"validationQuery"
value=
"${jdbc_validationQuery:select 1 from INFORMATION_SCHEMA.SYSTEM_USERS}"
/>
<property
name=
"testWhileIdle"
value=
"true"
/>
<property
name=
"testOnBorrow"
value=
"false"
/>
<property
name=
"testOnReturn"
value=
"false"
/>
<!-- 打开PSCache,并且指定每个连接上PSCache的大小 -->
<property
name=
"poolPreparedStatements"
value=
"true"
/>
<property
name=
"maxPoolPreparedStatementPerConnectionSize"
value=
"20"
/>
<!-- 配置监控统计拦截的filters -->
<property
name=
"filters"
value=
"stat"
/>
</bean>
</beans>
\ No newline at end of file
atms-api/src/main/resources/applicationContext.xml
View file @
ba76c7eb
...
...
@@ -32,7 +32,6 @@
</context:component-scan>
<import
resource=
"applicationContext-datasource.xml"
/>
<import
resource=
"applicationContext-datasource-mail.xml"
/>
<bean
id=
"sqlSessionFactory"
class=
"org.mybatis.spring.SqlSessionFactoryBean"
>
<property
name=
"dataSource"
ref=
"dataSource"
/>
...
...
@@ -48,20 +47,6 @@
<constructor-arg
ref=
"sqlSessionFactory"
/>
</bean>
<bean
id=
"sqlSessionFactoryMail"
class=
"org.mybatis.spring.SqlSessionFactoryBean"
>
<property
name=
"dataSource"
ref=
"dataSourceMail"
/>
<property
name=
"configLocation"
value=
"classpath:sqlMapConfig.xml"
/>
<property
name=
"mapperLocations"
>
<array>
<value>
classpath:pwc/taxtech/atms/dao/*Mapper.xml
</value>
</array>
</property>
</bean>
<bean
id=
"sqlSessionTemplateMail"
class=
"org.mybatis.spring.SqlSessionTemplate"
>
<constructor-arg
ref=
"sqlSessionFactoryMail"
/>
</bean>
<!-- <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"> <property name="basePackage" value="pwc.taxtech.atms" /> </bean> -->
<bean
id=
"transactionManager"
class=
"org.springframework.jdbc.datasource.DataSourceTransactionManager"
>
...
...
@@ -74,8 +59,9 @@
</tx:attributes>
</tx:advice>
<aop:config>
<aop:pointcut
id=
"txPointcut2"
expression=
"execution(public * pwc.taxtech.atms..*.*(..)) && @target(org.springframework.stereotype.Service)"
/>
<aop:config
proxy-target-class=
"true"
>
<aop:pointcut
id=
"txPointcut2"
expression=
"execution(public * pwc.taxtech.atms..*.*(..)) && @target(org.springframework.stereotype.Service)
and !execution(* pwc.taxtech.atms.vat.service.impl.FormulaAgent.*(..))"
/>
<aop:advisor
pointcut-ref=
"txPointcut2"
advice-ref=
"txAdvice"
/>
</aop:config>
...
...
atms-api/src/test/java/pwc/taxtech/atms/service/impl/MailServiceIT.java
View file @
ba76c7eb
package
pwc
.
taxtech
.
atms
.
service
.
impl
;
import
java.util.Date
;
import
javax.annotation.Resource
;
import
org.junit.Assert
;
import
org.junit.Before
;
import
org.junit.Test
;
import
org.mybatis.spring.SqlSessionTemplate
;
import
org.slf4j.Logger
;
import
org.slf4j.LoggerFactory
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
pwc.taxtech.atms.CommonIT
;
import
pwc.taxtech.atms.dao.MailQueueMapper
;
import
pwc.taxtech.atms.dto.MailMto
;
import
pwc.taxtech.atms.entitiy.MailQueue
;
import
pwc.taxtech.atms.service.CommonService
;
import
java.util.Date
;
public
class
MailServiceIT
extends
CommonIT
{
private
static
final
Logger
logger
=
LoggerFactory
.
getLogger
(
MailServiceIT
.
class
);
@Autowired
private
CommonService
commonService
;
@Autowired
private
MailQueueMapper
mailQueueMapper
;
@Resource
private
SqlSessionTemplate
sqlSessionTemplateMail
;
@Before
public
void
setUp
()
{
...
...
atms-web/pom.xml
View file @
ba76c7eb
<project
xmlns=
"http://maven.apache.org/POM/4.0.0"
xmlns:xsi=
"http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation=
"http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"
>
<project
xmlns=
"http://maven.apache.org/POM/4.0.0"
xmlns:xsi=
"http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation=
"http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"
>
<modelVersion>
4.0.0
</modelVersion>
<groupId>
pwc.taxtech.atms
</groupId>
<artifactId>
atms-web
</artifactId>
...
...
@@ -31,44 +32,21 @@
</dependencyManagement>
<dependencies>
<dependency>
<groupId>
org.springframework
</groupId>
<artifactId>
spring-context
</artifactId>
</dependency>
<dependency>
<groupId>
org.springframework
</groupId>
<artifactId>
spring-context-support
</artifactId>
</dependency>
<dependency>
<groupId>
org.springframework
</groupId>
<artifactId>
spring-web
</artifactId>
</dependency>
<dependency>
<groupId>
org.springframework
</groupId>
<artifactId>
spring-webmvc
</artifactId>
</dependency>
<dependency>
<groupId>
org.springframework
</groupId>
<artifactId>
spring-aspects
</artifactId>
</dependency>
<dependency>
<groupId>
org.springframework.security
</groupId>
<artifactId>
spring-security-config
</artifactId>
<version>
4.2.3.RELEASE
</version>
</dependency>
<dependency>
<groupId>
org.springframework.security
</groupId>
<artifactId>
spring-security-web
</artifactId>
<version>
4.2.3.RELEASE
</version>
</dependency>
<dependency>
<groupId>
commons-fileupload
</groupId>
<artifactId>
commons-fileupload
</artifactId>
<version>
1.3.3
</version>
</dependency>
<dependency>
<groupId>
org.slf4j
</groupId>
<artifactId>
slf4j-log4j12
</artifactId>
...
...
@@ -125,17 +103,17 @@
<artifactId>
fastjson
</artifactId>
<version>
1.2.40
</version>
</dependency>
<dependency
>
<groupId>
org.nutz
</groupId
>
<artifactId>
nutz
</artifactId
>
<version>
1.r.63.r2
</version
>
</dependency
>
<!--<dependency>--
>
<!--<groupId>org.nutz</groupId>--
>
<!--<artifactId>nutz</artifactId>--
>
<!--<version>1.r.63.r2</version>--
>
<!--</dependency>--
>
<dependency
>
<groupId>
joda-time
</groupId
>
<artifactId>
joda-time
</artifactId
>
<version>
2.9.9
</version
>
</dependency
>
<!--<dependency>--
>
<!--<groupId>joda-time</groupId>--
>
<!--<artifactId>joda-time</artifactId>--
>
<!--<version>2.9.9</version>--
>
<!--</dependency>--
>
<dependency>
<groupId>
org.jasypt
</groupId>
<artifactId>
jasypt
</artifactId>
...
...
@@ -146,25 +124,13 @@
<artifactId>
jasypt-spring31
</artifactId>
<version>
1.9.2
</version>
</dependency>
<!-- jackson json
-->
<!--<!– jackson json –>
-->
<dependency>
<groupId>
com.fasterxml.jackson.core
</groupId>
<artifactId>
jackson-databind
</artifactId>
<version>
2.9.4
</version>
</dependency>
<dependency>
<groupId>
org.springframework
</groupId>
<artifactId>
spring-test
</artifactId>
<scope>
test
</scope>
</dependency>
<dependency>
<groupId>
junit
</groupId>
<artifactId>
junit
</artifactId>
<version>
4.12
</version>
<scope>
test
</scope>
</dependency>
</dependencies>
<profiles>
...
...
@@ -206,7 +172,7 @@
</profile>
</profiles>
<build>
<build>
<finalName>
atms-web
</finalName>
<resources>
<resource>
...
...
@@ -258,6 +224,6 @@
</configuration>
</plugin>
</plugins>
</build>
</build>
</project>
atms-web/src/main/resources/applicationContext-mvc.xml
View file @
ba76c7eb
<?xml version="1.0" encoding="UTF-8"?>
<beans
xmlns=
"http://www.springframework.org/schema/beans"
xmlns:xsi=
"http://www.w3.org/2001/XMLSchema-instance"
xmlns:context=
"http://www.springframework.org/schema/context
"
xmlns:xsi=
"http://www.w3.org/2001/XMLSchema-instance
"
xmlns:mvc=
"http://www.springframework.org/schema/mvc"
xsi:schemaLocation=
"http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.3.xsd
http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.3.xsd"
>
<!-- **************************************************************** -->
<!-- Spring-MVC配置 -->
<!-- **************************************************************** -->
<mvc:resources
mapping=
"/**"
location=
"/"
/>
<mvc:resources
mapping=
"/**"
location=
"/"
/>
<mvc:annotation-driven>
<mvc:message-converters>
<!-- <ref bean="fastJsonHttpMessageConverter" /> -->
<ref
bean=
"mappingJackson2HttpMessageConverter"
/>
<ref
bean=
"mappingJackson2HttpMessageConverter"
/>
</mvc:message-converters>
</mvc:annotation-driven>
...
...
@@ -25,29 +24,29 @@
<!-- **************************************************************** -->
<bean
id=
"templateResolver"
class=
"org.thymeleaf.spring4.templateresolver.SpringResourceTemplateResolver"
>
<property
name=
"prefix"
value=
"/WEB-INF/templates/"
/>
<property
name=
"suffix"
value=
".html"
/>
<property
name=
"templateMode"
value=
"HTML"
/>
<property
name=
"cacheable"
value=
"false"
/>
<property
name=
"characterEncoding"
value=
"UTF-8"
/>
<property
name=
"prefix"
value=
"/WEB-INF/templates/"
/>
<property
name=
"suffix"
value=
".html"
/>
<property
name=
"templateMode"
value=
"HTML"
/>
<property
name=
"cacheable"
value=
"false"
/>
<property
name=
"characterEncoding"
value=
"UTF-8"
/>
</bean>
<bean
id=
"templateEngine"
class=
"org.thymeleaf.spring4.SpringTemplateEngine"
>
<property
name=
"templateResolver"
ref=
"templateResolver"
/>
<property
name=
"enableSpringELCompiler"
value=
"true"
/>
<property
name=
"templateResolver"
ref=
"templateResolver"
/>
<property
name=
"enableSpringELCompiler"
value=
"true"
/>
<property
name=
"additionalDialects"
>
<set>
<!-- Note the package would change to 'springsecurity3' if you are using
that version -->
<bean
class=
"org.thymeleaf.extras.springsecurity4.dialect.SpringSecurityDialect"
/>
class=
"org.thymeleaf.extras.springsecurity4.dialect.SpringSecurityDialect"
/>
</set>
</property>
</bean>
<bean
class=
"org.thymeleaf.spring4.view.ThymeleafViewResolver"
>
<property
name=
"templateEngine"
ref=
"templateEngine"
/>
<property
name=
"characterEncoding"
value=
"UTF-8"
/>
<property
name=
"order"
value=
"100"
/>
<property
name=
"templateEngine"
ref=
"templateEngine"
/>
<property
name=
"characterEncoding"
value=
"UTF-8"
/>
<property
name=
"order"
value=
"100"
/>
</bean>
</beans>
\ No newline at end of file
atms-web/src/main/resources/applicationContext.xml
View file @
ba76c7eb
<?xml version="1.0" encoding="UTF-8"?>
<beans
xmlns=
"http://www.springframework.org/schema/beans"
xmlns:xsi=
"http://www.w3.org/2001/XMLSchema-instance"
xmlns:context=
"http://www.springframework.org/schema/context"
xmlns:mvc=
"http://www.springframework.org/schema/mvc"
xmlns:aop=
"http://www.springframework.org/schema/aop"
xmlns:xsi=
"http://www.w3.org/2001/XMLSchema-instance"
xmlns:context=
"http://www.springframework.org/schema/context"
xsi:schemaLocation=
"http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.3.xsd
http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.3.xsd
http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd "
>
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.3.xsd"
>
<bean
id=
"standardPBEStringEncryptor"
class=
"org.jasypt.encryption.pbe.StandardPBEStringEncryptor"
>
<property
name=
"password"
value=
"${atms_password:9C7jLBQ62cDbVwIzP85DIlzdAm76DdMb}"
/>
value=
"${atms_password:9C7jLBQ62cDbVwIzP85DIlzdAm76DdMb}"
/>
</bean>
<bean
id=
"encryptablePropertyPlaceholderConfigurer"
class=
"org.jasypt.spring31.properties.EncryptablePropertyPlaceholderConfigurer"
>
<property
name=
"ignoreUnresolvablePlaceholders"
value=
"true"
/>
<constructor-arg
ref=
"standardPBEStringEncryptor"
/>
<property
name=
"ignoreUnresolvablePlaceholders"
value=
"true"
/>
<constructor-arg
ref=
"standardPBEStringEncryptor"
/>
<property
name=
"locations"
>
<list>
<!-- Base settings for all environments -->
...
...
@@ -28,7 +25,7 @@
</property>
</bean>
<context:component-scan
base-package=
"pwc.taxtech.atms.web"
/>
<context:component-scan
base-package=
"pwc.taxtech.atms.web"
/>
<!-- <tx:annotation-driven proxy-target-class="true" /> -->
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment