Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

0.3.0-rc release #1997

Merged
merged 594 commits into from
Oct 29, 2020
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
594 commits
Select commit Hold shift + click to select a range
e07b98d
feat:(members) #1708
ruanhan May 28, 2020
65e5b87
fix(Components): RichText toolbar color icon style
AndyFong May 21, 2020
4e9b624
fix(Display): setting form items&values error
AndyFong May 28, 2020
ddf6506
Merge pull request #1765 from scottsut/fix_chart_error
AndyFong May 28, 2020
bee24f6
Merge pull request #1766 from cabbage89/dev-0.3
xxxllluuu May 28, 2020
5628d66
Merge pull request #1764 from RichardShan/dev-0.3
xxxllluuu May 28, 2020
3f1ad68
Merge pull request #25 from edp963/dev-0.3
xxxllluuu May 28, 2020
7e0f634
Merge pull request #1769 from AndyFong/hotfix/pre-release
scottsut May 28, 2020
70463b6
style(Components): fix RichText style
AndyFong May 29, 2020
1c84515
Merge pull request #1771 from edp963/hotfix/style-richtext
scottsut May 29, 2020
0cb41c2
fix(Share): Display Share param p parse error
AndyFong May 29, 2020
6bdacb3
Merge pull request #1772 from AndyFong/hotfix/share-display
scottsut May 29, 2020
7797de2
https://github.com/edp963/davinci/issues/1774 1. fix
xxxllluuu May 30, 2020
d477db0
Merge pull request #1775 from xxxllluuu/dev-0.3
scottsut May 31, 2020
35344ed
fix(Components): RichText html deserialize Array.flat compatibility
AndyFong Jun 1, 2020
b43cffd
Merge pull request #1777 from AndyFong/hotfix/richtext-html-deserialize
scottsut Jun 1, 2020
3388c85
fix: Weird jumps when press Enter in input or textarea
scottsut Jun 1, 2020
9d2f8f0
fix: Array.flat compatibility of dependencies
scottsut Jun 1, 2020
2bc5a78
Merge pull request #1780 from scottsut/fix_array_flat
AndyFong Jun 1, 2020
dd7d94a
:zap:perf(display): optimize layer dragging performance
dlt1111 Jun 1, 2020
c045a0d
fix: drag error
dlt1111 Jun 1, 2020
6f4b548
Merge pull request #1779 from scottsut/fix_input_enter_jump
AndyFong Jun 1, 2020
e46a4c2
修复ScriptUtils.formatHeader bug
Jun 1, 2020
7995f6d
Merge pull request #1782 from bogeli5/dev-0.3
AndyFong Jun 2, 2020
711ec8d
feat(invite members): logic fix
scottsut Jun 2, 2020
fbe935c
Merge pull request #1 from scottsut/invite_member_fix
ruanhan Jun 3, 2020
684d848
Merge pull request #1768 from ruanhan/dev-0.3
scottsut Jun 3, 2020
d49a9e4
fix: allow user to set job start time after current time
Jun 3, 2020
88c535e
Merge pull request #1781 from dlt1111/opt_display
AndyFong Jun 4, 2020
d91603c
Merge pull request #1785 from bogeli5/dev-0.3
bogeli5 Jun 4, 2020
0d0afee
fix(table): Set table widget type to without aggregator by default
scottsut Jun 4, 2020
80e29a9
Merge pull request #1787 from scottsut/fix_table_aggregator
AndyFong Jun 4, 2020
2ebc54d
Merge pull request #26 from edp963/dev-0.3
xxxllluuu Jun 4, 2020
53e77be
Merge pull request #27 from edp963/master
xxxllluuu Jun 4, 2020
27a9440
chore: update babel config and pkgs with ie11 compatibility
AndyFong Jun 5, 2020
f45d9ae
fix: remove localStorage functions overwrites to fix error under ie11
AndyFong Jun 5, 2020
a8f9137
fix(Schedule): mail content length validation not work error
AndyFong Jun 5, 2020
42b22a1
fix(display): preview & share display
dlt1111 Jun 5, 2020
c925532
fix(bug): #1759
ruanhan Jun 5, 2020
7acf3aa
Merge pull request #1789 from ruanhan/dev-0.3
scottsut Jun 5, 2020
1a58c40
Merge pull request #1788 from dlt1111/opt_display
scottsut Jun 5, 2020
d8781e2
Merge pull request #1790 from AndyFong/fix/babel-and-schedule
scottsut Jun 5, 2020
0f68fdc
fix(statistic): Statistic request error of dashboard without global c…
scottsut Jun 11, 2020
555ceb3
fix: Build error due to case
scottsut Jun 12, 2020
1d0fda2
Merge pull request #1797 from scottsut/fix_download_statistic
ruanhan Jun 12, 2020
a2dd752
fix origanzation three fields
ruanhan Jun 12, 2020
056dda7
Merge pull request #1799 from ruanhan/dev-0.3
scottsut Jun 15, 2020
6748ee9
fix:(memberlist) invalid search source
ruanhan Jun 15, 2020
3dce91f
Merge pull request #1802 from ruanhan/dev-0.3
scottsut Jun 15, 2020
1656f00
fix(shareparam) #1796
ruanhan Jun 15, 2020
c5b7592
fix:(shareparams) add validate
ruanhan Jun 15, 2020
56d9990
Merge pull request #1804 from ruanhan/dev-0.3
scottsut Jun 15, 2020
89f9e1f
chore(deps): bump guava from 23.6-jre to 24.1.1-jre in /server
dependabot[bot] Jun 16, 2020
a50e78a
Merge pull request #1805 from edp963/dependabot/maven/server/com.goog…
xxxllluuu Jun 16, 2020
82dc2ff
https://github.com/edp963/davinci/issues/1816 1. fix it
xxxllluuu Jun 19, 2020
4cc3b38
Merge pull request #28 from edp963/dev-0.3
xxxllluuu Jun 19, 2020
c880ab1
Merge remote-tracking branch 'refs/remotes/origin/dev-0.3' into dev-0.3
xxxllluuu Jun 19, 2020
453cd63
Merge pull request #1817 from xxxllluuu/dev-0.3
xxxllluuu Jun 19, 2020
12955bb
fix(drill) dbar can not drill when stack
ruanhan Jun 22, 2020
8d1c83c
fix:(chart) remove uhooks
ruanhan Jun 23, 2020
3192cc2
https://github.com/edp963/davinci/issues/1822 1. add guest user
xxxllluuu Jun 23, 2020
93e471f
Merge pull request #1823 from xxxllluuu/dev-0.3
scottsut Jun 23, 2020
dbc5769
fix(stack) reset class com
ruanhan Jun 24, 2020
5831c7d
Merge pull request #1820 from ruanhan/dev-0.3
scottsut Jun 24, 2020
e4754fb
chore(deps): bump quartz from 2.3.0 to 2.3.2 in /server
dependabot[bot] Jul 1, 2020
92757cd
Merge pull request #1831 from edp963/dependabot/maven/server/org.quar…
xxxllluuu Jul 2, 2020
657a0a2
fix: variable recognition error in join select sql
RichardShan Jul 5, 2020
aa3282d
fix: extract auth@var fragment in join select
RichardShan Jul 6, 2020
b9460eb
Merge pull request #1836 from RichardShan/dev-0.3
xxxllluuu Jul 7, 2020
6cc8030
Merge pull request #29 from edp963/dev-0.3
xxxllluuu Jul 8, 2020
1a59f09
feat:(refactor) refactor avator component
ruanhan Jul 9, 2020
5cd41bc
feat:(refactor) transfer loading to spin
ruanhan Jul 13, 2020
2b6261f
feat:(refactor) multiple load
ruanhan Jul 13, 2020
3d7ee4b
fix: Project related role transfer search unavailable
scottsut Jul 14, 2020
6fdbe18
Merge pull request #1848 from scottsut/fix_role_transfer
scottsut Jul 14, 2020
0606011
fix: Organization member list avatar incorrect display due to react key
scottsut Jul 14, 2020
e500457
Merge pull request #2 from scottsut/fix_memeber_list_avatar
ruanhan Jul 14, 2020
f1d19ab
fix: Add IntersectionObserver polyfill manually
scottsut Jul 14, 2020
34e8973
Merge pull request #3 from scottsut/fix_memeber_list_avatar
ruanhan Jul 14, 2020
666b2c1
Merge pull request #1839 from ruanhan/image_refactor_0708
scottsut Jul 14, 2020
2a08e0b
https://github.com/edp963/davinci/issues/1846 1. fix it
xxxllluuu Jul 14, 2020
ce5488e
Merge pull request #1850 from xxxllluuu/dev-0.3
xxxllluuu Jul 14, 2020
ee516eb
fix(Display): Prevent edit button from triggering mouse events
scottsut Jul 16, 2020
749226c
Merge pull request #1853 from scottsut/dev-0.3
ruanhan Jul 16, 2020
16b97e1
https://github.com/edp963/davinci/issues/1854 1. resttemplate support…
xxxllluuu Jul 17, 2020
093822e
chore(deps): bump lodash from 4.17.13 to 4.17.19 in /webapp
dependabot[bot] Jul 18, 2020
989f89e
Merge pull request #1856 from edp963/dependabot/npm_and_yarn/webapp/l…
scottsut Jul 19, 2020
a9ac10f
修改版本号,统一风格
xxxllluuu Jul 21, 2020
404e723
Merge pull request #1855 from xxxllluuu/dev-0.3
bogeli5 Jul 21, 2020
e414d07
Merge pull request #31 from edp963/dev-0.3
xxxllluuu Jul 21, 2020
f45eab4
feature: common share factor
RichardShan Apr 22, 2020
1bef144
refactor: share widget
RichardShan Apr 23, 2020
b71f2f4
refactor: post share
RichardShan Apr 23, 2020
58c9f07
refactor: Add Aspect AOP for davinci `share` module
RichardShan Apr 26, 2020
c164083
refactor: refresh share token and data token
RichardShan Apr 26, 2020
0e9e32c
refactor: add preflight and get share permissions api
RichardShan Apr 26, 2020
d019542
refactor: share aop add download permission check
RichardShan Apr 29, 2020
f36726e
https://github.com/edp963/davinci/issues/1870 1. fix it 2. 添加独立的下载日志
xxxllluuu Jul 27, 2020
8f98e2b
https://github.com/edp963/davinci/issues/1870 1. 增加鲁棒性
xxxllluuu Jul 27, 2020
6b8ae80
Merge pull request #1871 from xxxllluuu/dev-0.3
xxxllluuu Jul 27, 2020
dd7b096
fix: spelling mistakes
RichardShan Jul 27, 2020
4c0c117
fix: import objects
RichardShan Jul 28, 2020
36b1d28
refactor: share
RichardShan Jul 28, 2020
eb74031
Merge pull request #32 from edp963/dev-0.3
xxxllluuu Jul 29, 2020
ead3f5f
refactor(display): remove antd tooltip fix layerBox repeat rendering
old-zsh Aug 4, 2020
e73c1ed
refactor(display): layerBox keyDown move bug and remove dragLayerInde…
old-zsh Aug 4, 2020
cad3e28
feature: common share factor
RichardShan Apr 22, 2020
0d62104
refactor: share widget
RichardShan Apr 23, 2020
f915e8a
refactor: post share
RichardShan Apr 23, 2020
220a240
refactor: Add Aspect AOP for davinci `share` module
RichardShan Apr 26, 2020
6afe245
refactor: refresh share token and data token
RichardShan Apr 26, 2020
ab8c527
refactor: add preflight and get share permissions api
RichardShan Apr 26, 2020
fe0ccd8
refactor: share aop add download permission check
RichardShan Apr 29, 2020
61d1352
fix: spelling mistakes
RichardShan Jul 27, 2020
21be397
fix: import objects
RichardShan Jul 28, 2020
eca33be
Merge branch 'dev-0.3' of github.com:RichardShan/davinci into dev-0.3
RichardShan Aug 6, 2020
f3e9081
fix: auth share get permission error
RichardShan Aug 7, 2020
b959fb6
Merge pull request #1882 from old-zsh/refactor_display_drayLayer_perf…
scottsut Aug 10, 2020
e9c0660
fix(Display): types and styles adjustment
scottsut Aug 11, 2020
12955ff
Merge pull request #1887 from scottsut/fix_display_perf_refactor
scottsut Aug 13, 2020
e7ddfe2
fix: auth share get parse Display
RichardShan Aug 17, 2020
433435d
Merge pull request #1875 from RichardShan/dev-0.3
xxxllluuu Aug 21, 2020
cb8700b
https://github.com/edp963/davinci/issues/1898 1. fix some issues
xxxllluuu Aug 21, 2020
8d2bf6c
Merge pull request #33 from edp963/dev-0.3
xxxllluuu Aug 21, 2020
f2f5298
Merge remote-tracking branch 'origin/dev-0.3' into dev-0.3
xxxllluuu Aug 21, 2020
240b7de
Merge pull request #1900 from xxxllluuu/dev-0.3
xxxllluuu Aug 21, 2020
ae0c741
feat(share): feat token share
ruanhan Aug 24, 2020
69236dd
fix: core-js error in windows
scottsut Aug 25, 2020
8dbf7d9
Merge pull request #1910 from scottsut/fix_windows_dependencies_install
scottsut Aug 25, 2020
eaa7d12
https://github.com/edp963/davinci/pull/1875 1. bug fix
xxxllluuu Aug 25, 2020
6cb170a
fix(share) fix userid
ruanhan Aug 25, 2020
7be3a78
fix(share) reset canvas
ruanhan Aug 25, 2020
23789a5
fix:(share) fix some error message;
ruanhan Aug 25, 2020
6997547
https://github.com/edp963/davinci/pull/1875 1. bug fix
xxxllluuu Aug 27, 2020
4499375
fix(share) rename some function arg
ruanhan Aug 28, 2020
9861155
Merge pull request #1911 from xxxllluuu/dev-0.3
xxxllluuu Aug 31, 2020
a6b234c
fix(share) add some deps
ruanhan Aug 31, 2020
f8c12c5
Merge pull request #1905 from ruanhan/share_0623
scottsut Aug 31, 2020
a36706b
feat:(table) added source table encryption function
chenweizhaoup Sep 1, 2020
5816343
fix(share): muti deps
ruanhan Sep 1, 2020
a5d5312
fix(share): remove console
ruanhan Sep 1, 2020
f511a86
Merge pull request #1917 from ruanhan/noneLogin_0824
scottsut Sep 1, 2020
0834a6d
https://github.com/edp963/davinci/pull/1875 1. bug fix
xxxllluuu Sep 1, 2020
edbc78b
Merge pull request #1919 from xxxllluuu/dev-0.3
scottsut Sep 2, 2020
d095300
feat:(table) added source table encryption function
chenweizhaoup Sep 2, 2020
afd5e03
refactor(Control): control enhancement
scottsut Aug 28, 2020
71e73e1
fix(Control): condition cann't be related with control itself
scottsut Sep 2, 2020
e34f337
fix(Control): options shouldn't be loaded automatically when only rel…
scottsut Sep 2, 2020
e820ece
Merge pull request #1920 from scottsut/refactor_control
scottsut Sep 2, 2020
ad0db91
refactor(Schedule): allow user to add cron expression manually
scottsut Sep 3, 2020
0ad0510
Merge pull request #1922 from scottsut/schedule_enhancement
scottsut Sep 3, 2020
53941b3
fix(share) rename some types
ruanhan Sep 3, 2020
68554cd
fix(share) resolve conflict
ruanhan Sep 3, 2020
ab56cab
Merge pull request #1924 from ruanhan/noneLogin_0824
scottsut Sep 3, 2020
d565150
fix(Widget): remove 600 data limit
scottsut Sep 4, 2020
8417e2b
feat:(table) added source table encryption function
chenweizhaoup Sep 4, 2020
10061c8
feat:(table) added source table encryption function
chenweizhaoup Sep 4, 2020
8d057fc
https://github.com/edp963/davinci/issues/1929 1. fix it
xxxllluuu Sep 4, 2020
4c54a96
fix(share) fix some build warning
ruanhan Sep 4, 2020
681b71e
Merge pull request #1930 from ruanhan/noneLogin_0824
scottsut Sep 4, 2020
e83b5c0
https://github.com/edp963/davinci/issues/1929 1. fix it
xxxllluuu Sep 4, 2020
5515c1b
Merge pull request #1931 from xxxllluuu/dev-0.3
scottsut Sep 4, 2020
6dac41b
Merge pull request #34 from edp963/dev-0.3
xxxllluuu Sep 4, 2020
24ac5ee
Merge pull request #1927 from scottsut/fix_limit
scottsut Sep 7, 2020
dc7f39f
Merge pull request #1916 from chenweizhaoup/feature-passwordEnhancement
xxxllluuu Sep 8, 2020
91717cc
fix(type) fix some ts type errors
ruanhan Sep 8, 2020
9f8a16c
Merge pull request #1936 from ruanhan/type_fixs
scottsut Sep 9, 2020
f728c00
fix:pro fix pro history sort error
ruanhan Sep 10, 2020
b415ec5
Merge pull request #1940 from ruanhan/fix_pro_sort
scottsut Sep 10, 2020
5ab3204
feat:(table) optimize source table encryption function
chenweizhaoup Sep 10, 2020
a6ac047
Merge pull request #35 from edp963/dev-0.3
xxxllluuu Sep 10, 2020
623276b
feat: add label richText and fix display copy,delete,cut command, cli…
old-zsh Aug 25, 2020
654c616
Merge pull request #1941 from chenweizhaoup/feature-passwordEnhancement
xxxllluuu Sep 14, 2020
4048237
Merge pull request #36 from edp963/dev-0.3
xxxllluuu Sep 14, 2020
d8ea2bb
https://github.com/edp963/davinci/issues/1946 1. fix it
xxxllluuu Sep 14, 2020
b344c3f
Merge remote-tracking branch 'origin/dev-0.3' into dev-0.3
xxxllluuu Sep 14, 2020
b329eb2
Merge pull request #1947 from xxxllluuu/dev-0.3
scottsut Sep 14, 2020
4fe45f8
fix: display layer add init focus, label input sending request optimi…
old-zsh Sep 14, 2020
5642fe3
fix: Remove package-lock.json
scottsut Sep 15, 2020
3cf2f47
Merge pull request #1948 from scottsut/test
scottsut Sep 15, 2020
4680dec
fix(type-error) fix some ts types error
ruanhan Sep 16, 2020
1f47a5b
Merge pull request #1950 from ruanhan/types_optimize
scottsut Sep 16, 2020
b8cea8b
fix: Add skipLibCheck ts config
scottsut Sep 15, 2020
53bb542
fix: Remove moment explicit dependency
scottsut Sep 15, 2020
b95808e
chore: Preparing for testing
scottsut Sep 16, 2020
92630a0
chore: Remove useless files
scottsut Sep 16, 2020
a11e524
fix: import syntax
scottsut Sep 16, 2020
a83bc39
fix: Type errors
scottsut Sep 16, 2020
64d5212
test: Test directory and code initialization
scottsut Sep 17, 2020
de7ccc4
Merge pull request #1944 from old-zsh/feat_label_editor_copy_commit_m…
scottsut Sep 17, 2020
55df7f4
Merge pull request #1951 from scottsut/test
scottsut Sep 18, 2020
8f8948a
https://github.com/edp963/davinci/issues/1954 1. fix it
xxxllluuu Sep 22, 2020
91d7c98
Merge pull request #37 from edp963/dev-0.3
xxxllluuu Sep 22, 2020
c6fcae5
Merge remote-tracking branch 'origin/dev-0.3' into dev-0.3
xxxllluuu Sep 22, 2020
a651d5d
Merge pull request #1955 from xxxllluuu/dev-0.3
scottsut Sep 22, 2020
9cb7a07
fix(share) : add password when submit widget task
ruanhan Sep 23, 2020
5fa3825
Merge pull request #1956 from ruanhan/fix_download_share
scottsut Sep 23, 2020
f347a97
https://github.com/edp963/davinci/issues/1965 1. fix it
xxxllluuu Sep 29, 2020
62c6de3
Merge pull request #38 from edp963/dev-0.3
xxxllluuu Sep 29, 2020
65c2600
Merge remote-tracking branch 'origin/dev-0.3' into dev-0.3
xxxllluuu Sep 29, 2020
734dd14
https://github.com/edp963/davinci/issues/1929 1. fix it
xxxllluuu Sep 29, 2020
cf995ba
Merge pull request #1966 from xxxllluuu/dev-0.3
scottsut Sep 30, 2020
4c9c7ea
feat:(test) init schdule organization projects profile
ruanhan Oct 19, 2020
178c4fb
fix(test) getOrganization sagas organizationDetailLoaded
ruanhan Oct 19, 2020
10d1e65
fix(test): fix schedule saga.test
ruanhan Oct 19, 2020
c1531bc
fix:(test) update jest.config.js
ruanhan Oct 19, 2020
9ce87ae
feat: add display unit test
old-zsh Oct 10, 2020
3810966
fix(test) fix schedule some tests in actions and reducers
ruanhan Oct 19, 2020
c46a798
fix:(test) fix shedule sagas
ruanhan Oct 20, 2020
716a030
Merge pull request #1974 from old-zsh/feat_display_test
scottsut Oct 20, 2020
d9c095c
Merge branch 'dev-0.3' into test_init
scottsut Oct 20, 2020
59a458f
Merge pull request #39 from edp963/dev-0.3
xxxllluuu Oct 20, 2020
d298f02
refactor(Widget): Change the logic of auto merge cells to group merge…
scottsut Oct 20, 2020
240fdff
Merge pull request #1977 from scottsut/table_merge_cell_ehc
ruanhan Oct 21, 2020
8362ecd
fix: display preview bug
old-zsh Oct 22, 2020
c084f40
Merge pull request #1978 from old-zsh/fix_display_preview_bug
scottsut Oct 23, 2020
298708a
chore: Remove globalConfig
scottsut Oct 22, 2020
f02cb52
refactor(control&share): support control manual option type cascading…
scottsut Oct 27, 2020
4d541d9
fix(control): cascading filters logic
scottsut Oct 27, 2020
622d156
Merge pull request #1975 from ruanhan/test_init
scottsut Oct 27, 2020
ac1e788
Merge pull request #1984 from scottsut/control_ehc
ruanhan Oct 27, 2020
cfb4c34
fix: type errors
scottsut Oct 27, 2020
773f165
fix: test case errors
scottsut Oct 27, 2020
1d84921
fix: TSLint rules compatible with prettier
scottsut Oct 27, 2020
95b3129
refactor: use getServerConfiguration instead of getVersion
scottsut Oct 27, 2020
e9bc889
refactor(oauth2): remove external log out action
scottsut Oct 28, 2020
6f19787
fix(Display): remove willChange property due to blur
scottsut Oct 28, 2020
82dc588
Merge pull request #1986 from scottsut/configuration
ruanhan Oct 28, 2020
9e8800c
Merge pull request #1987 from scottsut/css_transform
ruanhan Oct 28, 2020
6e31d92
fix(drill) #1971
ruanhan Oct 28, 2020
2105e6a
Merge pull request #1988 from ruanhan/dev-0.3
scottsut Oct 28, 2020
7310be2
feat(drill) support drill need not filters
ruanhan Oct 28, 2020
f53db01
Merge pull request #40 from edp963/dev-0.3
xxxllluuu Oct 28, 2020
4272405
https://github.com/edp963/davinci/issues/1965 https://github.com/edp9…
xxxllluuu Oct 28, 2020
d0a080b
Merge pull request #1992 from xxxllluuu/dev-0.3
scottsut Oct 28, 2020
06abc4b
fix(Control): Bugs caused by missing related variables
scottsut Oct 29, 2020
3bcece3
Merge pull request #1991 from ruanhan/dev-0.3
scottsut Oct 29, 2020
d3b660e
fix: moment locale issue
scottsut Oct 29, 2020
95ee2d1
Merge pull request #1993 from scottsut/controls
ruanhan Oct 29, 2020
567412d
Merge pull request #1994 from scottsut/moment_locale
ruanhan Oct 29, 2020
a2aba67
fix(davinci-ui) remove folder
ruanhan Oct 29, 2020
1e8bc49
Merge pull request #41 from edp963/dev-0.3
xxxllluuu Oct 29, 2020
7891637
提交005_rc.sql
xxxllluuu Oct 29, 2020
12d65c3
Merge pull request #1995 from ruanhan/dev-0.3
scottsut Oct 29, 2020
af07afa
Chore(doc): Update docs
scottsut Oct 29, 2020
93eaabb
Merge pull request #1996 from scottsut/docs
ruanhan Oct 29, 2020
ade7181
Merge pull request #42 from edp963/dev-0.3
xxxllluuu Oct 29, 2020
80bb036
Merge remote-tracking branch 'origin/dev-0.3' into dev-0.3
xxxllluuu Oct 29, 2020
c3518da
Merge branch 'dev-0.3'
xxxllluuu Oct 29, 2020
85ab9c0
0.3.0-rc release
xxxllluuu Oct 29, 2020
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
refactor: Add Aspect AOP for davinci share module
1. adapt pre-version share token
2. check token and data permission
  • Loading branch information
RichardShan committed Aug 6, 2020
commit 220a240f784f9036e84aa661ab779cc255b0cda4
2 changes: 1 addition & 1 deletion server/pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -424,7 +424,7 @@
<scope>runtime</scope>
</dependency>

<!--oracle -->
<!--oracle -->
<!--<dependency> -->
<!--<groupId>com.oracle</groupId> -->
<!--<artifactId>ojdbc6</artifactId> -->
Expand Down
6 changes: 6 additions & 0 deletions server/src/main/java/edp/core/annotation/AuthShare.java
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,9 @@

package edp.core.annotation;

import edp.davinci.service.share.ShareOperation;
import edp.davinci.service.share.ShareType;

import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
Expand All @@ -31,4 +34,7 @@
@Target({ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
public @interface AuthShare {
ShareType type();

ShareOperation operation() default ShareOperation.READ;
}
74 changes: 38 additions & 36 deletions server/src/main/java/edp/davinci/controller/DownloadController.java
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@
import edp.core.utils.FileUtils;
import edp.davinci.common.controller.BaseController;
import edp.davinci.core.common.Constants;
import edp.davinci.core.common.ErrorMsg;
import edp.davinci.core.common.ResultMap;
import edp.davinci.core.enums.DownloadType;
import edp.davinci.core.enums.FileTypeEnum;
Expand All @@ -35,6 +36,8 @@
import edp.davinci.model.User;
import edp.davinci.service.DownloadService;
import edp.davinci.service.ShareDownloadService;
import edp.davinci.service.share.ShareOperation;
import edp.davinci.service.share.ShareType;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import io.swagger.annotations.ApiResponse;
Expand Down Expand Up @@ -124,61 +127,38 @@ public ResponseEntity submitDownloadTask(@PathVariable String type,


@ApiOperation(value = "submit share download")
@PostMapping(value = "/share/submit/{type}/{uuid}/{dataToken:.*}", produces = MediaType.APPLICATION_JSON_UTF8_VALUE)
@AuthShare
public ResponseEntity submitShareDownloadTask(@PathVariable(name = "type") String type,
@PostMapping(value = "/share/submit/{type}/{uuid}/{token:.*}", produces = MediaType.APPLICATION_JSON_UTF8_VALUE)
@AuthShare(type = ShareType.DATA, operation = ShareOperation.DOWNLOAD)
public ResponseEntity submitShareDownloadTask(@PathVariable(name = "token") String token,
@RequestParam(required = false) String password,
@PathVariable(name = "uuid") String uuid,
@PathVariable(name = "dataToken") String dataToken,
@PathVariable(name = "type") String type,
@Valid @RequestBody(required = false) DownloadViewExecuteParam[] params,
@ApiIgnore @CurrentUser User user,
HttpServletRequest request) {


if (StringUtils.isEmpty(dataToken)) {
ResultMap resultMap = new ResultMap().fail().message("Invalid share token");
if (StringUtils.isEmpty(token)) {
ResultMap resultMap = new ResultMap().fail().message(ErrorMsg.ERR_INVALID_TOKEN);
return ResponseEntity.status(resultMap.getCode()).body(resultMap);
}

List<DownloadViewExecuteParam> downloadViewExecuteParams = Arrays.asList(params);
boolean rst = shareDownloadService.submit(DownloadType.getDownloadType(type), uuid, dataToken, user, downloadViewExecuteParams);
boolean rst = shareDownloadService.submit(DownloadType.getDownloadType(type), uuid, token, user, downloadViewExecuteParams);

return ResponseEntity.ok(rst ? new ResultMap().success() : new ResultMap().fail());
}


@ApiOperation(value = "get share download record page")
@GetMapping(value = "/share/page/{uuid}/{token:.*}", produces = MediaType.APPLICATION_JSON_UTF8_VALUE)
@AuthShare
public ResponseEntity getShareDownloadRecordPage(@PathVariable(name = "uuid") String uuid,
@PathVariable(name = "token") String token,
@ApiIgnore @CurrentUser User user,
HttpServletRequest request) {
if (StringUtils.isEmpty(token)) {
ResultMap resultMap = new ResultMap().fail().message("Invalid share token");
return ResponseEntity.status(resultMap.getCode()).body(resultMap);
}

List<ShareDownloadRecord> records = shareDownloadService.queryDownloadRecordPage(uuid, token, user);

if (null == user) {
return ResponseEntity.ok(new ResultMap(tokenUtils).payloads(records));
} else {
return ResponseEntity.ok(new ResultMap(tokenUtils).successAndRefreshToken(request).payloads(records));
}
}


@ApiOperation(value = "get download record file")
@GetMapping(value = "/share/record/file/{id}/{uuid}/{token:.*}", produces = MediaType.APPLICATION_OCTET_STREAM_VALUE)
@AuthShare
public ResponseEntity getShareDownloadRecordFile(@PathVariable(name = "id") String id,
@AuthShare(type = ShareType.FILE, operation = ShareOperation.DOWNLOAD)
public ResponseEntity getShareDownloadRecordFile(@PathVariable(name = "token") String token,
@RequestParam(required = false) String password,
@PathVariable(name = "uuid") String uuid,
@PathVariable(name = "token") String token,
@PathVariable(name = "id") String id,
@ApiIgnore @CurrentUser User user,
HttpServletRequest request,
HttpServletResponse response) {
if (StringUtils.isEmpty(token)) {
ResultMap resultMap = new ResultMap().fail().message("Invalid share token");
ResultMap resultMap = new ResultMap().fail().message(ErrorMsg.ERR_INVALID_TOKEN);
return ResponseEntity.status(resultMap.getCode()).body(resultMap);
}

Expand All @@ -196,6 +176,28 @@ public ResponseEntity getShareDownloadRecordFile(@PathVariable(name = "id") Stri
return null;
}

@ApiOperation(value = "get share download record page")
@GetMapping(value = "/share/page/{uuid}/{token:.*}", produces = MediaType.APPLICATION_JSON_UTF8_VALUE)
@AuthShare(type = ShareType.RECORD, operation = ShareOperation.DOWNLOAD)
public ResponseEntity getShareDownloadRecordPage(@PathVariable(name = "token") String token,
@RequestParam(required = false) String password,
@PathVariable(name = "uuid") String uuid,
@ApiIgnore @CurrentUser User user,
HttpServletRequest request) {
if (StringUtils.isEmpty(token)) {
ResultMap resultMap = new ResultMap().fail().message(ErrorMsg.ERR_INVALID_TOKEN);
return ResponseEntity.status(resultMap.getCode()).body(resultMap);
}

List<ShareDownloadRecord> records = shareDownloadService.queryDownloadRecordPage(uuid, token, user);

if (null == user) {
return ResponseEntity.ok(new ResultMap(tokenUtils).payloads(records));
} else {
return ResponseEntity.ok(new ResultMap(tokenUtils).successAndRefreshToken(request).payloads(records));
}
}


private void encodeFileName(HttpServletRequest request, HttpServletResponse response, String filename) throws UnsupportedEncodingException {
response.setHeader("Content-Type", "application/force-download");
Expand Down
63 changes: 21 additions & 42 deletions server/src/main/java/edp/davinci/controller/ShareController.java
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@
import edp.core.model.Paginate;
import edp.davinci.common.controller.BaseController;
import edp.davinci.core.common.Constants;
import edp.davinci.core.common.ErrorMsg;
import edp.davinci.core.common.ResultMap;
import edp.davinci.dto.shareDto.ShareDashboard;
import edp.davinci.dto.shareDto.ShareDisplay;
Expand All @@ -37,6 +38,8 @@
import edp.davinci.dto.viewDto.ViewExecuteParam;
import edp.davinci.model.User;
import edp.davinci.service.ShareService;
import edp.davinci.service.share.ShareOperation;
import edp.davinci.service.share.ShareType;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import io.swagger.annotations.ApiResponse;
Expand Down Expand Up @@ -105,13 +108,14 @@ public ResponseEntity shareLogin(@PathVariable String token,
* @return
*/
@ApiOperation(value = "get share dashboard")
@AuthShare
@AuthShare(type = ShareType.DASHBOARD, operation = ShareOperation.READ)
@GetMapping("/dashboard/{token}")
public ResponseEntity getShareDashboard(@PathVariable String token,
@RequestParam(required = false) String password,
@ApiIgnore @CurrentUser User user,
HttpServletRequest request) {
if (StringUtils.isEmpty(token)) {
ResultMap resultMap = new ResultMap().fail().message("Invalid share token");
ResultMap resultMap = new ResultMap().fail().message(ErrorMsg.ERR_INVALID_TOKEN);
return ResponseEntity.status(resultMap.getCode()).body(resultMap);
}

Expand All @@ -133,13 +137,14 @@ public ResponseEntity getShareDashboard(@PathVariable String token,
* @return
*/
@ApiOperation(value = "get share display")
@AuthShare
@AuthShare(type = ShareType.DISPLAY, operation = ShareOperation.READ)
@GetMapping("/display/{token}")
public ResponseEntity getShareDisplay(@PathVariable String token,
@RequestParam(required = false) String password,
@ApiIgnore @CurrentUser User user,
HttpServletRequest request) {
if (StringUtils.isEmpty(token)) {
ResultMap resultMap = new ResultMap().fail().message("Invalid share token");
ResultMap resultMap = new ResultMap().fail().message(ErrorMsg.ERR_INVALID_TOKEN);
return ResponseEntity.status(resultMap.getCode()).body(resultMap);
}

Expand All @@ -161,13 +166,14 @@ public ResponseEntity getShareDisplay(@PathVariable String token,
* @return
*/
@ApiOperation(value = "get share widget")
@AuthShare
@AuthShare(type = ShareType.WIDGET, operation = ShareOperation.READ)
@GetMapping("/widget/{token}")
public ResponseEntity getShareWidget(@PathVariable String token,
@RequestParam(required = false) String password,
@ApiIgnore @CurrentUser User user,
HttpServletRequest request) {
if (StringUtils.isEmpty(token)) {
ResultMap resultMap = new ResultMap().fail().message("Invalid share token");
ResultMap resultMap = new ResultMap().fail().message(ErrorMsg.ERR_INVALID_TOKEN);
return ResponseEntity.status(resultMap.getCode()).body(resultMap);
}

Expand All @@ -190,15 +196,16 @@ public ResponseEntity getShareWidget(@PathVariable String token,
* @return
*/
@ApiOperation(value = "get share data")
@AuthShare
@AuthShare(type = ShareType.DATA, operation = ShareOperation.LOAD_DATA)
@PostMapping(value = "/data/{token}", consumes = MediaType.APPLICATION_JSON_VALUE)
public ResponseEntity getShareData(@PathVariable String token,
@RequestParam(required = false) String password,
@RequestBody(required = false) ViewExecuteParam executeParam,
@ApiIgnore @CurrentUser User user,
HttpServletRequest request) throws SQLException {

if (StringUtils.isEmpty(token)) {
ResultMap resultMap = new ResultMap().fail().message("Invalid share token");
ResultMap resultMap = new ResultMap().fail().message(ErrorMsg.ERR_INVALID_TOKEN);
return ResponseEntity.status(resultMap.getCode()).body(resultMap);
}

Expand All @@ -223,17 +230,18 @@ public ResponseEntity getShareData(@PathVariable String token,
* @return
*/
@ApiOperation(value = "get share data")
@AuthShare
@AuthShare(type = ShareType.DATA, operation = ShareOperation.LOAD_DATA)
@PostMapping(value = "/data/{token}/distinctvalue/{viewId}", consumes = MediaType.APPLICATION_JSON_VALUE)
public ResponseEntity getDistinctValue(@PathVariable("token") String token,
@RequestParam(required = false) String password,
@PathVariable("viewId") Long viewId,
@Valid @RequestBody DistinctParam param,
@ApiIgnore BindingResult bindingResult,
@ApiIgnore @CurrentUser User user,
HttpServletRequest request) {

if (StringUtils.isEmpty(token)) {
ResultMap resultMap = new ResultMap().fail().message("Invalid share token");
ResultMap resultMap = new ResultMap().fail().message(ErrorMsg.ERR_INVALID_TOKEN);
return ResponseEntity.status(resultMap.getCode()).body(resultMap);
}

Expand All @@ -248,43 +256,14 @@ public ResponseEntity getDistinctValue(@PathVariable("token") String token,
}

try {
ResultMap resultMap = shareService.getDistinctValue(token, viewId, param, user, request);
//TODO
// shareService.getDistinctValue(token, viewId, param, user, request);
ResultMap resultMap = null;
return ResponseEntity.status(resultMap.getCode()).body(resultMap);
} catch (Exception e) {
e.printStackTrace();
log.error(e.getMessage());
return ResponseEntity.status(HttpCodeEnum.SERVER_ERROR.getCode()).body(HttpCodeEnum.SERVER_ERROR.getMessage());
}
}


/**
* share页获取csv信息
*
* @param token
* @param executeParam
* @param user
* @param request
* @return
*/
@ApiOperation(value = "get share data csv")
@AuthShare
@PostMapping(value = "/csv/{token}", consumes = MediaType.APPLICATION_JSON_VALUE)
public ResponseEntity generationShareDataCsv(@PathVariable String token,
@RequestBody(required = false) ViewExecuteParam executeParam,
@ApiIgnore @CurrentUser User user,
HttpServletRequest request) {

if (StringUtils.isEmpty(token)) {
ResultMap resultMap = new ResultMap().fail().message("Invalid share token");
return ResponseEntity.status(resultMap.getCode()).body(resultMap);
}

String filePath = shareService.generationShareDataCsv(executeParam, user, token);
if (null == user) {
return ResponseEntity.ok(new ResultMap().success().payload(filePath));
} else {
return ResponseEntity.ok(new ResultMap(tokenUtils).successAndRefreshToken(request).payload(filePath));
}
}
}
4 changes: 4 additions & 0 deletions server/src/main/java/edp/davinci/dao/RelRoleUserMapper.java
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@
import org.apache.ibatis.annotations.Select;

import java.util.List;
import java.util.Set;

public interface RelRoleUserMapper {
int insert(RelRoleUser relRoleUser);
Expand Down Expand Up @@ -56,6 +57,9 @@ public interface RelRoleUserMapper {
List<RelRoleUser> getByIds(List<Long> ids);


Set<RelRoleUser> selectByUserAndRoles(@Param("userId") Long userId, @Param("roleIds") Set<Long> roleIds);


@Select({
"SELECT rru.id, u.id as 'user.id', IFNULL(u.`name`, u.username) as 'user.username', u.avatar",
"FROM rel_role_user rru LEFT JOIN `user` u on u.id = rru.user_id",
Expand Down
23 changes: 4 additions & 19 deletions server/src/main/java/edp/davinci/dto/shareDto/ShareEntity.java
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,6 @@
package edp.davinci.dto.shareDto;

import edp.core.utils.CollectionUtils;
import edp.davinci.core.common.Constants;
import edp.davinci.service.share.ShareDataPermission;
import edp.davinci.service.share.ShareMode;
import lombok.Data;
Expand Down Expand Up @@ -54,14 +53,7 @@ public class ShareEntity {
* <p>
* for mode == 3
*/
private Set<Long> viewerIds;

/**
* viewer email
* <p>
* for mode == 3
*/
private Set<String> viewerEmails;
private Set<Long> viewers;

/**
* role id
Expand All @@ -83,23 +75,16 @@ public void valid() throws IllegalArgumentException {
}
break;
case AUTH:
if (CollectionUtils.isEmpty(this.viewerEmails) && CollectionUtils.isEmpty(this.roles) && CollectionUtils.isEmpty(viewerEmails)) {
if (CollectionUtils.isEmpty(this.viewers) && CollectionUtils.isEmpty(this.roles)) {
throw new IllegalArgumentException("Invalid shared user in AUTH share mode");
}
if (!CollectionUtils.isEmpty(viewerIds)) {
viewerIds.forEach(id -> {
if (!CollectionUtils.isEmpty(viewers)) {
viewers.forEach(id -> {
if (id < 1L) {
throw new IllegalArgumentException("Invalid viewer: " + id);
}
});
}
if (!CollectionUtils.isEmpty(viewerEmails)) {
viewerEmails.forEach(email -> {
if (!Constants.PATTERN_EMAIL_FORMAT.matcher(email).find()) {
throw new IllegalArgumentException("Invalid email: " + email);
}
});
}
if (!CollectionUtils.isEmpty(roles)) {
roles.forEach(id -> {
if (id < 1L) {
Expand Down
Loading