mirror of
				https://github.com/IntellectualSites/PlotSquared.git
				synced 2025-10-25 23:53:44 +02:00 
			
		
		
		
	Compare commits
	
		
			509 Commits
		
	
	
		
			refactor/v
			...
			reenable-c
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | ff89c614dd | ||
|   | fad038ef78 | ||
|   | 84b1af8856 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 13c5a67cb1 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 8ae894d51d | ||
|   | bbb3736846 | ||
|   | 1ebcbf60a6 | ||
|   | 494144dc4f | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 895cf0da66 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 05811d80ce | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 4de9967ef4 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 034bd866eb | ||
|   | 98aab56616 | ||
|   | 8f980c726b | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 7f59c03f06 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 480a5925b6 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | cee4493723 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | b8ac1a22c1 | ||
|   | 67e69e3fc1 | ||
|   | 670f5a802e | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | c4bd6b6500 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 161e3ffdc7 | ||
|   | be8f07c556 | ||
|   | 215053e364 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 4839a83279 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 0649ef33f0 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 1590a4b6eb | ||
|   | c793b4454a | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 7ab1a3eafb | ||
|   | c65c9e7827 | ||
|   | f88ea94bfe | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | c8e8eb919f | ||
|   | 83fe761fe4 | ||
|   | a7447c9d75 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 5867cc51a7 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 86e21f3e1a | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | d7d884ad6d | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 1c45e01a14 | ||
|   | 6ef1163325 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | c57d784df7 | ||
|   | c239908aa3 | ||
|   | a6412581a6 | ||
|   | f20c5f46e3 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 4db5954490 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 9f68654614 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 2e4c6199e5 | ||
|   | 7edca600fd | ||
|   | bc1cc074b8 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | d383187c6e | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 125a3f6772 | ||
|   | faca8c2da0 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 0ad5ef4f94 | ||
|   | 5e8d8629c2 | ||
|   | 9f4f213a8c | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | ce14036949 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 2dbb6ee025 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 0da1d9f17a | ||
|   | f1f41b0523 | ||
|   | fe324d3ea9 | ||
|   | ff83868cbc | ||
|   | 111ea7029e | ||
|   | 9be2eedf7f | ||
|   | 82f868ae7d | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | e46dbd826c | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 809ddce2b3 | ||
|   | 1b40cea51f | ||
|   | 022e0fc224 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | b32137a650 | ||
|   | 17c41c0494 | ||
|   | 1ee76bf2d9 | ||
|   | 2321831044 | ||
|   | 25e98618b9 | ||
|   | 5344efd1b7 | ||
|   | 68701b6201 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 64c610ef37 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 931bb90600 | ||
|   | 1dfa3b4e66 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 8f236a56a6 | ||
|   | e51121960d | ||
|   | cc011de032 | ||
|   | 28298ffdd6 | ||
|   | 499d3c39bc | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 3d56937f14 | ||
|   | 0f1c2cb4e4 | ||
|   | 7b233c944a | ||
|   | d9537ee9df | ||
|   | 0de6887526 | ||
|   | a2e3274215 | ||
|   | b369683b9c | ||
|   | 7f1f1e025e | ||
|   | 59787fe7f3 | ||
|   | 6783d5ece6 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | d9aa2a496c | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 809ed6778c | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 2fe44053a2 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | c36b87ca14 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 5aec7653b6 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | cc5d01e225 | ||
|   | 448577774a | ||
|   | 966c878a72 | ||
|   | 5021f5b379 | ||
|   | 76ea9e0d3c | ||
|   | 951f08bc8b | ||
|   | ae941e67a4 | ||
|   | 9566af5fda | ||
|   | fccc146053 | ||
|   | a1d94af242 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 6371cd4c5a | ||
|   | e4613cfc62 | ||
|   | 8c44b2d2d2 | ||
|   | 449af2f3a4 | ||
|   | ead7acdd76 | ||
|   | 1991142d48 | ||
|   | 63ae11b3d3 | ||
|   | 86fe3c6846 | ||
|   | a90e179338 | ||
|   | a6ae287908 | ||
|   | 1a33997099 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 6edd4b8220 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 9b0d1e484c | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 6971fa4c10 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 3c818f3e33 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 31be2e5eb3 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 945a8ad306 | ||
|   | c6b0b99cd6 | ||
|   | dbfc43e3cd | ||
|   | c8b4a2fa39 | ||
|   | d851e27aed | ||
|   | 4a45729c9e | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 7931c0864e | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 1456b29d93 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 761477b76d | ||
|   | e61bcf905f | ||
|   | 85bec710df | ||
|   | d130794453 | ||
|   | f5f875eb11 | ||
|   | 89511f07f9 | ||
|   | 1a18adcd95 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 65858c5f3e | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 5c7520b5f5 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | f3b9cd5ded | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 8a3eb25805 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 48bbd3c018 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | bf85013f70 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | d36a2d236b | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 79f111ec0a | ||
|   | 31ae62b62c | ||
|   | cdb44d4884 | ||
|   | eb63e4351d | ||
|   | ba7880241b | ||
|   | be6838f29e | ||
|   | dc73116401 | ||
|   | b6a87df072 | ||
|   | 8195afaa2f | ||
|   | 561eac2fbd | ||
|   | fdc887850c | ||
|   | e3bfd9b8bf | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | e689337188 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | ee6ae6cba0 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | dc8d7809bd | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | dcd63ed4d9 | ||
|   | 3cc770970f | ||
|   | 1c3776b605 | ||
|   | 95c7f621fb | ||
|   | 15b4cbdb0f | ||
|   | 812eac18d3 | ||
|   | 16a4ee835c | ||
|   | c013b92e62 | ||
|   | b00a46b286 | ||
|   | 44b1127181 | ||
|   | c7bfd48a21 | ||
|   | dc13783db8 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 0a390ab342 | ||
|   | d111740f64 | ||
|   | 28e97e8441 | ||
|   | a30cdb37d6 | ||
|   | f848162066 | ||
|   | 40c70aa98d | ||
|   | 0d2b36bac8 | ||
|   | d7e5bcdaa5 | ||
|   | fc783574a3 | ||
|   | 5f7bb784f0 | ||
|   | 26c55a318f | ||
|   | ee68bc3d9e | ||
|   | a3bc3968a5 | ||
|   | 79454da1a6 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 12a4c92ad9 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 167692d464 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | ae26e8155c | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 286ea62a21 | ||
|   | d95c74d8c9 | ||
|   | c1555ddbc7 | ||
|   | 4fe0c586d9 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | aae6ea4fee | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 385d018504 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | f4def082c1 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 69c9f1df83 | ||
|   | e138dc0267 | ||
|   | ca50b53f94 | ||
|   | f705487055 | ||
|   | b7c9453a1a | ||
|   | 1aa370d562 | ||
|   | d3dab0d736 | ||
|   | 764156b267 | ||
|   | 665f5251bf | ||
|   | 7c328095d7 | ||
|   | 7884c91d52 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | e9a19e0821 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 022847fc4b | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 1ee673be58 | ||
|   | 3c2aa99e86 | ||
|   | 11fac3f060 | ||
|   | 3e57e524b9 | ||
|   | f582ec03c5 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 893be136f0 | ||
|   | b74ba30281 | ||
|   | ba9dab1f73 | ||
|   | 8e60fdb477 | ||
|   | 443fe8dd47 | ||
|   | e56e52ba4f | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | cd008bed9b | ||
|   | d4c90283d6 | ||
|   | dc04ec955a | ||
|   | 72f511ce99 | ||
|   | 0d63c2bdb6 | ||
|   | 49e13384cf | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 1ddc19ff69 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | a6d436e841 | ||
|   | 9b0b39ac2e | ||
|   | 638f0bd078 | ||
|   | c27b838dad | ||
|   | e0cb2949df | ||
|   | 59be582c28 | ||
|   | f6cbb3792f | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | a68918f830 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 1a7ded864e | ||
|   | cbc8bc8879 | ||
|   | 21f79d1c13 | ||
|   | 293d7acf2d | ||
|   | d876d3722a | ||
|   | dffb7672ff | ||
|   | f867867a42 | ||
|   | 59eefd6865 | ||
|   | 587a286d05 | ||
|   | e10caf6aa0 | ||
|   | 08b325e37d | ||
|   | c394108ba6 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 31e89019f1 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 3a7075e28d | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 8373b7874e | ||
|   | fe13882b97 | ||
|   | f45064c4c4 | ||
|   | af32399dd2 | ||
|   | f3c03348d9 | ||
|   | a53330e39b | ||
|   | e2ba93dab9 | ||
|   | 9d43434e40 | ||
|   | 4f421167d1 | ||
|   | 94f4619c2c | ||
|   | 9885d3e506 | ||
|   | a54276d3b2 | ||
|   | cbb284b0fd | ||
|   | ed22b22e9c | ||
|   | 444ccda807 | ||
|   | db361cc420 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 079dc02cfe | ||
|   | e98791c865 | ||
|   | 7c3112f30f | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | c01f5f5c7d | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 95caa19505 | ||
|   | b8055201df | ||
|   | 81daefae4a | ||
|   | 02437a8c72 | ||
|   | 958c66b28f | ||
|   | c656190e14 | ||
|   | e914cb210e | ||
|   | 94c6af74d2 | ||
|   | ebb82bd66d | ||
|   | 66f907eb5d | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 9ffede2c5c | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 97172df0dc | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | c9746b182c | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 10a2b80ffc | ||
|   | ca0f38255d | ||
|   | 0484ac73af | ||
|   | 1a712ad3c1 | ||
|   | 2d1f483469 | ||
|   | 91830e233b | ||
|   | 561edb83bf | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 0e09cf223a | ||
|   | d78360d6eb | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 1464804c11 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 8629eae5fc | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 7b8ba7c3ac | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 77c7466c17 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 82fe76fd37 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 3f81ea4ef8 | ||
|   | 745b06a008 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 77b2bd166a | ||
|   | 8e02336c44 | ||
|   | 3adfbde45a | ||
|   | e6db8e2750 | ||
|   | 9cd0ee9b49 | ||
|   | d455d1fcd7 | ||
|   | ea19ff783f | ||
|   | 447e4c7d58 | ||
|   | 89031447f2 | ||
|   | 4210a3a555 | ||
|   | 42e146b8c7 | ||
|   | a5fdcda673 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 52823f5024 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 1326c257a0 | ||
|   | fc3137cd96 | ||
|   | a5c53a96d1 | ||
|   | c46cc73f52 | ||
|   | 276e619caa | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | f11acacedd | ||
|   | f636a5ec63 | ||
|   | d1bac90745 | ||
|   | 785362c576 | ||
|   | e98f628d34 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | b2ab61559c | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | dd6eb8e74f | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 97cdd03ea4 | ||
|   | f5118e6802 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 94ca5cf679 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 5a55a1f602 | ||
|   | 1e7ba7d173 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | ed33635a15 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 888682e5d0 | ||
|   | 72bb5f00b0 | ||
|   | 773fd6f59f | ||
|   | aa784e98f8 | ||
|   | 5cce86d924 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 84567bcb00 | ||
|   | d7c2ab1d16 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 0d359ade0c | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | ffbec24290 | ||
|   | 586474c8e6 | ||
|   | 70b6636f50 | ||
|   | ab357deb48 | ||
|   | bd62d1a1c7 | ||
|   | 6130c3dfa5 | ||
|   | 26692d6633 | ||
|   | bb0f200429 | ||
|   | 5787588500 | ||
|   | bed62edc02 | ||
|   | ee0f389c78 | ||
|   | b40383b5a4 | ||
|   | be8903128d | ||
|   | 08800ec16d | ||
|   | 83e274ff9f | ||
|   | 0dd8b1053c | ||
|   | 0558fcf5d5 | ||
|   | 5af8be4293 | ||
|   | cbacdd67eb | ||
|   | c45bbe3ec5 | ||
|   | 746028afbc | ||
|   | b79537ebbc | ||
|   | 6efd581500 | ||
|   | 07e598e48f | ||
|   | f6f00dfcda | ||
|   | 63a6bdc1d6 | ||
|   | abbac057ed | ||
|   | c978322036 | ||
|   | 39d2f1a72c | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 86919b8841 | ||
|   | 1448d8d4af | ||
|   | 8d9a387587 | ||
|   | 00722bc463 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 6a34a1996f | ||
|   | 1d201b04ba | ||
|   | e887a59158 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | d1b8f652a7 | ||
|   | 0707aa47c9 | ||
|   | 4aa7bc51bc | ||
|   | 0f0030916f | ||
|   | 8c57d616cf | ||
|   | 66660507e0 | ||
|   | a12490c3eb | ||
|   | bbf1e4fe61 | ||
|   | febac6fa40 | ||
|   | 99ee8a780d | ||
|   | 577a0d8ed9 | ||
|   | 02ae14894a | ||
|   | 36e5f36660 | ||
|   | 78dbe7fbbc | ||
|   | 669293566b | ||
|   | 350eae7813 | ||
|   | 12dc198a86 | ||
|   | fb2533d66a | ||
|   | 707c7be5bd | ||
|   | 37d6dcc7ea | ||
|   | becd8c4eaf | ||
|   | 530fcc0fea | ||
|   | 7135bdd6aa | ||
|   | 3198c3b081 | ||
|   | 339ca8e30f | ||
|   | 742d78a505 | ||
|   | 120bf37196 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 2a40a6b35e | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | ea1f35b45a | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 15e63378a7 | ||
|   | f3bc504a6f | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 3a8fae47a0 | ||
|   | 70cb1cd100 | ||
|   | 2067cc1670 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | e6338976dd | ||
|   | 90ebd5d5ed | ||
|   | c973ee8649 | ||
|   | c1543f034c | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 6baf339ecb | ||
|   | 11906ef1c9 | ||
|   | ee8902154a | ||
|   | b5bc1988e5 | ||
|   | 2147012beb | ||
|   | 52bb561689 | ||
|   | 25ce7a83f1 | ||
|   | 55c8a590e7 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 28bd993680 | ||
|   | 8330f37d8a | ||
|   | 985fae65b6 | ||
|   | db2d590e8e | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | c8d356783a | ||
|   | 4947450ff0 | ||
|   | de4e91ff62 | ||
|   | fe5e3d5f6d | ||
|   | b8b3098022 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 0ae8fc46b8 | ||
|   | e0762f63a8 | ||
|   | 9f3850000c | ||
|   | 76c6be9ba7 | ||
|   | 308a5aa781 | ||
|   | e244527538 | ||
|   | 11dd013333 | ||
|   | b740d5854c | ||
|   | d5445cfbef | ||
|   | 3effaefda7 | ||
|   | 49b19e0eaf | ||
|   | caef3a923b | ||
|   | d4c3ceaf2b | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 25e6aecf13 | ||
|   | 33c11fdee9 | ||
|   | 316dd92667 | ||
|   | e53d2ac449 | ||
|   | 5786e8cc7a | ||
|   | 1b717c9b10 | ||
|   | 35abae99ca | ||
|   | d1a85982fb | ||
|   | 3446b913cd | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 8b8fd6aab7 | ||
|   | 520bb64eca | ||
|   | 60d266b2d7 | ||
|   | 8deeef4f7d | ||
|   | 9b0b071c0c | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 81a3f1098d | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | efc248dcdb | ||
|   | 476f3d328d | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 69f5f88183 | ||
|   | 6df63f7fc7 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 295b8a0135 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | fcc5bc5473 | ||
|   | 408b834376 | ||
|   | 986812b9e4 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 8d4333ad9d | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 9ff9097ff9 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 1ef424a2f1 | ||
|   | 9fd96dbaa2 | ||
|   | b0a4e11c46 | ||
|   | 77bce43ace | ||
|   | cba1927cc7 | ||
|   | 3d19c5c2ad | ||
|   | e0eff15694 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 0bdeeea83b | ||
|   | 7669e79da1 | ||
|   | 6f96daae56 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | d1021d19da | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | ee589ac7f0 | ||
|   | 3b747ffecf | ||
|   | 4e5a2b9f96 | ||
|   | aeb4350ccb | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 9609990832 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 0e4319b757 | ||
|   | c8f4907f77 | ||
|   | dcf98c2298 | ||
|   | ae59c7442f | ||
|   | 98708118d8 | ||
|   | 276d8f8e1e | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 87f89541b5 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 93f6de7029 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 73d2686b17 | ||
|   | c446a95b07 | ||
|   | 3676e1df35 | ||
|   | 12e2705260 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 31e777a03a | ||
|   | 7f436c405b | ||
|   | 4d4d2ab087 | ||
|   | 91017acce4 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | e90fd231d9 | ||
|   | cd9f0789de | ||
|   | 5f4c8d92df | ||
|   | 263cb47a21 | ||
|   | 005600c99e | ||
|   | 26bec7fe2f | ||
|   | f4b886d977 | ||
|   | c09d0d882e | ||
|   | 312cb2996c | ||
|   | f218902581 | ||
|   | f27009216c | 
							
								
								
									
										630
									
								
								.editorconfig
									
									
									
									
									
								
							
							
						
						
									
										630
									
								
								.editorconfig
									
									
									
									
									
								
							| @@ -13,40 +13,6 @@ ij_formatter_tags_enabled = false | |||||||
| ij_smart_tabs = false | ij_smart_tabs = false | ||||||
| ij_wrap_on_typing = true | ij_wrap_on_typing = true | ||||||
|  |  | ||||||
| [*.conf] |  | ||||||
| indent_size = 2 |  | ||||||
| tab_width = 2 |  | ||||||
| ij_continuation_indent_size = 2 |  | ||||||
| ij_hocon_keep_blank_lines_before_right_brace = 2 |  | ||||||
| ij_hocon_keep_indents_on_empty_lines = false |  | ||||||
| ij_hocon_keep_line_breaks = true |  | ||||||
| ij_hocon_space_after_colon = true |  | ||||||
| ij_hocon_space_after_comma = true |  | ||||||
| ij_hocon_space_before_colon = true |  | ||||||
| ij_hocon_space_before_comma = false |  | ||||||
| ij_hocon_spaces_within_braces = false |  | ||||||
| ij_hocon_spaces_within_brackets = false |  | ||||||
| ij_hocon_spaces_within_method_call_parentheses = false |  | ||||||
|  |  | ||||||
| [*.css] |  | ||||||
| ij_css_align_closing_brace_with_properties = false |  | ||||||
| ij_css_blank_lines_around_nested_selector = 1 |  | ||||||
| ij_css_blank_lines_between_blocks = 1 |  | ||||||
| ij_css_brace_placement = end_of_line |  | ||||||
| ij_css_enforce_quotes_on_format = false |  | ||||||
| ij_css_hex_color_long_format = false |  | ||||||
| ij_css_hex_color_lower_case = false |  | ||||||
| ij_css_hex_color_short_format = false |  | ||||||
| ij_css_hex_color_upper_case = false |  | ||||||
| ij_css_keep_blank_lines_in_code = 2 |  | ||||||
| ij_css_keep_indents_on_empty_lines = false |  | ||||||
| ij_css_keep_single_line_blocks = false |  | ||||||
| ij_css_properties_order = font, font-family, font-size, font-weight, font-style, font-variant, font-size-adjust, font-stretch, line-height, position, z-index, top, right, bottom, left, display, visibility, float, clear, overflow, overflow-x, overflow-y, clip, zoom, align-content, align-items, align-self, flex, flex-flow, flex-basis, flex-direction, flex-grow, flex-shrink, flex-wrap, justify-content, order, box-sizing, width, min-width, max-width, height, min-height, max-height, margin, margin-top, margin-right, margin-bottom, margin-left, padding, padding-top, padding-right, padding-bottom, padding-left, table-layout, empty-cells, caption-side, border-spacing, border-collapse, list-style, list-style-position, list-style-type, list-style-image, content, quotes, counter-reset, counter-increment, resize, cursor, user-select, nav-index, nav-up, nav-right, nav-down, nav-left, transition, transition-delay, transition-timing-function, transition-duration, transition-property, transform, transform-origin, animation, animation-name, animation-duration, animation-play-state, animation-timing-function, animation-delay, animation-iteration-count, animation-direction, text-align, text-align-last, vertical-align, white-space, text-decoration, text-emphasis, text-emphasis-color, text-emphasis-style, text-emphasis-position, text-indent, text-justify, letter-spacing, word-spacing, text-outline, text-transform, text-wrap, text-overflow, text-overflow-ellipsis, text-overflow-mode, word-wrap, word-break, tab-size, hyphens, pointer-events, opacity, color, border, border-width, border-style, border-color, border-top, border-top-width, border-top-style, border-top-color, border-right, border-right-width, border-right-style, border-right-color, border-bottom, border-bottom-width, border-bottom-style, border-bottom-color, border-left, border-left-width, border-left-style, border-left-color, border-radius, border-top-left-radius, border-top-right-radius, border-bottom-right-radius, border-bottom-left-radius, border-image, border-image-source, border-image-slice, border-image-width, border-image-outset, border-image-repeat, outline, outline-width, outline-style, outline-color, outline-offset, background, background-color, background-image, background-repeat, background-attachment, background-position, background-position-x, background-position-y, background-clip, background-origin, background-size, box-decoration-break, box-shadow, text-shadow |  | ||||||
| ij_css_space_after_colon = true |  | ||||||
| ij_css_space_before_opening_brace = true |  | ||||||
| ij_css_use_double_quotes = true |  | ||||||
| ij_css_value_alignment = do_not_align |  | ||||||
|  |  | ||||||
| [*.java] | [*.java] | ||||||
| ij_java_align_consecutive_assignments = false | ij_java_align_consecutive_assignments = false | ||||||
| ij_java_align_consecutive_variable_declarations = false | ij_java_align_consecutive_variable_declarations = false | ||||||
| @@ -277,63 +243,12 @@ ij_java_wrap_comments = false | |||||||
| ij_java_wrap_first_method_in_call_chain = true | ij_java_wrap_first_method_in_call_chain = true | ||||||
| ij_java_wrap_long_lines = false | ij_java_wrap_long_lines = false | ||||||
|  |  | ||||||
| [*.nbtt] |  | ||||||
| max_line_length = 150 |  | ||||||
| ij_continuation_indent_size = 4 |  | ||||||
| ij_nbtt_keep_indents_on_empty_lines = false |  | ||||||
| ij_nbtt_space_after_colon = true |  | ||||||
| ij_nbtt_space_after_comma = true |  | ||||||
| ij_nbtt_space_before_colon = true |  | ||||||
| ij_nbtt_space_before_comma = false |  | ||||||
| ij_nbtt_spaces_within_brackets = false |  | ||||||
| ij_nbtt_spaces_within_parentheses = false |  | ||||||
|  |  | ||||||
| [*.properties] | [*.properties] | ||||||
| ij_properties_align_group_field_declarations = false | ij_properties_align_group_field_declarations = false | ||||||
| ij_properties_keep_blank_lines = false | ij_properties_keep_blank_lines = false | ||||||
| ij_properties_key_value_delimiter = equals | ij_properties_key_value_delimiter = equals | ||||||
| ij_properties_spaces_around_key_value_delimiter = false | ij_properties_spaces_around_key_value_delimiter = false | ||||||
|  |  | ||||||
| [*.sass] |  | ||||||
| indent_size = 2 |  | ||||||
| ij_sass_align_closing_brace_with_properties = false |  | ||||||
| ij_sass_blank_lines_around_nested_selector = 1 |  | ||||||
| ij_sass_blank_lines_between_blocks = 1 |  | ||||||
| ij_sass_brace_placement = 0 |  | ||||||
| ij_sass_enforce_quotes_on_format = false |  | ||||||
| ij_sass_hex_color_long_format = false |  | ||||||
| ij_sass_hex_color_lower_case = false |  | ||||||
| ij_sass_hex_color_short_format = false |  | ||||||
| ij_sass_hex_color_upper_case = false |  | ||||||
| ij_sass_keep_blank_lines_in_code = 2 |  | ||||||
| ij_sass_keep_indents_on_empty_lines = false |  | ||||||
| ij_sass_keep_single_line_blocks = false |  | ||||||
| ij_sass_properties_order = font, font-family, font-size, font-weight, font-style, font-variant, font-size-adjust, font-stretch, line-height, position, z-index, top, right, bottom, left, display, visibility, float, clear, overflow, overflow-x, overflow-y, clip, zoom, align-content, align-items, align-self, flex, flex-flow, flex-basis, flex-direction, flex-grow, flex-shrink, flex-wrap, justify-content, order, box-sizing, width, min-width, max-width, height, min-height, max-height, margin, margin-top, margin-right, margin-bottom, margin-left, padding, padding-top, padding-right, padding-bottom, padding-left, table-layout, empty-cells, caption-side, border-spacing, border-collapse, list-style, list-style-position, list-style-type, list-style-image, content, quotes, counter-reset, counter-increment, resize, cursor, user-select, nav-index, nav-up, nav-right, nav-down, nav-left, transition, transition-delay, transition-timing-function, transition-duration, transition-property, transform, transform-origin, animation, animation-name, animation-duration, animation-play-state, animation-timing-function, animation-delay, animation-iteration-count, animation-direction, text-align, text-align-last, vertical-align, white-space, text-decoration, text-emphasis, text-emphasis-color, text-emphasis-style, text-emphasis-position, text-indent, text-justify, letter-spacing, word-spacing, text-outline, text-transform, text-wrap, text-overflow, text-overflow-ellipsis, text-overflow-mode, word-wrap, word-break, tab-size, hyphens, pointer-events, opacity, color, border, border-width, border-style, border-color, border-top, border-top-width, border-top-style, border-top-color, border-right, border-right-width, border-right-style, border-right-color, border-bottom, border-bottom-width, border-bottom-style, border-bottom-color, border-left, border-left-width, border-left-style, border-left-color, border-radius, border-top-left-radius, border-top-right-radius, border-bottom-right-radius, border-bottom-left-radius, border-image, border-image-source, border-image-slice, border-image-width, border-image-outset, border-image-repeat, outline, outline-width, outline-style, outline-color, outline-offset, background, background-color, background-image, background-repeat, background-attachment, background-position, background-position-x, background-position-y, background-clip, background-origin, background-size, box-decoration-break, box-shadow, text-shadow |  | ||||||
| ij_sass_space_after_colon = true |  | ||||||
| ij_sass_space_before_opening_brace = true |  | ||||||
| ij_sass_use_double_quotes = true |  | ||||||
| ij_sass_value_alignment = 0 |  | ||||||
|  |  | ||||||
| [*.scss] |  | ||||||
| indent_size = 2 |  | ||||||
| ij_scss_align_closing_brace_with_properties = false |  | ||||||
| ij_scss_blank_lines_around_nested_selector = 1 |  | ||||||
| ij_scss_blank_lines_between_blocks = 1 |  | ||||||
| ij_scss_brace_placement = 0 |  | ||||||
| ij_scss_enforce_quotes_on_format = false |  | ||||||
| ij_scss_hex_color_long_format = false |  | ||||||
| ij_scss_hex_color_lower_case = false |  | ||||||
| ij_scss_hex_color_short_format = false |  | ||||||
| ij_scss_hex_color_upper_case = false |  | ||||||
| ij_scss_keep_blank_lines_in_code = 2 |  | ||||||
| ij_scss_keep_indents_on_empty_lines = false |  | ||||||
| ij_scss_keep_single_line_blocks = false |  | ||||||
| ij_scss_properties_order = font, font-family, font-size, font-weight, font-style, font-variant, font-size-adjust, font-stretch, line-height, position, z-index, top, right, bottom, left, display, visibility, float, clear, overflow, overflow-x, overflow-y, clip, zoom, align-content, align-items, align-self, flex, flex-flow, flex-basis, flex-direction, flex-grow, flex-shrink, flex-wrap, justify-content, order, box-sizing, width, min-width, max-width, height, min-height, max-height, margin, margin-top, margin-right, margin-bottom, margin-left, padding, padding-top, padding-right, padding-bottom, padding-left, table-layout, empty-cells, caption-side, border-spacing, border-collapse, list-style, list-style-position, list-style-type, list-style-image, content, quotes, counter-reset, counter-increment, resize, cursor, user-select, nav-index, nav-up, nav-right, nav-down, nav-left, transition, transition-delay, transition-timing-function, transition-duration, transition-property, transform, transform-origin, animation, animation-name, animation-duration, animation-play-state, animation-timing-function, animation-delay, animation-iteration-count, animation-direction, text-align, text-align-last, vertical-align, white-space, text-decoration, text-emphasis, text-emphasis-color, text-emphasis-style, text-emphasis-position, text-indent, text-justify, letter-spacing, word-spacing, text-outline, text-transform, text-wrap, text-overflow, text-overflow-ellipsis, text-overflow-mode, word-wrap, word-break, tab-size, hyphens, pointer-events, opacity, color, border, border-width, border-style, border-color, border-top, border-top-width, border-top-style, border-top-color, border-right, border-right-width, border-right-style, border-right-color, border-bottom, border-bottom-width, border-bottom-style, border-bottom-color, border-left, border-left-width, border-left-style, border-left-color, border-radius, border-top-left-radius, border-top-right-radius, border-bottom-right-radius, border-bottom-left-radius, border-image, border-image-source, border-image-slice, border-image-width, border-image-outset, border-image-repeat, outline, outline-width, outline-style, outline-color, outline-offset, background, background-color, background-image, background-repeat, background-attachment, background-position, background-position-x, background-position-y, background-clip, background-origin, background-size, box-decoration-break, box-shadow, text-shadow |  | ||||||
| ij_scss_space_after_colon = true |  | ||||||
| ij_scss_space_before_opening_brace = true |  | ||||||
| ij_scss_use_double_quotes = true |  | ||||||
| ij_scss_value_alignment = 0 |  | ||||||
|  |  | ||||||
| [.editorconfig] | [.editorconfig] | ||||||
| ij_editorconfig_align_group_field_declarations = false | ij_editorconfig_align_group_field_declarations = false | ||||||
| ij_editorconfig_space_after_colon = false | ij_editorconfig_space_after_colon = false | ||||||
| @@ -342,548 +257,6 @@ ij_editorconfig_space_before_colon = false | |||||||
| ij_editorconfig_space_before_comma = false | ij_editorconfig_space_before_comma = false | ||||||
| ij_editorconfig_spaces_around_assignment_operators = true | ij_editorconfig_spaces_around_assignment_operators = true | ||||||
|  |  | ||||||
| [{*.ant, *.fxml, *.jhm, *.jnlp, *.jrxml, *.pom, *.rng, *.tld, *.wsdl, *.xml, *.xsd, *.xsl, *.xslt, *.xul}] |  | ||||||
| ij_xml_align_attributes = true |  | ||||||
| ij_xml_align_text = false |  | ||||||
| ij_xml_attribute_wrap = normal |  | ||||||
| ij_xml_block_comment_at_first_column = true |  | ||||||
| ij_xml_keep_blank_lines = 2 |  | ||||||
| ij_xml_keep_indents_on_empty_lines = false |  | ||||||
| ij_xml_keep_line_breaks = true |  | ||||||
| ij_xml_keep_line_breaks_in_text = true |  | ||||||
| ij_xml_keep_whitespaces = false |  | ||||||
| ij_xml_keep_whitespaces_around_cdata = preserve |  | ||||||
| ij_xml_keep_whitespaces_inside_cdata = false |  | ||||||
| ij_xml_line_comment_at_first_column = true |  | ||||||
| ij_xml_space_after_tag_name = false |  | ||||||
| ij_xml_space_around_equals_in_attribute = false |  | ||||||
| ij_xml_space_inside_empty_tag = false |  | ||||||
| ij_xml_text_wrap = normal |  | ||||||
|  |  | ||||||
| [{*.ats, *.ts}] |  | ||||||
| ij_continuation_indent_size = 4 |  | ||||||
| ij_typescript_align_imports = false |  | ||||||
| ij_typescript_align_multiline_array_initializer_expression = false |  | ||||||
| ij_typescript_align_multiline_binary_operation = false |  | ||||||
| ij_typescript_align_multiline_chained_methods = false |  | ||||||
| ij_typescript_align_multiline_extends_list = false |  | ||||||
| ij_typescript_align_multiline_for = true |  | ||||||
| ij_typescript_align_multiline_parameters = true |  | ||||||
| ij_typescript_align_multiline_parameters_in_calls = false |  | ||||||
| ij_typescript_align_multiline_ternary_operation = false |  | ||||||
| ij_typescript_align_object_properties = 0 |  | ||||||
| ij_typescript_align_union_types = false |  | ||||||
| ij_typescript_align_var_statements = 0 |  | ||||||
| ij_typescript_array_initializer_new_line_after_left_brace = false |  | ||||||
| ij_typescript_array_initializer_right_brace_on_new_line = false |  | ||||||
| ij_typescript_array_initializer_wrap = off |  | ||||||
| ij_typescript_assignment_wrap = off |  | ||||||
| ij_typescript_binary_operation_sign_on_next_line = false |  | ||||||
| ij_typescript_binary_operation_wrap = off |  | ||||||
| ij_typescript_blacklist_imports = rxjs/Rx, node_modules/**, **/node_modules/**, @angular/material, @angular/material/typings/** |  | ||||||
| ij_typescript_blank_lines_after_imports = 1 |  | ||||||
| ij_typescript_blank_lines_around_class = 1 |  | ||||||
| ij_typescript_blank_lines_around_field = 0 |  | ||||||
| ij_typescript_blank_lines_around_field_in_interface = 0 |  | ||||||
| ij_typescript_blank_lines_around_function = 1 |  | ||||||
| ij_typescript_blank_lines_around_method = 1 |  | ||||||
| ij_typescript_blank_lines_around_method_in_interface = 1 |  | ||||||
| ij_typescript_block_brace_style = end_of_line |  | ||||||
| ij_typescript_call_parameters_new_line_after_left_paren = false |  | ||||||
| ij_typescript_call_parameters_right_paren_on_new_line = false |  | ||||||
| ij_typescript_call_parameters_wrap = off |  | ||||||
| ij_typescript_catch_on_new_line = false |  | ||||||
| ij_typescript_chained_call_dot_on_new_line = true |  | ||||||
| ij_typescript_class_brace_style = end_of_line |  | ||||||
| ij_typescript_comma_on_new_line = false |  | ||||||
| ij_typescript_do_while_brace_force = never |  | ||||||
| ij_typescript_else_on_new_line = false |  | ||||||
| ij_typescript_enforce_trailing_comma = keep |  | ||||||
| ij_typescript_extends_keyword_wrap = off |  | ||||||
| ij_typescript_extends_list_wrap = off |  | ||||||
| ij_typescript_field_prefix = _ |  | ||||||
| ij_typescript_file_name_style = relaxed |  | ||||||
| ij_typescript_finally_on_new_line = false |  | ||||||
| ij_typescript_for_brace_force = never |  | ||||||
| ij_typescript_for_statement_new_line_after_left_paren = false |  | ||||||
| ij_typescript_for_statement_right_paren_on_new_line = false |  | ||||||
| ij_typescript_for_statement_wrap = off |  | ||||||
| ij_typescript_force_quote_style = false |  | ||||||
| ij_typescript_force_semicolon_style = false |  | ||||||
| ij_typescript_function_expression_brace_style = end_of_line |  | ||||||
| ij_typescript_if_brace_force = never |  | ||||||
| ij_typescript_import_merge_members = global |  | ||||||
| ij_typescript_import_prefer_absolute_path = global |  | ||||||
| ij_typescript_import_sort_members = true |  | ||||||
| ij_typescript_import_sort_module_name = false |  | ||||||
| ij_typescript_import_use_node_resolution = true |  | ||||||
| ij_typescript_imports_wrap = on_every_item |  | ||||||
| ij_typescript_indent_case_from_switch = true |  | ||||||
| ij_typescript_indent_chained_calls = true |  | ||||||
| ij_typescript_indent_package_children = 0 |  | ||||||
| ij_typescript_jsdoc_include_types = false |  | ||||||
| ij_typescript_jsx_attribute_value = braces |  | ||||||
| ij_typescript_keep_blank_lines_in_code = 2 |  | ||||||
| ij_typescript_keep_first_column_comment = true |  | ||||||
| ij_typescript_keep_indents_on_empty_lines = false |  | ||||||
| ij_typescript_keep_line_breaks = true |  | ||||||
| ij_typescript_keep_simple_blocks_in_one_line = false |  | ||||||
| ij_typescript_keep_simple_methods_in_one_line = false |  | ||||||
| ij_typescript_line_comment_add_space = true |  | ||||||
| ij_typescript_line_comment_at_first_column = false |  | ||||||
| ij_typescript_method_brace_style = end_of_line |  | ||||||
| ij_typescript_method_call_chain_wrap = off |  | ||||||
| ij_typescript_method_parameters_new_line_after_left_paren = false |  | ||||||
| ij_typescript_method_parameters_right_paren_on_new_line = false |  | ||||||
| ij_typescript_method_parameters_wrap = off |  | ||||||
| ij_typescript_object_literal_wrap = on_every_item |  | ||||||
| ij_typescript_parentheses_expression_new_line_after_left_paren = false |  | ||||||
| ij_typescript_parentheses_expression_right_paren_on_new_line = false |  | ||||||
| ij_typescript_place_assignment_sign_on_next_line = false |  | ||||||
| ij_typescript_prefer_as_type_cast = false |  | ||||||
| ij_typescript_prefer_explicit_types_function_expression_returns = false |  | ||||||
| ij_typescript_prefer_explicit_types_function_returns = false |  | ||||||
| ij_typescript_prefer_explicit_types_vars_fields = false |  | ||||||
| ij_typescript_prefer_parameters_wrap = false |  | ||||||
| ij_typescript_reformat_c_style_comments = false |  | ||||||
| ij_typescript_space_after_colon = true |  | ||||||
| ij_typescript_space_after_comma = true |  | ||||||
| ij_typescript_space_after_dots_in_rest_parameter = false |  | ||||||
| ij_typescript_space_after_generator_mult = true |  | ||||||
| ij_typescript_space_after_property_colon = true |  | ||||||
| ij_typescript_space_after_quest = true |  | ||||||
| ij_typescript_space_after_type_colon = true |  | ||||||
| ij_typescript_space_after_unary_not = false |  | ||||||
| ij_typescript_space_before_async_arrow_lparen = true |  | ||||||
| ij_typescript_space_before_catch_keyword = true |  | ||||||
| ij_typescript_space_before_catch_left_brace = true |  | ||||||
| ij_typescript_space_before_catch_parentheses = true |  | ||||||
| ij_typescript_space_before_class_lbrace = true |  | ||||||
| ij_typescript_space_before_class_left_brace = true |  | ||||||
| ij_typescript_space_before_colon = true |  | ||||||
| ij_typescript_space_before_comma = false |  | ||||||
| ij_typescript_space_before_do_left_brace = true |  | ||||||
| ij_typescript_space_before_else_keyword = true |  | ||||||
| ij_typescript_space_before_else_left_brace = true |  | ||||||
| ij_typescript_space_before_finally_keyword = true |  | ||||||
| ij_typescript_space_before_finally_left_brace = true |  | ||||||
| ij_typescript_space_before_for_left_brace = true |  | ||||||
| ij_typescript_space_before_for_parentheses = true |  | ||||||
| ij_typescript_space_before_for_semicolon = false |  | ||||||
| ij_typescript_space_before_function_left_parenth = true |  | ||||||
| ij_typescript_space_before_generator_mult = false |  | ||||||
| ij_typescript_space_before_if_left_brace = true |  | ||||||
| ij_typescript_space_before_if_parentheses = true |  | ||||||
| ij_typescript_space_before_method_call_parentheses = false |  | ||||||
| ij_typescript_space_before_method_left_brace = true |  | ||||||
| ij_typescript_space_before_method_parentheses = false |  | ||||||
| ij_typescript_space_before_property_colon = false |  | ||||||
| ij_typescript_space_before_quest = true |  | ||||||
| ij_typescript_space_before_switch_left_brace = true |  | ||||||
| ij_typescript_space_before_switch_parentheses = true |  | ||||||
| ij_typescript_space_before_try_left_brace = true |  | ||||||
| ij_typescript_space_before_type_colon = false |  | ||||||
| ij_typescript_space_before_unary_not = false |  | ||||||
| ij_typescript_space_before_while_keyword = true |  | ||||||
| ij_typescript_space_before_while_left_brace = true |  | ||||||
| ij_typescript_space_before_while_parentheses = true |  | ||||||
| ij_typescript_spaces_around_additive_operators = true |  | ||||||
| ij_typescript_spaces_around_arrow_function_operator = true |  | ||||||
| ij_typescript_spaces_around_assignment_operators = true |  | ||||||
| ij_typescript_spaces_around_bitwise_operators = true |  | ||||||
| ij_typescript_spaces_around_equality_operators = true |  | ||||||
| ij_typescript_spaces_around_logical_operators = true |  | ||||||
| ij_typescript_spaces_around_multiplicative_operators = true |  | ||||||
| ij_typescript_spaces_around_relational_operators = true |  | ||||||
| ij_typescript_spaces_around_shift_operators = true |  | ||||||
| ij_typescript_spaces_around_unary_operator = false |  | ||||||
| ij_typescript_spaces_within_array_initializer_brackets = false |  | ||||||
| ij_typescript_spaces_within_brackets = false |  | ||||||
| ij_typescript_spaces_within_catch_parentheses = false |  | ||||||
| ij_typescript_spaces_within_for_parentheses = false |  | ||||||
| ij_typescript_spaces_within_if_parentheses = false |  | ||||||
| ij_typescript_spaces_within_imports = false |  | ||||||
| ij_typescript_spaces_within_interpolation_expressions = false |  | ||||||
| ij_typescript_spaces_within_method_call_parentheses = false |  | ||||||
| ij_typescript_spaces_within_method_parentheses = false |  | ||||||
| ij_typescript_spaces_within_object_literal_braces = false |  | ||||||
| ij_typescript_spaces_within_object_type_braces = true |  | ||||||
| ij_typescript_spaces_within_parentheses = false |  | ||||||
| ij_typescript_spaces_within_switch_parentheses = false |  | ||||||
| ij_typescript_spaces_within_type_assertion = false |  | ||||||
| ij_typescript_spaces_within_union_types = true |  | ||||||
| ij_typescript_spaces_within_while_parentheses = false |  | ||||||
| ij_typescript_special_else_if_treatment = true |  | ||||||
| ij_typescript_ternary_operation_signs_on_next_line = false |  | ||||||
| ij_typescript_ternary_operation_wrap = off |  | ||||||
| ij_typescript_union_types_wrap = on_every_item |  | ||||||
| ij_typescript_use_chained_calls_group_indents = false |  | ||||||
| ij_typescript_use_double_quotes = true |  | ||||||
| ij_typescript_use_explicit_js_extension = global |  | ||||||
| ij_typescript_use_path_mapping = always |  | ||||||
| ij_typescript_use_public_modifier = false |  | ||||||
| ij_typescript_use_semicolon_after_statement = true |  | ||||||
| ij_typescript_var_declaration_wrap = normal |  | ||||||
| ij_typescript_while_brace_force = never |  | ||||||
| ij_typescript_while_on_new_line = false |  | ||||||
| ij_typescript_wrap_comments = false |  | ||||||
|  |  | ||||||
| [{*.bash, *.sh, *.zsh}] |  | ||||||
| indent_size = 2 |  | ||||||
| tab_width = 2 |  | ||||||
| ij_shell_binary_ops_start_line = false |  | ||||||
| ij_shell_keep_column_alignment_padding = false |  | ||||||
| ij_shell_minify_program = false |  | ||||||
| ij_shell_redirect_followed_by_space = false |  | ||||||
| ij_shell_switch_cases_indented = false |  | ||||||
|  |  | ||||||
| [{*.cjs, *.js}] |  | ||||||
| ij_continuation_indent_size = 4 |  | ||||||
| ij_javascript_align_imports = false |  | ||||||
| ij_javascript_align_multiline_array_initializer_expression = false |  | ||||||
| ij_javascript_align_multiline_binary_operation = false |  | ||||||
| ij_javascript_align_multiline_chained_methods = false |  | ||||||
| ij_javascript_align_multiline_extends_list = false |  | ||||||
| ij_javascript_align_multiline_for = true |  | ||||||
| ij_javascript_align_multiline_parameters = true |  | ||||||
| ij_javascript_align_multiline_parameters_in_calls = false |  | ||||||
| ij_javascript_align_multiline_ternary_operation = false |  | ||||||
| ij_javascript_align_object_properties = 0 |  | ||||||
| ij_javascript_align_union_types = false |  | ||||||
| ij_javascript_align_var_statements = 0 |  | ||||||
| ij_javascript_array_initializer_new_line_after_left_brace = false |  | ||||||
| ij_javascript_array_initializer_right_brace_on_new_line = false |  | ||||||
| ij_javascript_array_initializer_wrap = off |  | ||||||
| ij_javascript_assignment_wrap = off |  | ||||||
| ij_javascript_binary_operation_sign_on_next_line = false |  | ||||||
| ij_javascript_binary_operation_wrap = off |  | ||||||
| ij_javascript_blacklist_imports = rxjs/Rx, node_modules/**, **/node_modules/**, @angular/material, @angular/material/typings/** |  | ||||||
| ij_javascript_blank_lines_after_imports = 1 |  | ||||||
| ij_javascript_blank_lines_around_class = 1 |  | ||||||
| ij_javascript_blank_lines_around_field = 0 |  | ||||||
| ij_javascript_blank_lines_around_function = 1 |  | ||||||
| ij_javascript_blank_lines_around_method = 1 |  | ||||||
| ij_javascript_block_brace_style = end_of_line |  | ||||||
| ij_javascript_call_parameters_new_line_after_left_paren = false |  | ||||||
| ij_javascript_call_parameters_right_paren_on_new_line = false |  | ||||||
| ij_javascript_call_parameters_wrap = off |  | ||||||
| ij_javascript_catch_on_new_line = false |  | ||||||
| ij_javascript_chained_call_dot_on_new_line = true |  | ||||||
| ij_javascript_class_brace_style = end_of_line |  | ||||||
| ij_javascript_comma_on_new_line = false |  | ||||||
| ij_javascript_do_while_brace_force = never |  | ||||||
| ij_javascript_else_on_new_line = false |  | ||||||
| ij_javascript_enforce_trailing_comma = keep |  | ||||||
| ij_javascript_extends_keyword_wrap = off |  | ||||||
| ij_javascript_extends_list_wrap = off |  | ||||||
| ij_javascript_field_prefix = _ |  | ||||||
| ij_javascript_file_name_style = relaxed |  | ||||||
| ij_javascript_finally_on_new_line = false |  | ||||||
| ij_javascript_for_brace_force = never |  | ||||||
| ij_javascript_for_statement_new_line_after_left_paren = false |  | ||||||
| ij_javascript_for_statement_right_paren_on_new_line = false |  | ||||||
| ij_javascript_for_statement_wrap = off |  | ||||||
| ij_javascript_force_quote_style = false |  | ||||||
| ij_javascript_force_semicolon_style = false |  | ||||||
| ij_javascript_function_expression_brace_style = end_of_line |  | ||||||
| ij_javascript_if_brace_force = never |  | ||||||
| ij_javascript_import_merge_members = global |  | ||||||
| ij_javascript_import_prefer_absolute_path = global |  | ||||||
| ij_javascript_import_sort_members = true |  | ||||||
| ij_javascript_import_sort_module_name = false |  | ||||||
| ij_javascript_import_use_node_resolution = true |  | ||||||
| ij_javascript_imports_wrap = on_every_item |  | ||||||
| ij_javascript_indent_case_from_switch = true |  | ||||||
| ij_javascript_indent_chained_calls = true |  | ||||||
| ij_javascript_indent_package_children = 0 |  | ||||||
| ij_javascript_jsx_attribute_value = braces |  | ||||||
| ij_javascript_keep_blank_lines_in_code = 2 |  | ||||||
| ij_javascript_keep_first_column_comment = true |  | ||||||
| ij_javascript_keep_indents_on_empty_lines = false |  | ||||||
| ij_javascript_keep_line_breaks = true |  | ||||||
| ij_javascript_keep_simple_blocks_in_one_line = false |  | ||||||
| ij_javascript_keep_simple_methods_in_one_line = false |  | ||||||
| ij_javascript_line_comment_add_space = true |  | ||||||
| ij_javascript_line_comment_at_first_column = false |  | ||||||
| ij_javascript_method_brace_style = end_of_line |  | ||||||
| ij_javascript_method_call_chain_wrap = off |  | ||||||
| ij_javascript_method_parameters_new_line_after_left_paren = false |  | ||||||
| ij_javascript_method_parameters_right_paren_on_new_line = false |  | ||||||
| ij_javascript_method_parameters_wrap = off |  | ||||||
| ij_javascript_object_literal_wrap = on_every_item |  | ||||||
| ij_javascript_parentheses_expression_new_line_after_left_paren = false |  | ||||||
| ij_javascript_parentheses_expression_right_paren_on_new_line = false |  | ||||||
| ij_javascript_place_assignment_sign_on_next_line = false |  | ||||||
| ij_javascript_prefer_as_type_cast = false |  | ||||||
| ij_javascript_prefer_explicit_types_function_expression_returns = false |  | ||||||
| ij_javascript_prefer_explicit_types_function_returns = false |  | ||||||
| ij_javascript_prefer_explicit_types_vars_fields = false |  | ||||||
| ij_javascript_prefer_parameters_wrap = false |  | ||||||
| ij_javascript_reformat_c_style_comments = false |  | ||||||
| ij_javascript_space_after_colon = true |  | ||||||
| ij_javascript_space_after_comma = true |  | ||||||
| ij_javascript_space_after_dots_in_rest_parameter = false |  | ||||||
| ij_javascript_space_after_generator_mult = true |  | ||||||
| ij_javascript_space_after_property_colon = true |  | ||||||
| ij_javascript_space_after_quest = true |  | ||||||
| ij_javascript_space_after_type_colon = true |  | ||||||
| ij_javascript_space_after_unary_not = false |  | ||||||
| ij_javascript_space_before_async_arrow_lparen = true |  | ||||||
| ij_javascript_space_before_catch_keyword = true |  | ||||||
| ij_javascript_space_before_catch_left_brace = true |  | ||||||
| ij_javascript_space_before_catch_parentheses = true |  | ||||||
| ij_javascript_space_before_class_lbrace = true |  | ||||||
| ij_javascript_space_before_class_left_brace = true |  | ||||||
| ij_javascript_space_before_colon = true |  | ||||||
| ij_javascript_space_before_comma = false |  | ||||||
| ij_javascript_space_before_do_left_brace = true |  | ||||||
| ij_javascript_space_before_else_keyword = true |  | ||||||
| ij_javascript_space_before_else_left_brace = true |  | ||||||
| ij_javascript_space_before_finally_keyword = true |  | ||||||
| ij_javascript_space_before_finally_left_brace = true |  | ||||||
| ij_javascript_space_before_for_left_brace = true |  | ||||||
| ij_javascript_space_before_for_parentheses = true |  | ||||||
| ij_javascript_space_before_for_semicolon = false |  | ||||||
| ij_javascript_space_before_function_left_parenth = true |  | ||||||
| ij_javascript_space_before_generator_mult = false |  | ||||||
| ij_javascript_space_before_if_left_brace = true |  | ||||||
| ij_javascript_space_before_if_parentheses = true |  | ||||||
| ij_javascript_space_before_method_call_parentheses = false |  | ||||||
| ij_javascript_space_before_method_left_brace = true |  | ||||||
| ij_javascript_space_before_method_parentheses = false |  | ||||||
| ij_javascript_space_before_property_colon = false |  | ||||||
| ij_javascript_space_before_quest = true |  | ||||||
| ij_javascript_space_before_switch_left_brace = true |  | ||||||
| ij_javascript_space_before_switch_parentheses = true |  | ||||||
| ij_javascript_space_before_try_left_brace = true |  | ||||||
| ij_javascript_space_before_type_colon = false |  | ||||||
| ij_javascript_space_before_unary_not = false |  | ||||||
| ij_javascript_space_before_while_keyword = true |  | ||||||
| ij_javascript_space_before_while_left_brace = true |  | ||||||
| ij_javascript_space_before_while_parentheses = true |  | ||||||
| ij_javascript_spaces_around_additive_operators = true |  | ||||||
| ij_javascript_spaces_around_arrow_function_operator = true |  | ||||||
| ij_javascript_spaces_around_assignment_operators = true |  | ||||||
| ij_javascript_spaces_around_bitwise_operators = true |  | ||||||
| ij_javascript_spaces_around_equality_operators = true |  | ||||||
| ij_javascript_spaces_around_logical_operators = true |  | ||||||
| ij_javascript_spaces_around_multiplicative_operators = true |  | ||||||
| ij_javascript_spaces_around_relational_operators = true |  | ||||||
| ij_javascript_spaces_around_shift_operators = true |  | ||||||
| ij_javascript_spaces_around_unary_operator = false |  | ||||||
| ij_javascript_spaces_within_array_initializer_brackets = false |  | ||||||
| ij_javascript_spaces_within_brackets = false |  | ||||||
| ij_javascript_spaces_within_catch_parentheses = false |  | ||||||
| ij_javascript_spaces_within_for_parentheses = false |  | ||||||
| ij_javascript_spaces_within_if_parentheses = false |  | ||||||
| ij_javascript_spaces_within_imports = false |  | ||||||
| ij_javascript_spaces_within_interpolation_expressions = false |  | ||||||
| ij_javascript_spaces_within_method_call_parentheses = false |  | ||||||
| ij_javascript_spaces_within_method_parentheses = false |  | ||||||
| ij_javascript_spaces_within_object_literal_braces = false |  | ||||||
| ij_javascript_spaces_within_object_type_braces = true |  | ||||||
| ij_javascript_spaces_within_parentheses = false |  | ||||||
| ij_javascript_spaces_within_switch_parentheses = false |  | ||||||
| ij_javascript_spaces_within_type_assertion = false |  | ||||||
| ij_javascript_spaces_within_union_types = true |  | ||||||
| ij_javascript_spaces_within_while_parentheses = false |  | ||||||
| ij_javascript_special_else_if_treatment = true |  | ||||||
| ij_javascript_ternary_operation_signs_on_next_line = false |  | ||||||
| ij_javascript_ternary_operation_wrap = off |  | ||||||
| ij_javascript_union_types_wrap = on_every_item |  | ||||||
| ij_javascript_use_chained_calls_group_indents = false |  | ||||||
| ij_javascript_use_double_quotes = true |  | ||||||
| ij_javascript_use_explicit_js_extension = global |  | ||||||
| ij_javascript_use_path_mapping = always |  | ||||||
| ij_javascript_use_public_modifier = false |  | ||||||
| ij_javascript_use_semicolon_after_statement = true |  | ||||||
| ij_javascript_var_declaration_wrap = normal |  | ||||||
| ij_javascript_while_brace_force = never |  | ||||||
| ij_javascript_while_on_new_line = false |  | ||||||
| ij_javascript_wrap_comments = false |  | ||||||
|  |  | ||||||
| [{*.ft, *.vm, *.vsl}] |  | ||||||
| ij_vtl_keep_indents_on_empty_lines = false |  | ||||||
|  |  | ||||||
| [{*.gant, *.gradle, *.groovy, *.gy}] |  | ||||||
| ij_groovy_align_group_field_declarations = false |  | ||||||
| ij_groovy_align_multiline_array_initializer_expression = false |  | ||||||
| ij_groovy_align_multiline_assignment = false |  | ||||||
| ij_groovy_align_multiline_binary_operation = false |  | ||||||
| ij_groovy_align_multiline_chained_methods = false |  | ||||||
| ij_groovy_align_multiline_extends_list = false |  | ||||||
| ij_groovy_align_multiline_for = true |  | ||||||
| ij_groovy_align_multiline_list_or_map = true |  | ||||||
| ij_groovy_align_multiline_method_parentheses = false |  | ||||||
| ij_groovy_align_multiline_parameters = true |  | ||||||
| ij_groovy_align_multiline_parameters_in_calls = false |  | ||||||
| ij_groovy_align_multiline_resources = true |  | ||||||
| ij_groovy_align_multiline_ternary_operation = false |  | ||||||
| ij_groovy_align_multiline_throws_list = false |  | ||||||
| ij_groovy_align_named_args_in_map = true |  | ||||||
| ij_groovy_align_throws_keyword = false |  | ||||||
| ij_groovy_array_initializer_new_line_after_left_brace = false |  | ||||||
| ij_groovy_array_initializer_right_brace_on_new_line = false |  | ||||||
| ij_groovy_array_initializer_wrap = off |  | ||||||
| ij_groovy_assert_statement_wrap = off |  | ||||||
| ij_groovy_assignment_wrap = off |  | ||||||
| ij_groovy_binary_operation_wrap = off |  | ||||||
| ij_groovy_blank_lines_after_class_header = 0 |  | ||||||
| ij_groovy_blank_lines_after_imports = 1 |  | ||||||
| ij_groovy_blank_lines_after_package = 1 |  | ||||||
| ij_groovy_blank_lines_around_class = 1 |  | ||||||
| ij_groovy_blank_lines_around_field = 0 |  | ||||||
| ij_groovy_blank_lines_around_field_in_interface = 0 |  | ||||||
| ij_groovy_blank_lines_around_method = 1 |  | ||||||
| ij_groovy_blank_lines_around_method_in_interface = 1 |  | ||||||
| ij_groovy_blank_lines_before_imports = 1 |  | ||||||
| ij_groovy_blank_lines_before_method_body = 0 |  | ||||||
| ij_groovy_blank_lines_before_package = 0 |  | ||||||
| ij_groovy_block_brace_style = end_of_line |  | ||||||
| ij_groovy_block_comment_at_first_column = true |  | ||||||
| ij_groovy_call_parameters_new_line_after_left_paren = false |  | ||||||
| ij_groovy_call_parameters_right_paren_on_new_line = false |  | ||||||
| ij_groovy_call_parameters_wrap = off |  | ||||||
| ij_groovy_catch_on_new_line = false |  | ||||||
| ij_groovy_class_annotation_wrap = split_into_lines |  | ||||||
| ij_groovy_class_brace_style = end_of_line |  | ||||||
| ij_groovy_class_count_to_use_import_on_demand = 5 |  | ||||||
| ij_groovy_do_while_brace_force = never |  | ||||||
| ij_groovy_else_on_new_line = false |  | ||||||
| ij_groovy_enum_constants_wrap = off |  | ||||||
| ij_groovy_extends_keyword_wrap = off |  | ||||||
| ij_groovy_extends_list_wrap = off |  | ||||||
| ij_groovy_field_annotation_wrap = split_into_lines |  | ||||||
| ij_groovy_finally_on_new_line = false |  | ||||||
| ij_groovy_for_brace_force = never |  | ||||||
| ij_groovy_for_statement_new_line_after_left_paren = false |  | ||||||
| ij_groovy_for_statement_right_paren_on_new_line = false |  | ||||||
| ij_groovy_for_statement_wrap = off |  | ||||||
| ij_groovy_if_brace_force = never |  | ||||||
| ij_groovy_import_annotation_wrap = 2 |  | ||||||
| ij_groovy_imports_layout = *, |, javax.**, java.**, |, $* |  | ||||||
| ij_groovy_indent_case_from_switch = true |  | ||||||
| ij_groovy_indent_label_blocks = true |  | ||||||
| ij_groovy_insert_inner_class_imports = false |  | ||||||
| ij_groovy_keep_blank_lines_before_right_brace = 2 |  | ||||||
| ij_groovy_keep_blank_lines_in_code = 2 |  | ||||||
| ij_groovy_keep_blank_lines_in_declarations = 2 |  | ||||||
| ij_groovy_keep_control_statement_in_one_line = true |  | ||||||
| ij_groovy_keep_first_column_comment = true |  | ||||||
| ij_groovy_keep_indents_on_empty_lines = false |  | ||||||
| ij_groovy_keep_line_breaks = true |  | ||||||
| ij_groovy_keep_multiple_expressions_in_one_line = false |  | ||||||
| ij_groovy_keep_simple_blocks_in_one_line = false |  | ||||||
| ij_groovy_keep_simple_classes_in_one_line = true |  | ||||||
| ij_groovy_keep_simple_lambdas_in_one_line = true |  | ||||||
| ij_groovy_keep_simple_methods_in_one_line = true |  | ||||||
| ij_groovy_label_indent_absolute = false |  | ||||||
| ij_groovy_label_indent_size = 0 |  | ||||||
| ij_groovy_lambda_brace_style = end_of_line |  | ||||||
| ij_groovy_layout_static_imports_separately = true |  | ||||||
| ij_groovy_line_comment_add_space = false |  | ||||||
| ij_groovy_line_comment_at_first_column = true |  | ||||||
| ij_groovy_method_annotation_wrap = split_into_lines |  | ||||||
| ij_groovy_method_brace_style = end_of_line |  | ||||||
| ij_groovy_method_call_chain_wrap = off |  | ||||||
| ij_groovy_method_parameters_new_line_after_left_paren = false |  | ||||||
| ij_groovy_method_parameters_right_paren_on_new_line = false |  | ||||||
| ij_groovy_method_parameters_wrap = off |  | ||||||
| ij_groovy_modifier_list_wrap = false |  | ||||||
| ij_groovy_names_count_to_use_import_on_demand = 3 |  | ||||||
| ij_groovy_parameter_annotation_wrap = off |  | ||||||
| ij_groovy_parentheses_expression_new_line_after_left_paren = false |  | ||||||
| ij_groovy_parentheses_expression_right_paren_on_new_line = false |  | ||||||
| ij_groovy_prefer_parameters_wrap = false |  | ||||||
| ij_groovy_resource_list_new_line_after_left_paren = false |  | ||||||
| ij_groovy_resource_list_right_paren_on_new_line = false |  | ||||||
| ij_groovy_resource_list_wrap = off |  | ||||||
| ij_groovy_space_after_assert_separator = true |  | ||||||
| ij_groovy_space_after_colon = true |  | ||||||
| ij_groovy_space_after_comma = true |  | ||||||
| ij_groovy_space_after_comma_in_type_arguments = true |  | ||||||
| ij_groovy_space_after_for_semicolon = true |  | ||||||
| ij_groovy_space_after_quest = true |  | ||||||
| ij_groovy_space_after_type_cast = true |  | ||||||
| ij_groovy_space_before_annotation_parameter_list = false |  | ||||||
| ij_groovy_space_before_array_initializer_left_brace = false |  | ||||||
| ij_groovy_space_before_assert_separator = false |  | ||||||
| ij_groovy_space_before_catch_keyword = true |  | ||||||
| ij_groovy_space_before_catch_left_brace = true |  | ||||||
| ij_groovy_space_before_catch_parentheses = true |  | ||||||
| ij_groovy_space_before_class_left_brace = true |  | ||||||
| ij_groovy_space_before_closure_left_brace = true |  | ||||||
| ij_groovy_space_before_colon = true |  | ||||||
| ij_groovy_space_before_comma = false |  | ||||||
| ij_groovy_space_before_do_left_brace = true |  | ||||||
| ij_groovy_space_before_else_keyword = true |  | ||||||
| ij_groovy_space_before_else_left_brace = true |  | ||||||
| ij_groovy_space_before_finally_keyword = true |  | ||||||
| ij_groovy_space_before_finally_left_brace = true |  | ||||||
| ij_groovy_space_before_for_left_brace = true |  | ||||||
| ij_groovy_space_before_for_parentheses = true |  | ||||||
| ij_groovy_space_before_for_semicolon = false |  | ||||||
| ij_groovy_space_before_if_left_brace = true |  | ||||||
| ij_groovy_space_before_if_parentheses = true |  | ||||||
| ij_groovy_space_before_method_call_parentheses = false |  | ||||||
| ij_groovy_space_before_method_left_brace = true |  | ||||||
| ij_groovy_space_before_method_parentheses = false |  | ||||||
| ij_groovy_space_before_quest = true |  | ||||||
| ij_groovy_space_before_switch_left_brace = true |  | ||||||
| ij_groovy_space_before_switch_parentheses = true |  | ||||||
| ij_groovy_space_before_synchronized_left_brace = true |  | ||||||
| ij_groovy_space_before_synchronized_parentheses = true |  | ||||||
| ij_groovy_space_before_try_left_brace = true |  | ||||||
| ij_groovy_space_before_try_parentheses = true |  | ||||||
| ij_groovy_space_before_while_keyword = true |  | ||||||
| ij_groovy_space_before_while_left_brace = true |  | ||||||
| ij_groovy_space_before_while_parentheses = true |  | ||||||
| ij_groovy_space_in_named_argument = true |  | ||||||
| ij_groovy_space_in_named_argument_before_colon = false |  | ||||||
| ij_groovy_space_within_empty_array_initializer_braces = false |  | ||||||
| ij_groovy_space_within_empty_method_call_parentheses = false |  | ||||||
| ij_groovy_spaces_around_additive_operators = true |  | ||||||
| ij_groovy_spaces_around_assignment_operators = true |  | ||||||
| ij_groovy_spaces_around_bitwise_operators = true |  | ||||||
| ij_groovy_spaces_around_equality_operators = true |  | ||||||
| ij_groovy_spaces_around_lambda_arrow = true |  | ||||||
| ij_groovy_spaces_around_logical_operators = true |  | ||||||
| ij_groovy_spaces_around_multiplicative_operators = true |  | ||||||
| ij_groovy_spaces_around_regex_operators = true |  | ||||||
| ij_groovy_spaces_around_relational_operators = true |  | ||||||
| ij_groovy_spaces_around_shift_operators = true |  | ||||||
| ij_groovy_spaces_within_annotation_parentheses = false |  | ||||||
| ij_groovy_spaces_within_array_initializer_braces = false |  | ||||||
| ij_groovy_spaces_within_braces = true |  | ||||||
| ij_groovy_spaces_within_brackets = false |  | ||||||
| ij_groovy_spaces_within_cast_parentheses = false |  | ||||||
| ij_groovy_spaces_within_catch_parentheses = false |  | ||||||
| ij_groovy_spaces_within_for_parentheses = false |  | ||||||
| ij_groovy_spaces_within_gstring_injection_braces = false |  | ||||||
| ij_groovy_spaces_within_if_parentheses = false |  | ||||||
| ij_groovy_spaces_within_list_or_map = false |  | ||||||
| ij_groovy_spaces_within_method_call_parentheses = false |  | ||||||
| ij_groovy_spaces_within_method_parentheses = false |  | ||||||
| ij_groovy_spaces_within_parentheses = false |  | ||||||
| ij_groovy_spaces_within_switch_parentheses = false |  | ||||||
| ij_groovy_spaces_within_synchronized_parentheses = false |  | ||||||
| ij_groovy_spaces_within_try_parentheses = false |  | ||||||
| ij_groovy_spaces_within_tuple_expression = false |  | ||||||
| ij_groovy_spaces_within_while_parentheses = false |  | ||||||
| ij_groovy_special_else_if_treatment = true |  | ||||||
| ij_groovy_ternary_operation_wrap = off |  | ||||||
| ij_groovy_throws_keyword_wrap = off |  | ||||||
| ij_groovy_throws_list_wrap = off |  | ||||||
| ij_groovy_use_flying_geese_braces = false |  | ||||||
| ij_groovy_use_fq_class_names = false |  | ||||||
| ij_groovy_use_fq_class_names_in_javadoc = true |  | ||||||
| ij_groovy_use_relative_indents = false |  | ||||||
| ij_groovy_use_single_class_imports = true |  | ||||||
| ij_groovy_variable_annotation_wrap = off |  | ||||||
| ij_groovy_while_brace_force = never |  | ||||||
| ij_groovy_while_on_new_line = false |  | ||||||
| ij_groovy_wrap_long_lines = false |  | ||||||
|  |  | ||||||
| [{*.gradle.kts, *.kt, *.kts, *.main.kts}] | [{*.gradle.kts, *.kt, *.kts, *.main.kts}] | ||||||
| ij_kotlin_align_in_columns_case_branch = false | ij_kotlin_align_in_columns_case_branch = false | ||||||
| ij_kotlin_align_multiline_binary_operation = false | ij_kotlin_align_multiline_binary_operation = false | ||||||
| @@ -963,7 +336,8 @@ ij_kotlin_wrap_elvis_expressions = 1 | |||||||
| ij_kotlin_wrap_expression_body_functions = 0 | ij_kotlin_wrap_expression_body_functions = 0 | ||||||
| ij_kotlin_wrap_first_method_in_call_chain = false | ij_kotlin_wrap_first_method_in_call_chain = false | ||||||
|  |  | ||||||
| [{*.har, *.jsb2, *.jsb3, *.json, .babelrc, .eslintrc, .stylelintrc, bowerrc, jest.config, mcmod.info}] |  | ||||||
|  | [*.json] | ||||||
| indent_size = 2 | indent_size = 2 | ||||||
| ij_json_keep_blank_lines_in_code = 0 | ij_json_keep_blank_lines_in_code = 0 | ||||||
| ij_json_keep_indents_on_empty_lines = false | ij_json_keep_indents_on_empty_lines = false | ||||||
|   | |||||||
							
								
								
									
										4
									
								
								.gitattributes
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								.gitattributes
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,4 @@ | |||||||
|  | * text=auto | ||||||
|  |  | ||||||
|  | *.java text | ||||||
|  | *.jar binary | ||||||
							
								
								
									
										17
									
								
								.github/ISSUE_TEMPLATE/bug_report.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										17
									
								
								.github/ISSUE_TEMPLATE/bug_report.yml
									
									
									
									
										vendored
									
									
								
							| @@ -7,8 +7,8 @@ body: | |||||||
|     attributes: |     attributes: | ||||||
|       value: | |       value: | | ||||||
|         Thanks for taking the time to fill out this bug report for PlotSquared! Fill out the following form to your best ability to help us fix the problem. |         Thanks for taking the time to fill out this bug report for PlotSquared! Fill out the following form to your best ability to help us fix the problem. | ||||||
|         Only use this if you're absolutely sure that you found a bug and can reproduce it. For anything else, use: [our Discord server](https://discord.gg/intellectualsites) or [the wiki](https://intellectualsites.github.io/plotsquared-documentation/). |         Only use this if you're absolutely sure that you found a bug and can reproduce it. For anything else, use: [our Discord server](https://discord.gg/intellectualsites) or [the wiki](https://intellectualsites.gitbook.io/plotsquared/). | ||||||
|         Do NOT use the public issue tracker to report security vulnerabilities! They are disclosed using [this](https://forms.gle/btgdRn9yhGtzEiGW8) form! |         Do NOT use the public issue tracker to report security vulnerabilities! They are disclosed using [this](https://github.com/IntellectualSites/PlotSquared/security/policy) GitHub form! | ||||||
|  |  | ||||||
|   - type: dropdown |   - type: dropdown | ||||||
|     attributes: |     attributes: | ||||||
| @@ -24,15 +24,14 @@ body: | |||||||
|   - type: dropdown |   - type: dropdown | ||||||
|     attributes: |     attributes: | ||||||
|       label: Server Version |       label: Server Version | ||||||
|       description: Which server version version you using? If your server version is not listed, it is not supported. Update to a supported version first. |       description: Which server version are you using? If your server version is not listed, it is not supported. Update to a supported version first. | ||||||
|       multiple: false |       multiple: false | ||||||
|       options: |       options: | ||||||
|         - '1.19' |         - '1.21.1' | ||||||
|         - '1.18.2' |         - '1.20.6' | ||||||
|         - '1.18.1' |         - '1.20.4' | ||||||
|         - '1.18' |         - '1.20' | ||||||
|         - '1.17.1' |         - '1.19.4' | ||||||
|         - '1.16.5' |  | ||||||
|     validations: |     validations: | ||||||
|       required: true |       required: true | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								.github/ISSUE_TEMPLATE/config.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/ISSUE_TEMPLATE/config.yml
									
									
									
									
										vendored
									
									
								
							| @@ -4,5 +4,5 @@ contact_links: | |||||||
|     url: https://discord.gg/intellectualsites |     url: https://discord.gg/intellectualsites | ||||||
|     about: Our support Discord, please ask questions and seek support here. |     about: Our support Discord, please ask questions and seek support here. | ||||||
|   - name: PlotSquared Wiki |   - name: PlotSquared Wiki | ||||||
|     url: https://intellectualsites.github.io/plotsquared-documentation/ |     url: https://intellectualsites.gitbook.io/plotsquared/ | ||||||
|     about: Take a look at the wiki page for instructions how to setup PlotSquared and use its commands. |     about: Take a look at the wiki page for instructions how to setup PlotSquared and use its commands. | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								.github/ISSUE_TEMPLATE/feature_request.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/ISSUE_TEMPLATE/feature_request.yml
									
									
									
									
										vendored
									
									
								
							| @@ -7,7 +7,7 @@ body: | |||||||
|     attributes: |     attributes: | ||||||
|       value: | |       value: | | ||||||
|         Thanks for taking the time to fill out this feature request for PlotSquared! Fill out the following form to your best ability to help us understand your feature request and greately improve the change of it getting added. |         Thanks for taking the time to fill out this feature request for PlotSquared! Fill out the following form to your best ability to help us understand your feature request and greately improve the change of it getting added. | ||||||
|         For anything else than a feature request, use: [our Discord server](https://discord.gg/intellectualsites) or [the wiki](https://intellectualsites.github.io/plotsquared-documentation/). |         For anything else than a feature request, use: [our Discord server](https://discord.gg/intellectualsites) or [the wiki](https://intellectualsites.gitbook.io/plotsquared/). | ||||||
|  |  | ||||||
|   - type: textarea |   - type: textarea | ||||||
|     attributes: |     attributes: | ||||||
|   | |||||||
							
								
								
									
										18
									
								
								.github/renovate.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								.github/renovate.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,18 @@ | |||||||
|  | { | ||||||
|  |   "$schema": "https://docs.renovatebot.com/renovate-schema.json", | ||||||
|  |   "extends": [ | ||||||
|  |     "config:base", | ||||||
|  |     ":semanticCommitsDisabled" | ||||||
|  |   ], | ||||||
|  |   "automerge": true, | ||||||
|  |   "labels": [ | ||||||
|  |     "dependencies" | ||||||
|  |   ], | ||||||
|  |   "rebaseWhen": "conflicted", | ||||||
|  |   "ignoreDeps": [ | ||||||
|  |     "com.google.code.gson:gson", | ||||||
|  |     "com.google.guava:guava", | ||||||
|  |     "org.yaml:snakeyaml", | ||||||
|  |     "org.apache.logging.log4j:log4j-api" | ||||||
|  |   ] | ||||||
|  | } | ||||||
							
								
								
									
										24
									
								
								.github/workflows/announce-release-on-discord.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										24
									
								
								.github/workflows/announce-release-on-discord.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,24 @@ | |||||||
|  | name: Announce release on discord | ||||||
|  | on: | ||||||
|  |   release: | ||||||
|  |     types: [ published ] | ||||||
|  | jobs: | ||||||
|  |   send_announcement: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     steps: | ||||||
|  |       - name: send custom message with args | ||||||
|  |         env: | ||||||
|  |           DISCORD_WEBHOOK: ${{ secrets.DISCORD_WEBHOOK }} | ||||||
|  |           DISCORD_USERNAME: PlotSquared Release | ||||||
|  |           DISCORD_AVATAR: https://raw.githubusercontent.com/IntellectualSites/Assets/main/plugins/PlotSquared/PlotSquared.png | ||||||
|  |         uses: Ilshidur/action-discord@0.3.2 | ||||||
|  |         with: | ||||||
|  |           args: | | ||||||
|  |             "<@&525015541815967744> <@&679322738552471574> <@&699293353862496266>" | ||||||
|  |             "" | ||||||
|  |             "<:plotsquared:730750385886593039> **PlotSquared ${{ github.event.release.tag_name }} has been released!**" | ||||||
|  |             "" | ||||||
|  |             "Click here to view changelog: https://github.com/IntellectualSites/PlotSquared/releases/tag/${{ github.event.release.tag_name }}" | ||||||
|  |             "" | ||||||
|  |             "The download is available at:" | ||||||
|  |             "- Spigot: <https://www.spigotmc.org/resources/77506/>" | ||||||
							
								
								
									
										21
									
								
								.github/workflows/build-pr.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								.github/workflows/build-pr.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,21 @@ | |||||||
|  | name: Build PR | ||||||
|  | on: [ pull_request ] | ||||||
|  | jobs: | ||||||
|  |   build_pr: | ||||||
|  |     if: github.repository_owner == 'IntellectualSites' | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     strategy: | ||||||
|  |       matrix: | ||||||
|  |         os: [ ubuntu-latest, windows-latest, macos-latest ] | ||||||
|  |     steps: | ||||||
|  |       - name: Checkout Repository | ||||||
|  |         uses: actions/checkout@v4 | ||||||
|  |       - name: Validate Gradle Wrapper | ||||||
|  |         uses: gradle/actions/wrapper-validation@v4 | ||||||
|  |       - name: Setup Java | ||||||
|  |         uses: actions/setup-java@v4 | ||||||
|  |         with: | ||||||
|  |           distribution: temurin | ||||||
|  |           java-version: 21 | ||||||
|  |       - name: Clean Build | ||||||
|  |         run: ./gradlew clean build | ||||||
							
								
								
									
										31
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										31
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,21 +1,22 @@ | |||||||
| name: build | name: build | ||||||
|  | on: | ||||||
| on: [ pull_request, push ] |   push: | ||||||
|  |     branches: | ||||||
|  |       - main | ||||||
| jobs: | jobs: | ||||||
|   build: |   build: | ||||||
|     if: ${{ github.event_name != 'pull_request' || github.repository != github.event.pull_request.head.repo.full_name }} |     if: github.repository_owner == 'IntellectualSites' | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     steps: |     steps: | ||||||
|       - name: Checkout Repository |       - name: Checkout Repository | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v4 | ||||||
|       - name: Validate Gradle Wrapper" |       - name: Validate Gradle Wrapper | ||||||
|         uses: gradle/wrapper-validation-action@v1 |         uses: gradle/actions/wrapper-validation@v4 | ||||||
|       - name: Setup Java |       - name: Setup Java | ||||||
|         uses: actions/setup-java@v3 |         uses: actions/setup-java@v4 | ||||||
|         with: |         with: | ||||||
|           distribution: temurin |           distribution: temurin | ||||||
|           java-version: 17 |           java-version: 21 | ||||||
|       - name: Clean Build |       - name: Clean Build | ||||||
|         run: ./gradlew clean build |         run: ./gradlew clean build | ||||||
|       - name: Determine release status |       - name: Determine release status | ||||||
| @@ -27,7 +28,7 @@ jobs: | |||||||
|             echo "STATUS=release" >> $GITHUB_ENV |             echo "STATUS=release" >> $GITHUB_ENV | ||||||
|           fi |           fi | ||||||
|       - name: Publish Release |       - name: Publish Release | ||||||
|         if: ${{ runner.os == 'Linux' && env.STATUS == 'release' && github.event_name == 'push' && github.ref == 'refs/heads/v6'}} |         if: ${{ runner.os == 'Linux' && env.STATUS == 'release' && github.event_name == 'push' && github.ref == 'refs/heads/main'}} | ||||||
|         run: ./gradlew publishToSonatype closeAndReleaseSonatypeStagingRepository |         run: ./gradlew publishToSonatype closeAndReleaseSonatypeStagingRepository | ||||||
|         env: |         env: | ||||||
|           ORG_GRADLE_PROJECT_sonatypeUsername: ${{ secrets.SONATYPE_USERNAME }} |           ORG_GRADLE_PROJECT_sonatypeUsername: ${{ secrets.SONATYPE_USERNAME }} | ||||||
| @@ -35,13 +36,13 @@ jobs: | |||||||
|           ORG_GRADLE_PROJECT_signingKey: ${{ secrets.SIGNING_KEY }} |           ORG_GRADLE_PROJECT_signingKey: ${{ secrets.SIGNING_KEY }} | ||||||
|           ORG_GRADLE_PROJECT_signingPassword: ${{ secrets.SIGNING_PASSWORD }} |           ORG_GRADLE_PROJECT_signingPassword: ${{ secrets.SIGNING_PASSWORD }} | ||||||
|       - name: Publish Snapshot |       - name: Publish Snapshot | ||||||
|         if: ${{ runner.os == 'Linux' && env.STATUS != 'release' && github.event_name == 'push' && github.ref == 'refs/heads/v6' }} |         if: ${{ runner.os == 'Linux' && env.STATUS != 'release' && github.event_name == 'push' && github.ref == 'refs/heads/main' }} | ||||||
|         run: ./gradlew publishToSonatype |         run: ./gradlew publishToSonatype | ||||||
|         env: |         env: | ||||||
|           ORG_GRADLE_PROJECT_sonatypeUsername: ${{ secrets.SONATYPE_USERNAME }} |           ORG_GRADLE_PROJECT_sonatypeUsername: ${{ secrets.SONATYPE_USERNAME }} | ||||||
|           ORG_GRADLE_PROJECT_sonatypePassword: ${{ secrets.SONATYPE_PASSWORD }} |           ORG_GRADLE_PROJECT_sonatypePassword: ${{ secrets.SONATYPE_PASSWORD }} | ||||||
|       - name: Publish core javadoc |       - name: Publish core javadoc | ||||||
|         if: ${{ runner.os == 'Linux' && env.STATUS == 'release' && github.event_name == 'push' && github.ref == 'refs/heads/v6'}} |         if: ${{ runner.os == 'Linux' && env.STATUS == 'release' && github.event_name == 'push' && github.ref == 'refs/heads/main'}} | ||||||
|         uses: cpina/github-action-push-to-another-repository@main |         uses: cpina/github-action-push-to-another-repository@main | ||||||
|         env: |         env: | ||||||
|           SSH_DEPLOY_KEY: ${{ secrets.SSH_DEPLOY_KEY }} |           SSH_DEPLOY_KEY: ${{ secrets.SSH_DEPLOY_KEY }} | ||||||
| @@ -51,9 +52,9 @@ jobs: | |||||||
|           destination-repository-name: 'plotsquared-javadocs' |           destination-repository-name: 'plotsquared-javadocs' | ||||||
|           user-email: ${{ secrets.USER_EMAIL }} |           user-email: ${{ secrets.USER_EMAIL }} | ||||||
|           target-branch: main |           target-branch: main | ||||||
|           target-directory: core |           target-directory: v7/core | ||||||
|       - name: Publish bukkit javadoc |       - name: Publish bukkit javadoc | ||||||
|         if: ${{ runner.os == 'Linux' && env.STATUS == 'release' && github.event_name == 'push' && github.ref == 'refs/heads/v6'}} |         if: ${{ runner.os == 'Linux' && env.STATUS == 'release' && github.event_name == 'push' && github.ref == 'refs/heads/main'}} | ||||||
|         uses: cpina/github-action-push-to-another-repository@main |         uses: cpina/github-action-push-to-another-repository@main | ||||||
|         env: |         env: | ||||||
|           SSH_DEPLOY_KEY: ${{ secrets.SSH_DEPLOY_KEY }} |           SSH_DEPLOY_KEY: ${{ secrets.SSH_DEPLOY_KEY }} | ||||||
| @@ -63,4 +64,4 @@ jobs: | |||||||
|           destination-repository-name: 'plotsquared-javadocs' |           destination-repository-name: 'plotsquared-javadocs' | ||||||
|           user-email: ${{ secrets.USER_EMAIL }} |           user-email: ${{ secrets.USER_EMAIL }} | ||||||
|           target-branch: main |           target-branch: main | ||||||
|           target-directory: bukkit |           target-directory: v7/bukkit | ||||||
|   | |||||||
							
								
								
									
										23
									
								
								.github/workflows/codeql.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										23
									
								
								.github/workflows/codeql.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,11 +1,10 @@ | |||||||
| name: "CodeQL" | name: "CodeQL" | ||||||
|  |  | ||||||
| on: | on: | ||||||
|   push: |   push: | ||||||
|     branches: [ v6 ] |     branches: [ main ] | ||||||
|   pull_request: |   pull_request: | ||||||
|     # The branches below must be a subset of the branches above |     # The branches below must be a subset of the branches above | ||||||
|     branches: [ v6 ] |     branches: [ main ] | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
|   analyze: |   analyze: | ||||||
| @@ -15,23 +14,23 @@ jobs: | |||||||
|       actions: read |       actions: read | ||||||
|       contents: read |       contents: read | ||||||
|       security-events: write |       security-events: write | ||||||
|  |  | ||||||
|     strategy: |     strategy: | ||||||
|       fail-fast: false |       fail-fast: false | ||||||
|       matrix: |       matrix: | ||||||
|         language: [ 'java' ] |         language: [ 'java' ] | ||||||
|  |  | ||||||
|     steps: |     steps: | ||||||
|       - name: Checkout repository |       - name: Checkout repository | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v4 | ||||||
|  |       - name: Setup Java | ||||||
|  |         uses: actions/setup-java@v4 | ||||||
|  |         with: | ||||||
|  |           distribution: temurin | ||||||
|  |           java-version: 21 | ||||||
|       - name: Initialize CodeQL |       - name: Initialize CodeQL | ||||||
|         uses: github/codeql-action/init@v2 |         uses: github/codeql-action/init@v3 | ||||||
|         with: |         with: | ||||||
|           languages: ${{ matrix.language }} |           languages: ${{ matrix.language }} | ||||||
|  |  | ||||||
|       - name: Autobuild |       - name: Autobuild | ||||||
|         uses: github/codeql-action/autobuild@v2 |         uses: github/codeql-action/autobuild@v3 | ||||||
|  |  | ||||||
|       - name: Perform CodeQL Analysis |       - name: Perform CodeQL Analysis | ||||||
|         uses: github/codeql-action/analyze@v2 |         uses: github/codeql-action/analyze@v3 | ||||||
|   | |||||||
							
								
								
									
										23
									
								
								.github/workflows/label-merge-conflicts.yaml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								.github/workflows/label-merge-conflicts.yaml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,23 @@ | |||||||
|  | name: "Label conflicting PRs" | ||||||
|  | on: | ||||||
|  |   push: | ||||||
|  |   pull_request_target: | ||||||
|  |     types: [ synchronize ] | ||||||
|  |   pull_request: | ||||||
|  |     types: [ synchronize ] | ||||||
|  |  | ||||||
|  | permissions: | ||||||
|  |   pull-requests: write | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   main: | ||||||
|  |     if: github.event.pull_request.user.login != 'dependabot[bot]' | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     steps: | ||||||
|  |       - name: Label conflicting PRs | ||||||
|  |         uses: eps1lon/actions-label-merge-conflict@v3.0.2 | ||||||
|  |         with: | ||||||
|  |           dirtyLabel: "unresolved-merge-conflict" | ||||||
|  |           repoToken: "${{ secrets.GITHUB_TOKEN }}" | ||||||
|  |           commentOnDirty: "Please take a moment and address the merge conflicts of your pull request. Thanks!" | ||||||
|  |           continueOnMissingPermissions: true | ||||||
							
								
								
									
										6
									
								
								.github/workflows/release-drafter.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								.github/workflows/release-drafter.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,19 +1,17 @@ | |||||||
| name: draft release | name: draft release | ||||||
|  |  | ||||||
| on: | on: | ||||||
|   push: |   push: | ||||||
|     branches: |     branches: | ||||||
|       - v6 |       - main | ||||||
|   pull_request: |   pull_request: | ||||||
|     types: [ opened, reopened, synchronize ] |     types: [ opened, reopened, synchronize ] | ||||||
|   pull_request_target: |   pull_request_target: | ||||||
|     types: [ opened, reopened, synchronize ] |     types: [ opened, reopened, synchronize ] | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
|   update_release_draft: |   update_release_draft: | ||||||
|     if: ${{ github.event_name != 'pull_request' || github.repository != github.event.pull_request.head.repo.full_name }} |     if: ${{ github.event_name != 'pull_request' || github.repository != github.event.pull_request.head.repo.full_name }} | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     steps: |     steps: | ||||||
|       - uses: release-drafter/release-drafter@v5 |       - uses: release-drafter/release-drafter@v6 | ||||||
|         env: |         env: | ||||||
|           GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} |           GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||||||
|   | |||||||
							
								
								
									
										3
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -137,3 +137,6 @@ docs/ | |||||||
| build/ | build/ | ||||||
|  |  | ||||||
| .DS_Store | .DS_Store | ||||||
|  | # Ignore run folders | ||||||
|  | run-[0-9].[0-9][0-9]/ | ||||||
|  | run-[0-9].[0-9][0-9].[0-9]/ | ||||||
|   | |||||||
							
								
								
									
										154
									
								
								.idea/icon.svg
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										154
									
								
								.idea/icon.svg
									
									
									
										generated
									
									
									
								
							| @@ -1,48 +1,144 @@ | |||||||
| <?xml version="1.0" encoding="UTF-8" standalone="no"?> | <?xml version="1.0" encoding="UTF-8" standalone="no"?> | ||||||
| <svg xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:cc="http://creativecommons.org/ns#" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:svg="http://www.w3.org/2000/svg" xmlns="http://www.w3.org/2000/svg" xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" version="1.1" id="svg2" xml:space="preserve" width="4000" height="3333.3333" viewBox="0 0 4000 3333.3333" sodipodi:docname="PlotSquared.ai"> | <svg | ||||||
| 		<metadata id="metadata8"> |    version="1.1" | ||||||
|  |    id="svg2" | ||||||
|  |    xml:space="preserve" | ||||||
|  |    width="512" | ||||||
|  |    height="512" | ||||||
|  |    viewBox="0 0 512 512.00001" | ||||||
|  |    sodipodi:docname="icon.svg" | ||||||
|  |    inkscape:version="1.1.2 (b8e25be8, 2022-02-05)" | ||||||
|  |    xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" | ||||||
|  |    xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" | ||||||
|  |    xmlns="http://www.w3.org/2000/svg" | ||||||
|  |    xmlns:svg="http://www.w3.org/2000/svg" | ||||||
|  |    xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" | ||||||
|  |    xmlns:cc="http://creativecommons.org/ns#" | ||||||
|  |    xmlns:dc="http://purl.org/dc/elements/1.1/"> | ||||||
|  | 		<metadata | ||||||
|  |    id="metadata8"> | ||||||
| 			<rdf:RDF> | 			<rdf:RDF> | ||||||
| 				<cc:Work rdf:about=""> | 				<cc:Work | ||||||
|  |    rdf:about=""> | ||||||
| 					<dc:format>image/svg+xml</dc:format> | 					<dc:format>image/svg+xml</dc:format> | ||||||
|                     <dc:type rdf:resource="http://purl.org/dc/dcmitype/StillImage" /> |                     <dc:type | ||||||
|  |    rdf:resource="http://purl.org/dc/dcmitype/StillImage" /> | ||||||
| 				</cc:Work> | 				</cc:Work> | ||||||
| 			</rdf:RDF> | 			</rdf:RDF> | ||||||
| 		</metadata> | 		</metadata> | ||||||
|     <defs id="defs6"> |     <defs | ||||||
| 			<clipPath clipPathUnits="userSpaceOnUse" id="clipPath18"> |    id="defs6"> | ||||||
| 				<path d="M 0,2500 H 3000 V 0 H 0 Z" id="path16" /> | 			<clipPath | ||||||
|  |    clipPathUnits="userSpaceOnUse" | ||||||
|  |    id="clipPath18"> | ||||||
|  | 				<path | ||||||
|  |    d="M 0,2500 H 3000 V 0 H 0 Z" | ||||||
|  |    id="path16" /> | ||||||
| 			</clipPath> | 			</clipPath> | ||||||
| 		</defs> | 		</defs> | ||||||
|     <sodipodi:namedview pagecolor="#ffffff" bordercolor="#666666" borderopacity="1" objecttolerance="10" gridtolerance="10" guidetolerance="10" inkscape:pageopacity="0" inkscape:pageshadow="2" inkscape:window-width="640" inkscape:window-height="480" id="namedview4" /> |     <sodipodi:namedview | ||||||
|     <g id="g10" inkscape:groupmode="layer" inkscape:label="PlotSquared" transform="matrix(1.3333333,0,0,-1.3333333,0,3333.3333)"> |    pagecolor="#ffffff" | ||||||
| 			<g id="g12"> |    bordercolor="#666666" | ||||||
| 				<g id="g14" clip-path="url(#clipPath18)"> |    borderopacity="1" | ||||||
| 					<g id="g20" transform="translate(1486.1511,2242.6453)"> |    objecttolerance="10" | ||||||
| 						<path d="m 0,0 c 16.533,10.846 33.211,21.453 50.104,31.699 78.972,-48.281 153.985,-102.704 227.269,-159.144 148.61,-115.422 287.884,-243.01 414.393,-382.333 111.39,-122.861 212.751,-255.152 298.898,-396.971 52.744,-87.322 100.544,-177.884 139.514,-272.214 -11.638,-3.551 -23.108,-7.655 -34.362,-12.286 l -0.24,0.288 c -11.135,12.982 -24.141,24.212 -34.915,37.506 -22.557,23.013 -45.425,45.737 -68.03,68.678 -19.725,20.253 -40.601,39.45 -58.958,60.974 -36.355,36.451 -72.517,73.093 -108.944,109.471 -22.628,26.013 -48.064,49.385 -71.965,74.197 -19.029,19.485 -38.706,38.346 -57.519,57.999 -12.166,14.998 -26.684,27.716 -39.93,41.658 -27.668,27.524 -54.903,55.479 -82.571,82.979 -23.924,27.956 -51.664,52.264 -76.692,79.164 -4.68,4.487 -8.855,10.774 -15.886,11.326 -22.34,34.027 -58.311,57.327 -97.377,67.502 -104.312,99.153 -215.487,191.202 -332.661,274.782 -117.942,-83.94 -229.476,-176.781 -334.484,-276.39 -26.684,-0.024 -53.368,0.024 -80.076,-0.024 0.024,-26.564 0.048,-53.104 0,-79.668 -72.229,-73.021 -139.491,-150.937 -202.385,-232.092 -63.758,-82.619 -121.973,-169.51 -173.541,-260.264 131.932,-69.061 257.864,-149.521 375.926,-240.275 0.096,-26.444 -0.12,-52.888 0.096,-79.332 l 0.744,-0.984 c 20.109,-24.14 43.409,-45.233 65.126,-67.861 15.118,-15.382 30.571,-30.404 45.569,-45.881 17.565,-20.733 37.698,-39.042 56.607,-58.503 19.917,-20.781 41.25,-40.218 59.967,-62.151 29.156,-29.299 58.167,-58.815 87.515,-87.922 29.155,-33.043 61.502,-63.111 92.169,-94.738 13.726,-12.67 25.124,-27.571 38.634,-40.457 25.029,-25.365 50.129,-50.657 75.325,-75.853 -37.914,-51.208 -73.741,-103.952 -107.192,-158.183 -167.83,273.317 -397.235,507.305 -662.37,687.158 -81.875,55.335 -167.23,105.584 -255.681,149.641 -52.815,26.276 -106.831,50.248 -162.239,70.381 99.393,233.628 242.795,446.715 410.289,636.79 93.562,106.088 194.634,205.433 301.466,298.13 C -217.335,-155.808 -111.439,-73.789 0,0" style="fill:#062f4c;fill-opacity:1;fill-rule:nonzero;stroke:none" id="path22" /> |    gridtolerance="10" | ||||||
|  |    guidetolerance="10" | ||||||
|  |    inkscape:pageopacity="0" | ||||||
|  |    inkscape:pageshadow="2" | ||||||
|  |    inkscape:window-width="1440" | ||||||
|  |    inkscape:window-height="900" | ||||||
|  |    id="namedview4" | ||||||
|  |    inkscape:pagecheckerboard="0" | ||||||
|  |    showgrid="false" | ||||||
|  |    inkscape:zoom="0.1632" | ||||||
|  |    inkscape:cx="1087.6225" | ||||||
|  |    inkscape:cy="1666.6666" | ||||||
|  |    inkscape:window-x="0" | ||||||
|  |    inkscape:window-y="0" | ||||||
|  |    inkscape:window-maximized="0" | ||||||
|  |    inkscape:current-layer="g10" /> | ||||||
|  |     <g | ||||||
|  |    id="g10" | ||||||
|  |    inkscape:groupmode="layer" | ||||||
|  |    inkscape:label="PlotSquared" | ||||||
|  |    transform="matrix(1.3333333,0,0,-1.3333333,0,3333.3333)"> | ||||||
|  | 			<g | ||||||
|  |    id="g12" | ||||||
|  |    transform="matrix(0.16955078,0,0,0.16955078,-68.456969,2101.8529)"> | ||||||
|  | 				<g | ||||||
|  |    id="g14" | ||||||
|  |    clip-path="url(#clipPath18)"> | ||||||
|  | 					<g | ||||||
|  |    id="g20" | ||||||
|  |    transform="translate(1486.1511,2242.6453)"> | ||||||
|  | 						<path | ||||||
|  |    d="m 0,0 c 16.533,10.846 33.211,21.453 50.104,31.699 78.972,-48.281 153.985,-102.704 227.269,-159.144 148.61,-115.422 287.884,-243.01 414.393,-382.333 111.39,-122.861 212.751,-255.152 298.898,-396.971 52.744,-87.322 100.544,-177.884 139.514,-272.214 -11.638,-3.551 -23.108,-7.655 -34.362,-12.286 l -0.24,0.288 c -11.135,12.982 -24.141,24.212 -34.915,37.506 -22.557,23.013 -45.425,45.737 -68.03,68.678 -19.725,20.253 -40.601,39.45 -58.958,60.974 -36.355,36.451 -72.517,73.093 -108.944,109.471 -22.628,26.013 -48.064,49.385 -71.965,74.197 -19.029,19.485 -38.706,38.346 -57.519,57.999 -12.166,14.998 -26.684,27.716 -39.93,41.658 -27.668,27.524 -54.903,55.479 -82.571,82.979 -23.924,27.956 -51.664,52.264 -76.692,79.164 -4.68,4.487 -8.855,10.774 -15.886,11.326 -22.34,34.027 -58.311,57.327 -97.377,67.502 -104.312,99.153 -215.487,191.202 -332.661,274.782 -117.942,-83.94 -229.476,-176.781 -334.484,-276.39 -26.684,-0.024 -53.368,0.024 -80.076,-0.024 0.024,-26.564 0.048,-53.104 0,-79.668 -72.229,-73.021 -139.491,-150.937 -202.385,-232.092 -63.758,-82.619 -121.973,-169.51 -173.541,-260.264 131.932,-69.061 257.864,-149.521 375.926,-240.275 0.096,-26.444 -0.12,-52.888 0.096,-79.332 l 0.744,-0.984 c 20.109,-24.14 43.409,-45.233 65.126,-67.861 15.118,-15.382 30.571,-30.404 45.569,-45.881 17.565,-20.733 37.698,-39.042 56.607,-58.503 19.917,-20.781 41.25,-40.218 59.967,-62.151 29.156,-29.299 58.167,-58.815 87.515,-87.922 29.155,-33.043 61.502,-63.111 92.169,-94.738 13.726,-12.67 25.124,-27.571 38.634,-40.457 25.029,-25.365 50.129,-50.657 75.325,-75.853 -37.914,-51.208 -73.741,-103.952 -107.192,-158.183 -167.83,273.317 -397.235,507.305 -662.37,687.158 -81.875,55.335 -167.23,105.584 -255.681,149.641 -52.815,26.276 -106.831,50.248 -162.239,70.381 99.393,233.628 242.795,446.715 410.289,636.79 93.562,106.088 194.634,205.433 301.466,298.13 C -217.335,-155.808 -111.439,-73.789 0,0" | ||||||
|  |    style="fill:#062f4c;fill-opacity:1;fill-rule:nonzero;stroke:none" | ||||||
|  |    id="path22" /> | ||||||
| 					</g> | 					</g> | ||||||
|                     <g id="g24" transform="translate(1201.7948,1741.5303)"> |                     <g | ||||||
| 						<path d="M 0,0 C 105.008,99.609 216.543,192.45 334.485,276.39 451.659,192.81 562.833,100.76 667.146,1.608 c -34.987,8.83 -71.51,9.718 -107.264,6.431 -41.202,-4.296 -82.907,-19.077 -112.543,-48.953 -33.019,-32.155 -49.456,-77.604 -55.311,-122.501 -28.124,27.908 -56.104,55.983 -84.035,84.083 -2.976,2.976 -6.839,4.823 -10.391,6.911 -19.029,26.348 -45.953,46.673 -76.62,57.495 C 187.555,-2.472 151.513,-0.12 116.166,0 Z" style="fill:#4c8fcc;fill-opacity:1;fill-rule:nonzero;stroke:none" id="path26" /> |    id="g24" | ||||||
|  |    transform="translate(1201.7948,1741.5303)"> | ||||||
|  | 						<path | ||||||
|  |    d="M 0,0 C 105.008,99.609 216.543,192.45 334.485,276.39 451.659,192.81 562.833,100.76 667.146,1.608 c -34.987,8.83 -71.51,9.718 -107.264,6.431 -41.202,-4.296 -82.907,-19.077 -112.543,-48.953 -33.019,-32.155 -49.456,-77.604 -55.311,-122.501 -28.124,27.908 -56.104,55.983 -84.035,84.083 -2.976,2.976 -6.839,4.823 -10.391,6.911 -19.029,26.348 -45.953,46.673 -76.62,57.495 C 187.555,-2.472 151.513,-0.12 116.166,0 Z" | ||||||
|  |    style="fill:#4c8fcc;fill-opacity:1;fill-rule:nonzero;stroke:none" | ||||||
|  |    id="path26" /> | ||||||
| 					</g> | 					</g> | ||||||
|                     <g id="g28" transform="translate(919.3342,1429.7462)"> |                     <g | ||||||
| 						<path d="m 0,0 c 62.894,81.156 130.156,159.072 202.385,232.092 0.048,-244.21 0.024,-488.421 0,-732.631 C 84.323,-409.785 -41.61,-329.325 -173.541,-260.264 -121.973,-169.51 -63.758,-82.619 0,0" style="fill:#4c8fcc;fill-opacity:1;fill-rule:nonzero;stroke:none" id="path30" /> |    id="g28" | ||||||
|  |    transform="translate(919.3342,1429.7462)"> | ||||||
|  | 						<path | ||||||
|  |    d="m 0,0 c 62.894,81.156 130.156,159.072 202.385,232.092 0.048,-244.21 0.024,-488.421 0,-732.631 C 84.323,-409.785 -41.61,-329.325 -173.541,-260.264 -121.973,-169.51 -63.758,-82.619 0,0" | ||||||
|  |    style="fill:#4c8fcc;fill-opacity:1;fill-rule:nonzero;stroke:none" | ||||||
|  |    id="path30" /> | ||||||
| 					</g> | 					</g> | ||||||
|                     <g id="g32" transform="translate(1649.134,1700.6166)"> |                     <g | ||||||
| 						<path d="m 0,0 c 29.635,29.875 71.341,44.657 112.543,48.952 35.754,3.288 72.277,2.4 107.263,-6.431 39.066,-10.174 75.037,-33.474 97.377,-67.501 11.879,-17.661 20.181,-37.411 26.42,-57.687 10.871,-38.802 11.95,-79.356 11.446,-119.358 -44.345,-0.072 -88.69,0.048 -133.035,-0.072 -1.032,30.907 3.263,63.686 -10.175,92.626 -9.526,20.325 -32.107,31.243 -53.751,32.131 -21.453,1.44 -45.065,-4.32 -59.175,-21.597 -12.79,-15.861 -15.382,-37.002 -16.558,-56.655 -1.295,-29.132 3.696,-59.031 17.518,-84.923 16.821,-30.619 39.378,-57.783 64.526,-81.9 31.387,-32.634 67.501,-60.374 97.857,-94.041 27.332,-28.988 51.256,-61.479 68.005,-97.785 20.541,-41.13 26.972,-87.827 25.82,-133.372 -0.912,-32.107 -5.231,-64.406 -16.149,-94.737 -11.59,-31.699 -31.123,-61.047 -58.335,-81.371 -25.124,-19.125 -55.696,-29.852 -86.651,-34.771 -49.552,-6.743 -101.888,-4.847 -148.465,14.854 -35.227,14.829 -64.238,42.689 -81.708,76.548 -20.996,40.242 -27.115,86.339 -27.259,131.212 0.048,17.829 0,35.658 0.048,53.463 44.345,0.048 88.69,-0.023 133.059,0.048 1.728,-35.538 -4.055,-72.06 5.663,-106.807 5.783,-22.173 26.204,-37.794 48.185,-41.754 20.733,-3.431 43.577,-2.015 61.622,9.791 15.502,9.43 23.949,26.78 26.78,44.225 5.903,35.922 1.872,74.293 -15.381,106.688 -16.918,30.595 -39.474,57.711 -64.55,81.899 -33.187,34.099 -71.173,63.254 -102.585,99.081 -26.756,28.867 -49.408,61.646 -65.486,97.641 -24.572,52.48 -26.731,112.422 -20.18,169.102 C -49.456,-77.604 -33.019,-32.155 0,0" style="fill:#feeeee;fill-opacity:1;fill-rule:nonzero;stroke:none" id="path34" /> |    id="g32" | ||||||
|  |    transform="translate(1649.134,1700.6166)"> | ||||||
|  | 						<path | ||||||
|  |    d="m 0,0 c 29.635,29.875 71.341,44.657 112.543,48.952 35.754,3.288 72.277,2.4 107.263,-6.431 39.066,-10.174 75.037,-33.474 97.377,-67.501 11.879,-17.661 20.181,-37.411 26.42,-57.687 10.871,-38.802 11.95,-79.356 11.446,-119.358 -44.345,-0.072 -88.69,0.048 -133.035,-0.072 -1.032,30.907 3.263,63.686 -10.175,92.626 -9.526,20.325 -32.107,31.243 -53.751,32.131 -21.453,1.44 -45.065,-4.32 -59.175,-21.597 -12.79,-15.861 -15.382,-37.002 -16.558,-56.655 -1.295,-29.132 3.696,-59.031 17.518,-84.923 16.821,-30.619 39.378,-57.783 64.526,-81.9 31.387,-32.634 67.501,-60.374 97.857,-94.041 27.332,-28.988 51.256,-61.479 68.005,-97.785 20.541,-41.13 26.972,-87.827 25.82,-133.372 -0.912,-32.107 -5.231,-64.406 -16.149,-94.737 -11.59,-31.699 -31.123,-61.047 -58.335,-81.371 -25.124,-19.125 -55.696,-29.852 -86.651,-34.771 -49.552,-6.743 -101.888,-4.847 -148.465,14.854 -35.227,14.829 -64.238,42.689 -81.708,76.548 -20.996,40.242 -27.115,86.339 -27.259,131.212 0.048,17.829 0,35.658 0.048,53.463 44.345,0.048 88.69,-0.023 133.059,0.048 1.728,-35.538 -4.055,-72.06 5.663,-106.807 5.783,-22.173 26.204,-37.794 48.185,-41.754 20.733,-3.431 43.577,-2.015 61.622,9.791 15.502,9.43 23.949,26.78 26.78,44.225 5.903,35.922 1.872,74.293 -15.381,106.688 -16.918,30.595 -39.474,57.711 -64.55,81.899 -33.187,34.099 -71.173,63.254 -102.585,99.081 -26.756,28.867 -49.408,61.646 -65.486,97.641 -24.572,52.48 -26.731,112.422 -20.18,169.102 C -49.456,-77.604 -33.019,-32.155 0,0" | ||||||
|  |    style="fill:#feeeee;fill-opacity:1;fill-rule:nonzero;stroke:none" | ||||||
|  |    id="path34" /> | ||||||
| 					</g> | 					</g> | ||||||
|                     <g id="g36" transform="translate(1262.7214,1613.126)"> |                     <g | ||||||
| 						<path d="m 0,0 v -301.13 c 23.204,0.024 46.409,-0.048 69.613,0.024 18.525,0.288 38.202,6.575 50.153,21.429 12.43,17.277 13.917,39.522 14.613,60.111 0.024,43.985 -0.048,87.994 0.024,131.979 -0.48,23.637 -0.983,50.369 -17.277,69.23 C 104.864,-5.711 86.867,-0.24 69.589,0 46.385,0.048 23.204,0.024 0,0 m -141.002,128.38 c 26.708,0.048 53.392,0 80.075,0.024 H 55.24 c 35.346,-0.12 71.389,-2.471 104.815,-14.925 30.668,-10.823 57.592,-31.148 76.621,-57.496 26.852,-39.09 36.69,-87.202 38.058,-133.947 0.024,-48.833 0.096,-97.689 -0.024,-146.521 -1.728,-47.993 -11.974,-97.953 -41.514,-136.971 -22.748,-30.644 -57.495,-50.801 -94.281,-59.583 -45.377,-11.878 -92.578,-6.791 -138.891,-7.847 -0.072,-111.799 0,-223.574 -0.024,-335.373 -13.942,0 -27.86,0.024 -41.778,-0.024 -32.802,0.072 -65.605,0 -98.384,0.048 l -0.744,0.984 c -0.216,26.444 0,52.888 -0.096,79.332 0.024,244.211 0.048,488.421 0,732.632 0.048,26.563 0.024,53.103 0,79.667" style="fill:#feeeee;fill-opacity:1;fill-rule:nonzero;stroke:none" id="path38" /> |    id="g36" | ||||||
|  |    transform="translate(1262.7214,1613.126)"> | ||||||
|  | 						<path | ||||||
|  |    d="m 0,0 v -301.13 c 23.204,0.024 46.409,-0.048 69.613,0.024 18.525,0.288 38.202,6.575 50.153,21.429 12.43,17.277 13.917,39.522 14.613,60.111 0.024,43.985 -0.048,87.994 0.024,131.979 -0.48,23.637 -0.983,50.369 -17.277,69.23 C 104.864,-5.711 86.867,-0.24 69.589,0 46.385,0.048 23.204,0.024 0,0 m -141.002,128.38 c 26.708,0.048 53.392,0 80.075,0.024 H 55.24 c 35.346,-0.12 71.389,-2.471 104.815,-14.925 30.668,-10.823 57.592,-31.148 76.621,-57.496 26.852,-39.09 36.69,-87.202 38.058,-133.947 0.024,-48.833 0.096,-97.689 -0.024,-146.521 -1.728,-47.993 -11.974,-97.953 -41.514,-136.971 -22.748,-30.644 -57.495,-50.801 -94.281,-59.583 -45.377,-11.878 -92.578,-6.791 -138.891,-7.847 -0.072,-111.799 0,-223.574 -0.024,-335.373 -13.942,0 -27.86,0.024 -41.778,-0.024 -32.802,0.072 -65.605,0 -98.384,0.048 l -0.744,0.984 c -0.216,26.444 0,52.888 -0.096,79.332 0.024,244.211 0.048,488.421 0,732.632 0.048,26.563 0.024,53.103 0,79.667" | ||||||
|  |    style="fill:#feeeee;fill-opacity:1;fill-rule:nonzero;stroke:none" | ||||||
|  |    id="path38" /> | ||||||
| 					</g> | 					</g> | ||||||
|                     <g id="g40" transform="translate(1966.3174,1675.6364)"> |                     <g | ||||||
| 						<path d="m 0,0 c 7.031,-0.552 11.206,-6.839 15.885,-11.326 25.029,-26.9 52.768,-51.208 76.693,-79.164 27.667,-27.5 54.903,-55.456 82.571,-82.979 13.246,-13.942 27.764,-26.66 39.93,-41.658 18.813,-19.653 38.49,-38.514 57.519,-57.999 23.9,-24.812 49.337,-48.185 71.965,-74.197 36.427,-36.378 72.589,-73.02 108.943,-109.471 18.358,-21.524 39.234,-40.722 58.959,-60.974 22.605,-22.941 45.473,-45.665 68.03,-68.678 10.774,-13.294 23.78,-24.524 34.914,-37.506 -103.904,-41.97 -203.488,-94.114 -298.922,-152.761 -246.994,-152.28 -466.224,-350.298 -639.333,-583.398 -25.197,25.196 -50.297,50.488 -75.325,75.852 -13.51,12.886 -24.908,27.788 -38.634,40.458 -30.667,31.627 -63.014,61.695 -92.17,94.738 -29.347,29.107 -58.359,58.623 -87.514,87.922 -18.717,21.933 -40.05,41.37 -59.967,62.151 -18.909,19.461 -39.042,37.77 -56.607,58.503 -14.998,15.477 -30.452,30.499 -45.569,45.88 -21.717,22.629 -45.017,43.722 -65.126,67.862 32.779,-0.048 65.582,0.024 98.384,-0.048 114.391,-98.097 220.407,-205.984 315.384,-322.99 92.914,114.318 196.242,220.022 307.753,316.271 30.955,4.919 61.526,15.646 86.65,34.771 27.212,20.325 46.745,49.672 58.335,81.371 107.312,77.988 219.327,149.929 337.509,210.376 -35.299,64.67 -75.829,126.437 -118.254,186.643 C 176.253,-228.037 104.24,-140.115 26.42,-57.687 20.181,-37.41 11.878,-17.661 0,0" style="fill:#042338;fill-opacity:1;fill-rule:nonzero;stroke:none" id="path42" /> |    id="g40" | ||||||
|  |    transform="translate(1966.3174,1675.6364)"> | ||||||
|  | 						<path | ||||||
|  |    d="m 0,0 c 7.031,-0.552 11.206,-6.839 15.885,-11.326 25.029,-26.9 52.768,-51.208 76.693,-79.164 27.667,-27.5 54.903,-55.456 82.571,-82.979 13.246,-13.942 27.764,-26.66 39.93,-41.658 18.813,-19.653 38.49,-38.514 57.519,-57.999 23.9,-24.812 49.337,-48.185 71.965,-74.197 36.427,-36.378 72.589,-73.02 108.943,-109.471 18.358,-21.524 39.234,-40.722 58.959,-60.974 22.605,-22.941 45.473,-45.665 68.03,-68.678 10.774,-13.294 23.78,-24.524 34.914,-37.506 -103.904,-41.97 -203.488,-94.114 -298.922,-152.761 -246.994,-152.28 -466.224,-350.298 -639.333,-583.398 -25.197,25.196 -50.297,50.488 -75.325,75.852 -13.51,12.886 -24.908,27.788 -38.634,40.458 -30.667,31.627 -63.014,61.695 -92.17,94.738 -29.347,29.107 -58.359,58.623 -87.514,87.922 -18.717,21.933 -40.05,41.37 -59.967,62.151 -18.909,19.461 -39.042,37.77 -56.607,58.503 -14.998,15.477 -30.452,30.499 -45.569,45.88 -21.717,22.629 -45.017,43.722 -65.126,67.862 32.779,-0.048 65.582,0.024 98.384,-0.048 114.391,-98.097 220.407,-205.984 315.384,-322.99 92.914,114.318 196.242,220.022 307.753,316.271 30.955,4.919 61.526,15.646 86.65,34.771 27.212,20.325 46.745,49.672 58.335,81.371 107.312,77.988 219.327,149.929 337.509,210.376 -35.299,64.67 -75.829,126.437 -118.254,186.643 C 176.253,-228.037 104.24,-140.115 26.42,-57.687 20.181,-37.41 11.878,-17.661 0,0" | ||||||
|  |    style="fill:#042338;fill-opacity:1;fill-rule:nonzero;stroke:none" | ||||||
|  |    id="path42" /> | ||||||
| 					</g> | 					</g> | ||||||
|                     <g id="g44" transform="translate(1499.3971,1669.1094)"> |                     <g | ||||||
| 						<path d="m 0,0 c 3.551,-2.088 7.415,-3.935 10.39,-6.911 27.932,-28.1 55.912,-56.175 84.036,-84.083 -6.551,-56.679 -4.392,-116.622 20.18,-169.102 16.078,-35.994 38.73,-68.774 65.486,-97.641 31.412,-35.826 69.398,-64.982 102.585,-99.081 25.076,-24.188 47.632,-51.304 64.55,-81.899 17.253,-32.395 21.284,-70.765 15.381,-106.688 -2.831,-17.445 -11.278,-34.794 -26.78,-44.225 -18.045,-11.806 -40.889,-13.222 -61.622,-9.79 -21.981,3.959 -42.402,19.58 -48.185,41.753 -9.718,34.747 -3.935,71.269 -5.663,106.808 -44.369,-0.072 -88.714,0 -133.059,-0.048 -0.048,-17.806 0,-35.635 -0.048,-53.464 0.144,-44.873 6.263,-90.97 27.259,-131.212 17.47,-33.859 46.481,-61.718 81.708,-76.548 46.577,-19.701 98.913,-21.597 148.465,-14.854 -111.511,-96.249 -214.839,-201.953 -307.753,-316.271 -94.977,117.006 -200.993,224.893 -315.383,322.99 13.918,0.048 27.836,0.024 41.777,0.024 0.024,111.799 -0.048,223.574 0.024,335.372 46.313,1.056 93.514,-4.031 138.891,7.847 36.786,8.783 71.533,28.94 94.282,59.583 29.539,39.018 39.785,88.978 41.513,136.971 0.12,48.833 0.048,97.689 0.024,146.522 C 36.69,-87.203 26.852,-39.09 0,0" style="fill:#1c72ba;fill-opacity:1;fill-rule:nonzero;stroke:none" id="path46" /> |    id="g44" | ||||||
|  |    transform="translate(1499.3971,1669.1094)"> | ||||||
|  | 						<path | ||||||
|  |    d="m 0,0 c 3.551,-2.088 7.415,-3.935 10.39,-6.911 27.932,-28.1 55.912,-56.175 84.036,-84.083 -6.551,-56.679 -4.392,-116.622 20.18,-169.102 16.078,-35.994 38.73,-68.774 65.486,-97.641 31.412,-35.826 69.398,-64.982 102.585,-99.081 25.076,-24.188 47.632,-51.304 64.55,-81.899 17.253,-32.395 21.284,-70.765 15.381,-106.688 -2.831,-17.445 -11.278,-34.794 -26.78,-44.225 -18.045,-11.806 -40.889,-13.222 -61.622,-9.79 -21.981,3.959 -42.402,19.58 -48.185,41.753 -9.718,34.747 -3.935,71.269 -5.663,106.808 -44.369,-0.072 -88.714,0 -133.059,-0.048 -0.048,-17.806 0,-35.635 -0.048,-53.464 0.144,-44.873 6.263,-90.97 27.259,-131.212 17.47,-33.859 46.481,-61.718 81.708,-76.548 46.577,-19.701 98.913,-21.597 148.465,-14.854 -111.511,-96.249 -214.839,-201.953 -307.753,-316.271 -94.977,117.006 -200.993,224.893 -315.383,322.99 13.918,0.048 27.836,0.024 41.777,0.024 0.024,111.799 -0.048,223.574 0.024,335.372 46.313,1.056 93.514,-4.031 138.891,7.847 36.786,8.783 71.533,28.94 94.282,59.583 29.539,39.018 39.785,88.978 41.513,136.971 0.12,48.833 0.048,97.689 0.024,146.522 C 36.69,-87.203 26.852,-39.09 0,0" | ||||||
|  |    style="fill:#1c72ba;fill-opacity:1;fill-rule:nonzero;stroke:none" | ||||||
|  |    id="path46" /> | ||||||
| 					</g> | 					</g> | ||||||
|                     <g id="g48" transform="translate(1748.0469,1601.6797)"> |                     <g | ||||||
| 						<path d="M 0,0 C 14.11,17.277 37.722,23.036 59.175,21.597 80.82,20.709 103.4,9.791 112.927,-10.534 c 13.438,-28.94 9.142,-61.719 10.174,-92.626 44.345,0.12 88.691,0 133.036,0.072 0.504,40.002 -0.576,80.556 -11.447,119.358 77.82,-82.428 149.833,-170.35 215.583,-262.664 42.426,-60.207 82.956,-121.973 118.254,-186.643 -118.182,-60.447 -230.196,-132.388 -337.508,-210.376 10.918,30.331 15.238,62.63 16.149,94.737 1.152,45.545 -5.279,92.242 -25.82,133.372 -16.749,36.306 -40.673,68.797 -68.005,97.785 -30.355,33.667 -66.47,61.406 -97.857,94.041 -25.148,24.117 -47.705,51.28 -64.526,81.9 -13.822,25.892 -18.813,55.791 -17.517,84.923 C -15.382,-37.002 -12.79,-15.862 0,0" style="fill:#1c72ba;fill-opacity:1;fill-rule:nonzero;stroke:none" id="path50" /> |    id="g48" | ||||||
|  |    transform="translate(1748.0469,1601.6797)"> | ||||||
|  | 						<path | ||||||
|  |    d="M 0,0 C 14.11,17.277 37.722,23.036 59.175,21.597 80.82,20.709 103.4,9.791 112.927,-10.534 c 13.438,-28.94 9.142,-61.719 10.174,-92.626 44.345,0.12 88.691,0 133.036,0.072 0.504,40.002 -0.576,80.556 -11.447,119.358 77.82,-82.428 149.833,-170.35 215.583,-262.664 42.426,-60.207 82.956,-121.973 118.254,-186.643 -118.182,-60.447 -230.196,-132.388 -337.508,-210.376 10.918,30.331 15.238,62.63 16.149,94.737 1.152,45.545 -5.279,92.242 -25.82,133.372 -16.749,36.306 -40.673,68.797 -68.005,97.785 -30.355,33.667 -66.47,61.406 -97.857,94.041 -25.148,24.117 -47.705,51.28 -64.526,81.9 -13.822,25.892 -18.813,55.791 -17.517,84.923 C -15.382,-37.002 -12.79,-15.862 0,0" | ||||||
|  |    style="fill:#1c72ba;fill-opacity:1;fill-rule:nonzero;stroke:none" | ||||||
|  |    id="path50" /> | ||||||
| 					</g> | 					</g> | ||||||
|                     <g id="g52" transform="translate(1262.7214,1613.126)"> |                     <g | ||||||
| 						<path d="m 0,0 c 23.204,0.024 46.385,0.048 69.589,0 17.278,-0.24 35.275,-5.711 47.537,-18.357 16.294,-18.861 16.797,-45.593 17.277,-69.23 -0.072,-43.985 0,-87.994 -0.024,-131.979 -0.696,-20.589 -2.183,-42.834 -14.613,-60.111 -11.951,-14.854 -31.628,-21.141 -50.153,-21.429 -23.204,-0.072 -46.409,0 -69.613,-0.024 z" style="fill:#1c72ba;fill-opacity:1;fill-rule:nonzero;stroke:none" id="path54" /> |    id="g52" | ||||||
|  |    transform="translate(1262.7214,1613.126)"> | ||||||
|  | 						<path | ||||||
|  |    d="m 0,0 c 23.204,0.024 46.385,0.048 69.589,0 17.278,-0.24 35.275,-5.711 47.537,-18.357 16.294,-18.861 16.797,-45.593 17.277,-69.23 -0.072,-43.985 0,-87.994 -0.024,-131.979 -0.696,-20.589 -2.183,-42.834 -14.613,-60.111 -11.951,-14.854 -31.628,-21.141 -50.153,-21.429 -23.204,-0.072 -46.409,0 -69.613,-0.024 z" | ||||||
|  |    style="fill:#1c72ba;fill-opacity:1;fill-rule:nonzero;stroke:none" | ||||||
|  |    id="path54" /> | ||||||
| 					</g> | 					</g> | ||||||
| 				</g> | 				</g> | ||||||
| 			</g> | 			</g> | ||||||
|   | |||||||
| Before Width: | Height: | Size: 11 KiB After Width: | Height: | Size: 12 KiB | 
| @@ -21,20 +21,20 @@ dependencies { | |||||||
|     api(projects.plotsquaredCore) |     api(projects.plotsquaredCore) | ||||||
|  |  | ||||||
|     // Metrics |     // Metrics | ||||||
|     implementation("org.bstats:bstats-bukkit") |     implementation(libs.bstatsBukkit) | ||||||
|  |  | ||||||
|     // Paper |     // Paper | ||||||
|     compileOnly(libs.paper) |     compileOnly(libs.paper) | ||||||
|     implementation("io.papermc:paperlib") |     implementation(libs.paperlib) | ||||||
|  |  | ||||||
|     // Plugins |     // Plugins | ||||||
|     compileOnly(libs.worldeditBukkit) { |     compileOnly(libs.worldeditBukkit) { | ||||||
|         exclude(group = "org.bukkit") |         exclude(group = "org.bukkit") | ||||||
|         exclude(group = "org.spigotmc") |         exclude(group = "org.spigotmc") | ||||||
|     } |     } | ||||||
|     compileOnly("com.fastasyncworldedit:FastAsyncWorldEdit-Bukkit") { isTransitive = false } |     compileOnly(libs.faweBukkit) { isTransitive = false } | ||||||
|     testImplementation("com.fastasyncworldedit:FastAsyncWorldEdit-Bukkit") { isTransitive = false } |     testImplementation(libs.faweBukkit) { isTransitive = false } | ||||||
|     compileOnly("com.github.MilkBowl:VaultAPI") { |     compileOnly(libs.vault) { | ||||||
|         exclude(group = "org.bukkit") |         exclude(group = "org.bukkit") | ||||||
|     } |     } | ||||||
|     compileOnly(libs.placeholderapi) |     compileOnly(libs.placeholderapi) | ||||||
| @@ -44,15 +44,15 @@ dependencies { | |||||||
|  |  | ||||||
|     // Other libraries |     // Other libraries | ||||||
|     implementation(libs.squirrelid) { isTransitive = false } |     implementation(libs.squirrelid) { isTransitive = false } | ||||||
|     implementation("dev.notmyfault.serverlib:ServerLib") |     implementation(libs.serverlib) | ||||||
|  |  | ||||||
|     // Our libraries |     // Our libraries | ||||||
|     implementation(libs.arkitektonika) |     implementation(libs.arkitektonika) | ||||||
|     implementation(libs.http4j) |     implementation(libs.paster) | ||||||
|     implementation("com.intellectualsites.paster:Paster") |     implementation(libs.informativeAnnotations) | ||||||
|  |  | ||||||
|     // Adventure |     // Adventure | ||||||
|     implementation("net.kyori:adventure-platform-bukkit") |     implementation(libs.adventureBukkit) | ||||||
| } | } | ||||||
|  |  | ||||||
| tasks.processResources { | tasks.processResources { | ||||||
| @@ -62,10 +62,12 @@ tasks.processResources { | |||||||
| } | } | ||||||
|  |  | ||||||
| tasks.named<ShadowJar>("shadowJar") { | tasks.named<ShadowJar>("shadowJar") { | ||||||
|  |     dependsOn(":plotsquared-core:shadowJar") | ||||||
|     dependencies { |     dependencies { | ||||||
|         exclude(dependency("org.checkerframework:")) |         exclude(dependency("org.checkerframework:")) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     relocate("net.kyori.option", "com.plotsquared.core.configuration.option") | ||||||
|     relocate("net.kyori.adventure", "com.plotsquared.core.configuration.adventure") |     relocate("net.kyori.adventure", "com.plotsquared.core.configuration.adventure") | ||||||
|     relocate("net.kyori.examination", "com.plotsquared.core.configuration.examination") |     relocate("net.kyori.examination", "com.plotsquared.core.configuration.examination") | ||||||
|     relocate("io.papermc.lib", "com.plotsquared.bukkit.paperlib") |     relocate("io.papermc.lib", "com.plotsquared.bukkit.paperlib") | ||||||
| @@ -87,6 +89,7 @@ tasks.named<ShadowJar>("shadowJar") { | |||||||
|     relocate("javax.inject", "com.plotsquared.core.annotation.inject") |     relocate("javax.inject", "com.plotsquared.core.annotation.inject") | ||||||
|     relocate("net.jcip", "com.plotsquared.core.annotations.jcip") |     relocate("net.jcip", "com.plotsquared.core.annotations.jcip") | ||||||
|     relocate("edu.umd.cs.findbugs", "com.plotsquared.core.annotations.findbugs") |     relocate("edu.umd.cs.findbugs", "com.plotsquared.core.annotations.findbugs") | ||||||
|  |     relocate("com.intellectualsites.annotations", "com.plotsquared.core.annotations.informative") | ||||||
|  |  | ||||||
|     // Get rid of all the libs which are 100% unused. |     // Get rid of all the libs which are 100% unused. | ||||||
|     minimize() |     minimize() | ||||||
| @@ -96,12 +99,20 @@ tasks.named<ShadowJar>("shadowJar") { | |||||||
|  |  | ||||||
| tasks { | tasks { | ||||||
|     withType<Javadoc> { |     withType<Javadoc> { | ||||||
|  |         val isRelease = if (rootProject.version.toString().endsWith("-SNAPSHOT")) "TODO" else rootProject.version.toString() | ||||||
|         val opt = options as StandardJavadocDocletOptions |         val opt = options as StandardJavadocDocletOptions | ||||||
|         opt.links("https://jd.papermc.io/paper/1.18/") |         opt.links("https://jd.papermc.io/paper/1.20/") | ||||||
|         opt.links("https://docs.enginehub.org/javadoc/com.sk89q.worldedit/worldedit-bukkit/" + libs.worldeditBukkit.get().versionConstraint.toString()) |         opt.links("https://docs.enginehub.org/javadoc/com.sk89q.worldedit/worldedit-bukkit/" + libs.worldeditBukkit.get().versionConstraint.toString()) | ||||||
|         opt.links("https://intellectualsites.github.io/plotsquared-javadocs/core/") |         opt.links("https://intellectualsites.github.io/plotsquared-javadocs/core/") | ||||||
|         opt.links("https://jd.adventure.kyori.net/api/4.9.3/") |         opt.links("https://jd.advntr.dev/api/4.14.0/") | ||||||
|         opt.links("https://google.github.io/guice/api-docs/" + libs.guice.get().versionConstraint.toString() + "/javadoc/") |         opt.links("https://google.github.io/guice/api-docs/" + libs.guice.get().versionConstraint.toString() + "/javadoc/") | ||||||
|         opt.links("https://checkerframework.org/api/") |         opt.links("https://checkerframework.org/api/") | ||||||
|  |         opt.isLinkSource = true | ||||||
|  |         opt.bottom(File("$rootDir/javadocfooter.html").readText()) | ||||||
|  |         opt.isUse = true | ||||||
|  |         opt.encoding("UTF-8") | ||||||
|  |         opt.keyWords() | ||||||
|  |         opt.addStringOption("-since", isRelease) | ||||||
|  |         opt.noTimestamp() | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -24,7 +24,6 @@ import com.google.inject.Injector; | |||||||
| import com.google.inject.Key; | import com.google.inject.Key; | ||||||
| import com.google.inject.Singleton; | import com.google.inject.Singleton; | ||||||
| import com.google.inject.Stage; | import com.google.inject.Stage; | ||||||
| import com.google.inject.TypeLiteral; |  | ||||||
| import com.plotsquared.bukkit.generator.BukkitPlotGenerator; | import com.plotsquared.bukkit.generator.BukkitPlotGenerator; | ||||||
| import com.plotsquared.bukkit.inject.BackupModule; | import com.plotsquared.bukkit.inject.BackupModule; | ||||||
| import com.plotsquared.bukkit.inject.BukkitModule; | import com.plotsquared.bukkit.inject.BukkitModule; | ||||||
| @@ -35,20 +34,22 @@ import com.plotsquared.bukkit.listener.BlockEventListener117; | |||||||
| import com.plotsquared.bukkit.listener.ChunkListener; | import com.plotsquared.bukkit.listener.ChunkListener; | ||||||
| import com.plotsquared.bukkit.listener.EntityEventListener; | import com.plotsquared.bukkit.listener.EntityEventListener; | ||||||
| import com.plotsquared.bukkit.listener.EntitySpawnListener; | import com.plotsquared.bukkit.listener.EntitySpawnListener; | ||||||
|  | import com.plotsquared.bukkit.listener.HighFreqBlockEventListener; | ||||||
| import com.plotsquared.bukkit.listener.PaperListener; | import com.plotsquared.bukkit.listener.PaperListener; | ||||||
| import com.plotsquared.bukkit.listener.PaperListener113; |  | ||||||
| import com.plotsquared.bukkit.listener.PlayerEventListener; | import com.plotsquared.bukkit.listener.PlayerEventListener; | ||||||
|  | import com.plotsquared.bukkit.listener.PlayerEventListener1201; | ||||||
| import com.plotsquared.bukkit.listener.ProjectileEventListener; | import com.plotsquared.bukkit.listener.ProjectileEventListener; | ||||||
| import com.plotsquared.bukkit.listener.ServerListener; | import com.plotsquared.bukkit.listener.ServerListener; | ||||||
| import com.plotsquared.bukkit.listener.SingleWorldListener; | import com.plotsquared.bukkit.listener.SingleWorldListener; | ||||||
|  | import com.plotsquared.bukkit.listener.SpigotListener; | ||||||
| import com.plotsquared.bukkit.listener.WorldEvents; | import com.plotsquared.bukkit.listener.WorldEvents; | ||||||
| import com.plotsquared.bukkit.placeholder.PAPIPlaceholders; | import com.plotsquared.bukkit.placeholder.PAPIPlaceholders; | ||||||
| import com.plotsquared.bukkit.placeholder.PlaceholderFormatter; | import com.plotsquared.bukkit.placeholder.PlaceholderFormatter; | ||||||
| import com.plotsquared.bukkit.player.BukkitPlayer; |  | ||||||
| import com.plotsquared.bukkit.player.BukkitPlayerManager; | import com.plotsquared.bukkit.player.BukkitPlayerManager; | ||||||
| import com.plotsquared.bukkit.util.BukkitUtil; | import com.plotsquared.bukkit.util.BukkitUtil; | ||||||
| import com.plotsquared.bukkit.util.BukkitWorld; | import com.plotsquared.bukkit.util.BukkitWorld; | ||||||
| import com.plotsquared.bukkit.util.SetGenCB; | import com.plotsquared.bukkit.util.SetGenCB; | ||||||
|  | import com.plotsquared.bukkit.util.TranslationUpdateManager; | ||||||
| import com.plotsquared.bukkit.util.UpdateUtility; | import com.plotsquared.bukkit.util.UpdateUtility; | ||||||
| import com.plotsquared.bukkit.util.task.BukkitTaskManager; | import com.plotsquared.bukkit.util.task.BukkitTaskManager; | ||||||
| import com.plotsquared.bukkit.util.task.PaperTimeConverter; | import com.plotsquared.bukkit.util.task.PaperTimeConverter; | ||||||
| @@ -71,6 +72,8 @@ import com.plotsquared.core.configuration.Storage; | |||||||
| import com.plotsquared.core.configuration.caption.ChatFormatter; | import com.plotsquared.core.configuration.caption.ChatFormatter; | ||||||
| import com.plotsquared.core.configuration.file.YamlConfiguration; | import com.plotsquared.core.configuration.file.YamlConfiguration; | ||||||
| import com.plotsquared.core.database.DBFunc; | import com.plotsquared.core.database.DBFunc; | ||||||
|  | import com.plotsquared.core.events.RemoveRoadEntityEvent; | ||||||
|  | import com.plotsquared.core.events.Result; | ||||||
| import com.plotsquared.core.generator.GeneratorWrapper; | import com.plotsquared.core.generator.GeneratorWrapper; | ||||||
| import com.plotsquared.core.generator.IndependentPlotGenerator; | import com.plotsquared.core.generator.IndependentPlotGenerator; | ||||||
| import com.plotsquared.core.generator.SingleWorldGenerator; | import com.plotsquared.core.generator.SingleWorldGenerator; | ||||||
| @@ -109,6 +112,7 @@ import com.plotsquared.core.uuid.CacheUUIDService; | |||||||
| import com.plotsquared.core.uuid.UUIDPipeline; | import com.plotsquared.core.uuid.UUIDPipeline; | ||||||
| import com.plotsquared.core.uuid.offline.OfflineModeUUIDService; | import com.plotsquared.core.uuid.offline.OfflineModeUUIDService; | ||||||
| import com.sk89q.worldedit.WorldEdit; | import com.sk89q.worldedit.WorldEdit; | ||||||
|  | import com.sk89q.worldedit.bukkit.BukkitAdapter; | ||||||
| import io.papermc.lib.PaperLib; | import io.papermc.lib.PaperLib; | ||||||
| import net.kyori.adventure.audience.Audience; | import net.kyori.adventure.audience.Audience; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| @@ -131,12 +135,14 @@ import org.bukkit.generator.ChunkGenerator; | |||||||
| import org.bukkit.metadata.FixedMetadataValue; | import org.bukkit.metadata.FixedMetadataValue; | ||||||
| import org.bukkit.metadata.MetadataValue; | import org.bukkit.metadata.MetadataValue; | ||||||
| import org.bukkit.plugin.Plugin; | import org.bukkit.plugin.Plugin; | ||||||
|  | import org.bukkit.plugin.RegisteredServiceProvider; | ||||||
| import org.bukkit.plugin.java.JavaPlugin; | import org.bukkit.plugin.java.JavaPlugin; | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
| import org.checkerframework.checker.nullness.qual.Nullable; | import org.checkerframework.checker.nullness.qual.Nullable; | ||||||
| import org.incendo.serverlib.ServerLib; | import org.incendo.serverlib.ServerLib; | ||||||
|  |  | ||||||
| import java.io.File; | import java.io.File; | ||||||
|  | import java.io.IOException; | ||||||
| import java.lang.reflect.Method; | import java.lang.reflect.Method; | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
| import java.util.Arrays; | import java.util.Arrays; | ||||||
| @@ -247,6 +253,7 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|  |     @SuppressWarnings("deprecation") // Paper deprecation | ||||||
|     public void onEnable() { |     public void onEnable() { | ||||||
|         this.pluginName = getDescription().getName(); |         this.pluginName = getDescription().getName(); | ||||||
|  |  | ||||||
| @@ -290,6 +297,12 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|                 ); |                 ); | ||||||
|         this.injector.injectMembers(this); |         this.injector.injectMembers(this); | ||||||
|  |  | ||||||
|  |         try { | ||||||
|  |             this.injector.getInstance(TranslationUpdateManager.class).upgradeTranslationFile(); | ||||||
|  |         } catch (IOException e) { | ||||||
|  |             throw new RuntimeException(e); | ||||||
|  |         } | ||||||
|  |  | ||||||
|         this.serverLocale = Locale.forLanguageTag(Settings.Enabled_Components.DEFAULT_LOCALE); |         this.serverLocale = Locale.forLanguageTag(Settings.Enabled_Components.DEFAULT_LOCALE); | ||||||
|  |  | ||||||
|         if (PremiumVerification.isPremium() && Settings.Enabled_Components.UPDATE_NOTIFICATIONS) { |         if (PremiumVerification.isPremium() && Settings.Enabled_Components.UPDATE_NOTIFICATIONS) { | ||||||
| @@ -346,7 +359,13 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|  |  | ||||||
|         if (Settings.Enabled_Components.EVENTS) { |         if (Settings.Enabled_Components.EVENTS) { | ||||||
|             getServer().getPluginManager().registerEvents(injector().getInstance(PlayerEventListener.class), this); |             getServer().getPluginManager().registerEvents(injector().getInstance(PlayerEventListener.class), this); | ||||||
|  |             if ((serverVersion()[1] == 20 && serverVersion()[2] >= 1) || serverVersion()[1] > 20) { | ||||||
|  |                 getServer().getPluginManager().registerEvents(injector().getInstance(PlayerEventListener1201.class), this); | ||||||
|  |             } | ||||||
|             getServer().getPluginManager().registerEvents(injector().getInstance(BlockEventListener.class), this); |             getServer().getPluginManager().registerEvents(injector().getInstance(BlockEventListener.class), this); | ||||||
|  |             if (Settings.HIGH_FREQUENCY_LISTENER) { | ||||||
|  |                 getServer().getPluginManager().registerEvents(injector().getInstance(HighFreqBlockEventListener.class), this); | ||||||
|  |             } | ||||||
|             if (serverVersion()[1] >= 17) { |             if (serverVersion()[1] >= 17) { | ||||||
|                 getServer().getPluginManager().registerEvents(injector().getInstance(BlockEventListener117.class), this); |                 getServer().getPluginManager().registerEvents(injector().getInstance(BlockEventListener117.class), this); | ||||||
|             } |             } | ||||||
| @@ -355,11 +374,9 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|             getServer().getPluginManager().registerEvents(injector().getInstance(ServerListener.class), this); |             getServer().getPluginManager().registerEvents(injector().getInstance(ServerListener.class), this); | ||||||
|             getServer().getPluginManager().registerEvents(injector().getInstance(EntitySpawnListener.class), this); |             getServer().getPluginManager().registerEvents(injector().getInstance(EntitySpawnListener.class), this); | ||||||
|             if (PaperLib.isPaper() && Settings.Paper_Components.PAPER_LISTENERS) { |             if (PaperLib.isPaper() && Settings.Paper_Components.PAPER_LISTENERS) { | ||||||
|                 if (serverVersion()[1] == 13) { |  | ||||||
|                     getServer().getPluginManager().registerEvents(injector().getInstance(PaperListener113.class), this); |  | ||||||
|                 } else { |  | ||||||
|                 getServer().getPluginManager().registerEvents(injector().getInstance(PaperListener.class), this); |                 getServer().getPluginManager().registerEvents(injector().getInstance(PaperListener.class), this); | ||||||
|                 } |             } else { | ||||||
|  |                 getServer().getPluginManager().registerEvents(injector().getInstance(SpigotListener.class), this); | ||||||
|             } |             } | ||||||
|             this.plotListener.startRunnable(); |             this.plotListener.startRunnable(); | ||||||
|         } |         } | ||||||
| @@ -541,7 +558,7 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|         this.startMetrics(); |         this.startMetrics(); | ||||||
|  |  | ||||||
|         if (Settings.Enabled_Components.WORLDS) { |         if (Settings.Enabled_Components.WORLDS) { | ||||||
|             TaskManager.getPlatformImplementation().taskRepeat(this::unload, TaskTime.seconds(1L)); |             TaskManager.getPlatformImplementation().taskRepeat(this::unload, TaskTime.seconds(10L)); | ||||||
|             try { |             try { | ||||||
|                 singleWorldListener = injector().getInstance(SingleWorldListener.class); |                 singleWorldListener = injector().getInstance(SingleWorldListener.class); | ||||||
|                 Bukkit.getPluginManager().registerEvents(singleWorldListener, this); |                 Bukkit.getPluginManager().registerEvents(singleWorldListener, this); | ||||||
| @@ -656,20 +673,15 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|             final @NonNull SQLiteUUIDService sqLiteUUIDService, |             final @NonNull SQLiteUUIDService sqLiteUUIDService, | ||||||
|             final @NonNull CacheUUIDService cacheUUIDService |             final @NonNull CacheUUIDService cacheUUIDService | ||||||
|     ) { |     ) { | ||||||
|         // Load all uuids into a big chunky boi queue |         // Record all unique UUID's and put them into a queue | ||||||
|         final Queue<UUID> uuidQueue = new LinkedBlockingQueue<>(); |         final Set<UUID> uuidSet = new HashSet<>(); | ||||||
|         PlotSquared.get().forEachPlotRaw(plot -> { |         PlotSquared.get().forEachPlotRaw(plot -> { | ||||||
|             final Set<UUID> uuids = new HashSet<>(); |             uuidSet.add(plot.getOwnerAbs()); | ||||||
|             uuids.add(plot.getOwnerAbs()); |             uuidSet.addAll(plot.getMembers()); | ||||||
|             uuids.addAll(plot.getMembers()); |             uuidSet.addAll(plot.getTrusted()); | ||||||
|             uuids.addAll(plot.getTrusted()); |             uuidSet.addAll(plot.getDenied()); | ||||||
|             uuids.addAll(plot.getDenied()); |  | ||||||
|             for (final UUID uuid : uuids) { |  | ||||||
|                 if (!uuidQueue.contains(uuid)) { |  | ||||||
|                     uuidQueue.add(uuid); |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         }); |         }); | ||||||
|  |         final Queue<UUID> uuidQueue = new LinkedBlockingQueue<>(uuidSet); | ||||||
|  |  | ||||||
|         LOGGER.info("(UUID) {} UUIDs will be cached", uuidQueue.size()); |         LOGGER.info("(UUID) {} UUIDs will be cached", uuidQueue.size()); | ||||||
|  |  | ||||||
| @@ -732,6 +744,11 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|         this.getServer().getPluginManager().disablePlugin(this); |         this.getServer().getPluginManager().disablePlugin(this); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public void shutdownServer() { | ||||||
|  |         getServer().shutdown(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     private void registerCommands() { |     private void registerCommands() { | ||||||
|         final BukkitCommand bukkitCommand = new BukkitCommand(); |         final BukkitCommand bukkitCommand = new BukkitCommand(); | ||||||
|         final PluginCommand plotCommand = getCommand("plots"); |         final PluginCommand plotCommand = getCommand("plots"); | ||||||
| @@ -764,6 +781,14 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|                 Iterator<Entity> iterator = entities.iterator(); |                 Iterator<Entity> iterator = entities.iterator(); | ||||||
|                 while (iterator.hasNext()) { |                 while (iterator.hasNext()) { | ||||||
|                     Entity entity = iterator.next(); |                     Entity entity = iterator.next(); | ||||||
|  |                     //noinspection ConstantValue - getEntitySpawnReason annotated as NotNull, but is not NotNull. lol. | ||||||
|  |                     if (PaperLib.isPaper() && entity.getEntitySpawnReason() != null && "CUSTOM".equals(entity.getEntitySpawnReason().name())) { | ||||||
|  |                         continue; | ||||||
|  |                     } | ||||||
|  |                     // Fallback for Spigot not having Entity#getEntitySpawnReason | ||||||
|  |                     if (entity.getMetadata("ps_custom_spawned").stream().anyMatch(MetadataValue::asBoolean)) { | ||||||
|  |                         continue; | ||||||
|  |                     } | ||||||
|                     switch (entity.getType().toString()) { |                     switch (entity.getType().toString()) { | ||||||
|                         case "EGG": |                         case "EGG": | ||||||
|                         case "FISHING_HOOK": |                         case "FISHING_HOOK": | ||||||
| @@ -803,6 +828,7 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|                         case "MINECART_MOB_SPAWNER": |                         case "MINECART_MOB_SPAWNER": | ||||||
|                         case "ENDER_CRYSTAL": |                         case "ENDER_CRYSTAL": | ||||||
|                         case "MINECART_TNT": |                         case "MINECART_TNT": | ||||||
|  |                         case "CHEST_BOAT": | ||||||
|                         case "BOAT": |                         case "BOAT": | ||||||
|                             if (Settings.Enabled_Components.KILL_ROAD_VEHICLES) { |                             if (Settings.Enabled_Components.KILL_ROAD_VEHICLES) { | ||||||
|                                 com.plotsquared.core.location.Location location = BukkitUtil.adapt(entity.getLocation()); |                                 com.plotsquared.core.location.Location location = BukkitUtil.adapt(entity.getLocation()); | ||||||
| @@ -812,8 +838,7 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|                                         if (entity.hasMetadata("ps-tmp-teleport")) { |                                         if (entity.hasMetadata("ps-tmp-teleport")) { | ||||||
|                                             continue; |                                             continue; | ||||||
|                                         } |                                         } | ||||||
|                                         iterator.remove(); |                                         this.removeRoadEntity(entity, iterator); | ||||||
|                                         entity.remove(); |  | ||||||
|                                     } |                                     } | ||||||
|                                     continue; |                                     continue; | ||||||
|                                 } |                                 } | ||||||
| @@ -826,8 +851,7 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|                                     if (entity.hasMetadata("ps-tmp-teleport")) { |                                     if (entity.hasMetadata("ps-tmp-teleport")) { | ||||||
|                                         continue; |                                         continue; | ||||||
|                                     } |                                     } | ||||||
|                                     iterator.remove(); |                                     this.removeRoadEntity(entity, iterator); | ||||||
|                                     entity.remove(); |  | ||||||
|                                 } |                                 } | ||||||
|                             } |                             } | ||||||
|                             continue; |                             continue; | ||||||
| @@ -837,7 +861,7 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|                         case "DROPPED_ITEM": |                         case "DROPPED_ITEM": | ||||||
|                             if (Settings.Enabled_Components.KILL_ROAD_ITEMS |                             if (Settings.Enabled_Components.KILL_ROAD_ITEMS | ||||||
|                                     && plotArea.getOwnedPlotAbs(BukkitUtil.adapt(entity.getLocation())) == null) { |                                     && plotArea.getOwnedPlotAbs(BukkitUtil.adapt(entity.getLocation())) == null) { | ||||||
|                                 entity.remove(); |                                 this.removeRoadEntity(entity, iterator); | ||||||
|                             } |                             } | ||||||
|                             // dropped item |                             // dropped item | ||||||
|                             continue; |                             continue; | ||||||
| @@ -846,15 +870,14 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|                             // managed elsewhere |                             // managed elsewhere | ||||||
|                             continue; |                             continue; | ||||||
|                         case "SHULKER": |                         case "SHULKER": | ||||||
|                             if (Settings.Enabled_Components.KILL_ROAD_MOBS) { |                             if (Settings.Enabled_Components.KILL_ROAD_MOBS && (Settings.Enabled_Components.KILL_NAMED_ROAD_MOBS || entity.getCustomName() == null)) { | ||||||
|                                 LivingEntity livingEntity = (LivingEntity) entity; |                                 LivingEntity livingEntity = (LivingEntity) entity; | ||||||
|                                 List<MetadataValue> meta = entity.getMetadata("shulkerPlot"); |                                 List<MetadataValue> meta = entity.getMetadata("shulkerPlot"); | ||||||
|                                 if (!meta.isEmpty()) { |                                 if (!meta.isEmpty()) { | ||||||
|                                     if (livingEntity.isLeashed()) { |                                     if (livingEntity.isLeashed() && !Settings.Enabled_Components.KILL_OWNED_ROAD_MOBS) { | ||||||
|                                         continue; |                                         continue; | ||||||
|                                     } |                                     } | ||||||
|                                     List<MetadataValue> keep = entity.getMetadata("keep"); |                                     if (entity.hasMetadata("keep")) { | ||||||
|                                     if (!keep.isEmpty()) { |  | ||||||
|                                         continue; |                                         continue; | ||||||
|                                     } |                                     } | ||||||
|  |  | ||||||
| @@ -863,15 +886,12 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|                                         com.plotsquared.core.location.Location pLoc = BukkitUtil.adapt(entity.getLocation()); |                                         com.plotsquared.core.location.Location pLoc = BukkitUtil.adapt(entity.getLocation()); | ||||||
|                                         PlotArea area = pLoc.getPlotArea(); |                                         PlotArea area = pLoc.getPlotArea(); | ||||||
|                                         if (area != null) { |                                         if (area != null) { | ||||||
|                                             PlotId currentPlotId = area.getPlotAbs(pLoc).getId(); |                                             Plot currentPlot = area.getPlotAbs(pLoc); | ||||||
|                                             if (!originalPlotId.equals(currentPlotId) && (currentPlotId == null || !area.getPlot( |                                             if (currentPlot == null || !originalPlotId.equals(currentPlot.getId())) { | ||||||
|                                                             originalPlotId) |  | ||||||
|                                                     .equals(area.getPlot(currentPlotId)))) { |  | ||||||
|                                                 if (entity.hasMetadata("ps-tmp-teleport")) { |                                                 if (entity.hasMetadata("ps-tmp-teleport")) { | ||||||
|                                                     continue; |                                                     continue; | ||||||
|                                                 } |                                                 } | ||||||
|                                                 iterator.remove(); |                                                 this.removeRoadEntity(entity, iterator); | ||||||
|                                                 entity.remove(); |  | ||||||
|                                             } |                                             } | ||||||
|                                         } |                                         } | ||||||
|                                     } |                                     } | ||||||
| @@ -880,11 +900,11 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|                                     com.plotsquared.core.location.Location pLoc = BukkitUtil.adapt(entity.getLocation()); |                                     com.plotsquared.core.location.Location pLoc = BukkitUtil.adapt(entity.getLocation()); | ||||||
|                                     PlotArea area = pLoc.getPlotArea(); |                                     PlotArea area = pLoc.getPlotArea(); | ||||||
|                                     if (area != null) { |                                     if (area != null) { | ||||||
|                                         PlotId currentPlotId = area.getPlotAbs(pLoc).getId(); |                                         Plot currentPlot = area.getPlotAbs(pLoc); | ||||||
|                                         if (currentPlotId != null) { |                                         if (currentPlot != null) { | ||||||
|                                             entity.setMetadata( |                                             entity.setMetadata( | ||||||
|                                                     "shulkerPlot", |                                                     "shulkerPlot", | ||||||
|                                                     new FixedMetadataValue((Plugin) PlotSquared.platform(), currentPlotId) |                                                     new FixedMetadataValue((Plugin) PlotSquared.platform(), currentPlot.getId()) | ||||||
|                                             ); |                                             ); | ||||||
|                                         } |                                         } | ||||||
|                                     } |                                     } | ||||||
| @@ -970,23 +990,24 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|                                                 || !entity.hasMetadata("keep")) { |                                                 || !entity.hasMetadata("keep")) { | ||||||
|                                             Entity passenger = entity.getPassenger(); |                                             Entity passenger = entity.getPassenger(); | ||||||
|                                             if ((Settings.Enabled_Components.KILL_OWNED_ROAD_MOBS |                                             if ((Settings.Enabled_Components.KILL_OWNED_ROAD_MOBS | ||||||
|                                                     || !(passenger instanceof Player)) && entity.getMetadata("keep").isEmpty()) { |                                                     || !((passenger instanceof Player) || livingEntity.isLeashed())) | ||||||
|  |                                                     && (Settings.Enabled_Components.KILL_NAMED_ROAD_MOBS || entity.getCustomName() == null) | ||||||
|  |                                                     && entity.getMetadata("keep").isEmpty()) { | ||||||
|                                                 if (entity.hasMetadata("ps-tmp-teleport")) { |                                                 if (entity.hasMetadata("ps-tmp-teleport")) { | ||||||
|                                                     continue; |                                                     continue; | ||||||
|                                                 } |                                                 } | ||||||
|                                                 iterator.remove(); |                                                 this.removeRoadEntity(entity, iterator); | ||||||
|                                                 entity.remove(); |  | ||||||
|                                             } |                                             } | ||||||
|                                         } |                                         } | ||||||
|                                     } else { |                                     } else { | ||||||
|                                         Entity passenger = entity.getPassenger(); |                                         Entity passenger = entity.getPassenger(); | ||||||
|                                         if ((Settings.Enabled_Components.KILL_OWNED_ROAD_MOBS |                                         if ((Settings.Enabled_Components.KILL_OWNED_ROAD_MOBS || !(passenger instanceof Player)) | ||||||
|                                                 || !(passenger instanceof Player)) && entity.getMetadata("keep").isEmpty()) { |                                                 && (Settings.Enabled_Components.KILL_NAMED_ROAD_MOBS && entity.getCustomName() != null) | ||||||
|  |                                                 && entity.getMetadata("keep").isEmpty()) { | ||||||
|                                             if (entity.hasMetadata("ps-tmp-teleport")) { |                                             if (entity.hasMetadata("ps-tmp-teleport")) { | ||||||
|                                                 continue; |                                                 continue; | ||||||
|                                             } |                                             } | ||||||
|                                             iterator.remove(); |                                             this.removeRoadEntity(entity, iterator); | ||||||
|                                             entity.remove(); |  | ||||||
|                                         } |                                         } | ||||||
|                                     } |                                     } | ||||||
|                                 } |                                 } | ||||||
| @@ -1000,6 +1021,17 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|         }), TaskTime.seconds(1L)); |         }), TaskTime.seconds(1L)); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     private void removeRoadEntity(Entity entity, Iterator<Entity> entityIterator) { | ||||||
|  |         RemoveRoadEntityEvent event = eventDispatcher.callRemoveRoadEntity(BukkitAdapter.adapt(entity)); | ||||||
|  |  | ||||||
|  |         if (event.getEventResult() == Result.DENY) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         entityIterator.remove(); | ||||||
|  |         entity.remove(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public @Nullable |     public @Nullable | ||||||
|     final ChunkGenerator getDefaultWorldGenerator( |     final ChunkGenerator getDefaultWorldGenerator( | ||||||
| @@ -1144,6 +1176,7 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|         return new BukkitPlotGenerator(world, generator, this.plotAreaManager); |         return new BukkitPlotGenerator(world, generator, this.plotAreaManager); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @SuppressWarnings("deprecation") // Paper deprecation | ||||||
|     @Override |     @Override | ||||||
|     public @NonNull String pluginsFormatted() { |     public @NonNull String pluginsFormatted() { | ||||||
|         StringBuilder msg = new StringBuilder(); |         StringBuilder msg = new StringBuilder(); | ||||||
| @@ -1160,18 +1193,37 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|                     .append("  • Load Before: ").append(p.getDescription().getLoadBefore()).append("\n") |                     .append("  • Load Before: ").append(p.getDescription().getLoadBefore()).append("\n") | ||||||
|                     .append("  • Dependencies: ").append(p.getDescription().getDepend()).append("\n") |                     .append("  • Dependencies: ").append(p.getDescription().getDepend()).append("\n") | ||||||
|                     .append("  • Soft Dependencies: ").append(p.getDescription().getSoftDepend()).append("\n"); |                     .append("  • Soft Dependencies: ").append(p.getDescription().getSoftDepend()).append("\n"); | ||||||
|  |             List<RegisteredServiceProvider<?>> providers = Bukkit.getServicesManager().getRegistrations(p); | ||||||
|  |             if (!providers.isEmpty()) { | ||||||
|  |                 msg.append("  • Provided Services: \n"); | ||||||
|  |                 for (RegisteredServiceProvider<?> provider : providers) { | ||||||
|  |                     msg.append("    • ") | ||||||
|  |                             .append(provider.getService().getName()).append(" = ") | ||||||
|  |                             .append(provider.getProvider().getClass().getName()) | ||||||
|  |                             .append(" (priority: ").append(provider.getPriority()).append(")") | ||||||
|  |                             .append("\n"); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|         } |         } | ||||||
|         return msg.toString(); |         return msg.toString(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     @SuppressWarnings("ConstantConditions") |     @SuppressWarnings({"ConstantConditions", "deprecation"}) // Paper deprecation | ||||||
|     public @NonNull String worldEditImplementations() { |     public @NonNull String worldEditImplementations() { | ||||||
|         StringBuilder msg = new StringBuilder(); |         StringBuilder msg = new StringBuilder(); | ||||||
|         if (Bukkit.getPluginManager().getPlugin("FastAsyncWorldEdit") != null) { |         if (Bukkit.getPluginManager().getPlugin("FastAsyncWorldEdit") != null) { | ||||||
|             msg.append("FastAsyncWorldEdit: ").append(Bukkit.getPluginManager().getPlugin("FastAsyncWorldEdit").getDescription().getVersion()); |             msg.append("FastAsyncWorldEdit: ").append(Bukkit | ||||||
|  |                     .getPluginManager() | ||||||
|  |                     .getPlugin("FastAsyncWorldEdit") | ||||||
|  |                     .getDescription() | ||||||
|  |                     .getVersion()); | ||||||
|         } else if (Bukkit.getPluginManager().getPlugin("AsyncWorldEdit") != null) { |         } else if (Bukkit.getPluginManager().getPlugin("AsyncWorldEdit") != null) { | ||||||
|             msg.append("AsyncWorldEdit: ").append(Bukkit.getPluginManager().getPlugin("AsyncWorldEdit").getDescription().getVersion()).append("\n"); |             msg.append("AsyncWorldEdit: ").append(Bukkit | ||||||
|  |                     .getPluginManager() | ||||||
|  |                     .getPlugin("AsyncWorldEdit") | ||||||
|  |                     .getDescription() | ||||||
|  |                     .getVersion()).append("\n"); | ||||||
|             msg.append("WorldEdit: ").append(Bukkit.getPluginManager().getPlugin("WorldEdit").getDescription().getVersion()); |             msg.append("WorldEdit: ").append(Bukkit.getPluginManager().getPlugin("WorldEdit").getDescription().getVersion()); | ||||||
|         } else { |         } else { | ||||||
|             msg.append("WorldEdit: ").append(Bukkit.getPluginManager().getPlugin("WorldEdit").getDescription().getVersion()); |             msg.append("WorldEdit: ").append(Bukkit.getPluginManager().getPlugin("WorldEdit").getDescription().getVersion()); | ||||||
| @@ -1221,15 +1273,13 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public @NonNull PlatformWorldManager<?> worldManager() { |     public @NonNull PlatformWorldManager<?> worldManager() { | ||||||
|         return injector().getInstance(Key.get(new TypeLiteral<PlatformWorldManager<World>>() { |         return this.worldManager; | ||||||
|         })); |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     @NonNull |     @NonNull | ||||||
|     @SuppressWarnings("unchecked") |  | ||||||
|     public PlayerManager<? extends PlotPlayer<Player>, ? extends Player> playerManager() { |     public PlayerManager<? extends PlotPlayer<Player>, ? extends Player> playerManager() { | ||||||
|         return (PlayerManager<BukkitPlayer, Player>) injector().getInstance(PlayerManager.class); |         return this.playerManager; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|   | |||||||
| @@ -33,6 +33,7 @@ import org.bukkit.entity.Ageable; | |||||||
| import org.bukkit.entity.ArmorStand; | import org.bukkit.entity.ArmorStand; | ||||||
| import org.bukkit.entity.Bat; | import org.bukkit.entity.Bat; | ||||||
| import org.bukkit.entity.Boat; | import org.bukkit.entity.Boat; | ||||||
|  | import org.bukkit.entity.Breedable; | ||||||
| import org.bukkit.entity.ChestedHorse; | import org.bukkit.entity.ChestedHorse; | ||||||
| import org.bukkit.entity.EnderDragon; | import org.bukkit.entity.EnderDragon; | ||||||
| import org.bukkit.entity.Entity; | import org.bukkit.entity.Entity; | ||||||
| @@ -74,6 +75,7 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|     private HorseStats horse; |     private HorseStats horse; | ||||||
|     private boolean noGravity; |     private boolean noGravity; | ||||||
|  |  | ||||||
|  |     @SuppressWarnings("deprecation") // Deprecation exists since 1.20, while we support 1.16 onwards | ||||||
|     public ReplicatingEntityWrapper(Entity entity, short depth) { |     public ReplicatingEntityWrapper(Entity entity, short depth) { | ||||||
|         super(entity); |         super(entity); | ||||||
|  |  | ||||||
| @@ -101,50 +103,26 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|             this.noGravity = true; |             this.noGravity = true; | ||||||
|         } |         } | ||||||
|         switch (entity.getType().toString()) { |         switch (entity.getType().toString()) { | ||||||
|             case "BOAT": |             case "BOAT" -> { | ||||||
|                 Boat boat = (Boat) entity; |                 Boat boat = (Boat) entity; | ||||||
|                 this.dataByte = getOrdinal(TreeSpecies.values(), boat.getWoodType()); |                 this.dataByte = getOrdinal(TreeSpecies.values(), boat.getWoodType()); | ||||||
|                 return; |                 return; | ||||||
|             case "ARROW": |             } | ||||||
|             case "EGG": |             case "ARROW", "EGG", "ENDER_CRYSTAL", "ENDER_PEARL", "ENDER_SIGNAL", "EXPERIENCE_ORB", "FALLING_BLOCK", "FIREBALL", | ||||||
|             case "ENDER_CRYSTAL": |                     "FIREWORK", "FISHING_HOOK", "LEASH_HITCH", "LIGHTNING", "MINECART", "MINECART_COMMAND", "MINECART_MOB_SPAWNER", | ||||||
|             case "ENDER_PEARL": |                     "MINECART_TNT", "PLAYER", "PRIMED_TNT", "SLIME", "SMALL_FIREBALL", "SNOWBALL", "MINECART_FURNACE", "SPLASH_POTION", | ||||||
|             case "ENDER_SIGNAL": |                     "THROWN_EXP_BOTTLE", "WITHER_SKULL", "UNKNOWN", "SPECTRAL_ARROW", "SHULKER_BULLET", "DRAGON_FIREBALL", "AREA_EFFECT_CLOUD", | ||||||
|             case "EXPERIENCE_ORB": |                     "TRIDENT", "LLAMA_SPIT" -> { | ||||||
|             case "FALLING_BLOCK": |  | ||||||
|             case "FIREBALL": |  | ||||||
|             case "FIREWORK": |  | ||||||
|             case "FISHING_HOOK": |  | ||||||
|             case "LEASH_HITCH": |  | ||||||
|             case "LIGHTNING": |  | ||||||
|             case "MINECART": |  | ||||||
|             case "MINECART_COMMAND": |  | ||||||
|             case "MINECART_MOB_SPAWNER": |  | ||||||
|             case "MINECART_TNT": |  | ||||||
|             case "PLAYER": |  | ||||||
|             case "PRIMED_TNT": |  | ||||||
|             case "SLIME": |  | ||||||
|             case "SMALL_FIREBALL": |  | ||||||
|             case "SNOWBALL": |  | ||||||
|             case "MINECART_FURNACE": |  | ||||||
|             case "SPLASH_POTION": |  | ||||||
|             case "THROWN_EXP_BOTTLE": |  | ||||||
|             case "WITHER_SKULL": |  | ||||||
|             case "UNKNOWN": |  | ||||||
|             case "SPECTRAL_ARROW": |  | ||||||
|             case "SHULKER_BULLET": |  | ||||||
|             case "DRAGON_FIREBALL": |  | ||||||
|             case "AREA_EFFECT_CLOUD": |  | ||||||
|             case "TRIDENT": |  | ||||||
|             case "LLAMA_SPIT": |  | ||||||
|                 // Do this stuff later |                 // Do this stuff later | ||||||
|                 return; |                 return; | ||||||
|  |             } | ||||||
|             // MISC // |             // MISC // | ||||||
|             case "DROPPED_ITEM": |             case "DROPPED_ITEM" -> { | ||||||
|                 Item item = (Item) entity; |                 Item item = (Item) entity; | ||||||
|                 this.stack = item.getItemStack(); |                 this.stack = item.getItemStack(); | ||||||
|                 return; |                 return; | ||||||
|             case "ITEM_FRAME": |             } | ||||||
|  |             case "ITEM_FRAME" -> { | ||||||
|                 this.x = Math.floor(this.getX()); |                 this.x = Math.floor(this.getX()); | ||||||
|                 this.y = Math.floor(this.getY()); |                 this.y = Math.floor(this.getY()); | ||||||
|                 this.z = Math.floor(this.getZ()); |                 this.z = Math.floor(this.getZ()); | ||||||
| @@ -152,7 +130,8 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|                 this.dataByte = getOrdinal(Rotation.values(), itemFrame.getRotation()); |                 this.dataByte = getOrdinal(Rotation.values(), itemFrame.getRotation()); | ||||||
|                 this.stack = itemFrame.getItem().clone(); |                 this.stack = itemFrame.getItem().clone(); | ||||||
|                 return; |                 return; | ||||||
|             case "PAINTING": |             } | ||||||
|  |             case "PAINTING" -> { | ||||||
|                 this.x = Math.floor(this.getX()); |                 this.x = Math.floor(this.getX()); | ||||||
|                 this.y = Math.floor(this.getY()); |                 this.y = Math.floor(this.getY()); | ||||||
|                 this.z = Math.floor(this.getZ()); |                 this.z = Math.floor(this.getZ()); | ||||||
| @@ -165,20 +144,17 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|                 } |                 } | ||||||
|                 this.dataString = art.name(); |                 this.dataString = art.name(); | ||||||
|                 return; |                 return; | ||||||
|  |             } | ||||||
|             // END MISC // |             // END MISC // | ||||||
|             // INVENTORY HOLDER // |             // INVENTORY HOLDER // | ||||||
|             case "MINECART_CHEST": |             case "MINECART_CHEST", "MINECART_HOPPER" -> { | ||||||
|             case "MINECART_HOPPER": |  | ||||||
|                 storeInventory((InventoryHolder) entity); |                 storeInventory((InventoryHolder) entity); | ||||||
|                 return; |                 return; | ||||||
|  |             } | ||||||
|             // START LIVING ENTITY // |             // START LIVING ENTITY // | ||||||
|             // START AGEABLE // |             // START AGEABLE // | ||||||
|             // START TAMEABLE // |             // START TAMEABLE // | ||||||
|             case "HORSE": |             case "HORSE", "DONKEY", "LLAMA", "MULE", "SKELETON_HORSE" -> { | ||||||
|             case "DONKEY": |  | ||||||
|             case "LLAMA": |  | ||||||
|             case "MULE": |  | ||||||
|             case "SKELETON_HORSE": |  | ||||||
|                 AbstractHorse horse = (AbstractHorse) entity; |                 AbstractHorse horse = (AbstractHorse) entity; | ||||||
|                 this.horse = new HorseStats(); |                 this.horse = new HorseStats(); | ||||||
|                 this.horse.jump = horse.getJumpStrength(); |                 this.horse.jump = horse.getJumpStrength(); | ||||||
| @@ -190,20 +166,21 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|                 //this.horse.style = horse.getStyle(); |                 //this.horse.style = horse.getStyle(); | ||||||
|                 //this.horse.color = horse.getColor(); |                 //this.horse.color = horse.getColor(); | ||||||
|                 storeTameable(horse); |                 storeTameable(horse); | ||||||
|                 storeAgeable(horse); |                 storeBreedable(horse); | ||||||
|                 storeLiving(horse); |                 storeLiving(horse); | ||||||
|                 storeInventory(horse); |                 storeInventory(horse); | ||||||
|                 return; |                 return; | ||||||
|  |             } | ||||||
|             // END INVENTORY HOLDER // |             // END INVENTORY HOLDER // | ||||||
|             case "WOLF": |             case "WOLF", "OCELOT" -> { | ||||||
|             case "OCELOT": |  | ||||||
|                 storeTameable((Tameable) entity); |                 storeTameable((Tameable) entity); | ||||||
|                 storeAgeable((Ageable) entity); |                 storeBreedable((Breedable) entity); | ||||||
|                 storeLiving((LivingEntity) entity); |                 storeLiving((LivingEntity) entity); | ||||||
|                 return; |                 return; | ||||||
|  |             } | ||||||
|             // END TAMEABLE // |             // END TAMEABLE // | ||||||
|             //todo fix sheep |             //todo fix sheep | ||||||
|             case "SHEEP": |             case "SHEEP" -> { | ||||||
|                 Sheep sheep = (Sheep) entity; |                 Sheep sheep = (Sheep) entity; | ||||||
|                 if (sheep.isSheared()) { |                 if (sheep.isSheared()) { | ||||||
|                     this.dataByte = (byte) 1; |                     this.dataByte = (byte) 1; | ||||||
| @@ -211,26 +188,23 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|                     this.dataByte = (byte) 0; |                     this.dataByte = (byte) 0; | ||||||
|                 } |                 } | ||||||
|                 this.dataByte2 = sheep.getColor().getDyeData(); |                 this.dataByte2 = sheep.getColor().getDyeData(); | ||||||
|                 storeAgeable(sheep); |                 storeBreedable(sheep); | ||||||
|                 storeLiving(sheep); |                 storeLiving(sheep); | ||||||
|                 return; |                 return; | ||||||
|             case "VILLAGER": |             } | ||||||
|             case "CHICKEN": |             case "VILLAGER", "CHICKEN", "COW", "MUSHROOM_COW", "PIG", "TURTLE", "POLAR_BEAR" -> { | ||||||
|             case "COW": |                 storeBreedable((Breedable) entity); | ||||||
|             case "MUSHROOM_COW": |  | ||||||
|             case "PIG": |  | ||||||
|             case "TURTLE": |  | ||||||
|             case "POLAR_BEAR": |  | ||||||
|                 storeAgeable((Ageable) entity); |  | ||||||
|                 storeLiving((LivingEntity) entity); |                 storeLiving((LivingEntity) entity); | ||||||
|                 return; |                 return; | ||||||
|             case "RABBIT": |             } | ||||||
|  |             case "RABBIT" -> { | ||||||
|                 this.dataByte = getOrdinal(Rabbit.Type.values(), ((Rabbit) entity).getRabbitType()); |                 this.dataByte = getOrdinal(Rabbit.Type.values(), ((Rabbit) entity).getRabbitType()); | ||||||
|                 storeAgeable((Ageable) entity); |                 storeBreedable((Breedable) entity); | ||||||
|                 storeLiving((LivingEntity) entity); |                 storeLiving((LivingEntity) entity); | ||||||
|                 return; |                 return; | ||||||
|  |             } | ||||||
|             // END AGEABLE // |             // END AGEABLE // | ||||||
|             case "ARMOR_STAND": |             case "ARMOR_STAND" -> { | ||||||
|                 ArmorStand stand = (ArmorStand) entity; |                 ArmorStand stand = (ArmorStand) entity; | ||||||
|                 this.inventory = |                 this.inventory = | ||||||
|                         new ItemStack[]{stand.getItemInHand().clone(), stand.getHelmet().clone(), |                         new ItemStack[]{stand.getItemInHand().clone(), stand.getHelmet().clone(), | ||||||
| @@ -238,37 +212,30 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|                                 stand.getBoots().clone()}; |                                 stand.getBoots().clone()}; | ||||||
|                 storeLiving(stand); |                 storeLiving(stand); | ||||||
|                 this.stand = new ArmorStandStats(); |                 this.stand = new ArmorStandStats(); | ||||||
|  |  | ||||||
|                 EulerAngle head = stand.getHeadPose(); |                 EulerAngle head = stand.getHeadPose(); | ||||||
|                 this.stand.head[0] = (float) head.getX(); |                 this.stand.head[0] = (float) head.getX(); | ||||||
|                 this.stand.head[1] = (float) head.getY(); |                 this.stand.head[1] = (float) head.getY(); | ||||||
|                 this.stand.head[2] = (float) head.getZ(); |                 this.stand.head[2] = (float) head.getZ(); | ||||||
|  |  | ||||||
|                 EulerAngle body = stand.getBodyPose(); |                 EulerAngle body = stand.getBodyPose(); | ||||||
|                 this.stand.body[0] = (float) body.getX(); |                 this.stand.body[0] = (float) body.getX(); | ||||||
|                 this.stand.body[1] = (float) body.getY(); |                 this.stand.body[1] = (float) body.getY(); | ||||||
|                 this.stand.body[2] = (float) body.getZ(); |                 this.stand.body[2] = (float) body.getZ(); | ||||||
|  |  | ||||||
|                 EulerAngle leftLeg = stand.getLeftLegPose(); |                 EulerAngle leftLeg = stand.getLeftLegPose(); | ||||||
|                 this.stand.leftLeg[0] = (float) leftLeg.getX(); |                 this.stand.leftLeg[0] = (float) leftLeg.getX(); | ||||||
|                 this.stand.leftLeg[1] = (float) leftLeg.getY(); |                 this.stand.leftLeg[1] = (float) leftLeg.getY(); | ||||||
|                 this.stand.leftLeg[2] = (float) leftLeg.getZ(); |                 this.stand.leftLeg[2] = (float) leftLeg.getZ(); | ||||||
|  |  | ||||||
|                 EulerAngle rightLeg = stand.getRightLegPose(); |                 EulerAngle rightLeg = stand.getRightLegPose(); | ||||||
|                 this.stand.rightLeg[0] = (float) rightLeg.getX(); |                 this.stand.rightLeg[0] = (float) rightLeg.getX(); | ||||||
|                 this.stand.rightLeg[1] = (float) rightLeg.getY(); |                 this.stand.rightLeg[1] = (float) rightLeg.getY(); | ||||||
|                 this.stand.rightLeg[2] = (float) rightLeg.getZ(); |                 this.stand.rightLeg[2] = (float) rightLeg.getZ(); | ||||||
|  |  | ||||||
|                 EulerAngle leftArm = stand.getLeftArmPose(); |                 EulerAngle leftArm = stand.getLeftArmPose(); | ||||||
|                 this.stand.leftArm[0] = (float) leftArm.getX(); |                 this.stand.leftArm[0] = (float) leftArm.getX(); | ||||||
|                 this.stand.leftArm[1] = (float) leftArm.getY(); |                 this.stand.leftArm[1] = (float) leftArm.getY(); | ||||||
|                 this.stand.leftArm[2] = (float) leftArm.getZ(); |                 this.stand.leftArm[2] = (float) leftArm.getZ(); | ||||||
|  |  | ||||||
|                 EulerAngle rightArm = stand.getRightArmPose(); |                 EulerAngle rightArm = stand.getRightArmPose(); | ||||||
|                 this.stand.rightArm[0] = (float) rightArm.getX(); |                 this.stand.rightArm[0] = (float) rightArm.getX(); | ||||||
|                 this.stand.rightArm[1] = (float) rightArm.getY(); |                 this.stand.rightArm[1] = (float) rightArm.getY(); | ||||||
|                 this.stand.rightArm[2] = (float) rightArm.getZ(); |                 this.stand.rightArm[2] = (float) rightArm.getZ(); | ||||||
|  |  | ||||||
|                 if (stand.hasArms()) { |                 if (stand.hasArms()) { | ||||||
|                     this.stand.arms = true; |                     this.stand.arms = true; | ||||||
|                 } |                 } | ||||||
| @@ -282,52 +249,37 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|                     this.stand.small = true; |                     this.stand.small = true; | ||||||
|                 } |                 } | ||||||
|                 return; |                 return; | ||||||
|             case "ENDERMITE": |             } | ||||||
|  |             case "ENDERMITE" -> { | ||||||
|                 return; |                 return; | ||||||
|             case "BAT": |             } | ||||||
|  |             case "BAT" -> { | ||||||
|                 if (((Bat) entity).isAwake()) { |                 if (((Bat) entity).isAwake()) { | ||||||
|                     this.dataByte = (byte) 1; |                     this.dataByte = (byte) 1; | ||||||
|                 } else { |                 } else { | ||||||
|                     this.dataByte = (byte) 0; |                     this.dataByte = (byte) 0; | ||||||
|                 } |                 } | ||||||
|                 return; |                 return; | ||||||
|             case "ENDER_DRAGON": |             } | ||||||
|  |             case "ENDER_DRAGON" -> { | ||||||
|                 EnderDragon entity1 = (EnderDragon) entity; |                 EnderDragon entity1 = (EnderDragon) entity; | ||||||
|                 this.dataByte = (byte) entity1.getPhase().ordinal(); |                 this.dataByte = (byte) entity1.getPhase().ordinal(); | ||||||
|                 return; |                 return; | ||||||
|             case "SKELETON": |             } | ||||||
|             case "WITHER_SKELETON": |             case "SKELETON", "WITHER_SKELETON", "GUARDIAN", "ELDER_GUARDIAN", "GHAST", "MAGMA_CUBE", "SQUID", "PIG_ZOMBIE", "HOGLIN", | ||||||
|             case "GUARDIAN": |                     "ZOMBIFIED_PIGLIN", "PIGLIN", "PIGLIN_BRUTE", "ZOMBIE", "WITHER", "WITCH", "SPIDER", "CAVE_SPIDER", "SILVERFISH", | ||||||
|             case "ELDER_GUARDIAN": |                     "GIANT", "ENDERMAN", "CREEPER", "BLAZE", "SHULKER", "SNOWMAN" -> { | ||||||
|             case "GHAST": |  | ||||||
|             case "MAGMA_CUBE": |  | ||||||
|             case "SQUID": |  | ||||||
|             case "PIG_ZOMBIE": |  | ||||||
|             case "HOGLIN": |  | ||||||
|             case "ZOMBIFIED_PIGLIN": |  | ||||||
|             case "PIGLIN": |  | ||||||
|             case "PIGLIN_BRUTE": |  | ||||||
|             case "ZOMBIE": |  | ||||||
|             case "WITHER": |  | ||||||
|             case "WITCH": |  | ||||||
|             case "SPIDER": |  | ||||||
|             case "CAVE_SPIDER": |  | ||||||
|             case "SILVERFISH": |  | ||||||
|             case "GIANT": |  | ||||||
|             case "ENDERMAN": |  | ||||||
|             case "CREEPER": |  | ||||||
|             case "BLAZE": |  | ||||||
|             case "SHULKER": |  | ||||||
|             case "SNOWMAN": |  | ||||||
|                 storeLiving((LivingEntity) entity); |                 storeLiving((LivingEntity) entity); | ||||||
|                 return; |                 return; | ||||||
|             case "IRON_GOLEM": |             } | ||||||
|  |             case "IRON_GOLEM" -> { | ||||||
|                 if (((IronGolem) entity).isPlayerCreated()) { |                 if (((IronGolem) entity).isPlayerCreated()) { | ||||||
|                     this.dataByte = (byte) 1; |                     this.dataByte = (byte) 1; | ||||||
|                 } else { |                 } else { | ||||||
|                     this.dataByte = (byte) 0; |                     this.dataByte = (byte) 0; | ||||||
|                 } |                 } | ||||||
|                 storeLiving((LivingEntity) entity); |                 storeLiving((LivingEntity) entity); | ||||||
|  |             } | ||||||
|             // END LIVING // |             // END LIVING // | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| @@ -431,6 +383,11 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @deprecated Use {@link #restoreBreedable(Breedable)} instead | ||||||
|  |      * @since 7.1.0 | ||||||
|  |      */ | ||||||
|  |     @Deprecated(forRemoval = true, since = "7.1.0") | ||||||
|     private void restoreAgeable(Ageable entity) { |     private void restoreAgeable(Ageable entity) { | ||||||
|         if (!this.aged.adult) { |         if (!this.aged.adult) { | ||||||
|             entity.setBaby(); |             entity.setBaby(); | ||||||
| @@ -441,6 +398,11 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @deprecated Use {@link #storeBreedable(Breedable)} instead | ||||||
|  |      * @since 7.1.0 | ||||||
|  |      */ | ||||||
|  |     @Deprecated(forRemoval = true, since = "7.1.0") | ||||||
|     public void storeAgeable(Ageable aged) { |     public void storeAgeable(Ageable aged) { | ||||||
|         this.aged = new AgeableStats(); |         this.aged = new AgeableStats(); | ||||||
|         this.aged.age = aged.getAge(); |         this.aged.age = aged.getAge(); | ||||||
| @@ -448,6 +410,29 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|         this.aged.adult = aged.isAdult(); |         this.aged.adult = aged.isAdult(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @since 7.1.0 | ||||||
|  |      */ | ||||||
|  |     private void restoreBreedable(Breedable entity) { | ||||||
|  |         if (!this.aged.adult) { | ||||||
|  |             entity.setBaby(); | ||||||
|  |         } | ||||||
|  |         entity.setAgeLock(this.aged.locked); | ||||||
|  |         if (this.aged.age > 0) { | ||||||
|  |             entity.setAge(this.aged.age); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @since 7.1.0 | ||||||
|  |      */ | ||||||
|  |     private void storeBreedable(Breedable breedable) { | ||||||
|  |         this.aged = new AgeableStats(); | ||||||
|  |         this.aged.age = breedable.getAge(); | ||||||
|  |         this.aged.locked = breedable.getAgeLock(); | ||||||
|  |         this.aged.adult = breedable.isAdult(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     public void storeTameable(Tameable tamed) { |     public void storeTameable(Tameable tamed) { | ||||||
|         this.tamed = new TameableStats(); |         this.tamed = new TameableStats(); | ||||||
|         this.tamed.owner = tamed.getOwner(); |         this.tamed.owner = tamed.getOwner(); | ||||||
| @@ -465,20 +450,15 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|         } |         } | ||||||
|         Entity entity; |         Entity entity; | ||||||
|         switch (this.getType().toString()) { |         switch (this.getType().toString()) { | ||||||
|             case "DROPPED_ITEM": |             case "DROPPED_ITEM" -> { | ||||||
|                 return world.dropItem(location, this.stack); |                 return world.dropItem(location, this.stack); | ||||||
|             case "PLAYER": |             } | ||||||
|             case "LEASH_HITCH": |             case "PLAYER", "LEASH_HITCH" -> { | ||||||
|                 return null; |                 return null; | ||||||
|             case "ITEM_FRAME": |             } | ||||||
|                 entity = world.spawn(location, ItemFrame.class); |             case "ITEM_FRAME" -> entity = world.spawn(location, ItemFrame.class); | ||||||
|                 break; |             case "PAINTING" -> entity = world.spawn(location, Painting.class); | ||||||
|             case "PAINTING": |             default -> entity = world.spawnEntity(location, this.getType()); | ||||||
|                 entity = world.spawn(location, Painting.class); |  | ||||||
|                 break; |  | ||||||
|             default: |  | ||||||
|                 entity = world.spawnEntity(location, this.getType()); |  | ||||||
|                 break; |  | ||||||
|         } |         } | ||||||
|         if (this.depth == 0) { |         if (this.depth == 0) { | ||||||
|             return entity; |             return entity; | ||||||
| @@ -506,72 +486,46 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|             entity.setGravity(false); |             entity.setGravity(false); | ||||||
|         } |         } | ||||||
|         switch (entity.getType().toString()) { |         switch (entity.getType().toString()) { | ||||||
|             case "BOAT": |             case "BOAT" -> { | ||||||
|                 Boat boat = (Boat) entity; |                 Boat boat = (Boat) entity; | ||||||
|                 boat.setWoodType(TreeSpecies.values()[dataByte]); |                 boat.setWoodType(TreeSpecies.values()[dataByte]); | ||||||
|                 return entity; |                 return entity; | ||||||
|             case "SLIME": |             } | ||||||
|  |             case "SLIME" -> { | ||||||
|                 ((Slime) entity).setSize(this.dataByte); |                 ((Slime) entity).setSize(this.dataByte); | ||||||
|                 return entity; |                 return entity; | ||||||
|             case "ARROW": |             } | ||||||
|             case "EGG": |             case "ARROW", "EGG", "ENDER_CRYSTAL", "ENDER_PEARL", "ENDER_SIGNAL", "DROPPED_ITEM", "EXPERIENCE_ORB", "FALLING_BLOCK", | ||||||
|             case "ENDER_CRYSTAL": |                     "FIREBALL", "FIREWORK", "FISHING_HOOK", "LEASH_HITCH", "LIGHTNING", "MINECART", "MINECART_COMMAND", | ||||||
|             case "ENDER_PEARL": |                     "MINECART_MOB_SPAWNER", "MINECART_TNT", "PLAYER", "PRIMED_TNT", "SMALL_FIREBALL", "SNOWBALL", | ||||||
|             case "ENDER_SIGNAL": |                     "SPLASH_POTION", "THROWN_EXP_BOTTLE", "SPECTRAL_ARROW", "SHULKER_BULLET", "AREA_EFFECT_CLOUD", | ||||||
|             case "DROPPED_ITEM": |                     "DRAGON_FIREBALL", "WITHER_SKULL", "MINECART_FURNACE", "LLAMA_SPIT", "TRIDENT", "UNKNOWN" -> { | ||||||
|             case "EXPERIENCE_ORB": |  | ||||||
|             case "FALLING_BLOCK": |  | ||||||
|             case "FIREBALL": |  | ||||||
|             case "FIREWORK": |  | ||||||
|             case "FISHING_HOOK": |  | ||||||
|             case "LEASH_HITCH": |  | ||||||
|             case "LIGHTNING": |  | ||||||
|             case "MINECART": |  | ||||||
|             case "MINECART_COMMAND": |  | ||||||
|             case "MINECART_MOB_SPAWNER": |  | ||||||
|             case "MINECART_TNT": |  | ||||||
|             case "PLAYER": |  | ||||||
|             case "PRIMED_TNT": |  | ||||||
|             case "SMALL_FIREBALL": |  | ||||||
|             case "SNOWBALL": |  | ||||||
|             case "SPLASH_POTION": |  | ||||||
|             case "THROWN_EXP_BOTTLE": |  | ||||||
|             case "SPECTRAL_ARROW": |  | ||||||
|             case "SHULKER_BULLET": |  | ||||||
|             case "AREA_EFFECT_CLOUD": |  | ||||||
|             case "DRAGON_FIREBALL": |  | ||||||
|             case "WITHER_SKULL": |  | ||||||
|             case "MINECART_FURNACE": |  | ||||||
|             case "LLAMA_SPIT": |  | ||||||
|             case "TRIDENT": |  | ||||||
|             case "UNKNOWN": |  | ||||||
|                 // Do this stuff later |                 // Do this stuff later | ||||||
|                 return entity; |                 return entity; | ||||||
|  |             } | ||||||
|             // MISC // |             // MISC // | ||||||
|             case "ITEM_FRAME": |             case "ITEM_FRAME" -> { | ||||||
|                 ItemFrame itemframe = (ItemFrame) entity; |                 ItemFrame itemframe = (ItemFrame) entity; | ||||||
|                 itemframe.setRotation(Rotation.values()[this.dataByte]); |                 itemframe.setRotation(Rotation.values()[this.dataByte]); | ||||||
|                 itemframe.setItem(this.stack); |                 itemframe.setItem(this.stack); | ||||||
|                 return entity; |                 return entity; | ||||||
|             case "PAINTING": |             } | ||||||
|  |             case "PAINTING" -> { | ||||||
|                 Painting painting = (Painting) entity; |                 Painting painting = (Painting) entity; | ||||||
|                 painting.setFacingDirection(BlockFace.values()[this.dataByte], true); |                 painting.setFacingDirection(BlockFace.values()[this.dataByte], true); | ||||||
|                 painting.setArt(Art.getByName(this.dataString), true); |                 painting.setArt(Art.getByName(this.dataString), true); | ||||||
|                 return entity; |                 return entity; | ||||||
|  |             } | ||||||
|             // END MISC // |             // END MISC // | ||||||
|             // INVENTORY HOLDER // |             // INVENTORY HOLDER // | ||||||
|             case "MINECART_CHEST": |             case "MINECART_CHEST", "MINECART_HOPPER" -> { | ||||||
|             case "MINECART_HOPPER": |  | ||||||
|                 restoreInventory((InventoryHolder) entity); |                 restoreInventory((InventoryHolder) entity); | ||||||
|                 return entity; |                 return entity; | ||||||
|  |             } | ||||||
|             // START LIVING ENTITY // |             // START LIVING ENTITY // | ||||||
|             // START AGEABLE // |             // START AGEABLE // | ||||||
|             // START TAMEABLE // |             // START TAMEABLE // | ||||||
|             case "HORSE": |             case "HORSE", "LLAMA", "SKELETON_HORSE", "DONKEY", "MULE" -> { | ||||||
|             case "LLAMA": |  | ||||||
|             case "SKELETON_HORSE": |  | ||||||
|             case "DONKEY": |  | ||||||
|             case "MULE": |  | ||||||
|                 AbstractHorse horse = (AbstractHorse) entity; |                 AbstractHorse horse = (AbstractHorse) entity; | ||||||
|                 horse.setJumpStrength(this.horse.jump); |                 horse.setJumpStrength(this.horse.jump); | ||||||
|                 if (horse instanceof ChestedHorse) { |                 if (horse instanceof ChestedHorse) { | ||||||
| @@ -582,19 +536,20 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|                 //horse.setStyle(this.horse.style); |                 //horse.setStyle(this.horse.style); | ||||||
|                 //horse.setColor(this.horse.color); |                 //horse.setColor(this.horse.color); | ||||||
|                 restoreTameable(horse); |                 restoreTameable(horse); | ||||||
|                 restoreAgeable(horse); |                 restoreBreedable(horse); | ||||||
|                 restoreLiving(horse); |                 restoreLiving(horse); | ||||||
|                 restoreInventory(horse); |                 restoreInventory(horse); | ||||||
|                 return entity; |                 return entity; | ||||||
|  |             } | ||||||
|             // END INVENTORY HOLDER // |             // END INVENTORY HOLDER // | ||||||
|             case "WOLF": |             case "WOLF", "OCELOT" -> { | ||||||
|             case "OCELOT": |  | ||||||
|                 restoreTameable((Tameable) entity); |                 restoreTameable((Tameable) entity); | ||||||
|                 restoreAgeable((Ageable) entity); |                 restoreBreedable((Breedable) entity); | ||||||
|                 restoreLiving((LivingEntity) entity); |                 restoreLiving((LivingEntity) entity); | ||||||
|                 return entity; |                 return entity; | ||||||
|  |             } | ||||||
|             // END AGEABLE // |             // END AGEABLE // | ||||||
|             case "SHEEP": |             case "SHEEP" -> { | ||||||
|                 Sheep sheep = (Sheep) entity; |                 Sheep sheep = (Sheep) entity; | ||||||
|                 if (this.dataByte == 1) { |                 if (this.dataByte == 1) { | ||||||
|                     sheep.setSheared(true); |                     sheep.setSheared(true); | ||||||
| @@ -602,28 +557,25 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|                 if (this.dataByte2 != 0) { |                 if (this.dataByte2 != 0) { | ||||||
|                     sheep.setColor(DyeColor.getByDyeData(this.dataByte2)); |                     sheep.setColor(DyeColor.getByDyeData(this.dataByte2)); | ||||||
|                 } |                 } | ||||||
|                 restoreAgeable(sheep); |                 restoreBreedable(sheep); | ||||||
|                 restoreLiving(sheep); |                 restoreLiving(sheep); | ||||||
|                 return sheep; |                 return sheep; | ||||||
|             case "VILLAGER": |             } | ||||||
|             case "CHICKEN": |             case "VILLAGER", "CHICKEN", "COW", "TURTLE", "POLAR_BEAR", "MUSHROOM_COW", "PIG" -> { | ||||||
|             case "COW": |                 restoreBreedable((Breedable) entity); | ||||||
|             case "TURTLE": |  | ||||||
|             case "POLAR_BEAR": |  | ||||||
|             case "MUSHROOM_COW": |  | ||||||
|             case "PIG": |  | ||||||
|                 restoreAgeable((Ageable) entity); |  | ||||||
|                 restoreLiving((LivingEntity) entity); |                 restoreLiving((LivingEntity) entity); | ||||||
|                 return entity; |                 return entity; | ||||||
|  |             } | ||||||
|             // END AGEABLE // |             // END AGEABLE // | ||||||
|             case "RABBIT": |             case "RABBIT" -> { | ||||||
|                 if (this.dataByte != 0) { |                 if (this.dataByte != 0) { | ||||||
|                     ((Rabbit) entity).setRabbitType(Rabbit.Type.values()[this.dataByte]); |                     ((Rabbit) entity).setRabbitType(Rabbit.Type.values()[this.dataByte]); | ||||||
|                 } |                 } | ||||||
|                 restoreAgeable((Ageable) entity); |                 restoreBreedable((Breedable) entity); | ||||||
|                 restoreLiving((LivingEntity) entity); |                 restoreLiving((LivingEntity) entity); | ||||||
|                 return entity; |                 return entity; | ||||||
|             case "ARMOR_STAND": |             } | ||||||
|  |             case "ARMOR_STAND" -> { | ||||||
|                 // CHECK positions |                 // CHECK positions | ||||||
|                 ArmorStand stand = (ArmorStand) entity; |                 ArmorStand stand = (ArmorStand) entity; | ||||||
|                 if (this.inventory[0] != null) { |                 if (this.inventory[0] != null) { | ||||||
| @@ -693,56 +645,38 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|                 } |                 } | ||||||
|                 restoreLiving(stand); |                 restoreLiving(stand); | ||||||
|                 return stand; |                 return stand; | ||||||
|             case "BAT": |             } | ||||||
|  |             case "BAT" -> { | ||||||
|                 if (this.dataByte != 0) { |                 if (this.dataByte != 0) { | ||||||
|                     ((Bat) entity).setAwake(true); |                     ((Bat) entity).setAwake(true); | ||||||
|                 } |                 } | ||||||
|                 restoreLiving((LivingEntity) entity); |                 restoreLiving((LivingEntity) entity); | ||||||
|                 return entity; |                 return entity; | ||||||
|             case "ENDER_DRAGON": |             } | ||||||
|  |             case "ENDER_DRAGON" -> { | ||||||
|                 if (this.dataByte != 0) { |                 if (this.dataByte != 0) { | ||||||
|                     ((EnderDragon) entity).setPhase(EnderDragon.Phase.values()[this.dataByte]); |                     ((EnderDragon) entity).setPhase(EnderDragon.Phase.values()[this.dataByte]); | ||||||
|                 } |                 } | ||||||
|                 restoreLiving((LivingEntity) entity); |                 restoreLiving((LivingEntity) entity); | ||||||
|                 return entity; |                 return entity; | ||||||
|             case "ENDERMITE": |             } | ||||||
|             case "GHAST": |             case "ENDERMITE", "GHAST", "MAGMA_CUBE", "SQUID", "PIG_ZOMBIE", "HOGLIN", "PIGLIN", "ZOMBIFIED_PIGLIN", "PIGLIN_BRUTE", "ZOMBIE", "WITHER", "WITCH", "SPIDER", "CAVE_SPIDER", "SILVERFISH", "GIANT", "ENDERMAN", "CREEPER", "BLAZE", "SNOWMAN", "SHULKER", "GUARDIAN", "ELDER_GUARDIAN", "SKELETON", "WITHER_SKELETON" -> { | ||||||
|             case "MAGMA_CUBE": |  | ||||||
|             case "SQUID": |  | ||||||
|             case "PIG_ZOMBIE": |  | ||||||
|             case "HOGLIN": |  | ||||||
|             case "PIGLIN": |  | ||||||
|             case "ZOMBIFIED_PIGLIN": |  | ||||||
|             case "PIGLIN_BRUTE": |  | ||||||
|             case "ZOMBIE": |  | ||||||
|             case "WITHER": |  | ||||||
|             case "WITCH": |  | ||||||
|             case "SPIDER": |  | ||||||
|             case "CAVE_SPIDER": |  | ||||||
|             case "SILVERFISH": |  | ||||||
|             case "GIANT": |  | ||||||
|             case "ENDERMAN": |  | ||||||
|             case "CREEPER": |  | ||||||
|             case "BLAZE": |  | ||||||
|             case "SNOWMAN": |  | ||||||
|             case "SHULKER": |  | ||||||
|             case "GUARDIAN": |  | ||||||
|             case "ELDER_GUARDIAN": |  | ||||||
|             case "SKELETON": |  | ||||||
|             case "WITHER_SKELETON": |  | ||||||
|                 restoreLiving((LivingEntity) entity); |                 restoreLiving((LivingEntity) entity); | ||||||
|                 return entity; |                 return entity; | ||||||
|             case "IRON_GOLEM": |             } | ||||||
|  |             case "IRON_GOLEM" -> { | ||||||
|                 if (this.dataByte != 0) { |                 if (this.dataByte != 0) { | ||||||
|                     ((IronGolem) entity).setPlayerCreated(true); |                     ((IronGolem) entity).setPlayerCreated(true); | ||||||
|                 } |                 } | ||||||
|                 restoreLiving((LivingEntity) entity); |                 restoreLiving((LivingEntity) entity); | ||||||
|                 return entity; |                 return entity; | ||||||
|             default: |             } | ||||||
|  |             default -> { | ||||||
|                 if (Settings.DEBUG) { |                 if (Settings.DEBUG) { | ||||||
|                     LOGGER.info("Could not identify entity: {}", entity.getType()); |                     LOGGER.info("Could not identify entity: {}", entity.getType()); | ||||||
|                 } |                 } | ||||||
|                 return entity; |                 return entity; | ||||||
|  |             } | ||||||
|             // END LIVING |             // END LIVING | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -24,7 +24,6 @@ import com.plotsquared.core.generator.IndependentPlotGenerator; | |||||||
| import com.plotsquared.core.location.Location; | import com.plotsquared.core.location.Location; | ||||||
| import com.plotsquared.core.location.UncheckedWorldLocation; | import com.plotsquared.core.location.UncheckedWorldLocation; | ||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; |  | ||||||
| import com.plotsquared.core.plot.world.SinglePlotArea; | import com.plotsquared.core.plot.world.SinglePlotArea; | ||||||
| import com.plotsquared.core.queue.ZeroedDelegateScopedQueueCoordinator; | import com.plotsquared.core.queue.ZeroedDelegateScopedQueueCoordinator; | ||||||
| import org.bukkit.generator.BlockPopulator; | import org.bukkit.generator.BlockPopulator; | ||||||
| @@ -47,17 +46,6 @@ final class BlockStatePopulator extends BlockPopulator { | |||||||
|         this.plotGenerator = plotGenerator; |         this.plotGenerator = plotGenerator; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * @deprecated Use {@link BlockStatePopulator#BlockStatePopulator(IndependentPlotGenerator)} as plotAreManager is unused |  | ||||||
|      */ |  | ||||||
|     @Deprecated(forRemoval = true, since = "6.9.0") |  | ||||||
|     public BlockStatePopulator( |  | ||||||
|             final @NonNull IndependentPlotGenerator plotGenerator, |  | ||||||
|             final @NonNull PlotAreaManager plotAreaManager |  | ||||||
|     ) { |  | ||||||
|         this.plotGenerator = plotGenerator; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public void populate( |     public void populate( | ||||||
|             @NonNull final WorldInfo worldInfo, |             @NonNull final WorldInfo worldInfo, | ||||||
|   | |||||||
| @@ -34,9 +34,12 @@ import com.plotsquared.core.queue.ZeroedDelegateScopedQueueCoordinator; | |||||||
| import com.plotsquared.core.util.ChunkManager; | import com.plotsquared.core.util.ChunkManager; | ||||||
| import com.sk89q.worldedit.bukkit.BukkitAdapter; | import com.sk89q.worldedit.bukkit.BukkitAdapter; | ||||||
| import com.sk89q.worldedit.math.BlockVector2; | import com.sk89q.worldedit.math.BlockVector2; | ||||||
|  | import com.sk89q.worldedit.math.BlockVector3; | ||||||
| import org.apache.logging.log4j.LogManager; | import org.apache.logging.log4j.LogManager; | ||||||
| import org.apache.logging.log4j.Logger; | import org.apache.logging.log4j.Logger; | ||||||
| import org.bukkit.HeightMap; | import org.bukkit.HeightMap; | ||||||
|  | import org.bukkit.NamespacedKey; | ||||||
|  | import org.bukkit.Registry; | ||||||
| import org.bukkit.World; | import org.bukkit.World; | ||||||
| import org.bukkit.block.Biome; | import org.bukkit.block.Biome; | ||||||
| import org.bukkit.generator.BiomeProvider; | import org.bukkit.generator.BiomeProvider; | ||||||
| @@ -48,10 +51,14 @@ import org.jetbrains.annotations.NotNull; | |||||||
| import org.jetbrains.annotations.Nullable; | import org.jetbrains.annotations.Nullable; | ||||||
|  |  | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
|  | import java.util.Arrays; | ||||||
|  | import java.util.EnumSet; | ||||||
| import java.util.List; | import java.util.List; | ||||||
| import java.util.Random; | import java.util.Random; | ||||||
| import java.util.Set; | import java.util.Set; | ||||||
|  |  | ||||||
|  | import static java.util.function.Predicate.not; | ||||||
|  |  | ||||||
| public class BukkitPlotGenerator extends ChunkGenerator implements GeneratorWrapper<ChunkGenerator> { | public class BukkitPlotGenerator extends ChunkGenerator implements GeneratorWrapper<ChunkGenerator> { | ||||||
|  |  | ||||||
|     private static final Logger LOGGER = LogManager.getLogger("PlotSquared/" + BukkitPlotGenerator.class.getSimpleName()); |     private static final Logger LOGGER = LogManager.getLogger("PlotSquared/" + BukkitPlotGenerator.class.getSimpleName()); | ||||||
| @@ -277,9 +284,14 @@ public class BukkitPlotGenerator extends ChunkGenerator implements GeneratorWrap | |||||||
|         return super.getBaseHeight(worldInfo, random, x, z, heightMap); |         return super.getBaseHeight(worldInfo, random, x, z, heightMap); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * The entire method is deprecated, but kept for compatibility with versions lower than or equal to 1.16.2. | ||||||
|  |      * The method will be removed in future versions, because WorldEdit and FastAsyncWorldEdit only support the latest point | ||||||
|  |      * release. | ||||||
|  |      */ | ||||||
|     @SuppressWarnings("deprecation") // The entire method is deprecated, but kept for compatibility with <=1.16.2 |     @SuppressWarnings("deprecation") // The entire method is deprecated, but kept for compatibility with <=1.16.2 | ||||||
|     @Override |     @Override | ||||||
|     @Deprecated(since = "TODO") |     @Deprecated(since = "7.0.0") | ||||||
|     public @NonNull ChunkData generateChunkData( |     public @NonNull ChunkData generateChunkData( | ||||||
|             @NonNull World world, @NonNull Random random, int x, int z, @NonNull BiomeGrid biome |             @NonNull World world, @NonNull Random random, int x, int z, @NonNull BiomeGrid biome | ||||||
|     ) { |     ) { | ||||||
| @@ -287,8 +299,8 @@ public class BukkitPlotGenerator extends ChunkGenerator implements GeneratorWrap | |||||||
|             if (this.platformGenerator != this) { |             if (this.platformGenerator != this) { | ||||||
|                 return this.platformGenerator.generateChunkData(world, random, x, z, biome); |                 return this.platformGenerator.generateChunkData(world, random, x, z, biome); | ||||||
|             } else { |             } else { | ||||||
|                 // Return super as it will throw an exception caught by the server that will mean this method is no longer used. |                 // Throw exception to be caught by the server that indicates the new generation API is being used. | ||||||
|                 return super.generateChunkData(world, random, x, z, biome); |                 throw new UnsupportedOperationException("Using new generation methods. This method is unsupported."); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @@ -409,9 +421,14 @@ public class BukkitPlotGenerator extends ChunkGenerator implements GeneratorWrap | |||||||
|         if (lastPlotArea != null && name.equals(this.levelName) && chunkX == lastChunkX && chunkZ == lastChunkZ) { |         if (lastPlotArea != null && name.equals(this.levelName) && chunkX == lastChunkX && chunkZ == lastChunkZ) { | ||||||
|             return lastPlotArea; |             return lastPlotArea; | ||||||
|         } |         } | ||||||
|         PlotArea area = UncheckedWorldLocation.at(name, chunkX << 4, 0, chunkZ << 4).getPlotArea(); |         BlockVector3 loc = BlockVector3.at(chunkX << 4, 0, chunkZ << 4); | ||||||
|  |         if (lastPlotArea != null && lastPlotArea.getRegion().contains(loc) && lastPlotArea.getRegion().contains(loc)) { | ||||||
|  |             return lastPlotArea; | ||||||
|  |         } | ||||||
|  |         PlotArea area = UncheckedWorldLocation.at(name, loc).getPlotArea(); | ||||||
|         if (area == null) { |         if (area == null) { | ||||||
|             throw new IllegalStateException(String.format("Cannot generate chunk that does not belong to a plot area. World: %s", |             throw new IllegalStateException(String.format( | ||||||
|  |                     "Cannot generate chunk that does not belong to a plot area. World: %s", | ||||||
|                     name |                     name | ||||||
|             )); |             )); | ||||||
|         } |         } | ||||||
| @@ -428,9 +445,16 @@ public class BukkitPlotGenerator extends ChunkGenerator implements GeneratorWrap | |||||||
|         private static final List<Biome> BIOMES; |         private static final List<Biome> BIOMES; | ||||||
|  |  | ||||||
|         static { |         static { | ||||||
|             ArrayList<Biome> biomes = new ArrayList<>(List.of(Biome.values())); |             Set<Biome> disabledBiomes = EnumSet.of(Biome.CUSTOM); | ||||||
|             biomes.remove(Biome.CUSTOM); |             if (PlotSquared.platform().serverVersion()[1] <= 19) { | ||||||
|             BIOMES = List.copyOf(biomes); |                 final Biome cherryGrove = Registry.BIOME.get(NamespacedKey.minecraft("cherry_grove")); | ||||||
|  |                 if (cherryGrove != null) { | ||||||
|  |                     disabledBiomes.add(cherryGrove); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |             BIOMES = Arrays.stream(Biome.values()) | ||||||
|  |                     .filter(not(disabledBiomes::contains)) | ||||||
|  |                     .toList(); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         @Override |         @Override | ||||||
|   | |||||||
| @@ -33,7 +33,6 @@ import org.bukkit.Chunk; | |||||||
| import org.bukkit.World; | import org.bukkit.World; | ||||||
| import org.bukkit.generator.BlockPopulator; | import org.bukkit.generator.BlockPopulator; | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
| import org.jetbrains.annotations.NotNull; |  | ||||||
|  |  | ||||||
| import java.util.Random; | import java.util.Random; | ||||||
|  |  | ||||||
| @@ -51,7 +50,7 @@ final class LegacyBlockStatePopulator extends BlockPopulator { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public void populate(@NotNull final World world, @NotNull final Random random, @NotNull final Chunk source) { |     public void populate(@NonNull final World world, @NonNull final Random random, @NonNull final Chunk source) { | ||||||
|         int chunkMinX = source.getX() << 4; |         int chunkMinX = source.getX() << 4; | ||||||
|         int chunkMinZ = source.getZ() << 4; |         int chunkMinZ = source.getZ() << 4; | ||||||
|         PlotArea area = Location.at(world.getName(), chunkMinX, 0, chunkMinZ).getPlotArea(); |         PlotArea area = Location.at(world.getName(), chunkMinX, 0, chunkMinZ).getPlotArea(); | ||||||
|   | |||||||
| @@ -23,13 +23,13 @@ import com.google.inject.Provides; | |||||||
| import com.google.inject.Singleton; | import com.google.inject.Singleton; | ||||||
| import com.google.inject.assistedinject.FactoryModuleBuilder; | import com.google.inject.assistedinject.FactoryModuleBuilder; | ||||||
| import com.plotsquared.bukkit.BukkitPlatform; | import com.plotsquared.bukkit.BukkitPlatform; | ||||||
|  | import com.plotsquared.bukkit.listener.ServerListener; | ||||||
| import com.plotsquared.bukkit.listener.SingleWorldListener; | import com.plotsquared.bukkit.listener.SingleWorldListener; | ||||||
| import com.plotsquared.bukkit.player.BukkitPlayerManager; | import com.plotsquared.bukkit.player.BukkitPlayerManager; | ||||||
| import com.plotsquared.bukkit.queue.BukkitChunkCoordinator; | import com.plotsquared.bukkit.queue.BukkitChunkCoordinator; | ||||||
| import com.plotsquared.bukkit.queue.BukkitQueueCoordinator; | import com.plotsquared.bukkit.queue.BukkitQueueCoordinator; | ||||||
| import com.plotsquared.bukkit.schematic.BukkitSchematicHandler; | import com.plotsquared.bukkit.schematic.BukkitSchematicHandler; | ||||||
| import com.plotsquared.bukkit.util.BukkitChunkManager; | import com.plotsquared.bukkit.util.BukkitChunkManager; | ||||||
| import com.plotsquared.bukkit.util.BukkitEconHandler; |  | ||||||
| import com.plotsquared.bukkit.util.BukkitInventoryUtil; | import com.plotsquared.bukkit.util.BukkitInventoryUtil; | ||||||
| import com.plotsquared.bukkit.util.BukkitRegionManager; | import com.plotsquared.bukkit.util.BukkitRegionManager; | ||||||
| import com.plotsquared.bukkit.util.BukkitSetupUtils; | import com.plotsquared.bukkit.util.BukkitSetupUtils; | ||||||
| @@ -47,6 +47,9 @@ import com.plotsquared.core.inject.factory.ChunkCoordinatorBuilderFactory; | |||||||
| import com.plotsquared.core.inject.factory.ChunkCoordinatorFactory; | import com.plotsquared.core.inject.factory.ChunkCoordinatorFactory; | ||||||
| import com.plotsquared.core.inject.factory.HybridPlotWorldFactory; | import com.plotsquared.core.inject.factory.HybridPlotWorldFactory; | ||||||
| import com.plotsquared.core.inject.factory.ProgressSubscriberFactory; | import com.plotsquared.core.inject.factory.ProgressSubscriberFactory; | ||||||
|  | import com.plotsquared.core.player.OfflinePlotPlayer; | ||||||
|  | import com.plotsquared.core.player.PlotPlayer; | ||||||
|  | import com.plotsquared.core.plot.PlotArea; | ||||||
| import com.plotsquared.core.plot.world.DefaultPlotAreaManager; | import com.plotsquared.core.plot.world.DefaultPlotAreaManager; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
| import com.plotsquared.core.plot.world.SinglePlotAreaManager; | import com.plotsquared.core.plot.world.SinglePlotAreaManager; | ||||||
| @@ -72,6 +75,8 @@ import org.bukkit.command.ConsoleCommandSender; | |||||||
| import org.bukkit.plugin.java.JavaPlugin; | import org.bukkit.plugin.java.JavaPlugin; | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
|  | import java.util.Objects; | ||||||
|  |  | ||||||
| public class BukkitModule extends AbstractModule { | public class BukkitModule extends AbstractModule { | ||||||
|  |  | ||||||
|     private static final Logger LOGGER = LogManager.getLogger("PlotSquared/" + BukkitModule.class.getSimpleName()); |     private static final Logger LOGGER = LogManager.getLogger("PlotSquared/" + BukkitModule.class.getSimpleName()); | ||||||
| @@ -128,21 +133,64 @@ public class BukkitModule extends AbstractModule { | |||||||
|     @Provides |     @Provides | ||||||
|     @Singleton |     @Singleton | ||||||
|     @NonNull EconHandler provideEconHandler() { |     @NonNull EconHandler provideEconHandler() { | ||||||
|         if (!Settings.Enabled_Components.ECONOMY) { |         if (!Settings.Enabled_Components.ECONOMY || !Bukkit.getPluginManager().isPluginEnabled("Vault")) { | ||||||
|             return EconHandler.nullEconHandler(); |             return EconHandler.nullEconHandler(); | ||||||
|         } |         } | ||||||
|         if (Bukkit.getPluginManager().isPluginEnabled("Vault")) { |         // Guice eagerly initializes singletons, so we need to bring the laziness ourselves | ||||||
|             try { |         return new LazyEconHandler(); | ||||||
|                 BukkitEconHandler econHandler = new BukkitEconHandler(); |  | ||||||
|                 if (!econHandler.init()) { |  | ||||||
|                     LOGGER.warn("Economy is enabled but no plugin is providing an economy service. Falling back..."); |  | ||||||
|                     return EconHandler.nullEconHandler(); |  | ||||||
|     } |     } | ||||||
|                 return econHandler; |  | ||||||
|             } catch (final Exception ignored) { |     private static final class LazyEconHandler extends EconHandler implements ServerListener.MutableEconHandler { | ||||||
|  |         private volatile EconHandler implementation; | ||||||
|  |  | ||||||
|  |         public void setImplementation(EconHandler econHandler) { | ||||||
|  |             this.implementation = econHandler; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |         @Override | ||||||
|  |         public boolean init() { | ||||||
|  |             return get().init(); | ||||||
|         } |         } | ||||||
|         return EconHandler.nullEconHandler(); |  | ||||||
|  |         @Override | ||||||
|  |         public double getBalance(final PlotPlayer<?> player) { | ||||||
|  |             return get().getBalance(player); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         @Override | ||||||
|  |         public void withdrawMoney(final PlotPlayer<?> player, final double amount) { | ||||||
|  |             get().withdrawMoney(player, amount); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         @Override | ||||||
|  |         public void depositMoney(final PlotPlayer<?> player, final double amount) { | ||||||
|  |             get().depositMoney(player, amount); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         @Override | ||||||
|  |         public void depositMoney(final OfflinePlotPlayer player, final double amount) { | ||||||
|  |             get().depositMoney(player, amount); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         @Override | ||||||
|  |         public boolean isEnabled(final PlotArea plotArea) { | ||||||
|  |             return get().isEnabled(plotArea); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         @Override | ||||||
|  |         public @NonNull String format(final double balance) { | ||||||
|  |             return get().format(balance); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         @Override | ||||||
|  |         public boolean isSupported() { | ||||||
|  |             return get().isSupported(); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         private EconHandler get() { | ||||||
|  |             return Objects.requireNonNull(this.implementation, "EconHandler not ready yet."); | ||||||
|  |         } | ||||||
|  |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -24,7 +24,6 @@ import com.plotsquared.bukkit.util.BukkitUtil; | |||||||
| import com.plotsquared.core.PlotSquared; | import com.plotsquared.core.PlotSquared; | ||||||
| import com.plotsquared.core.configuration.Settings; | import com.plotsquared.core.configuration.Settings; | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.database.DBFunc; |  | ||||||
| import com.plotsquared.core.location.Location; | import com.plotsquared.core.location.Location; | ||||||
| import com.plotsquared.core.permissions.Permission; | import com.plotsquared.core.permissions.Permission; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| @@ -33,6 +32,7 @@ import com.plotsquared.core.plot.PlotArea; | |||||||
| import com.plotsquared.core.plot.flag.implementations.BlockBurnFlag; | import com.plotsquared.core.plot.flag.implementations.BlockBurnFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.BlockIgnitionFlag; | import com.plotsquared.core.plot.flag.implementations.BlockIgnitionFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.BreakFlag; | import com.plotsquared.core.plot.flag.implementations.BreakFlag; | ||||||
|  | import com.plotsquared.core.plot.flag.implementations.ConcreteHardenFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.CoralDryFlag; | import com.plotsquared.core.plot.flag.implementations.CoralDryFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.CropGrowFlag; | import com.plotsquared.core.plot.flag.implementations.CropGrowFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.DisablePhysicsFlag; | import com.plotsquared.core.plot.flag.implementations.DisablePhysicsFlag; | ||||||
| @@ -47,7 +47,6 @@ import com.plotsquared.core.plot.flag.implementations.LeafDecayFlag; | |||||||
| import com.plotsquared.core.plot.flag.implementations.LiquidFlowFlag; | import com.plotsquared.core.plot.flag.implementations.LiquidFlowFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.MycelGrowFlag; | import com.plotsquared.core.plot.flag.implementations.MycelGrowFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.PlaceFlag; | import com.plotsquared.core.plot.flag.implementations.PlaceFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.RedstoneFlag; |  | ||||||
| import com.plotsquared.core.plot.flag.implementations.SnowFormFlag; | import com.plotsquared.core.plot.flag.implementations.SnowFormFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.SnowMeltFlag; | import com.plotsquared.core.plot.flag.implementations.SnowMeltFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.SoilDryFlag; | import com.plotsquared.core.plot.flag.implementations.SoilDryFlag; | ||||||
| @@ -55,13 +54,12 @@ import com.plotsquared.core.plot.flag.implementations.VineGrowFlag; | |||||||
| import com.plotsquared.core.plot.flag.types.BlockTypeWrapper; | import com.plotsquared.core.plot.flag.types.BlockTypeWrapper; | ||||||
| import com.plotsquared.core.plot.flag.types.BooleanFlag; | import com.plotsquared.core.plot.flag.types.BooleanFlag; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
| import com.plotsquared.core.util.Permissions; | import com.plotsquared.core.util.PlotFlagUtil; | ||||||
| import com.plotsquared.core.util.task.TaskManager; | import com.plotsquared.core.util.task.TaskManager; | ||||||
| import com.plotsquared.core.util.task.TaskTime; | import com.plotsquared.core.util.task.TaskTime; | ||||||
| import com.sk89q.worldedit.WorldEdit; | import com.sk89q.worldedit.WorldEdit; | ||||||
| import com.sk89q.worldedit.bukkit.BukkitAdapter; | import com.sk89q.worldedit.bukkit.BukkitAdapter; | ||||||
| import com.sk89q.worldedit.world.block.BlockType; | import com.sk89q.worldedit.world.block.BlockType; | ||||||
| import net.kyori.adventure.text.Component; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; | import net.kyori.adventure.text.minimessage.tag.Tag; | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | ||||||
| import org.bukkit.Bukkit; | import org.bukkit.Bukkit; | ||||||
| @@ -71,6 +69,8 @@ import org.bukkit.block.Block; | |||||||
| import org.bukkit.block.BlockFace; | import org.bukkit.block.BlockFace; | ||||||
| import org.bukkit.block.BlockState; | import org.bukkit.block.BlockState; | ||||||
| import org.bukkit.block.data.BlockData; | import org.bukkit.block.data.BlockData; | ||||||
|  | import org.bukkit.block.data.type.Dispenser; | ||||||
|  | import org.bukkit.block.data.type.Farmland; | ||||||
| import org.bukkit.entity.Entity; | import org.bukkit.entity.Entity; | ||||||
| import org.bukkit.entity.Fireball; | import org.bukkit.entity.Fireball; | ||||||
| import org.bukkit.entity.Player; | import org.bukkit.entity.Player; | ||||||
| @@ -89,18 +89,16 @@ import org.bukkit.event.block.BlockFromToEvent; | |||||||
| import org.bukkit.event.block.BlockGrowEvent; | import org.bukkit.event.block.BlockGrowEvent; | ||||||
| import org.bukkit.event.block.BlockIgniteEvent; | import org.bukkit.event.block.BlockIgniteEvent; | ||||||
| import org.bukkit.event.block.BlockMultiPlaceEvent; | import org.bukkit.event.block.BlockMultiPlaceEvent; | ||||||
| import org.bukkit.event.block.BlockPhysicsEvent; |  | ||||||
| import org.bukkit.event.block.BlockPistonExtendEvent; | import org.bukkit.event.block.BlockPistonExtendEvent; | ||||||
| import org.bukkit.event.block.BlockPistonRetractEvent; | import org.bukkit.event.block.BlockPistonRetractEvent; | ||||||
| import org.bukkit.event.block.BlockPlaceEvent; | import org.bukkit.event.block.BlockPlaceEvent; | ||||||
| import org.bukkit.event.block.BlockRedstoneEvent; |  | ||||||
| import org.bukkit.event.block.BlockSpreadEvent; | import org.bukkit.event.block.BlockSpreadEvent; | ||||||
| import org.bukkit.event.block.CauldronLevelChangeEvent; | import org.bukkit.event.block.CauldronLevelChangeEvent; | ||||||
| import org.bukkit.event.block.EntityBlockFormEvent; | import org.bukkit.event.block.EntityBlockFormEvent; | ||||||
| import org.bukkit.event.block.LeavesDecayEvent; | import org.bukkit.event.block.LeavesDecayEvent; | ||||||
|  | import org.bukkit.event.block.MoistureChangeEvent; | ||||||
| import org.bukkit.event.block.SpongeAbsorbEvent; | import org.bukkit.event.block.SpongeAbsorbEvent; | ||||||
| import org.bukkit.event.world.StructureGrowEvent; | import org.bukkit.event.world.StructureGrowEvent; | ||||||
| import org.bukkit.material.Directional; |  | ||||||
| import org.bukkit.projectiles.BlockProjectileSource; | import org.bukkit.projectiles.BlockProjectileSource; | ||||||
| import org.bukkit.util.Vector; | import org.bukkit.util.Vector; | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
| @@ -108,20 +106,13 @@ import org.checkerframework.checker.nullness.qual.NonNull; | |||||||
| import java.util.Iterator; | import java.util.Iterator; | ||||||
| import java.util.List; | import java.util.List; | ||||||
| import java.util.Objects; | import java.util.Objects; | ||||||
| import java.util.Set; |  | ||||||
| import java.util.UUID; | import static org.bukkit.Tag.CORALS; | ||||||
|  | import static org.bukkit.Tag.CORAL_BLOCKS; | ||||||
|  | import static org.bukkit.Tag.WALL_CORALS; | ||||||
|  |  | ||||||
| @SuppressWarnings("unused") | @SuppressWarnings("unused") | ||||||
| public class BlockEventListener implements Listener { | public class BlockEventListener implements Listener { | ||||||
|  |  | ||||||
|     private static final Set<Material> PISTONS = Set.of( |  | ||||||
|             Material.PISTON, |  | ||||||
|             Material.STICKY_PISTON |  | ||||||
|     ); |  | ||||||
|     private static final Set<Material> PHYSICS_BLOCKS = Set.of( |  | ||||||
|             Material.TURTLE_EGG, |  | ||||||
|             Material.TURTLE_SPAWN_EGG |  | ||||||
|     ); |  | ||||||
|     private final PlotAreaManager plotAreaManager; |     private final PlotAreaManager plotAreaManager; | ||||||
|     private final WorldEdit worldEdit; |     private final WorldEdit worldEdit; | ||||||
|  |  | ||||||
| @@ -150,111 +141,6 @@ public class BlockEventListener implements Listener { | |||||||
|         }, TaskTime.ticks(3L)); |         }, TaskTime.ticks(3L)); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @EventHandler |  | ||||||
|     public void onRedstoneEvent(BlockRedstoneEvent event) { |  | ||||||
|         Block block = event.getBlock(); |  | ||||||
|         Location location = BukkitUtil.adapt(block.getLocation()); |  | ||||||
|         PlotArea area = location.getPlotArea(); |  | ||||||
|         if (area == null) { |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|         Plot plot = location.getOwnedPlot(); |  | ||||||
|         if (plot == null) { |  | ||||||
|             if (area.isRoadFlags() && !area.getRoadFlag(RedstoneFlag.class)) { |  | ||||||
|                 event.setNewCurrent(0); |  | ||||||
|             } |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|         if (!plot.getFlag(RedstoneFlag.class)) { |  | ||||||
|             event.setNewCurrent(0); |  | ||||||
|             plot.debug("Redstone event was cancelled because redstone = false"); |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|         if (Settings.Redstone.DISABLE_OFFLINE) { |  | ||||||
|             boolean disable = false; |  | ||||||
|             if (!DBFunc.SERVER.equals(plot.getOwner())) { |  | ||||||
|                 if (plot.isMerged()) { |  | ||||||
|                     disable = true; |  | ||||||
|                     for (UUID owner : plot.getOwners()) { |  | ||||||
|                         if (PlotSquared.platform().playerManager().getPlayerIfExists(owner) != null) { |  | ||||||
|                             disable = false; |  | ||||||
|                             break; |  | ||||||
|                         } |  | ||||||
|                     } |  | ||||||
|                 } else { |  | ||||||
|                     disable = PlotSquared.platform().playerManager().getPlayerIfExists(plot.getOwnerAbs()) == null; |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|             if (disable) { |  | ||||||
|                 for (UUID trusted : plot.getTrusted()) { |  | ||||||
|                     if (PlotSquared.platform().playerManager().getPlayerIfExists(trusted) != null) { |  | ||||||
|                         disable = false; |  | ||||||
|                         break; |  | ||||||
|                     } |  | ||||||
|                 } |  | ||||||
|                 if (disable) { |  | ||||||
|                     event.setNewCurrent(0); |  | ||||||
|                     plot.debug("Redstone event was cancelled because no trusted player was in the plot"); |  | ||||||
|                     return; |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         if (Settings.Redstone.DISABLE_UNOCCUPIED) { |  | ||||||
|             for (final PlotPlayer<?> player : PlotSquared.platform().playerManager().getPlayers()) { |  | ||||||
|                 if (plot.equals(player.getCurrentPlot())) { |  | ||||||
|                     return; |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|             event.setNewCurrent(0); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @EventHandler(ignoreCancelled = true, priority = EventPriority.HIGHEST) |  | ||||||
|     public void onPhysicsEvent(BlockPhysicsEvent event) { |  | ||||||
|         Block block = event.getBlock(); |  | ||||||
|         Location location = BukkitUtil.adapt(block.getLocation()); |  | ||||||
|         PlotArea area = location.getPlotArea(); |  | ||||||
|         if (area == null) { |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|         Plot plot = area.getOwnedPlotAbs(location); |  | ||||||
|         if (plot == null) { |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|         if (event.getChangedType().hasGravity() && plot.getFlag(DisablePhysicsFlag.class)) { |  | ||||||
|             event.setCancelled(true); |  | ||||||
|             sendBlockChange(event.getBlock().getLocation(), event.getBlock().getBlockData()); |  | ||||||
|             plot.debug("Prevented block physics and resent block change because disable-physics = true"); |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|         if (event.getChangedType() == Material.COMPARATOR) { |  | ||||||
|             if (!plot.getFlag(RedstoneFlag.class)) { |  | ||||||
|                 event.setCancelled(true); |  | ||||||
|                 plot.debug("Prevented comparator update because redstone = false"); |  | ||||||
|             } |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|         if (PHYSICS_BLOCKS.contains(event.getChangedType())) { |  | ||||||
|             if (plot.getFlag(DisablePhysicsFlag.class)) { |  | ||||||
|                 event.setCancelled(true); |  | ||||||
|                 plot.debug("Prevented block physics because disable-physics = true"); |  | ||||||
|             } |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|         if (Settings.Redstone.DETECT_INVALID_EDGE_PISTONS) { |  | ||||||
|             if (PISTONS.contains(block.getType())) { |  | ||||||
|                 org.bukkit.block.data.Directional piston = (org.bukkit.block.data.Directional) block.getBlockData(); |  | ||||||
|                 final BlockFace facing = piston.getFacing(); |  | ||||||
|                 location = location.add(facing.getModX(), facing.getModY(), facing.getModZ()); |  | ||||||
|                 Plot newPlot = area.getOwnedPlotAbs(location); |  | ||||||
|                 if (!plot.equals(newPlot)) { |  | ||||||
|                     event.setCancelled(true); |  | ||||||
|                     plot.debug("Prevented piston update because of invalid edge piston detection"); |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) |     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) | ||||||
|     public void blockCreate(BlockPlaceEvent event) { |     public void blockCreate(BlockPlaceEvent event) { | ||||||
|         Location location = BukkitUtil.adapt(event.getBlock().getLocation()); |         Location location = BukkitUtil.adapt(event.getBlock().getLocation()); | ||||||
| @@ -266,20 +152,12 @@ public class BlockEventListener implements Listener { | |||||||
|         BukkitPlayer pp = BukkitUtil.adapt(player); |         BukkitPlayer pp = BukkitUtil.adapt(player); | ||||||
|         Plot plot = area.getPlot(location); |         Plot plot = area.getPlot(location); | ||||||
|         if (plot != null) { |         if (plot != null) { | ||||||
|             if ((location.getY() >= area.getMaxBuildHeight() || location.getY() < area |             if (area.notifyIfOutsideBuildArea(pp, location.getY())) { | ||||||
|                     .getMinBuildHeight()) && !Permissions |  | ||||||
|                     .hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_HEIGHT_LIMIT)) { |  | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|                 pp.sendMessage( |                 return; | ||||||
|                         TranslatableCaption.of("height.height_limit"), |  | ||||||
|                         TagResolver.builder() |  | ||||||
|                                 .tag("minheight", Tag.inserting(Component.text(area.getMinBuildHeight()))) |  | ||||||
|                                 .tag("maxheight", Tag.inserting(Component.text(area.getMaxBuildHeight()))) |  | ||||||
|                                 .build() |  | ||||||
|                 ); |  | ||||||
|             } |             } | ||||||
|             if (!plot.hasOwner()) { |             if (!plot.hasOwner()) { | ||||||
|                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_UNOWNED)) { |                 if (!pp.hasPermission(Permission.PERMISSION_ADMIN_BUILD_UNOWNED)) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             TagResolver.resolver( | ||||||
| @@ -299,7 +177,7 @@ public class BlockEventListener implements Listener { | |||||||
|                         return; |                         return; | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_OTHER)) { |                 if (!pp.hasPermission(Permission.PERMISSION_ADMIN_BUILD_OTHER)) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             TagResolver.resolver( | ||||||
| @@ -313,7 +191,7 @@ public class BlockEventListener implements Listener { | |||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|             } else if (Settings.Done.RESTRICT_BUILDING && DoneFlag.isDone(plot)) { |             } else if (Settings.Done.RESTRICT_BUILDING && DoneFlag.isDone(plot)) { | ||||||
|                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_OTHER)) { |                 if (!pp.hasPermission(Permission.PERMISSION_ADMIN_BUILD_OTHER)) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
|                             TranslatableCaption.of("done.building_restricted") |                             TranslatableCaption.of("done.building_restricted") | ||||||
|                     ); |                     ); | ||||||
| @@ -329,7 +207,7 @@ public class BlockEventListener implements Listener { | |||||||
|                             + " did not fall because of disable-physics = true"); |                             + " did not fall because of disable-physics = true"); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } else if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_ROAD)) { |         } else if (!pp.hasPermission(Permission.PERMISSION_ADMIN_BUILD_ROAD)) { | ||||||
|             pp.sendMessage( |             pp.sendMessage( | ||||||
|                     TranslatableCaption.of("permission.no_permission_event"), |                     TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                     TagResolver.resolver( |                     TagResolver.resolver( | ||||||
| @@ -354,8 +232,7 @@ public class BlockEventListener implements Listener { | |||||||
|             BukkitPlayer plotPlayer = BukkitUtil.adapt(player); |             BukkitPlayer plotPlayer = BukkitUtil.adapt(player); | ||||||
|             // == rather than <= as we only care about the "ground level" not being destroyed |             // == rather than <= as we only care about the "ground level" not being destroyed | ||||||
|             if (event.getBlock().getY() == area.getMinGenHeight()) { |             if (event.getBlock().getY() == area.getMinGenHeight()) { | ||||||
|                 if (!Permissions |                 if (!plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_DESTROY_GROUNDLEVEL)) { | ||||||
|                         .hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_DESTROY_GROUNDLEVEL)) { |  | ||||||
|                     plotPlayer.sendMessage( |                     plotPlayer.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             TagResolver.resolver( | ||||||
| @@ -366,21 +243,12 @@ public class BlockEventListener implements Listener { | |||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|             } else if ((location.getY() >= area.getMaxBuildHeight() || location.getY() < area |             } else if (area.notifyIfOutsideBuildArea(plotPlayer, location.getY())) { | ||||||
|                     .getMinBuildHeight()) && !Permissions |  | ||||||
|                     .hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_BUILD_HEIGHT_LIMIT)) { |  | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|                 plotPlayer.sendMessage( |                 return; | ||||||
|                         TranslatableCaption.of("height.height_limit"), |  | ||||||
|                         TagResolver.builder() |  | ||||||
|                                 .tag("minheight", Tag.inserting(Component.text(area.getMinBuildHeight()))) |  | ||||||
|                                 .tag("maxheight", Tag.inserting(Component.text(area.getMaxBuildHeight()))) |  | ||||||
|                                 .build() |  | ||||||
|                 ); |  | ||||||
|             } |             } | ||||||
|             if (!plot.hasOwner()) { |             if (!plot.hasOwner()) { | ||||||
|                 if (!Permissions |                 if (!plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_DESTROY_UNOWNED, true)) { | ||||||
|                         .hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_DESTROY_UNOWNED, true)) { |  | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                 } |                 } | ||||||
|                 return; |                 return; | ||||||
| @@ -394,8 +262,7 @@ public class BlockEventListener implements Listener { | |||||||
|                         return; |                         return; | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|                 if (Permissions |                 if (plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_DESTROY_OTHER)) { | ||||||
|                         .hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_DESTROY_OTHER)) { |  | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 plotPlayer.sendMessage( |                 plotPlayer.sendMessage( | ||||||
| @@ -407,7 +274,7 @@ public class BlockEventListener implements Listener { | |||||||
|                 ); |                 ); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } else if (Settings.Done.RESTRICT_BUILDING && DoneFlag.isDone(plot)) { |             } else if (Settings.Done.RESTRICT_BUILDING && DoneFlag.isDone(plot)) { | ||||||
|                 if (!Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_BUILD_OTHER)) { |                 if (!plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_BUILD_OTHER)) { | ||||||
|                     plotPlayer.sendMessage( |                     plotPlayer.sendMessage( | ||||||
|                             TranslatableCaption.of("done.building_restricted") |                             TranslatableCaption.of("done.building_restricted") | ||||||
|                     ); |                     ); | ||||||
| @@ -418,7 +285,7 @@ public class BlockEventListener implements Listener { | |||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         BukkitPlayer pp = BukkitUtil.adapt(player); |         BukkitPlayer pp = BukkitUtil.adapt(player); | ||||||
|         if (Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_DESTROY_ROAD)) { |         if (pp.hasPermission(Permission.PERMISSION_ADMIN_DESTROY_ROAD)) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         if (this.worldEdit != null && pp.getAttribute("worldedit")) { |         if (this.worldEdit != null && pp.getAttribute("worldedit")) { | ||||||
| @@ -470,6 +337,7 @@ public class BlockEventListener implements Listener { | |||||||
|             case "TWISTING_VINES": |             case "TWISTING_VINES": | ||||||
|             case "CAVE_VINES": |             case "CAVE_VINES": | ||||||
|             case "VINE": |             case "VINE": | ||||||
|  |             case "GLOW_BERRIES": | ||||||
|                 if (!plot.getFlag(VineGrowFlag.class)) { |                 if (!plot.getFlag(VineGrowFlag.class)) { | ||||||
|                     plot.debug("Vine could not grow because vine-grow = false"); |                     plot.debug("Vine could not grow because vine-grow = false"); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
| @@ -505,18 +373,18 @@ public class BlockEventListener implements Listener { | |||||||
|                     BukkitPlayer plotPlayer = BukkitUtil.adapt(player); |                     BukkitPlayer plotPlayer = BukkitUtil.adapt(player); | ||||||
|                     if (plot != null) { |                     if (plot != null) { | ||||||
|                         if (!plot.hasOwner()) { |                         if (!plot.hasOwner()) { | ||||||
|                             if (Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_INTERACT_UNOWNED)) { |                             if (plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_INTERACT_UNOWNED)) { | ||||||
|                                 return; |                                 return; | ||||||
|                             } |                             } | ||||||
|                         } else if (!plot.isAdded(plotPlayer.getUUID())) { |                         } else if (!plot.isAdded(plotPlayer.getUUID())) { | ||||||
|                             if (Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_INTERACT_OTHER)) { |                             if (plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_INTERACT_OTHER)) { | ||||||
|                                 return; |                                 return; | ||||||
|                             } |                             } | ||||||
|                         } else { |                         } else { | ||||||
|                             return; |                             return; | ||||||
|                         } |                         } | ||||||
|                     } else { |                     } else { | ||||||
|                         if (Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_INTERACT_ROAD)) { |                         if (plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_INTERACT_ROAD)) { | ||||||
|                             return; |                             return; | ||||||
|                         } |                         } | ||||||
|                         if (this.worldEdit != null && plotPlayer.getAttribute("worldedit")) { |                         if (this.worldEdit != null && plotPlayer.getAttribute("worldedit")) { | ||||||
| @@ -560,7 +428,7 @@ public class BlockEventListener implements Listener { | |||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         if (location.getY() >= area.getMaxBuildHeight() || location.getY() < area.getMinBuildHeight()) { |         if (!area.buildRangeContainsY(location.getY())) { | ||||||
|             event.setCancelled(true); |             event.setCancelled(true); | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
| @@ -577,6 +445,12 @@ public class BlockEventListener implements Listener { | |||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |         if (event.getNewState().getType().toString().endsWith("CONCRETE")) { | ||||||
|  |             if (!plot.getFlag(ConcreteHardenFlag.class)) { | ||||||
|  |                 plot.debug("Concrete powder could not harden because concrete-harden = false"); | ||||||
|  |                 event.setCancelled(true); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) |     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) | ||||||
| @@ -651,7 +525,11 @@ public class BlockEventListener implements Listener { | |||||||
|                 BlockBreakEvent call = new BlockBreakEvent(block, player); |                 BlockBreakEvent call = new BlockBreakEvent(block, player); | ||||||
|                 Bukkit.getServer().getPluginManager().callEvent(call); |                 Bukkit.getServer().getPluginManager().callEvent(call); | ||||||
|                 if (!call.isCancelled()) { |                 if (!call.isCancelled()) { | ||||||
|                     event.getBlock().breakNaturally(); |                     if (Settings.Flags.INSTABREAK_CONSIDER_TOOL) { | ||||||
|  |                         block.breakNaturally(event.getItemInHand()); | ||||||
|  |                     } else { | ||||||
|  |                         block.breakNaturally(); | ||||||
|  |                     } | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             // == rather than <= as we only care about the "ground level" not being destroyed |             // == rather than <= as we only care about the "ground level" not being destroyed | ||||||
| @@ -661,8 +539,7 @@ public class BlockEventListener implements Listener { | |||||||
|             } |             } | ||||||
|             if (!plot.hasOwner()) { |             if (!plot.hasOwner()) { | ||||||
|                 BukkitPlayer plotPlayer = BukkitUtil.adapt(player); |                 BukkitPlayer plotPlayer = BukkitUtil.adapt(player); | ||||||
|                 if (Permissions |                 if (plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_DESTROY_UNOWNED)) { | ||||||
|                         .hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_DESTROY_UNOWNED)) { |  | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
| @@ -674,8 +551,7 @@ public class BlockEventListener implements Listener { | |||||||
|                 Block block = event.getBlock(); |                 Block block = event.getBlock(); | ||||||
|                 if (destroy |                 if (destroy | ||||||
|                         .contains(BlockTypeWrapper.get(BukkitAdapter.asBlockType(block.getType()))) |                         .contains(BlockTypeWrapper.get(BukkitAdapter.asBlockType(block.getType()))) | ||||||
|                         || Permissions |                         || plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_DESTROY_OTHER)) { | ||||||
|                         .hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_DESTROY_OTHER)) { |  | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 plot.debug(player.getName() + " could not break " + block.getType() |                 plot.debug(player.getName() + " could not break " + block.getType() | ||||||
| @@ -686,7 +562,7 @@ public class BlockEventListener implements Listener { | |||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         BukkitPlayer plotPlayer = BukkitUtil.adapt(player); |         BukkitPlayer plotPlayer = BukkitUtil.adapt(player); | ||||||
|         if (Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_DESTROY_ROAD)) { |         if (plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_DESTROY_ROAD)) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         event.setCancelled(true); |         event.setCancelled(true); | ||||||
| @@ -727,7 +603,7 @@ public class BlockEventListener implements Listener { | |||||||
|             } |             } | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         if (org.bukkit.Tag.CORAL_BLOCKS.isTagged(blockType) || org.bukkit.Tag.CORALS.isTagged(blockType)) { |         if (CORAL_BLOCKS.isTagged(blockType) || CORALS.isTagged(blockType) || WALL_CORALS.isTagged(blockType)) { | ||||||
|             if (!plot.getFlag(CoralDryFlag.class)) { |             if (!plot.getFlag(CoralDryFlag.class)) { | ||||||
|                 plot.debug("Coral could not dry because coral-dry = false"); |                 plot.debug("Coral could not dry because coral-dry = false"); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
| @@ -735,6 +611,43 @@ public class BlockEventListener implements Listener { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) | ||||||
|  |     public void onMoistureChange(MoistureChangeEvent event) { | ||||||
|  |         Block block = event.getBlock(); | ||||||
|  |         Location location = BukkitUtil.adapt(block.getLocation()); | ||||||
|  |         PlotArea area = location.getPlotArea(); | ||||||
|  |  | ||||||
|  |         if (area == null) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         Plot plot = area.getOwnedPlot(location); | ||||||
|  |  | ||||||
|  |         if (plot == null) { | ||||||
|  |             event.setCancelled(true); | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if (block.getBlockData() instanceof Farmland farmland && event | ||||||
|  |                 .getNewState() | ||||||
|  |                 .getBlockData() instanceof Farmland newFarmland) { | ||||||
|  |             int currentMoisture = farmland.getMoisture(); | ||||||
|  |             int newMoisture = newFarmland.getMoisture(); | ||||||
|  |  | ||||||
|  |             // farmland gets moisturizes | ||||||
|  |             if (newMoisture > currentMoisture) { | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             if (plot.getFlag(SoilDryFlag.class)) { | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             plot.debug("Soil could not dry because soil-dry = false"); | ||||||
|  |             event.setCancelled(true); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) |     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) | ||||||
|     public void onChange(BlockFromToEvent event) { |     public void onChange(BlockFromToEvent event) { | ||||||
|         Block fromBlock = event.getBlock(); |         Block fromBlock = event.getBlock(); | ||||||
| @@ -762,7 +675,7 @@ public class BlockEventListener implements Listener { | |||||||
|             } |             } | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         if (toLocation.getY() >= toArea.getMaxBuildHeight() || toLocation.getY() < toArea.getMinBuildHeight()) { |         if (!toArea.buildRangeContainsY(toLocation.getY())) { | ||||||
|             event.setCancelled(true); |             event.setCancelled(true); | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
| @@ -780,7 +693,10 @@ public class BlockEventListener implements Listener { | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         if (toPlot != null) { |         if (toPlot != null) { | ||||||
|             if (!toArea.contains(fromLocation.getX(), fromLocation.getZ()) || !Objects.equals(toPlot, toArea.getOwnedPlot(fromLocation))) { |             if (!toArea.contains(fromLocation.getX(), fromLocation.getZ()) || !Objects.equals( | ||||||
|  |                     toPlot, | ||||||
|  |                     toArea.getOwnedPlot(fromLocation) | ||||||
|  |             )) { | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
| @@ -796,7 +712,10 @@ public class BlockEventListener implements Listener { | |||||||
|                 toPlot.debug("Liquid could not flow because liquid-flow = disabled"); |                 toPlot.debug("Liquid could not flow because liquid-flow = disabled"); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } |             } | ||||||
|         } else if (!toArea.contains(fromLocation.getX(), fromLocation.getZ()) || !Objects.equals(null, toArea.getOwnedPlot(fromLocation))) { |         } else if (!toArea.contains(fromLocation.getX(), fromLocation.getZ()) || !Objects.equals( | ||||||
|  |                 null, | ||||||
|  |                 toArea.getOwnedPlot(fromLocation) | ||||||
|  |         )) { | ||||||
|             event.setCancelled(true); |             event.setCancelled(true); | ||||||
|         } else if (event.getBlock().isLiquid()) { |         } else if (event.getBlock().isLiquid()) { | ||||||
|             final org.bukkit.Location location = event.getBlock().getLocation(); |             final org.bukkit.Location location = event.getBlock().getLocation(); | ||||||
| @@ -836,6 +755,11 @@ public class BlockEventListener implements Listener { | |||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |         if (!area.buildRangeContainsY(location.getY())) { | ||||||
|  |             event.setCancelled(true); | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|         Plot plot = location.getOwnedPlot(); |         Plot plot = location.getOwnedPlot(); | ||||||
|         if (plot == null || !plot.getFlag(CropGrowFlag.class)) { |         if (plot == null || !plot.getFlag(CropGrowFlag.class)) { | ||||||
|             if (plot != null) { |             if (plot != null) { | ||||||
| @@ -879,15 +803,16 @@ public class BlockEventListener implements Listener { | |||||||
|         } |         } | ||||||
|         for (Block block1 : event.getBlocks()) { |         for (Block block1 : event.getBlocks()) { | ||||||
|             Location bloc = BukkitUtil.adapt(block1.getLocation()); |             Location bloc = BukkitUtil.adapt(block1.getLocation()); | ||||||
|             if (!area.contains(bloc.getX(), bloc.getZ()) || !area.contains( |             Location newLoc = bloc.add(relative.getBlockX(), relative.getBlockY(), relative.getBlockZ()); | ||||||
|                     bloc.getX() + relative.getBlockX(), |             if (!area.contains(bloc.getX(), bloc.getZ()) || !area.contains(newLoc)) { | ||||||
|                     bloc.getZ() + relative.getBlockZ() |  | ||||||
|             )) { |  | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             if (!plot.equals(area.getOwnedPlot(bloc)) || !plot |             if (!plot.equals(area.getOwnedPlot(bloc)) || !plot.equals(area.getOwnedPlot(newLoc))) { | ||||||
|                     .equals(area.getOwnedPlot(bloc.add(relative.getBlockX(), relative.getBlockY(), relative.getBlockZ())))) { |                 event.setCancelled(true); | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|  |             if (!area.buildRangeContainsY(bloc.getY()) || !area.buildRangeContainsY(newLoc.getY())) { | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
| @@ -913,9 +838,8 @@ public class BlockEventListener implements Listener { | |||||||
|             } |             } | ||||||
|             for (Block block1 : event.getBlocks()) { |             for (Block block1 : event.getBlocks()) { | ||||||
|                 Location bloc = BukkitUtil.adapt(block1.getLocation()); |                 Location bloc = BukkitUtil.adapt(block1.getLocation()); | ||||||
|                 if (bloc.isPlotArea() || bloc |                 Location newLoc = bloc.add(relative.getBlockX(), relative.getBlockY(), relative.getBlockZ()); | ||||||
|                         .add(relative.getBlockX(), relative.getBlockY(), relative.getBlockZ()) |                 if (bloc.isPlotArea() || newLoc.isPlotArea()) { | ||||||
|                         .isPlotArea()) { |  | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
| @@ -929,15 +853,16 @@ public class BlockEventListener implements Listener { | |||||||
|         } |         } | ||||||
|         for (Block block1 : event.getBlocks()) { |         for (Block block1 : event.getBlocks()) { | ||||||
|             Location bloc = BukkitUtil.adapt(block1.getLocation()); |             Location bloc = BukkitUtil.adapt(block1.getLocation()); | ||||||
|             if (!area.contains(bloc.getX(), bloc.getZ()) || !area.contains( |             Location newLoc = bloc.add(relative.getBlockX(), relative.getBlockY(), relative.getBlockZ()); | ||||||
|                     bloc.getX() + relative.getBlockX(), |             if (!area.contains(bloc.getX(), bloc.getZ()) || !area.contains(newLoc)) { | ||||||
|                     bloc.getZ() + relative.getBlockZ() |  | ||||||
|             )) { |  | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             if (!plot.equals(area.getOwnedPlot(bloc)) || !plot |             if (!plot.equals(area.getOwnedPlot(bloc)) || !plot.equals(area.getOwnedPlot(newLoc))) { | ||||||
|                     .equals(area.getOwnedPlot(bloc.add(relative.getBlockX(), relative.getBlockY(), relative.getBlockZ())))) { |                 event.setCancelled(true); | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|  |             if (!area.buildRangeContainsY(bloc.getY()) || !area.buildRangeContainsY(newLoc.getY())) { | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
| @@ -946,6 +871,9 @@ public class BlockEventListener implements Listener { | |||||||
|  |  | ||||||
|     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) |     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) | ||||||
|     public void onBlockDispense(BlockDispenseEvent event) { |     public void onBlockDispense(BlockDispenseEvent event) { | ||||||
|  |         if (!this.plotAreaManager.hasPlotArea(event.getBlock().getWorld().getName())) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|         Material type = event.getItem().getType(); |         Material type = event.getItem().getType(); | ||||||
|         switch (type.toString()) { |         switch (type.toString()) { | ||||||
|             case "SHULKER_BOX", "WHITE_SHULKER_BOX", "ORANGE_SHULKER_BOX", "MAGENTA_SHULKER_BOX", "LIGHT_BLUE_SHULKER_BOX", |             case "SHULKER_BOX", "WHITE_SHULKER_BOX", "ORANGE_SHULKER_BOX", "MAGENTA_SHULKER_BOX", "LIGHT_BLUE_SHULKER_BOX", | ||||||
| @@ -957,10 +885,15 @@ public class BlockEventListener implements Listener { | |||||||
|                 if (event.getBlock().getType() == Material.DROPPER) { |                 if (event.getBlock().getType() == Material.DROPPER) { | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 BlockFace targetFace = ((Directional) event.getBlock().getState().getData()).getFacing(); |                 BlockFace targetFace = ((Dispenser) event.getBlock().getBlockData()).getFacing(); | ||||||
|                 Location location = BukkitUtil.adapt(event.getBlock().getRelative(targetFace).getLocation()); |                 Location location = BukkitUtil.adapt(event.getBlock().getRelative(targetFace).getLocation()); | ||||||
|                 if (location.isPlotRoad()) { |                 if (location.isPlotRoad()) { | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|  |                     return; | ||||||
|  |                 } | ||||||
|  |                 PlotArea area = location.getPlotArea(); | ||||||
|  |                 if (area != null && !area.buildRangeContainsY(location.getY())) { | ||||||
|  |                     event.setCancelled(true); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| @@ -1000,6 +933,10 @@ public class BlockEventListener implements Listener { | |||||||
|                 Plot plot = area.getOwnedPlot(location); |                 Plot plot = area.getOwnedPlot(location); | ||||||
|                 if (!Objects.equals(plot, origin)) { |                 if (!Objects.equals(plot, origin)) { | ||||||
|                     event.getBlocks().remove(i); |                     event.getBlocks().remove(i); | ||||||
|  |                     continue; | ||||||
|  |                 } | ||||||
|  |                 if (!area.buildRangeContainsY(location.getY())) { | ||||||
|  |                     event.getBlocks().remove(i); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| @@ -1048,6 +985,7 @@ public class BlockEventListener implements Listener { | |||||||
|             if (plot != null) { |             if (plot != null) { | ||||||
|                 plot.debug("Explosion was cancelled because explosion = false"); |                 plot.debug("Explosion was cancelled because explosion = false"); | ||||||
|             } |             } | ||||||
|  |             return; | ||||||
|         } |         } | ||||||
|         event.blockList().removeIf(blox -> !plot.equals(area.getOwnedPlot(BukkitUtil.adapt(blox.getLocation())))); |         event.blockList().removeIf(blox -> !plot.equals(area.getOwnedPlot(BukkitUtil.adapt(blox.getLocation())))); | ||||||
|     } |     } | ||||||
| @@ -1091,8 +1029,14 @@ public class BlockEventListener implements Listener { | |||||||
|         Plot plot = area.getOwnedPlot(location1); |         Plot plot = area.getOwnedPlot(location1); | ||||||
|         if (player != null) { |         if (player != null) { | ||||||
|             BukkitPlayer pp = BukkitUtil.adapt(player); |             BukkitPlayer pp = BukkitUtil.adapt(player); | ||||||
|  |             if (area.notifyIfOutsideBuildArea(pp, location1.getY())) { | ||||||
|  |                 event.setCancelled(true); | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|             if (plot == null) { |             if (plot == null) { | ||||||
|                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_ROAD)) { |                 if (!PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, BlockIgnitionFlag.class, true) && !pp.hasPermission( | ||||||
|  |                         Permission.PERMISSION_ADMIN_BUILD_ROAD | ||||||
|  |                 )) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             TagResolver.resolver( | ||||||
| @@ -1103,7 +1047,9 @@ public class BlockEventListener implements Listener { | |||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                 } |                 } | ||||||
|             } else if (!plot.hasOwner()) { |             } else if (!plot.hasOwner()) { | ||||||
|                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_UNOWNED)) { |                 if (!PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, BlockIgnitionFlag.class, true) && !pp.hasPermission( | ||||||
|  |                         Permission.PERMISSION_ADMIN_BUILD_UNOWNED | ||||||
|  |                 )) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             TagResolver.resolver( | ||||||
| @@ -1114,7 +1060,7 @@ public class BlockEventListener implements Listener { | |||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                 } |                 } | ||||||
|             } else if (!plot.isAdded(pp.getUUID())) { |             } else if (!plot.isAdded(pp.getUUID())) { | ||||||
|                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_OTHER)) { |                 if (!pp.hasPermission(Permission.PERMISSION_ADMIN_BUILD_OTHER)) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             TagResolver.resolver( | ||||||
| @@ -1207,7 +1153,10 @@ public class BlockEventListener implements Listener { | |||||||
|                     return true; |                     return true; | ||||||
|                 } |                 } | ||||||
|                 Plot plot = area.getOwnedPlot(blockLocation); |                 Plot plot = area.getOwnedPlot(blockLocation); | ||||||
|                 return !Objects.equals(plot, origin); |                 if (!Objects.equals(plot, origin)) { | ||||||
|  |                     return true; | ||||||
|  |                 } | ||||||
|  |                 return !area.buildRangeContainsY(location.getY()); | ||||||
|             }); |             }); | ||||||
|         } |         } | ||||||
|         if (blocks.isEmpty()) { |         if (blocks.isEmpty()) { | ||||||
| @@ -1238,8 +1187,7 @@ public class BlockEventListener implements Listener { | |||||||
|  |  | ||||||
|         for (final BlockState state : event.getReplacedBlockStates()) { |         for (final BlockState state : event.getReplacedBlockStates()) { | ||||||
|             Location currentLocation = BukkitUtil.adapt(state.getLocation()); |             Location currentLocation = BukkitUtil.adapt(state.getLocation()); | ||||||
|             if (!Permissions.hasPermission( |             if (!pp.hasPermission( | ||||||
|                     pp, |  | ||||||
|                     Permission.PERMISSION_ADMIN_BUILD_ROAD |                     Permission.PERMISSION_ADMIN_BUILD_ROAD | ||||||
|             ) && !(Objects.equals(currentLocation.getPlot(), plot))) { |             ) && !(Objects.equals(currentLocation.getPlot(), plot))) { | ||||||
|                 pp.sendMessage( |                 pp.sendMessage( | ||||||
| @@ -1249,21 +1197,15 @@ public class BlockEventListener implements Listener { | |||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|                 break; |                 break; | ||||||
|             } |             } | ||||||
|             if (Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_HEIGHT_LIMIT)) { |             if (pp.hasPermission(Permission.PERMISSION_ADMIN_BUILD_HEIGHT_LIMIT)) { | ||||||
|                 continue; |                 continue; | ||||||
|             } |             } | ||||||
|             if (currentLocation.getY() >= area.getMaxBuildHeight() || currentLocation.getY() < area.getMinBuildHeight()) { |             if (area.notifyIfOutsideBuildArea(pp, currentLocation.getY())) { | ||||||
|                 pp.sendMessage( |  | ||||||
|                         TranslatableCaption.of("height.height_limit"), |  | ||||||
|                         TagResolver.builder() |  | ||||||
|                                 .tag("minheight", Tag.inserting(Component.text(area.getMinBuildHeight()))) |  | ||||||
|                                 .tag("maxheight", Tag.inserting(Component.text(area.getMaxBuildHeight()))) |  | ||||||
|                                 .build() |  | ||||||
|                 ); |  | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|                 break; |                 break; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -26,6 +26,8 @@ import com.plotsquared.core.plot.Plot; | |||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
| import com.plotsquared.core.plot.flag.implementations.CopperOxideFlag; | import com.plotsquared.core.plot.flag.implementations.CopperOxideFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.MiscInteractFlag; | import com.plotsquared.core.plot.flag.implementations.MiscInteractFlag; | ||||||
|  | import com.plotsquared.core.plot.flag.implementations.SculkSensorInteractFlag; | ||||||
|  | import com.plotsquared.core.util.PlotFlagUtil; | ||||||
| import org.bukkit.Material; | import org.bukkit.Material; | ||||||
| import org.bukkit.block.Block; | import org.bukkit.block.Block; | ||||||
| import org.bukkit.entity.Entity; | import org.bukkit.entity.Entity; | ||||||
| @@ -80,13 +82,27 @@ public class BlockEventListener117 implements Listener { | |||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         Plot plot = location.getOwnedPlot(); |         BukkitPlayer plotPlayer = null; | ||||||
|         if (plot == null || !plot.getFlag(MiscInteractFlag.class)) { |  | ||||||
|         if (entity instanceof Player player) { |         if (entity instanceof Player player) { | ||||||
|                 BukkitPlayer plotPlayer = BukkitUtil.adapt(player); |             plotPlayer = BukkitUtil.adapt(player); | ||||||
|  |             if (area.notifyIfOutsideBuildArea(plotPlayer, location.getY())) { | ||||||
|  |                 event.setCancelled(true); | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         Plot plot = location.getOwnedPlot(); | ||||||
|  |         if (plot == null && !PlotFlagUtil.isAreaRoadFlagsAndFlagEquals( | ||||||
|  |                 area, | ||||||
|  |                 MiscInteractFlag.class, | ||||||
|  |                 true | ||||||
|  |         ) || plot != null && (!plot.getFlag(MiscInteractFlag.class) || !plot.getFlag(SculkSensorInteractFlag.class))) { | ||||||
|  |             if (plotPlayer != null) { | ||||||
|                 if (plot != null) { |                 if (plot != null) { | ||||||
|                     if (!plot.isAdded(plotPlayer.getUUID())) { |                     if (!plot.isAdded(plotPlayer.getUUID())) { | ||||||
|                         plot.debug(plotPlayer.getName() + " couldn't trigger sculk sensors because misc-interact = false"); |                         plot.debug(plotPlayer.getName() + " couldn't trigger sculk sensors because both " + | ||||||
|  |                                 "sculk-sensor-interact and misc-interact = false"); | ||||||
|                         event.setCancelled(true); |                         event.setCancelled(true); | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
| @@ -95,9 +111,17 @@ public class BlockEventListener117 implements Listener { | |||||||
|             if (entity instanceof Item item) { |             if (entity instanceof Item item) { | ||||||
|                 UUID itemThrower = item.getThrower(); |                 UUID itemThrower = item.getThrower(); | ||||||
|                 if (plot != null) { |                 if (plot != null) { | ||||||
|  |                     if (itemThrower == null && (itemThrower = item.getOwner()) == null) { | ||||||
|  |                         plot.debug( | ||||||
|  |                                 "A thrown item couldn't trigger sculk sensors because both sculk-sensor-interact and " + | ||||||
|  |                                         "misc-interact = false and the item's owner could not be resolved."); | ||||||
|  |                         event.setCancelled(true); | ||||||
|  |                         return; | ||||||
|  |                     } | ||||||
|                     if (!plot.isAdded(itemThrower)) { |                     if (!plot.isAdded(itemThrower)) { | ||||||
|                         if (!plot.isAdded(itemThrower)) { |                         if (!plot.isAdded(itemThrower)) { | ||||||
|                             plot.debug("A thrown item couldn't trigger sculk sensors because misc-interact = false"); |                             plot.debug("A thrown item couldn't trigger sculk sensors because both sculk-sensor-interact and " + | ||||||
|  |                                     "misc-interact = false"); | ||||||
|                             event.setCancelled(true); |                             event.setCancelled(true); | ||||||
|                         } |                         } | ||||||
|                     } |                     } | ||||||
| @@ -115,12 +139,11 @@ public class BlockEventListener117 implements Listener { | |||||||
|         PlotArea area = location.getPlotArea(); |         PlotArea area = location.getPlotArea(); | ||||||
|         if (area == null) { |         if (area == null) { | ||||||
|             for (int i = blocks.size() - 1; i >= 0; i--) { |             for (int i = blocks.size() - 1; i >= 0; i--) { | ||||||
|                 location = BukkitUtil.adapt(blocks.get(i).getLocation()); |                 Location blockLocation = BukkitUtil.adapt(blocks.get(i).getLocation()); | ||||||
|                 if (location.isPlotArea()) { |                 if (blockLocation.isPlotArea()) { | ||||||
|                     blocks.remove(i); |                     blocks.remove(i); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             return; |  | ||||||
|         } else { |         } else { | ||||||
|             Plot origin = area.getOwnedPlot(location); |             Plot origin = area.getOwnedPlot(location); | ||||||
|             if (origin == null) { |             if (origin == null) { | ||||||
| @@ -128,30 +151,22 @@ public class BlockEventListener117 implements Listener { | |||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             for (int i = blocks.size() - 1; i >= 0; i--) { |             for (int i = blocks.size() - 1; i >= 0; i--) { | ||||||
|                 location = BukkitUtil.adapt(blocks.get(i).getLocation()); |                 Location blockLocation = BukkitUtil.adapt(blocks.get(i).getLocation()); | ||||||
|                 if (!area.contains(location.getX(), location.getZ())) { |                 if (!area.contains(blockLocation.getX(), blockLocation.getZ())) { | ||||||
|                     blocks.remove(i); |                     blocks.remove(i); | ||||||
|                     continue; |                     continue; | ||||||
|                 } |                 } | ||||||
|                 Plot plot = area.getOwnedPlot(location); |                 Plot plot = area.getOwnedPlot(blockLocation); | ||||||
|                 if (!Objects.equals(plot, origin)) { |                 if (!Objects.equals(plot, origin)) { | ||||||
|                     event.getBlocks().remove(i); |                     event.getBlocks().remove(i); | ||||||
|  |                     continue; | ||||||
|                 } |                 } | ||||||
|             } |                 if (!area.buildRangeContainsY(location.getY())) { | ||||||
|         } |  | ||||||
|         Plot origin = area.getPlot(location); |  | ||||||
|         if (origin == null) { |  | ||||||
|             event.setCancelled(true); |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|         for (int i = blocks.size() - 1; i >= 0; i--) { |  | ||||||
|             location = BukkitUtil.adapt(blocks.get(i).getLocation()); |  | ||||||
|             Plot plot = area.getOwnedPlot(location); |  | ||||||
|             if (!Objects.equals(plot, origin) && (!plot.isMerged() && !origin.isMerged())) { |  | ||||||
|                     event.getBlocks().remove(i); |                     event.getBlocks().remove(i); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) |     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) | ||||||
|     public void onBlockForm(BlockFormEvent event) { |     public void onBlockForm(BlockFormEvent event) { | ||||||
|   | |||||||
| @@ -26,6 +26,7 @@ import com.plotsquared.core.plot.Plot; | |||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
| import com.plotsquared.core.plot.world.SinglePlotArea; | import com.plotsquared.core.plot.world.SinglePlotArea; | ||||||
|  | import com.plotsquared.core.util.ReflectionUtils; | ||||||
| import com.plotsquared.core.util.ReflectionUtils.RefClass; | import com.plotsquared.core.util.ReflectionUtils.RefClass; | ||||||
| import com.plotsquared.core.util.ReflectionUtils.RefField; | import com.plotsquared.core.util.ReflectionUtils.RefField; | ||||||
| import com.plotsquared.core.util.ReflectionUtils.RefMethod; | import com.plotsquared.core.util.ReflectionUtils.RefMethod; | ||||||
| @@ -64,9 +65,11 @@ public class ChunkListener implements Listener { | |||||||
|     private final PlotAreaManager plotAreaManager; |     private final PlotAreaManager plotAreaManager; | ||||||
|     private final int version; |     private final int version; | ||||||
|  |  | ||||||
|  |     private RefMethod methodSetUnsaved; | ||||||
|     private RefMethod methodGetHandleChunk; |     private RefMethod methodGetHandleChunk; | ||||||
|     private RefMethod methodGetHandleWorld; |     private RefMethod methodGetHandleWorld; | ||||||
|     private RefField mustSave; |     private RefField mustNotSave; | ||||||
|  |     private Object objChunkStatusFull = null; | ||||||
|     /* |     /* | ||||||
|     private RefMethod methodGetFullChunk; |     private RefMethod methodGetFullChunk; | ||||||
|     private RefMethod methodGetBukkitChunk; |     private RefMethod methodGetBukkitChunk; | ||||||
| @@ -79,7 +82,6 @@ public class ChunkListener implements Listener { | |||||||
|     */ |     */ | ||||||
|     private Chunk lastChunk; |     private Chunk lastChunk; | ||||||
|     private boolean ignoreUnload = false; |     private boolean ignoreUnload = false; | ||||||
|     private boolean isTrueForNotSave = true; |  | ||||||
|  |  | ||||||
|     @Inject |     @Inject | ||||||
|     public ChunkListener(final @NonNull PlotAreaManager plotAreaManager) { |     public ChunkListener(final @NonNull PlotAreaManager plotAreaManager) { | ||||||
| @@ -90,22 +92,27 @@ public class ChunkListener implements Listener { | |||||||
|         } |         } | ||||||
|         try { |         try { | ||||||
|             RefClass classCraftWorld = getRefClass("{cb}.CraftWorld"); |             RefClass classCraftWorld = getRefClass("{cb}.CraftWorld"); | ||||||
|             this.methodGetHandleWorld = classCraftWorld.getMethod("getHandle"); |  | ||||||
|             RefClass classCraftChunk = getRefClass("{cb}.CraftChunk"); |             RefClass classCraftChunk = getRefClass("{cb}.CraftChunk"); | ||||||
|  |             ReflectionUtils.RefClass classChunkAccess = getRefClass("net.minecraft.world.level.chunk.IChunkAccess"); | ||||||
|  |             this.methodSetUnsaved = classChunkAccess.getMethod("a", boolean.class); | ||||||
|  |             try { | ||||||
|                 this.methodGetHandleChunk = classCraftChunk.getMethod("getHandle"); |                 this.methodGetHandleChunk = classCraftChunk.getMethod("getHandle"); | ||||||
|  |             } catch (NoSuchMethodException ignored) { | ||||||
|  |                 try { | ||||||
|  |                     RefClass classChunkStatus = getRefClass("net.minecraft.world.level.chunk.ChunkStatus"); | ||||||
|  |                     this.objChunkStatusFull = classChunkStatus.getRealClass().getField("n").get(null); | ||||||
|  |                     this.methodGetHandleChunk = classCraftChunk.getMethod("getHandle", classChunkStatus.getRealClass()); | ||||||
|  |                 } catch (NoSuchMethodException ex) { | ||||||
|  |                     throw new RuntimeException(ex); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|             try { |             try { | ||||||
|                 if (version < 17) { |                 if (version < 17) { | ||||||
|                     RefClass classChunk = getRefClass("{nms}.Chunk"); |                     RefClass classChunk = getRefClass("{nms}.Chunk"); | ||||||
|                     if (version == 13) { |                     this.mustNotSave = classChunk.getField("mustNotSave"); | ||||||
|                         this.mustSave = classChunk.getField("mustSave"); |  | ||||||
|                         this.isTrueForNotSave = false; |  | ||||||
|                     } else { |  | ||||||
|                         this.mustSave = classChunk.getField("mustNotSave"); |  | ||||||
|                     } |  | ||||||
|                 } else { |                 } else { | ||||||
|                     RefClass classChunk = getRefClass("net.minecraft.world.level.chunk.Chunk"); |                     RefClass classChunk = getRefClass("net.minecraft.world.level.chunk.Chunk"); | ||||||
|                     this.mustSave = classChunk.getField("mustNotSave"); |                     this.mustNotSave = classChunk.getField("mustNotSave"); | ||||||
|  |  | ||||||
|                 } |                 } | ||||||
|             } catch (NoSuchFieldException e) { |             } catch (NoSuchFieldException e) { | ||||||
|                 e.printStackTrace(); |                 e.printStackTrace(); | ||||||
| @@ -167,10 +174,13 @@ public class ChunkListener implements Listener { | |||||||
|         if (safe && shouldSave(world, chunk.getX(), chunk.getZ())) { |         if (safe && shouldSave(world, chunk.getX(), chunk.getZ())) { | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         Object c = this.methodGetHandleChunk.of(chunk).call(); |         Object c = objChunkStatusFull != null | ||||||
|         RefField.RefExecutor field = this.mustSave.of(c); |                 ? this.methodGetHandleChunk.of(chunk).call(objChunkStatusFull) | ||||||
|         if ((Boolean) field.get() != isTrueForNotSave) { |                 : this.methodGetHandleChunk.of(chunk).call(); | ||||||
|             field.set(isTrueForNotSave); |         RefField.RefExecutor field = this.mustNotSave.of(c); | ||||||
|  |         methodSetUnsaved.of(c).call(false); | ||||||
|  |         if (!((Boolean) field.get())) { | ||||||
|  |             field.set(true); | ||||||
|             if (chunk.isLoaded()) { |             if (chunk.isLoaded()) { | ||||||
|                 ignoreUnload = true; |                 ignoreUnload = true; | ||||||
|                 chunk.unload(false); |                 chunk.unload(false); | ||||||
| @@ -234,7 +244,8 @@ public class ChunkListener implements Listener { | |||||||
|         Chunk chunk = event.getChunk(); |         Chunk chunk = event.getChunk(); | ||||||
|         if (Settings.Chunk_Processor.AUTO_TRIM) { |         if (Settings.Chunk_Processor.AUTO_TRIM) { | ||||||
|             String world = chunk.getWorld().getName(); |             String world = chunk.getWorld().getName(); | ||||||
|             if ((!Settings.Enabled_Components.WORLDS || !SinglePlotArea.isSinglePlotWorld(world)) && this.plotAreaManager.hasPlotArea(world)) { |             if ((!Settings.Enabled_Components.WORLDS || !SinglePlotArea.isSinglePlotWorld(world)) && this.plotAreaManager.hasPlotArea( | ||||||
|  |                     world)) { | ||||||
|                 if (unloadChunk(world, chunk, true)) { |                 if (unloadChunk(world, chunk, true)) { | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|   | |||||||
| @@ -19,6 +19,7 @@ | |||||||
| package com.plotsquared.bukkit.listener; | package com.plotsquared.bukkit.listener; | ||||||
|  |  | ||||||
| import com.google.inject.Inject; | import com.google.inject.Inject; | ||||||
|  | import com.plotsquared.bukkit.BukkitPlatform; | ||||||
| import com.plotsquared.bukkit.player.BukkitPlayer; | import com.plotsquared.bukkit.player.BukkitPlayer; | ||||||
| import com.plotsquared.bukkit.util.BukkitEntityUtil; | import com.plotsquared.bukkit.util.BukkitEntityUtil; | ||||||
| import com.plotsquared.bukkit.util.BukkitUtil; | import com.plotsquared.bukkit.util.BukkitUtil; | ||||||
| @@ -35,11 +36,13 @@ import com.plotsquared.core.plot.flag.implementations.DisablePhysicsFlag; | |||||||
| import com.plotsquared.core.plot.flag.implementations.EntityChangeBlockFlag; | import com.plotsquared.core.plot.flag.implementations.EntityChangeBlockFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.ExplosionFlag; | import com.plotsquared.core.plot.flag.implementations.ExplosionFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.InvincibleFlag; | import com.plotsquared.core.plot.flag.implementations.InvincibleFlag; | ||||||
|  | import com.plotsquared.core.plot.flag.implementations.ProjectileChangeBlockFlag; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
| import com.plotsquared.core.util.EventDispatcher; | import com.plotsquared.core.util.EventDispatcher; | ||||||
| import com.plotsquared.core.util.Permissions; | import com.plotsquared.core.util.PlotFlagUtil; | ||||||
| import com.sk89q.worldedit.bukkit.BukkitAdapter; | import com.sk89q.worldedit.bukkit.BukkitAdapter; | ||||||
| import com.sk89q.worldedit.world.block.BlockType; | import com.sk89q.worldedit.world.block.BlockType; | ||||||
|  | import io.papermc.lib.PaperLib; | ||||||
| import org.bukkit.Material; | import org.bukkit.Material; | ||||||
| import org.bukkit.Particle; | import org.bukkit.Particle; | ||||||
| import org.bukkit.World; | import org.bukkit.World; | ||||||
| @@ -53,6 +56,7 @@ import org.bukkit.entity.Player; | |||||||
| import org.bukkit.entity.Projectile; | import org.bukkit.entity.Projectile; | ||||||
| import org.bukkit.entity.TNTPrimed; | import org.bukkit.entity.TNTPrimed; | ||||||
| import org.bukkit.entity.Vehicle; | import org.bukkit.entity.Vehicle; | ||||||
|  | import org.bukkit.event.Cancellable; | ||||||
| import org.bukkit.event.EventHandler; | import org.bukkit.event.EventHandler; | ||||||
| import org.bukkit.event.EventPriority; | import org.bukkit.event.EventPriority; | ||||||
| import org.bukkit.event.Listener; | import org.bukkit.event.Listener; | ||||||
| @@ -77,52 +81,43 @@ import java.util.List; | |||||||
| @SuppressWarnings("unused") | @SuppressWarnings("unused") | ||||||
| public class EntityEventListener implements Listener { | public class EntityEventListener implements Listener { | ||||||
|  |  | ||||||
|  |     private final BukkitPlatform platform; | ||||||
|     private final PlotAreaManager plotAreaManager; |     private final PlotAreaManager plotAreaManager; | ||||||
|     private final EventDispatcher eventDispatcher; |     private final EventDispatcher eventDispatcher; | ||||||
|     private float lastRadius; |     private float lastRadius; | ||||||
|  |  | ||||||
|     @Inject |     @Inject | ||||||
|     public EntityEventListener( |     public EntityEventListener( | ||||||
|  |             final @NonNull BukkitPlatform platform, | ||||||
|             final @NonNull PlotAreaManager plotAreaManager, |             final @NonNull PlotAreaManager plotAreaManager, | ||||||
|             final @NonNull EventDispatcher eventDispatcher |             final @NonNull EventDispatcher eventDispatcher | ||||||
|     ) { |     ) { | ||||||
|  |         this.platform = platform; | ||||||
|         this.plotAreaManager = plotAreaManager; |         this.plotAreaManager = plotAreaManager; | ||||||
|         this.eventDispatcher = eventDispatcher; |         this.eventDispatcher = eventDispatcher; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @EventHandler(priority = EventPriority.HIGHEST) |     @EventHandler(priority = EventPriority.HIGHEST) | ||||||
|     public void onEntityCombustByEntity(EntityCombustByEntityEvent event) { |     public void onEntityCombustByEntity(EntityCombustByEntityEvent event) { | ||||||
|         EntityDamageByEntityEvent eventChange = |         onEntityDamageByEntityCommon(event.getCombuster(), event.getEntity(), EntityDamageEvent.DamageCause.FIRE_TICK, event); | ||||||
|                 new EntityDamageByEntityEvent( |  | ||||||
|                         event.getCombuster(), |  | ||||||
|                         event.getEntity(), |  | ||||||
|                         EntityDamageEvent.DamageCause.FIRE_TICK, |  | ||||||
|                         event.getDuration() |  | ||||||
|                 ); |  | ||||||
|         onEntityDamageByEntityEvent(eventChange); |  | ||||||
|         if (eventChange.isCancelled()) { |  | ||||||
|             event.setCancelled(true); |  | ||||||
|         } |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @EventHandler(priority = EventPriority.HIGHEST) |     @EventHandler(priority = EventPriority.HIGHEST) | ||||||
|     public void onEntityDamageByEntityEvent(EntityDamageByEntityEvent event) { |     public void onEntityDamageByEntityEvent(EntityDamageByEntityEvent event) { | ||||||
|         Entity damager = event.getDamager(); |         onEntityDamageByEntityCommon(event.getDamager(), event.getEntity(), event.getCause(), event); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private void onEntityDamageByEntityCommon( | ||||||
|  |             final Entity damager, | ||||||
|  |             final Entity victim, | ||||||
|  |             final EntityDamageEvent.DamageCause cause, | ||||||
|  |             final Cancellable event | ||||||
|  |     ) { | ||||||
|         Location location = BukkitUtil.adapt(damager.getLocation()); |         Location location = BukkitUtil.adapt(damager.getLocation()); | ||||||
|         if (!this.plotAreaManager.hasPlotArea(location.getWorldName())) { |         if (!this.plotAreaManager.hasPlotArea(location.getWorldName())) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         Entity victim = event.getEntity(); |         if (!BukkitEntityUtil.entityDamage(damager, victim, cause)) { | ||||||
| /* |  | ||||||
|         if (victim.getType().equals(EntityType.ITEM_FRAME)) { |  | ||||||
|             Plot plot = BukkitUtil.getLocation(victim).getPlot(); |  | ||||||
|             if (plot != null && !plot.isAdded(damager.getUniqueId())) { |  | ||||||
|                 event.setCancelled(true); |  | ||||||
|                 return; |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
| */ |  | ||||||
|         if (!BukkitEntityUtil.entityDamage(damager, victim, event.getCause())) { |  | ||||||
|             if (event.isCancelled()) { |             if (event.isCancelled()) { | ||||||
|                 if (victim instanceof Ageable ageable) { |                 if (victim instanceof Ageable ageable) { | ||||||
|                     if (ageable.getAge() == -24000) { |                     if (ageable.getAge() == -24000) { | ||||||
| @@ -143,56 +138,55 @@ public class EntityEventListener implements Listener { | |||||||
|         if (area == null) { |         if (area == null) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|  |         // Armour-stands are handled elsewhere and should not be handled by area-wide entity-spawn options | ||||||
|  |         if (entity.getType() == EntityType.ARMOR_STAND) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|         CreatureSpawnEvent.SpawnReason reason = event.getSpawnReason(); |         CreatureSpawnEvent.SpawnReason reason = event.getSpawnReason(); | ||||||
|         switch (reason.toString()) { |         switch (reason.toString()) { | ||||||
|             case "DISPENSE_EGG": |             case "DISPENSE_EGG", "EGG", "OCELOT_BABY", "SPAWNER_EGG" -> { | ||||||
|             case "EGG": |  | ||||||
|             case "OCELOT_BABY": |  | ||||||
|             case "SPAWNER_EGG": |  | ||||||
|                 if (!area.isSpawnEggs()) { |                 if (!area.isSpawnEggs()) { | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 break; |             } | ||||||
|             case "REINFORCEMENTS": |             case "REINFORCEMENTS", "NATURAL", "MOUNT", "PATROL", "RAID", "SHEARED", "SILVERFISH_BLOCK", "ENDER_PEARL", | ||||||
|             case "NATURAL": |                     "TRAP", "VILLAGE_DEFENSE", "VILLAGE_INVASION", "BEEHIVE", "CHUNK_GEN", "NETHER_PORTAL", | ||||||
|             case "MOUNT": |                     "FROZEN", "SPELL", "DEFAULT" -> { | ||||||
|             case "PATROL": |  | ||||||
|             case "RAID": |  | ||||||
|             case "SHEARED": |  | ||||||
|             case "SILVERFISH_BLOCK": |  | ||||||
|             case "ENDER_PEARL": |  | ||||||
|             case "TRAP": |  | ||||||
|             case "VILLAGE_DEFENSE": |  | ||||||
|             case "VILLAGE_INVASION": |  | ||||||
|             case "BEEHIVE": |  | ||||||
|             case "CHUNK_GEN": |  | ||||||
|                 if (!area.isMobSpawning()) { |                 if (!area.isMobSpawning()) { | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 break; |             } | ||||||
|             case "BREEDING": |             case "BREEDING", "DUPLICATION" -> { | ||||||
|                 if (!area.isSpawnBreeding()) { |                 if (!area.isSpawnBreeding()) { | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 break; |             } | ||||||
|             case "BUILD_IRONGOLEM": |             case "CUSTOM" -> { | ||||||
|             case "BUILD_SNOWMAN": |                 if (!area.isSpawnCustom()) { | ||||||
|             case "BUILD_WITHER": |  | ||||||
|             case "CUSTOM": |  | ||||||
|                 if (!area.isSpawnCustom() && entity.getType() != EntityType.ARMOR_STAND) { |  | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 break; |                 // No need to clutter metadata if running paper | ||||||
|             case "SPAWNER": |                 if (!PaperLib.isPaper()) { | ||||||
|  |                     entity.setMetadata("ps_custom_spawned", new FixedMetadataValue(this.platform, true)); | ||||||
|  |                 } | ||||||
|  |                 return; // Don't cancel if mob spawning is disabled | ||||||
|  |             } | ||||||
|  |             case "BUILD_IRONGOLEM", "BUILD_SNOWMAN", "BUILD_WITHER" -> { | ||||||
|  |                 if (!area.isSpawnCustom()) { | ||||||
|  |                     event.setCancelled(true); | ||||||
|  |                     return; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |             case "SPAWNER" -> { | ||||||
|                 if (!area.isMobSpawnerSpawning()) { |                 if (!area.isMobSpawnerSpawning()) { | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 break; |             } | ||||||
|         } |         } | ||||||
|         Plot plot = area.getOwnedPlotAbs(location); |         Plot plot = area.getOwnedPlotAbs(location); | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
| @@ -261,7 +255,7 @@ public class EntityEventListener implements Listener { | |||||||
|         } |         } | ||||||
|         Plot plot = location.getOwnedPlot(); |         Plot plot = location.getOwnedPlot(); | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             if (area.isRoadFlags() && area.getRoadFlag(InvincibleFlag.class)) { |             if (PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, InvincibleFlag.class, true)) { | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } |             } | ||||||
|             return; |             return; | ||||||
| @@ -370,14 +364,13 @@ public class EntityEventListener implements Listener { | |||||||
|             if (shooter instanceof Player) { |             if (shooter instanceof Player) { | ||||||
|                 PlotPlayer<?> pp = BukkitUtil.adapt((Player) shooter); |                 PlotPlayer<?> pp = BukkitUtil.adapt((Player) shooter); | ||||||
|                 if (plot == null) { |                 if (plot == null) { | ||||||
|                     if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_PROJECTILE_UNOWNED)) { |                     if (area.isRoadFlags() && !area.getRoadFlag(ProjectileChangeBlockFlag.class) && !pp.hasPermission(Permission.PERMISSION_ADMIN_PROJECTILE_UNOWNED)) { | ||||||
|                         entity.remove(); |                         entity.remove(); | ||||||
|                         event.setCancelled(true); |                         event.setCancelled(true); | ||||||
|                     } |                     } | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 if (plot.isAdded(pp.getUUID()) || Permissions |                 if (plot.isAdded(pp.getUUID()) || plot.getFlag(ProjectileChangeBlockFlag.class) || pp.hasPermission(Permission.PERMISSION_ADMIN_PROJECTILE_OTHER)) { | ||||||
|                         .hasPermission(pp, Permission.PERMISSION_ADMIN_PROJECTILE_OTHER)) { |  | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 entity.remove(); |                 entity.remove(); | ||||||
|   | |||||||
| @@ -120,22 +120,28 @@ public class EntitySpawnListener implements Listener { | |||||||
|         Entity entity = event.getEntity(); |         Entity entity = event.getEntity(); | ||||||
|         Location location = BukkitUtil.adapt(entity.getLocation()); |         Location location = BukkitUtil.adapt(entity.getLocation()); | ||||||
|         PlotArea area = location.getPlotArea(); |         PlotArea area = location.getPlotArea(); | ||||||
|         if (!location.isPlotArea()) { |         if (!location.isPlotArea() || area == null) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|  |         if (PaperLib.isPaper()) { | ||||||
|  |             //noinspection ConstantValue - getEntitySpawnReason annotated as NotNull, but is not NotNull. lol. | ||||||
|  |             if (area.isSpawnCustom() && entity.getEntitySpawnReason() != null && "CUSTOM".equals(entity.getEntitySpawnReason().name())) { | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|         Plot plot = location.getOwnedPlotAbs(); |         Plot plot = location.getOwnedPlotAbs(); | ||||||
|         EntityType type = entity.getType(); |         EntityType type = entity.getType(); | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             if (!area.isMobSpawning()) { |  | ||||||
|                 if (type == EntityType.PLAYER) { |  | ||||||
|                     return; |  | ||||||
|                 } |  | ||||||
|             if (type == EntityType.DROPPED_ITEM) { |             if (type == EntityType.DROPPED_ITEM) { | ||||||
|                 if (Settings.Enabled_Components.KILL_ROAD_ITEMS) { |                 if (Settings.Enabled_Components.KILL_ROAD_ITEMS) { | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                 } |                 } | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|  |             if (!area.isMobSpawning()) { | ||||||
|  |                 if (type == EntityType.PLAYER) { | ||||||
|  |                     return; | ||||||
|  |                 } | ||||||
|                 if (type.isAlive()) { |                 if (type.isAlive()) { | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                 } |                 } | ||||||
| @@ -148,7 +154,7 @@ public class EntitySpawnListener implements Listener { | |||||||
|         if (Settings.Done.RESTRICT_BUILDING && DoneFlag.isDone(plot)) { |         if (Settings.Done.RESTRICT_BUILDING && DoneFlag.isDone(plot)) { | ||||||
|             event.setCancelled(true); |             event.setCancelled(true); | ||||||
|         } |         } | ||||||
|         if (type == EntityType.ENDER_CRYSTAL) { |         if (type == EntityType.ENDER_CRYSTAL || type == EntityType.ARMOR_STAND) { | ||||||
|             if (BukkitEntityUtil.checkEntity(entity, plot)) { |             if (BukkitEntityUtil.checkEntity(entity, plot)) { | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } |             } | ||||||
|   | |||||||
| @@ -18,7 +18,6 @@ | |||||||
|  */ |  */ | ||||||
| package com.plotsquared.bukkit.listener; | package com.plotsquared.bukkit.listener; | ||||||
|  |  | ||||||
| import com.google.common.collect.Iterables; |  | ||||||
| import com.plotsquared.bukkit.player.BukkitPlayer; | import com.plotsquared.bukkit.player.BukkitPlayer; | ||||||
| import com.plotsquared.bukkit.util.BukkitUtil; | import com.plotsquared.bukkit.util.BukkitUtil; | ||||||
| import com.plotsquared.core.location.Location; | import com.plotsquared.core.location.Location; | ||||||
| @@ -26,7 +25,6 @@ import com.plotsquared.core.permissions.Permission; | |||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import com.plotsquared.core.plot.flag.implementations.ForcefieldFlag; | import com.plotsquared.core.plot.flag.implementations.ForcefieldFlag; | ||||||
| import com.plotsquared.core.util.Permissions; |  | ||||||
| import org.bukkit.entity.Player; | import org.bukkit.entity.Player; | ||||||
| import org.bukkit.util.Vector; | import org.bukkit.util.Vector; | ||||||
|  |  | ||||||
| @@ -39,8 +37,11 @@ public class ForceFieldListener { | |||||||
|  |  | ||||||
|     private static Set<PlotPlayer<?>> getNearbyPlayers(Player player, Plot plot) { |     private static Set<PlotPlayer<?>> getNearbyPlayers(Player player, Plot plot) { | ||||||
|         Set<PlotPlayer<?>> players = new HashSet<>(); |         Set<PlotPlayer<?>> players = new HashSet<>(); | ||||||
|         for (Player nearPlayer : Iterables |         for (Player nearPlayer : player.getNearbyEntities(5d, 5d, 5d).stream() | ||||||
|                 .filter(player.getNearbyEntities(5d, 5d, 5d), Player.class)) { |                 .filter(entity -> entity instanceof Player) | ||||||
|  |                 .map(entity -> (Player) entity) | ||||||
|  |                 .toList() | ||||||
|  |         ) { | ||||||
|             PlotPlayer<?> plotPlayer; |             PlotPlayer<?> plotPlayer; | ||||||
|             if ((plotPlayer = BukkitUtil.adapt(nearPlayer)) == null || !plot |             if ((plotPlayer = BukkitUtil.adapt(nearPlayer)) == null || !plot | ||||||
|                     .equals(plotPlayer.getCurrentPlot())) { |                     .equals(plotPlayer.getCurrentPlot())) { | ||||||
| @@ -54,8 +55,11 @@ public class ForceFieldListener { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     private static PlotPlayer<?> hasNearbyPermitted(Player player, Plot plot) { |     private static PlotPlayer<?> hasNearbyPermitted(Player player, Plot plot) { | ||||||
|         for (Player nearPlayer : Iterables |         for (Player nearPlayer : player.getNearbyEntities(5d, 5d, 5d).stream() | ||||||
|                 .filter(player.getNearbyEntities(5d, 5d, 5d), Player.class)) { |                 .filter(entity -> entity instanceof Player) | ||||||
|  |                 .map(entity -> (Player) entity) | ||||||
|  |                 .toList() | ||||||
|  |         ) { | ||||||
|             PlotPlayer<?> plotPlayer; |             PlotPlayer<?> plotPlayer; | ||||||
|             if ((plotPlayer = BukkitUtil.adapt(nearPlayer)) == null || !plot |             if ((plotPlayer = BukkitUtil.adapt(nearPlayer)) == null || !plot | ||||||
|                     .equals(plotPlayer.getCurrentPlot())) { |                     .equals(plotPlayer.getCurrentPlot())) { | ||||||
| @@ -104,8 +108,7 @@ public class ForceFieldListener { | |||||||
|             if (plot.isAdded(uuid)) { |             if (plot.isAdded(uuid)) { | ||||||
|                 Set<PlotPlayer<?>> players = getNearbyPlayers(player, plot); |                 Set<PlotPlayer<?>> players = getNearbyPlayers(player, plot); | ||||||
|                 for (PlotPlayer<?> oPlayer : players) { |                 for (PlotPlayer<?> oPlayer : players) { | ||||||
|                     if (!Permissions |                     if (!oPlayer.hasPermission(Permission.PERMISSION_ADMIN_ENTRY_FORCEFIELD)) { | ||||||
|                             .hasPermission(oPlayer, Permission.PERMISSION_ADMIN_ENTRY_FORCEFIELD)) { |  | ||||||
|                         ((BukkitPlayer) oPlayer).player |                         ((BukkitPlayer) oPlayer).player | ||||||
|                                 .setVelocity(calculateVelocity(plotPlayer, oPlayer)); |                                 .setVelocity(calculateVelocity(plotPlayer, oPlayer)); | ||||||
|                     } |                     } | ||||||
| @@ -115,8 +118,7 @@ public class ForceFieldListener { | |||||||
|                 if (oPlayer == null) { |                 if (oPlayer == null) { | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 if (!Permissions |                 if (!plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_ENTRY_FORCEFIELD)) { | ||||||
|                         .hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_ENTRY_FORCEFIELD)) { |  | ||||||
|                     player.setVelocity(calculateVelocity(oPlayer, plotPlayer)); |                     player.setVelocity(calculateVelocity(oPlayer, plotPlayer)); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|   | |||||||
| @@ -0,0 +1,201 @@ | |||||||
|  | /* | ||||||
|  |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  |  * | ||||||
|  |  * This program is free software: you can redistribute it and/or modify | ||||||
|  |  * it under the terms of the GNU General Public License as published by | ||||||
|  |  * the Free Software Foundation, either version 3 of the License, or | ||||||
|  |  * (at your option) any later version. | ||||||
|  |  * | ||||||
|  |  * This program is distributed in the hope that it will be useful, | ||||||
|  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||||
|  |  * GNU General Public License for more details. | ||||||
|  |  * | ||||||
|  |  * You should have received a copy of the GNU General Public License | ||||||
|  |  * along with this program.  If not, see <https://www.gnu.org/licenses/>. | ||||||
|  |  */ | ||||||
|  | package com.plotsquared.bukkit.listener; | ||||||
|  |  | ||||||
|  | import com.google.inject.Inject; | ||||||
|  | import com.plotsquared.bukkit.player.BukkitPlayer; | ||||||
|  | import com.plotsquared.bukkit.util.BukkitUtil; | ||||||
|  | import com.plotsquared.core.PlotSquared; | ||||||
|  | import com.plotsquared.core.configuration.Settings; | ||||||
|  | import com.plotsquared.core.database.DBFunc; | ||||||
|  | import com.plotsquared.core.location.Location; | ||||||
|  | import com.plotsquared.core.player.PlotPlayer; | ||||||
|  | import com.plotsquared.core.plot.Plot; | ||||||
|  | import com.plotsquared.core.plot.PlotArea; | ||||||
|  | import com.plotsquared.core.plot.flag.implementations.DisablePhysicsFlag; | ||||||
|  | import com.plotsquared.core.plot.flag.implementations.RedstoneFlag; | ||||||
|  | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
|  | import com.plotsquared.core.util.PlotFlagUtil; | ||||||
|  | import com.plotsquared.core.util.task.TaskManager; | ||||||
|  | import com.plotsquared.core.util.task.TaskTime; | ||||||
|  | import com.sk89q.worldedit.WorldEdit; | ||||||
|  | import org.bukkit.Bukkit; | ||||||
|  | import org.bukkit.Material; | ||||||
|  | import org.bukkit.block.Block; | ||||||
|  | import org.bukkit.block.BlockFace; | ||||||
|  | import org.bukkit.block.data.BlockData; | ||||||
|  | import org.bukkit.event.EventHandler; | ||||||
|  | import org.bukkit.event.EventPriority; | ||||||
|  | import org.bukkit.event.Listener; | ||||||
|  | import org.bukkit.event.block.BlockPhysicsEvent; | ||||||
|  | import org.bukkit.event.block.BlockRedstoneEvent; | ||||||
|  | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
|  | import java.util.Set; | ||||||
|  | import java.util.UUID; | ||||||
|  |  | ||||||
|  | @SuppressWarnings("unused") | ||||||
|  | public class HighFreqBlockEventListener implements Listener { | ||||||
|  |  | ||||||
|  |     private static final Set<Material> PISTONS = Set.of( | ||||||
|  |             Material.PISTON, | ||||||
|  |             Material.STICKY_PISTON | ||||||
|  |     ); | ||||||
|  |     private static final Set<Material> PHYSICS_BLOCKS = Set.of( | ||||||
|  |             Material.TURTLE_EGG, | ||||||
|  |             Material.TURTLE_SPAWN_EGG | ||||||
|  |     ); | ||||||
|  |  | ||||||
|  |     private final PlotAreaManager plotAreaManager; | ||||||
|  |     private final WorldEdit worldEdit; | ||||||
|  |  | ||||||
|  |     @Inject | ||||||
|  |     public HighFreqBlockEventListener(final @NonNull PlotAreaManager plotAreaManager, final @NonNull WorldEdit worldEdit) { | ||||||
|  |         this.plotAreaManager = plotAreaManager; | ||||||
|  |         this.worldEdit = worldEdit; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public static void sendBlockChange(final org.bukkit.Location bloc, final BlockData data) { | ||||||
|  |         TaskManager.runTaskLater(() -> { | ||||||
|  |             String world = bloc.getWorld().getName(); | ||||||
|  |             int x = bloc.getBlockX(); | ||||||
|  |             int z = bloc.getBlockZ(); | ||||||
|  |             int distance = Bukkit.getViewDistance() * 16; | ||||||
|  |  | ||||||
|  |             for (final PlotPlayer<?> player : PlotSquared.platform().playerManager().getPlayers()) { | ||||||
|  |                 Location location = player.getLocation(); | ||||||
|  |                 if (location.getWorldName().equals(world)) { | ||||||
|  |                     if (16 * Math.abs(location.getX() - x) / 16 > distance || 16 * Math.abs(location.getZ() - z) / 16 > distance) { | ||||||
|  |                         continue; | ||||||
|  |                     } | ||||||
|  |                     ((BukkitPlayer) player).player.sendBlockChange(bloc, data); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         }, TaskTime.ticks(3L)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @EventHandler | ||||||
|  |     public void onRedstoneEvent(BlockRedstoneEvent event) { | ||||||
|  |         Block block = event.getBlock(); | ||||||
|  |         Location location = BukkitUtil.adapt(block.getLocation()); | ||||||
|  |         PlotArea area = location.getPlotArea(); | ||||||
|  |         if (area == null) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |         Plot plot = location.getOwnedPlot(); | ||||||
|  |         if (plot == null) { | ||||||
|  |             if (PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, RedstoneFlag.class, false)) { | ||||||
|  |                 event.setNewCurrent(0); | ||||||
|  |             } | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |         if (!plot.getFlag(RedstoneFlag.class)) { | ||||||
|  |             event.setNewCurrent(0); | ||||||
|  |             plot.debug("Redstone event was cancelled because redstone = false"); | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |         if (Settings.Redstone.DISABLE_OFFLINE) { | ||||||
|  |             boolean disable = false; | ||||||
|  |             if (!DBFunc.SERVER.equals(plot.getOwner())) { | ||||||
|  |                 if (plot.isMerged()) { | ||||||
|  |                     disable = true; | ||||||
|  |                     for (UUID owner : plot.getOwners()) { | ||||||
|  |                         if (PlotSquared.platform().playerManager().getPlayerIfExists(owner) != null) { | ||||||
|  |                             disable = false; | ||||||
|  |                             break; | ||||||
|  |                         } | ||||||
|  |                     } | ||||||
|  |                 } else { | ||||||
|  |                     disable = PlotSquared.platform().playerManager().getPlayerIfExists(plot.getOwnerAbs()) == null; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |             if (disable) { | ||||||
|  |                 for (UUID trusted : plot.getTrusted()) { | ||||||
|  |                     if (PlotSquared.platform().playerManager().getPlayerIfExists(trusted) != null) { | ||||||
|  |                         disable = false; | ||||||
|  |                         break; | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |                 if (disable) { | ||||||
|  |                     event.setNewCurrent(0); | ||||||
|  |                     plot.debug("Redstone event was cancelled because no trusted player was in the plot"); | ||||||
|  |                     return; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         if (Settings.Redstone.DISABLE_UNOCCUPIED) { | ||||||
|  |             for (final PlotPlayer<?> player : PlotSquared.platform().playerManager().getPlayers()) { | ||||||
|  |                 if (plot.equals(player.getCurrentPlot())) { | ||||||
|  |                     return; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |             event.setNewCurrent(0); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @EventHandler(ignoreCancelled = true, priority = EventPriority.HIGHEST) | ||||||
|  |     public void onPhysicsEvent(BlockPhysicsEvent event) { | ||||||
|  |         Block block = event.getBlock(); | ||||||
|  |         Location location = BukkitUtil.adapt(block.getLocation()); | ||||||
|  |         PlotArea area = location.getPlotArea(); | ||||||
|  |         if (area == null) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |         Plot plot = area.getOwnedPlotAbs(location); | ||||||
|  |         if (plot == null) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |         if (event.getChangedType().hasGravity() && plot.getFlag(DisablePhysicsFlag.class)) { | ||||||
|  |             event.setCancelled(true); | ||||||
|  |             sendBlockChange(event.getBlock().getLocation(), event.getBlock().getBlockData()); | ||||||
|  |             plot.debug("Prevented block physics and resent block change because disable-physics = true"); | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |         if (event.getChangedType() == Material.COMPARATOR) { | ||||||
|  |             if (!plot.getFlag(RedstoneFlag.class)) { | ||||||
|  |                 event.setCancelled(true); | ||||||
|  |                 plot.debug("Prevented comparator update because redstone = false"); | ||||||
|  |             } | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |         if (PHYSICS_BLOCKS.contains(event.getChangedType())) { | ||||||
|  |             if (plot.getFlag(DisablePhysicsFlag.class)) { | ||||||
|  |                 event.setCancelled(true); | ||||||
|  |                 plot.debug("Prevented block physics because disable-physics = true"); | ||||||
|  |             } | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |         if (Settings.Redstone.DETECT_INVALID_EDGE_PISTONS) { | ||||||
|  |             if (PISTONS.contains(block.getType())) { | ||||||
|  |                 org.bukkit.block.data.Directional piston = (org.bukkit.block.data.Directional) block.getBlockData(); | ||||||
|  |                 final BlockFace facing = piston.getFacing(); | ||||||
|  |                 location = location.add(facing.getModX(), facing.getModY(), facing.getModZ()); | ||||||
|  |                 Plot newPlot = area.getOwnedPlotAbs(location); | ||||||
|  |                 if (plot.equals(newPlot)) { | ||||||
|  |                     return; | ||||||
|  |                 } | ||||||
|  |                 if (!plot.isMerged() || !plot.getConnectedPlots().contains(newPlot)) { | ||||||
|  |                     event.setCancelled(true); | ||||||
|  |                     plot.debug("Prevented piston update because of invalid edge piston detection"); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -18,6 +18,8 @@ | |||||||
|  */ |  */ | ||||||
| package com.plotsquared.bukkit.listener; | package com.plotsquared.bukkit.listener; | ||||||
|  |  | ||||||
|  | import com.destroystokyo.paper.event.block.BeaconEffectEvent; | ||||||
|  | import com.destroystokyo.paper.event.block.BlockDestroyEvent; | ||||||
| import com.destroystokyo.paper.event.entity.EntityPathfindEvent; | import com.destroystokyo.paper.event.entity.EntityPathfindEvent; | ||||||
| import com.destroystokyo.paper.event.entity.PlayerNaturallySpawnCreaturesEvent; | import com.destroystokyo.paper.event.entity.PlayerNaturallySpawnCreaturesEvent; | ||||||
| import com.destroystokyo.paper.event.entity.PreCreatureSpawnEvent; | import com.destroystokyo.paper.event.entity.PreCreatureSpawnEvent; | ||||||
| @@ -36,10 +38,15 @@ import com.plotsquared.core.permissions.Permission; | |||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
|  | import com.plotsquared.core.plot.flag.FlagContainer; | ||||||
|  | import com.plotsquared.core.plot.flag.implementations.BeaconEffectsFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.DoneFlag; | import com.plotsquared.core.plot.flag.implementations.DoneFlag; | ||||||
|  | import com.plotsquared.core.plot.flag.implementations.FishingFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.ProjectilesFlag; | import com.plotsquared.core.plot.flag.implementations.ProjectilesFlag; | ||||||
|  | import com.plotsquared.core.plot.flag.implementations.TileDropFlag; | ||||||
|  | import com.plotsquared.core.plot.flag.types.BooleanFlag; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
| import com.plotsquared.core.util.Permissions; | import com.plotsquared.core.util.PlotFlagUtil; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; | import net.kyori.adventure.text.minimessage.tag.Tag; | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | ||||||
| @@ -79,6 +86,19 @@ public class PaperListener implements Listener { | |||||||
|         this.plotAreaManager = plotAreaManager; |         this.plotAreaManager = plotAreaManager; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @EventHandler(ignoreCancelled = true, priority = EventPriority.LOWEST) | ||||||
|  |     public void onBlockDestroy(final BlockDestroyEvent event) { | ||||||
|  |         Location location = BukkitUtil.adapt(event.getBlock().getLocation()); | ||||||
|  |         PlotArea area = location.getPlotArea(); | ||||||
|  |         if (area == null) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |         Plot plot = area.getPlot(location); | ||||||
|  |         if (plot != null) { | ||||||
|  |             event.setWillDrop(plot.getFlag(TileDropFlag.class)); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|     @EventHandler |     @EventHandler | ||||||
|     public void onEntityPathfind(EntityPathfindEvent event) { |     public void onEntityPathfind(EntityPathfindEvent event) { | ||||||
|         if (!Settings.Paper_Components.ENTITY_PATHING) { |         if (!Settings.Paper_Components.ENTITY_PATHING) { | ||||||
| @@ -120,7 +140,7 @@ public class PaperListener implements Listener { | |||||||
|         } |         } | ||||||
|         Slime slime = event.getEntity(); |         Slime slime = event.getEntity(); | ||||||
|  |  | ||||||
|         Block b = slime.getTargetBlock(4); |         Block b = slime.getTargetBlockExact(4); | ||||||
|         if (b == null) { |         if (b == null) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
| @@ -162,86 +182,72 @@ public class PaperListener implements Listener { | |||||||
|         } |         } | ||||||
|         Location location = BukkitUtil.adapt(event.getSpawnLocation()); |         Location location = BukkitUtil.adapt(event.getSpawnLocation()); | ||||||
|         PlotArea area = location.getPlotArea(); |         PlotArea area = location.getPlotArea(); | ||||||
|         if (!location.isPlotArea()) { |         if (area == null) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         //If entities are spawning... the chunk should be loaded? |         // Armour-stands are handled elsewhere and should not be handled by area-wide entity-spawn options | ||||||
|  |         if (event.getType() == EntityType.ARMOR_STAND) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |         // If entities are spawning... the chunk should be loaded? | ||||||
|         Entity[] entities = event.getSpawnLocation().getChunk().getEntities(); |         Entity[] entities = event.getSpawnLocation().getChunk().getEntities(); | ||||||
|         if (entities.length > Settings.Chunk_Processor.MAX_ENTITIES) { |         if (entities.length >= Settings.Chunk_Processor.MAX_ENTITIES) { | ||||||
|             event.setShouldAbortSpawn(true); |             event.setShouldAbortSpawn(true); | ||||||
|             event.setCancelled(true); |             event.setCancelled(true); | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         CreatureSpawnEvent.SpawnReason reason = event.getReason(); |         CreatureSpawnEvent.SpawnReason reason = event.getReason(); | ||||||
|         switch (reason.toString()) { |         switch (reason.toString()) { | ||||||
|             case "DISPENSE_EGG": |             case "DISPENSE_EGG", "EGG", "OCELOT_BABY", "SPAWNER_EGG" -> { | ||||||
|             case "EGG": |  | ||||||
|             case "OCELOT_BABY": |  | ||||||
|             case "SPAWNER_EGG": |  | ||||||
|                 if (!area.isSpawnEggs()) { |                 if (!area.isSpawnEggs()) { | ||||||
|                     event.setShouldAbortSpawn(true); |                     event.setShouldAbortSpawn(true); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 break; |             } | ||||||
|             case "REINFORCEMENTS": |             case "REINFORCEMENTS", "NATURAL", "MOUNT", "PATROL", "RAID", "SHEARED", "SILVERFISH_BLOCK", "ENDER_PEARL", "TRAP", "VILLAGE_DEFENSE", "VILLAGE_INVASION", "BEEHIVE", "CHUNK_GEN" -> { | ||||||
|             case "NATURAL": |  | ||||||
|             case "MOUNT": |  | ||||||
|             case "PATROL": |  | ||||||
|             case "RAID": |  | ||||||
|             case "SHEARED": |  | ||||||
|             case "SILVERFISH_BLOCK": |  | ||||||
|             case "ENDER_PEARL": |  | ||||||
|             case "TRAP": |  | ||||||
|             case "VILLAGE_DEFENSE": |  | ||||||
|             case "VILLAGE_INVASION": |  | ||||||
|             case "BEEHIVE": |  | ||||||
|             case "CHUNK_GEN": |  | ||||||
|                 if (!area.isMobSpawning()) { |                 if (!area.isMobSpawning()) { | ||||||
|                     event.setShouldAbortSpawn(true); |                     event.setShouldAbortSpawn(true); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 break; |             } | ||||||
|             case "BREEDING": |             case "BREEDING" -> { | ||||||
|                 if (!area.isSpawnBreeding()) { |                 if (!area.isSpawnBreeding()) { | ||||||
|                     event.setShouldAbortSpawn(true); |                     event.setShouldAbortSpawn(true); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 break; |             } | ||||||
|             case "BUILD_IRONGOLEM": |             case "BUILD_IRONGOLEM", "BUILD_SNOWMAN", "BUILD_WITHER", "CUSTOM" -> { | ||||||
|             case "BUILD_SNOWMAN": |                 if (!area.isSpawnCustom()) { | ||||||
|             case "BUILD_WITHER": |  | ||||||
|             case "CUSTOM": |  | ||||||
|                 if (!area.isSpawnCustom() && event.getType() != EntityType.ARMOR_STAND) { |  | ||||||
|                     event.setShouldAbortSpawn(true); |                     event.setShouldAbortSpawn(true); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 break; |             } | ||||||
|             case "SPAWNER": |             case "SPAWNER" -> { | ||||||
|                 if (!area.isMobSpawnerSpawning()) { |                 if (!area.isMobSpawnerSpawning()) { | ||||||
|                     event.setShouldAbortSpawn(true); |                     event.setShouldAbortSpawn(true); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 break; |             } | ||||||
|         } |         } | ||||||
|         Plot plot = location.getOwnedPlotAbs(); |         Plot plot = location.getOwnedPlotAbs(); | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             EntityType type = event.getType(); |             EntityType type = event.getType(); | ||||||
|             if (!area.isMobSpawning()) { |             // PreCreatureSpawnEvent **should** not be called for DROPPED_ITEM, just for the sake of consistency | ||||||
|                 if (type == EntityType.PLAYER) { |  | ||||||
|                     return; |  | ||||||
|                 } |  | ||||||
|             if (type == EntityType.DROPPED_ITEM) { |             if (type == EntityType.DROPPED_ITEM) { | ||||||
|                 if (Settings.Enabled_Components.KILL_ROAD_ITEMS) { |                 if (Settings.Enabled_Components.KILL_ROAD_ITEMS) { | ||||||
|                         event.setShouldAbortSpawn(true); |  | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                 } |                 } | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|  |             if (!area.isMobSpawning()) { | ||||||
|  |                 if (type == EntityType.PLAYER) { | ||||||
|  |                     return; | ||||||
|  |                 } | ||||||
|                 if (type.isAlive()) { |                 if (type.isAlive()) { | ||||||
|                     event.setShouldAbortSpawn(true); |                     event.setShouldAbortSpawn(true); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
| @@ -324,14 +330,17 @@ public class PaperListener implements Listener { | |||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         Location location = BukkitUtil.adapt(entity.getLocation()); |         Location location = BukkitUtil.adapt(entity.getLocation()); | ||||||
|         if (!this.plotAreaManager.hasPlotArea(location.getWorldName())) { |         PlotArea area = location.getPlotArea(); | ||||||
|  |         if (area == null) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         PlotPlayer<Player> pp = BukkitUtil.adapt((Player) shooter); |         PlotPlayer<Player> pp = BukkitUtil.adapt((Player) shooter); | ||||||
|         Plot plot = location.getOwnedPlot(); |         Plot plot = location.getOwnedPlot(); | ||||||
|  |  | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_PROJECTILE_ROAD)) { |             if (!PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, ProjectilesFlag.class, true) && !pp.hasPermission( | ||||||
|  |                     Permission.PERMISSION_ADMIN_PROJECTILE_ROAD | ||||||
|  |             )) { | ||||||
|                 pp.sendMessage( |                 pp.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission_event"), |                         TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                         TagResolver.resolver( |                         TagResolver.resolver( | ||||||
| @@ -343,7 +352,7 @@ public class PaperListener implements Listener { | |||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } |             } | ||||||
|         } else if (!plot.hasOwner()) { |         } else if (!plot.hasOwner()) { | ||||||
|             if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_PROJECTILE_UNOWNED)) { |             if (!pp.hasPermission(Permission.PERMISSION_ADMIN_PROJECTILE_UNOWNED)) { | ||||||
|                 pp.sendMessage( |                 pp.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission_event"), |                         TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                         TagResolver.resolver( |                         TagResolver.resolver( | ||||||
| @@ -355,8 +364,13 @@ public class PaperListener implements Listener { | |||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } |             } | ||||||
|         } else if (!plot.isAdded(pp.getUUID())) { |         } else if (!plot.isAdded(pp.getUUID())) { | ||||||
|  |             if (entity.getType().equals(EntityType.FISHING_HOOK)) { | ||||||
|  |                 if (plot.getFlag(FishingFlag.class)) { | ||||||
|  |                     return; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|             if (!plot.getFlag(ProjectilesFlag.class)) { |             if (!plot.getFlag(ProjectilesFlag.class)) { | ||||||
|                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_PROJECTILE_OTHER)) { |                 if (!pp.hasPermission(Permission.PERMISSION_ADMIN_PROJECTILE_OTHER)) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             TagResolver.resolver( | ||||||
| @@ -411,4 +425,52 @@ public class PaperListener implements Listener { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @EventHandler(ignoreCancelled = true) | ||||||
|  |     public void onBeaconEffect(final BeaconEffectEvent event) { | ||||||
|  |         Block block = event.getBlock(); | ||||||
|  |         Location beaconLocation = BukkitUtil.adapt(block.getLocation()); | ||||||
|  |         Plot beaconPlot = beaconLocation.getPlot(); | ||||||
|  |  | ||||||
|  |         PlotArea area = beaconLocation.getPlotArea(); | ||||||
|  |         if (area == null) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         Player player = event.getPlayer(); | ||||||
|  |         Location playerLocation = BukkitUtil.adapt(player.getLocation()); | ||||||
|  |  | ||||||
|  |         PlotPlayer<Player> plotPlayer = BukkitUtil.adapt(player); | ||||||
|  |         Plot playerStandingPlot = playerLocation.getPlot(); | ||||||
|  |         if (playerStandingPlot == null) { | ||||||
|  |             FlagContainer container = area.getRoadFlagContainer(); | ||||||
|  |             if (!getBooleanFlagValue(container, BeaconEffectsFlag.class, true) || | ||||||
|  |                     (beaconPlot != null && Settings.Enabled_Components.DISABLE_BEACON_EFFECT_OVERFLOW)) { | ||||||
|  |                 event.setCancelled(true); | ||||||
|  |             } | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         FlagContainer container = playerStandingPlot.getFlagContainer(); | ||||||
|  |         boolean plotBeaconEffects = getBooleanFlagValue(container, BeaconEffectsFlag.class, true); | ||||||
|  |         if (playerStandingPlot.equals(beaconPlot)) { | ||||||
|  |             if (!plotBeaconEffects) { | ||||||
|  |                 event.setCancelled(true); | ||||||
|  |             } | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if (!plotBeaconEffects || Settings.Enabled_Components.DISABLE_BEACON_EFFECT_OVERFLOW) { | ||||||
|  |             event.setCancelled(true); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private boolean getBooleanFlagValue( | ||||||
|  |             @NonNull FlagContainer container, | ||||||
|  |             @NonNull Class<? extends BooleanFlag<?>> flagClass, | ||||||
|  |             boolean defaultValue | ||||||
|  |     ) { | ||||||
|  |         BooleanFlag<?> flag = container.getFlag(flagClass); | ||||||
|  |         return flag == null ? defaultValue : flag.getValue(); | ||||||
|  |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,89 +0,0 @@ | |||||||
| /* |  | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  | ||||||
|  * |  | ||||||
|  * This program is free software: you can redistribute it and/or modify |  | ||||||
|  * it under the terms of the GNU General Public License as published by |  | ||||||
|  * the Free Software Foundation, either version 3 of the License, or |  | ||||||
|  * (at your option) any later version. |  | ||||||
|  * |  | ||||||
|  * This program is distributed in the hope that it will be useful, |  | ||||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of |  | ||||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the |  | ||||||
|  * GNU General Public License for more details. |  | ||||||
|  * |  | ||||||
|  * You should have received a copy of the GNU General Public License |  | ||||||
|  * along with this program.  If not, see <https://www.gnu.org/licenses/>. |  | ||||||
|  */ |  | ||||||
| package com.plotsquared.bukkit.listener; |  | ||||||
|  |  | ||||||
| import com.google.inject.Inject; |  | ||||||
| import com.plotsquared.bukkit.util.BukkitUtil; |  | ||||||
| import com.plotsquared.core.configuration.Settings; |  | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; |  | ||||||
| import com.plotsquared.core.location.Location; |  | ||||||
| import com.plotsquared.core.player.PlotPlayer; |  | ||||||
| import com.plotsquared.core.plot.PlotArea; |  | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; |  | ||||||
| import net.kyori.adventure.text.Component; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; |  | ||||||
| import org.bukkit.block.Banner; |  | ||||||
| import org.bukkit.block.Beacon; |  | ||||||
| import org.bukkit.block.BlockState; |  | ||||||
| import org.bukkit.block.CommandBlock; |  | ||||||
| import org.bukkit.block.Comparator; |  | ||||||
| import org.bukkit.block.Conduit; |  | ||||||
| import org.bukkit.block.Container; |  | ||||||
| import org.bukkit.block.CreatureSpawner; |  | ||||||
| import org.bukkit.block.DaylightDetector; |  | ||||||
| import org.bukkit.block.EnchantingTable; |  | ||||||
| import org.bukkit.block.EndGateway; |  | ||||||
| import org.bukkit.block.EnderChest; |  | ||||||
| import org.bukkit.block.Jukebox; |  | ||||||
| import org.bukkit.block.Sign; |  | ||||||
| import org.bukkit.block.Skull; |  | ||||||
| import org.bukkit.block.Structure; |  | ||||||
| import org.bukkit.block.data.type.Bed; |  | ||||||
| import org.bukkit.event.EventHandler; |  | ||||||
| import org.bukkit.event.block.BlockPlaceEvent; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; |  | ||||||
|  |  | ||||||
| public class PaperListener113 extends PaperListener { |  | ||||||
|  |  | ||||||
|     @Inject |  | ||||||
|     public PaperListener113(@NonNull PlotAreaManager plotAreaManager) { |  | ||||||
|         super(plotAreaManager); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @EventHandler |  | ||||||
|     public void onBlockPlace(BlockPlaceEvent event) { |  | ||||||
|         if (!Settings.Paper_Components.TILE_ENTITY_CHECK || !Settings.Enabled_Components.CHUNK_PROCESSOR) { |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|         BlockState state = event.getBlock().getState(false); |  | ||||||
|         if (!(state instanceof Banner || state instanceof Beacon || state instanceof Bed || state instanceof CommandBlock |  | ||||||
|                 || state instanceof Comparator || state instanceof Conduit || state instanceof Container || state instanceof CreatureSpawner |  | ||||||
|                 || state instanceof DaylightDetector || state instanceof EnchantingTable || state instanceof EnderChest || state instanceof EndGateway |  | ||||||
|                 || state instanceof Jukebox || state instanceof Sign || state instanceof Skull || state instanceof Structure)) { |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|         final Location location = BukkitUtil.adapt(event.getBlock().getLocation()); |  | ||||||
|         final PlotArea plotArea = location.getPlotArea(); |  | ||||||
|         if (plotArea == null) { |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|         final int tileEntityCount = event.getBlock().getChunk().getTileEntities(false).length; |  | ||||||
|         if (tileEntityCount >= Settings.Chunk_Processor.MAX_TILES) { |  | ||||||
|             final PlotPlayer<?> plotPlayer = BukkitUtil.adapt(event.getPlayer()); |  | ||||||
|             plotPlayer.sendMessage( |  | ||||||
|                     TranslatableCaption.of("errors.tile_entity_cap_reached"), |  | ||||||
|                     TagResolver.resolver("amount", Tag.inserting(Component.text(Settings.Chunk_Processor.MAX_TILES))) |  | ||||||
|             ); |  | ||||||
|             event.setCancelled(true); |  | ||||||
|             event.setBuild(false); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @@ -50,6 +50,7 @@ import com.plotsquared.core.plot.flag.implementations.DenyPortalsFlag; | |||||||
| import com.plotsquared.core.plot.flag.implementations.DenyTeleportFlag; | import com.plotsquared.core.plot.flag.implementations.DenyTeleportFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.DoneFlag; | import com.plotsquared.core.plot.flag.implementations.DoneFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.DropProtectionFlag; | import com.plotsquared.core.plot.flag.implementations.DropProtectionFlag; | ||||||
|  | import com.plotsquared.core.plot.flag.implementations.EditSignFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.HangingBreakFlag; | import com.plotsquared.core.plot.flag.implementations.HangingBreakFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.HangingPlaceFlag; | import com.plotsquared.core.plot.flag.implementations.HangingPlaceFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.HostileInteractFlag; | import com.plotsquared.core.plot.flag.implementations.HostileInteractFlag; | ||||||
| @@ -60,6 +61,7 @@ import com.plotsquared.core.plot.flag.implementations.MiscInteractFlag; | |||||||
| import com.plotsquared.core.plot.flag.implementations.PlayerInteractFlag; | import com.plotsquared.core.plot.flag.implementations.PlayerInteractFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.PreventCreativeCopyFlag; | import com.plotsquared.core.plot.flag.implementations.PreventCreativeCopyFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.TamedInteractFlag; | import com.plotsquared.core.plot.flag.implementations.TamedInteractFlag; | ||||||
|  | import com.plotsquared.core.plot.flag.implementations.TileDropFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.UntrustedVisitFlag; | import com.plotsquared.core.plot.flag.implementations.UntrustedVisitFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.VehicleBreakFlag; | import com.plotsquared.core.plot.flag.implementations.VehicleBreakFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.VehicleUseFlag; | import com.plotsquared.core.plot.flag.implementations.VehicleUseFlag; | ||||||
| @@ -67,7 +69,7 @@ import com.plotsquared.core.plot.flag.implementations.VillagerInteractFlag; | |||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
| import com.plotsquared.core.util.EventDispatcher; | import com.plotsquared.core.util.EventDispatcher; | ||||||
| import com.plotsquared.core.util.MathMan; | import com.plotsquared.core.util.MathMan; | ||||||
| import com.plotsquared.core.util.Permissions; | import com.plotsquared.core.util.PlotFlagUtil; | ||||||
| import com.plotsquared.core.util.PremiumVerification; | import com.plotsquared.core.util.PremiumVerification; | ||||||
| import com.plotsquared.core.util.entity.EntityCategories; | import com.plotsquared.core.util.entity.EntityCategories; | ||||||
| import com.plotsquared.core.util.task.TaskManager; | import com.plotsquared.core.util.task.TaskManager; | ||||||
| @@ -87,6 +89,7 @@ import org.bukkit.Material; | |||||||
| import org.bukkit.block.Block; | import org.bukkit.block.Block; | ||||||
| import org.bukkit.block.BlockFace; | import org.bukkit.block.BlockFace; | ||||||
| import org.bukkit.block.BlockState; | import org.bukkit.block.BlockState; | ||||||
|  | import org.bukkit.block.Sign; | ||||||
| import org.bukkit.block.data.Waterlogged; | import org.bukkit.block.data.Waterlogged; | ||||||
| import org.bukkit.command.PluginCommand; | import org.bukkit.command.PluginCommand; | ||||||
| import org.bukkit.entity.ArmorStand; | import org.bukkit.entity.ArmorStand; | ||||||
| @@ -105,8 +108,10 @@ import org.bukkit.event.EventHandler; | |||||||
| import org.bukkit.event.EventPriority; | import org.bukkit.event.EventPriority; | ||||||
| import org.bukkit.event.Listener; | import org.bukkit.event.Listener; | ||||||
| import org.bukkit.event.block.Action; | import org.bukkit.event.block.Action; | ||||||
|  | import org.bukkit.event.block.BlockBreakEvent; | ||||||
| import org.bukkit.event.entity.EntityPickupItemEvent; | import org.bukkit.event.entity.EntityPickupItemEvent; | ||||||
| import org.bukkit.event.entity.EntityPlaceEvent; | import org.bukkit.event.entity.EntityPlaceEvent; | ||||||
|  | import org.bukkit.event.entity.EntityPotionEffectEvent; | ||||||
| import org.bukkit.event.entity.PlayerDeathEvent; | import org.bukkit.event.entity.PlayerDeathEvent; | ||||||
| import org.bukkit.event.hanging.HangingBreakByEntityEvent; | import org.bukkit.event.hanging.HangingBreakByEntityEvent; | ||||||
| import org.bukkit.event.hanging.HangingPlaceEvent; | import org.bukkit.event.hanging.HangingPlaceEvent; | ||||||
| @@ -143,6 +148,7 @@ import org.bukkit.inventory.meta.ItemMeta; | |||||||
| import org.bukkit.metadata.FixedMetadataValue; | import org.bukkit.metadata.FixedMetadataValue; | ||||||
| import org.bukkit.metadata.MetadataValue; | import org.bukkit.metadata.MetadataValue; | ||||||
| import org.bukkit.plugin.Plugin; | import org.bukkit.plugin.Plugin; | ||||||
|  | import org.bukkit.potion.PotionEffect; | ||||||
| import org.bukkit.util.Vector; | import org.bukkit.util.Vector; | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| @@ -157,7 +163,7 @@ import java.util.UUID; | |||||||
|  * Player Events involving plots. |  * Player Events involving plots. | ||||||
|  */ |  */ | ||||||
| @SuppressWarnings("unused") | @SuppressWarnings("unused") | ||||||
| public class PlayerEventListener extends PlotListener implements Listener { | public class PlayerEventListener implements Listener { | ||||||
|  |  | ||||||
|     private static final Set<Material> MINECARTS = Set.of( |     private static final Set<Material> MINECARTS = Set.of( | ||||||
|             Material.MINECART, |             Material.MINECART, | ||||||
| @@ -173,9 +179,102 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|             Material.WRITABLE_BOOK, |             Material.WRITABLE_BOOK, | ||||||
|             Material.WRITTEN_BOOK |             Material.WRITTEN_BOOK | ||||||
|     ); |     ); | ||||||
|  |     private static final Set<String> DYES; | ||||||
|  |     static { | ||||||
|  |         Set<String> mutableDyes = new HashSet<>(Set.of( | ||||||
|  |                 "WHITE_DYE", | ||||||
|  |                 "LIGHT_GRAY_DYE", | ||||||
|  |                 "GRAY_DYE", | ||||||
|  |                 "BLACK_DYE", | ||||||
|  |                 "BROWN_DYE", | ||||||
|  |                 "RED_DYE", | ||||||
|  |                 "ORANGE_DYE", | ||||||
|  |                 "YELLOW_DYE", | ||||||
|  |                 "LIME_DYE", | ||||||
|  |                 "GREEN_DYE", | ||||||
|  |                 "CYAN_DYE", | ||||||
|  |                 "LIGHT_BLUE_DYE", | ||||||
|  |                 "BLUE_DYE", | ||||||
|  |                 "PURPLE_DYE", | ||||||
|  |                 "MAGENTA_DYE", | ||||||
|  |                 "PINK_DYE", | ||||||
|  |                 "GLOW_INK_SAC" | ||||||
|  |         )); | ||||||
|  |         int[] version = PlotSquared.platform().serverVersion(); | ||||||
|  |         if (version[1] >= 20) { | ||||||
|  |             mutableDyes.add("HONEYCOMB"); | ||||||
|  |         } | ||||||
|  |         DYES = Set.copyOf(mutableDyes); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private static final Set<String> INTERACTABLE_MATERIALS; | ||||||
|  |  | ||||||
|  |     static { | ||||||
|  |         // @formatter:off | ||||||
|  |         // "temporary" fix for https://hub.spigotmc.org/jira/browse/SPIGOT-7813 | ||||||
|  |         // can (and should) be removed when 1.21 support is dropped | ||||||
|  |         // List of all interactable 1.21 materials | ||||||
|  |         INTERACTABLE_MATERIALS = Material.CHEST.isInteractable() ? null :  Set.of( | ||||||
|  |                 "REDSTONE_ORE", "DEEPSLATE_REDSTONE_ORE", "CHISELED_BOOKSHELF", "DECORATED_POT", "CHEST", "CRAFTING_TABLE", | ||||||
|  |                 "FURNACE", "JUKEBOX", "OAK_FENCE", "SPRUCE_FENCE", "BIRCH_FENCE", "JUNGLE_FENCE", "ACACIA_FENCE", "CHERRY_FENCE", | ||||||
|  |                 "DARK_OAK_FENCE", "MANGROVE_FENCE", "BAMBOO_FENCE", "CRIMSON_FENCE", "WARPED_FENCE", "PUMPKIN", | ||||||
|  |                 "NETHER_BRICK_FENCE", "ENCHANTING_TABLE", "DRAGON_EGG", "ENDER_CHEST", "COMMAND_BLOCK", "BEACON", "ANVIL", | ||||||
|  |                 "CHIPPED_ANVIL", "DAMAGED_ANVIL", "LIGHT", "REPEATING_COMMAND_BLOCK", "CHAIN_COMMAND_BLOCK", "SHULKER_BOX", | ||||||
|  |                 "WHITE_SHULKER_BOX", "ORANGE_SHULKER_BOX", "MAGENTA_SHULKER_BOX", "LIGHT_BLUE_SHULKER_BOX", "YELLOW_SHULKER_BOX", | ||||||
|  |                 "LIME_SHULKER_BOX", "PINK_SHULKER_BOX", "GRAY_SHULKER_BOX", "LIGHT_GRAY_SHULKER_BOX", "CYAN_SHULKER_BOX", | ||||||
|  |                 "PURPLE_SHULKER_BOX", "BLUE_SHULKER_BOX", "BROWN_SHULKER_BOX", "GREEN_SHULKER_BOX", "RED_SHULKER_BOX", | ||||||
|  |                 "BLACK_SHULKER_BOX", "REPEATER", "COMPARATOR", "HOPPER", "DISPENSER", "DROPPER", "LECTERN", "LEVER", | ||||||
|  |                 "DAYLIGHT_DETECTOR", "TRAPPED_CHEST", "TNT", "NOTE_BLOCK", "STONE_BUTTON", "POLISHED_BLACKSTONE_BUTTON", | ||||||
|  |                 "OAK_BUTTON", "SPRUCE_BUTTON", "BIRCH_BUTTON", "JUNGLE_BUTTON", "ACACIA_BUTTON", "CHERRY_BUTTON", | ||||||
|  |                 "DARK_OAK_BUTTON", "MANGROVE_BUTTON", "BAMBOO_BUTTON", "CRIMSON_BUTTON", "WARPED_BUTTON", "IRON_DOOR", "OAK_DOOR", | ||||||
|  |                 "SPRUCE_DOOR", "BIRCH_DOOR", "JUNGLE_DOOR", "ACACIA_DOOR", "CHERRY_DOOR", "DARK_OAK_DOOR", "MANGROVE_DOOR", | ||||||
|  |                 "BAMBOO_DOOR", "CRIMSON_DOOR", "WARPED_DOOR", "COPPER_DOOR", "EXPOSED_COPPER_DOOR", "WEATHERED_COPPER_DOOR", | ||||||
|  |                 "OXIDIZED_COPPER_DOOR", "WAXED_COPPER_DOOR", "WAXED_EXPOSED_COPPER_DOOR", "WAXED_WEATHERED_COPPER_DOOR", | ||||||
|  |                 "WAXED_OXIDIZED_COPPER_DOOR", "IRON_TRAPDOOR", "OAK_TRAPDOOR", "SPRUCE_TRAPDOOR", "BIRCH_TRAPDOOR", | ||||||
|  |                 "JUNGLE_TRAPDOOR", "ACACIA_TRAPDOOR", "CHERRY_TRAPDOOR", "DARK_OAK_TRAPDOOR", "MANGROVE_TRAPDOOR", | ||||||
|  |                 "BAMBOO_TRAPDOOR", "CRIMSON_TRAPDOOR", "WARPED_TRAPDOOR", "COPPER_TRAPDOOR", "EXPOSED_COPPER_TRAPDOOR", | ||||||
|  |                 "WEATHERED_COPPER_TRAPDOOR", "OXIDIZED_COPPER_TRAPDOOR", "WAXED_COPPER_TRAPDOOR", "WAXED_EXPOSED_COPPER_TRAPDOOR", | ||||||
|  |                 "WAXED_WEATHERED_COPPER_TRAPDOOR", "WAXED_OXIDIZED_COPPER_TRAPDOOR", "OAK_FENCE_GATE", "SPRUCE_FENCE_GATE", | ||||||
|  |                 "BIRCH_FENCE_GATE", "JUNGLE_FENCE_GATE", "ACACIA_FENCE_GATE", "CHERRY_FENCE_GATE", "DARK_OAK_FENCE_GATE", | ||||||
|  |                 "MANGROVE_FENCE_GATE", "BAMBOO_FENCE_GATE", "CRIMSON_FENCE_GATE", "WARPED_FENCE_GATE", "STRUCTURE_BLOCK", | ||||||
|  |                 "JIGSAW", "OAK_SIGN", "SPRUCE_SIGN", "BIRCH_SIGN", "JUNGLE_SIGN", "ACACIA_SIGN", "CHERRY_SIGN", "DARK_OAK_SIGN", | ||||||
|  |                 "MANGROVE_SIGN", "BAMBOO_SIGN", "CRIMSON_SIGN", "WARPED_SIGN", "OAK_HANGING_SIGN", "SPRUCE_HANGING_SIGN", | ||||||
|  |                 "BIRCH_HANGING_SIGN", "JUNGLE_HANGING_SIGN", "ACACIA_HANGING_SIGN", "CHERRY_HANGING_SIGN", | ||||||
|  |                 "DARK_OAK_HANGING_SIGN", "MANGROVE_HANGING_SIGN", "BAMBOO_HANGING_SIGN", "CRIMSON_HANGING_SIGN", | ||||||
|  |                 "WARPED_HANGING_SIGN", "CAKE", "WHITE_BED", "ORANGE_BED", "MAGENTA_BED", "LIGHT_BLUE_BED", "YELLOW_BED", | ||||||
|  |                 "LIME_BED", "PINK_BED", "GRAY_BED", "LIGHT_GRAY_BED", "CYAN_BED", "PURPLE_BED", "BLUE_BED", "BROWN_BED", | ||||||
|  |                 "GREEN_BED", "RED_BED", "BLACK_BED", "CRAFTER", "BREWING_STAND", "CAULDRON", "FLOWER_POT", "LOOM", "COMPOSTER", | ||||||
|  |                 "BARREL", "SMOKER", "BLAST_FURNACE", "CARTOGRAPHY_TABLE", "FLETCHING_TABLE", "GRINDSTONE", "SMITHING_TABLE", | ||||||
|  |                 "STONECUTTER", "BELL", "CAMPFIRE", "SOUL_CAMPFIRE", "BEE_NEST", "BEEHIVE", "RESPAWN_ANCHOR", "CANDLE", | ||||||
|  |                 "WHITE_CANDLE", "ORANGE_CANDLE", "MAGENTA_CANDLE", "LIGHT_BLUE_CANDLE", "YELLOW_CANDLE", "LIME_CANDLE", | ||||||
|  |                 "PINK_CANDLE", "GRAY_CANDLE", "LIGHT_GRAY_CANDLE", "CYAN_CANDLE", "PURPLE_CANDLE", "BLUE_CANDLE", "BROWN_CANDLE", | ||||||
|  |                 "GREEN_CANDLE", "RED_CANDLE", "BLACK_CANDLE", "VAULT", "MOVING_PISTON", "REDSTONE_WIRE", "OAK_WALL_SIGN", | ||||||
|  |                 "SPRUCE_WALL_SIGN", "BIRCH_WALL_SIGN", "ACACIA_WALL_SIGN", "CHERRY_WALL_SIGN", "JUNGLE_WALL_SIGN", | ||||||
|  |                 "DARK_OAK_WALL_SIGN", "MANGROVE_WALL_SIGN", "BAMBOO_WALL_SIGN", "OAK_WALL_HANGING_SIGN", | ||||||
|  |                 "SPRUCE_WALL_HANGING_SIGN", "BIRCH_WALL_HANGING_SIGN", "ACACIA_WALL_HANGING_SIGN", | ||||||
|  |                 "CHERRY_WALL_HANGING_SIGN", "JUNGLE_WALL_HANGING_SIGN", "DARK_OAK_WALL_HANGING_SIGN", | ||||||
|  |                 "MANGROVE_WALL_HANGING_SIGN", "CRIMSON_WALL_HANGING_SIGN", "WARPED_WALL_HANGING_SIGN", "BAMBOO_WALL_HANGING_SIGN", | ||||||
|  |                 "WATER_CAULDRON", "LAVA_CAULDRON", "POWDER_SNOW_CAULDRON", "POTTED_TORCHFLOWER", "POTTED_OAK_SAPLING", | ||||||
|  |                 "POTTED_SPRUCE_SAPLING", "POTTED_BIRCH_SAPLING", "POTTED_JUNGLE_SAPLING", "POTTED_ACACIA_SAPLING", | ||||||
|  |                 "POTTED_CHERRY_SAPLING", "POTTED_DARK_OAK_SAPLING", "POTTED_MANGROVE_PROPAGULE", "POTTED_FERN", | ||||||
|  |                 "POTTED_DANDELION", "POTTED_POPPY", "POTTED_BLUE_ORCHID", "POTTED_ALLIUM", "POTTED_AZURE_BLUET", | ||||||
|  |                 "POTTED_RED_TULIP", "POTTED_ORANGE_TULIP", "POTTED_WHITE_TULIP", "POTTED_PINK_TULIP", "POTTED_OXEYE_DAISY", | ||||||
|  |                 "POTTED_CORNFLOWER", "POTTED_LILY_OF_THE_VALLEY", "POTTED_WITHER_ROSE", "POTTED_RED_MUSHROOM", | ||||||
|  |                 "POTTED_BROWN_MUSHROOM", "POTTED_DEAD_BUSH", "POTTED_CACTUS", "POTTED_BAMBOO", "SWEET_BERRY_BUSH", | ||||||
|  |                 "CRIMSON_WALL_SIGN", "WARPED_WALL_SIGN", "POTTED_CRIMSON_FUNGUS", "POTTED_WARPED_FUNGUS", "POTTED_CRIMSON_ROOTS", | ||||||
|  |                 "POTTED_WARPED_ROOTS", "CANDLE_CAKE", "WHITE_CANDLE_CAKE", "ORANGE_CANDLE_CAKE", "MAGENTA_CANDLE_CAKE", | ||||||
|  |                 "LIGHT_BLUE_CANDLE_CAKE", "YELLOW_CANDLE_CAKE", "LIME_CANDLE_CAKE", "PINK_CANDLE_CAKE", "GRAY_CANDLE_CAKE", | ||||||
|  |                 "LIGHT_GRAY_CANDLE_CAKE", "CYAN_CANDLE_CAKE", "PURPLE_CANDLE_CAKE", "BLUE_CANDLE_CAKE", "BROWN_CANDLE_CAKE", | ||||||
|  |                 "GREEN_CANDLE_CAKE", "RED_CANDLE_CAKE", "BLACK_CANDLE_CAKE", "CAVE_VINES", "CAVE_VINES_PLANT", | ||||||
|  |                 "POTTED_AZALEA_BUSH", "POTTED_FLOWERING_AZALEA_BUSH" | ||||||
|  |         ); | ||||||
|  |         // @formatter:on | ||||||
|  |     } | ||||||
|  |  | ||||||
|     private final EventDispatcher eventDispatcher; |     private final EventDispatcher eventDispatcher; | ||||||
|     private final WorldEdit worldEdit; |     private final WorldEdit worldEdit; | ||||||
|     private final PlotAreaManager plotAreaManager; |     private final PlotAreaManager plotAreaManager; | ||||||
|  |     private final PlotListener plotListener; | ||||||
|     // To prevent recursion |     // To prevent recursion | ||||||
|     private boolean tmpTeleport = true; |     private boolean tmpTeleport = true; | ||||||
|     private Field fieldPlayer; |     private Field fieldPlayer; | ||||||
| @@ -195,12 +294,83 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|     public PlayerEventListener( |     public PlayerEventListener( | ||||||
|             final @NonNull PlotAreaManager plotAreaManager, |             final @NonNull PlotAreaManager plotAreaManager, | ||||||
|             final @NonNull EventDispatcher eventDispatcher, |             final @NonNull EventDispatcher eventDispatcher, | ||||||
|             final @NonNull WorldEdit worldEdit |             final @NonNull WorldEdit worldEdit, | ||||||
|  |             final @NonNull PlotListener plotListener | ||||||
|     ) { |     ) { | ||||||
|         super(eventDispatcher); |  | ||||||
|         this.eventDispatcher = eventDispatcher; |         this.eventDispatcher = eventDispatcher; | ||||||
|         this.worldEdit = worldEdit; |         this.worldEdit = worldEdit; | ||||||
|         this.plotAreaManager = plotAreaManager; |         this.plotAreaManager = plotAreaManager; | ||||||
|  |         this.plotListener = plotListener; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @EventHandler(ignoreCancelled = true, priority = EventPriority.LOWEST) | ||||||
|  |     public void onBlockBreak(final BlockBreakEvent event) { | ||||||
|  |         Location location = BukkitUtil.adapt(event.getBlock().getLocation()); | ||||||
|  |         PlotArea area = location.getPlotArea(); | ||||||
|  |         if (area == null) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |         Plot plot = area.getPlot(location); | ||||||
|  |         if (plot != null) { | ||||||
|  |             event.setDropItems(plot.getFlag(TileDropFlag.class)); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) | ||||||
|  |     public void onPlayerDyeSign(PlayerInteractEvent event) { | ||||||
|  |         ItemStack itemStack = event.getItem(); | ||||||
|  |         if (itemStack == null) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |         Block block = event.getClickedBlock(); | ||||||
|  |         if (block != null && block.getState() instanceof Sign) { | ||||||
|  |             if (DYES.contains(itemStack.getType().toString())) { | ||||||
|  |                 Location location = BukkitUtil.adapt(block.getLocation()); | ||||||
|  |                 PlotArea area = location.getPlotArea(); | ||||||
|  |                 if (area == null) { | ||||||
|  |                     return; | ||||||
|  |                 } | ||||||
|  |                 Plot plot = location.getOwnedPlot(); | ||||||
|  |                 if (plot == null) { | ||||||
|  |                     if (PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, EditSignFlag.class, false) | ||||||
|  |                             && !event.getPlayer().hasPermission(Permission.PERMISSION_ADMIN_INTERACT_ROAD.toString())) { | ||||||
|  |                         event.setCancelled(true); | ||||||
|  |                     } | ||||||
|  |                     return; | ||||||
|  |                 } | ||||||
|  |                 if (plot.isAdded(event.getPlayer().getUniqueId())) { | ||||||
|  |                     return; // allow for added players | ||||||
|  |                 } | ||||||
|  |                 if (!plot.getFlag(EditSignFlag.class) | ||||||
|  |                         && !event.getPlayer().hasPermission(Permission.PERMISSION_ADMIN_INTERACT_OTHER.toString())) { | ||||||
|  |                     plot.debug(event.getPlayer().getName() + " could not color the sign because of edit-sign = false"); | ||||||
|  |                     event.setCancelled(true); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @EventHandler(ignoreCancelled = true) | ||||||
|  |     public void onEffect(@NonNull EntityPotionEffectEvent event) { | ||||||
|  |         if (Settings.Enabled_Components.DISABLE_BEACON_EFFECT_OVERFLOW || | ||||||
|  |                 event.getCause() != EntityPotionEffectEvent.Cause.BEACON || | ||||||
|  |                 !(event.getEntity() instanceof Player player)) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         UUID uuid = player.getUniqueId(); | ||||||
|  |         PotionEffect effect = event.getNewEffect(); | ||||||
|  |         if (effect == null) { | ||||||
|  |             PotionEffect oldEffect = event.getOldEffect(); | ||||||
|  |             if (oldEffect != null) { | ||||||
|  |                 String name = oldEffect.getType().getName(); | ||||||
|  |                 plotListener.addEffect(uuid, name, -1); | ||||||
|  |             } | ||||||
|  |         } else { | ||||||
|  |             long expiresAt = System.currentTimeMillis() + effect.getDuration() * 50L; //Convert ticks to milliseconds | ||||||
|  |             String name = effect.getType().getName(); | ||||||
|  |             plotListener.addEffect(uuid, name, expiresAt); | ||||||
|  |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @EventHandler |     @EventHandler | ||||||
| @@ -246,14 +416,16 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|         Plot plot = plotPlayer.getCurrentPlot(); |         Plot plot = plotPlayer.getCurrentPlot(); | ||||||
|         // Check WorldEdit |         // Check WorldEdit | ||||||
|         switch (parts[0]) { |         switch (parts[0]) { | ||||||
|             case "up": |             case "up", "worldedit:up" -> { | ||||||
|             case "worldedit:up": |                 if (plot == null || (!plot.isAdded(plotPlayer.getUUID()) && !plotPlayer.hasPermission( | ||||||
|                 if (plot == null || (!plot.isAdded(plotPlayer.getUUID()) && !Permissions |                         Permission.PERMISSION_ADMIN_BUILD_OTHER, | ||||||
|                         .hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_BUILD_OTHER, true))) { |                         true | ||||||
|  |                 ))) { | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|  |         } | ||||||
|         if (plot == null && !area.isRoadFlags()) { |         if (plot == null && !area.isRoadFlags()) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
| @@ -264,7 +436,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|         if (blockedCommands.isEmpty()) { |         if (blockedCommands.isEmpty()) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         if (Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_INTERACT_BLOCKED_CMDS)) { |         if (plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_INTERACT_BLOCKED_CMDS)) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         // When using namespaced commands, we're not interested in the namespace |         // When using namespaced commands, we're not interested in the namespace | ||||||
| @@ -283,7 +455,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|                 } else { |                 } else { | ||||||
|                     perm = "plots.admin.command.blocked-cmds.road"; |                     perm = "plots.admin.command.blocked-cmds.road"; | ||||||
|                 } |                 } | ||||||
|                 if (!Permissions.hasPermission(plotPlayer, perm)) { |                 if (!plotPlayer.hasPermission(perm)) { | ||||||
|                     plotPlayer.sendMessage(TranslatableCaption.of("blockedcmds.command_blocked")); |                     plotPlayer.sendMessage(TranslatableCaption.of("blockedcmds.command_blocked")); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                 } |                 } | ||||||
| @@ -340,6 +512,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) |     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) | ||||||
|  |     @SuppressWarnings("deprecation") // Paper deprecation | ||||||
|     public void onConnect(PlayerJoinEvent event) { |     public void onConnect(PlayerJoinEvent event) { | ||||||
|         final Player player = event.getPlayer(); |         final Player player = event.getPlayer(); | ||||||
|         PlotSquared.platform().playerManager().removePlayer(player.getUniqueId()); |         PlotSquared.platform().playerManager().removePlayer(player.getUniqueId()); | ||||||
| @@ -353,7 +526,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|         if (area != null) { |         if (area != null) { | ||||||
|             Plot plot = area.getPlot(location); |             Plot plot = area.getPlot(location); | ||||||
|             if (plot != null) { |             if (plot != null) { | ||||||
|                 plotEntry(pp, plot); |                 plotListener.plotEntry(pp, plot); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         // Delayed |         // Delayed | ||||||
| @@ -409,7 +582,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|                 PlotArea area = location.getPlotArea(); |                 PlotArea area = location.getPlotArea(); | ||||||
|                 if (area == null) { |                 if (area == null) { | ||||||
|                     if (lastPlot != null) { |                     if (lastPlot != null) { | ||||||
|                         plotExit(pp, lastPlot); |                         plotListener.plotExit(pp, lastPlot); | ||||||
|                         lastPlotAccess.remove(); |                         lastPlotAccess.remove(); | ||||||
|                     } |                     } | ||||||
|                     try (final MetaDataAccess<Location> lastLocationAccess = |                     try (final MetaDataAccess<Location> lastLocationAccess = | ||||||
| @@ -425,9 +598,9 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|                     // to is identical to the plot's home location, and untrusted-visit is true |                     // to is identical to the plot's home location, and untrusted-visit is true | ||||||
|                     // i.e. untrusted-visit can override deny-teleport |                     // i.e. untrusted-visit can override deny-teleport | ||||||
|                     // this is acceptable, because otherwise it wouldn't make sense to have both flags set |                     // this is acceptable, because otherwise it wouldn't make sense to have both flags set | ||||||
|                     if (!result && !(plot.getFlag(UntrustedVisitFlag.class) && plot |                     if (result || (plot.getFlag(UntrustedVisitFlag.class) && plot.getHomeSynchronous().equals(BukkitUtil.adaptComplete(to)))) { | ||||||
|                             .getHomeSynchronous() |                         plotListener.plotEntry(pp, plot); | ||||||
|                             .equals(BukkitUtil.adaptComplete(to)))) { |                     } else { | ||||||
|                         pp.sendMessage( |                         pp.sendMessage( | ||||||
|                                 TranslatableCaption.of("deny.no_enter"), |                                 TranslatableCaption.of("deny.no_enter"), | ||||||
|                                 TagResolver.resolver("plot", Tag.inserting(Component.text(plot.toString()))) |                                 TagResolver.resolver("plot", Tag.inserting(Component.text(plot.toString()))) | ||||||
| @@ -440,6 +613,19 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|         playerMove(event); |         playerMove(event); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) | ||||||
|  |     public void onWorldChanged(PlayerChangedWorldEvent event) { | ||||||
|  |         Player player = event.getPlayer(); | ||||||
|  |         BukkitPlayer pp = BukkitUtil.adapt(player); | ||||||
|  |         if (this.worldEdit != null) { | ||||||
|  |             if (!pp.hasPermission(Permission.PERMISSION_WORLDEDIT_BYPASS)) { | ||||||
|  |                 if (pp.getAttribute("worldedit")) { | ||||||
|  |                     pp.removeAttribute("worldedit"); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) |     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) | ||||||
|     public void vehicleMove(VehicleMoveEvent event) |     public void vehicleMove(VehicleMoveEvent event) | ||||||
|             throws IllegalAccessException { |             throws IllegalAccessException { | ||||||
| @@ -543,7 +729,8 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|             if (now == null) { |             if (now == null) { | ||||||
|                 try (final MetaDataAccess<Boolean> kickAccess = |                 try (final MetaDataAccess<Boolean> kickAccess = | ||||||
|                              pp.accessTemporaryMetaData(PlayerMetaDataKeys.TEMPORARY_KICK)) { |                              pp.accessTemporaryMetaData(PlayerMetaDataKeys.TEMPORARY_KICK)) { | ||||||
|                     if (lastPlot != null && !plotExit(pp, lastPlot) && this.tmpTeleport && !kickAccess.get().orElse(false)) { |                     if (lastPlot != null && !plotListener.plotExit(pp, lastPlot) && this.tmpTeleport && !kickAccess.get().orElse( | ||||||
|  |                             false)) { | ||||||
|                         pp.sendMessage( |                         pp.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission_event"), |                                 TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                                 TagResolver.resolver( |                                 TagResolver.resolver( | ||||||
| @@ -564,7 +751,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|                 } |                 } | ||||||
|             } else if (now.equals(lastPlot)) { |             } else if (now.equals(lastPlot)) { | ||||||
|                 ForceFieldListener.handleForcefield(player, pp, now); |                 ForceFieldListener.handleForcefield(player, pp, now); | ||||||
|             } else if (!plotEntry(pp, now) && this.tmpTeleport) { |             } else if (!plotListener.plotEntry(pp, now) && this.tmpTeleport) { | ||||||
|                 pp.sendMessage( |                 pp.sendMessage( | ||||||
|                         TranslatableCaption.of("deny.no_enter"), |                         TranslatableCaption.of("deny.no_enter"), | ||||||
|                         TagResolver.resolver("plot", Tag.inserting(Component.text(now.toString()))) |                         TagResolver.resolver("plot", Tag.inserting(Component.text(now.toString()))) | ||||||
| @@ -577,10 +764,10 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|                 this.tmpTeleport = true; |                 this.tmpTeleport = true; | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             int border = area.getBorder(); |             int border = area.getBorder(true); | ||||||
|             int x1; |             int x1; | ||||||
|             if (x2 > border && this.tmpTeleport) { |             if (x2 > border && this.tmpTeleport) { | ||||||
|                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BYPASS_BORDER)) { |                 if (!pp.hasPermission(Permission.PERMISSION_ADMIN_BYPASS_BORDER)) { | ||||||
|                     to.setX(border - 1); |                     to.setX(border - 1); | ||||||
|                     this.tmpTeleport = false; |                     this.tmpTeleport = false; | ||||||
|                     player.teleport(event.getTo()); |                     player.teleport(event.getTo()); | ||||||
| @@ -590,7 +777,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|                     pp.sendMessage(TranslatableCaption.of("border.bypass.exited")); |                     pp.sendMessage(TranslatableCaption.of("border.bypass.exited")); | ||||||
|                 } |                 } | ||||||
|             } else if (x2 < -border && this.tmpTeleport) { |             } else if (x2 < -border && this.tmpTeleport) { | ||||||
|                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BYPASS_BORDER)) { |                 if (!pp.hasPermission(Permission.PERMISSION_ADMIN_BYPASS_BORDER)) { | ||||||
|                     to.setX(-border + 1); |                     to.setX(-border + 1); | ||||||
|                     this.tmpTeleport = false; |                     this.tmpTeleport = false; | ||||||
|                     player.teleport(event.getTo()); |                     player.teleport(event.getTo()); | ||||||
| @@ -600,7 +787,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|                     pp.sendMessage(TranslatableCaption.of("border.bypass.exited")); |                     pp.sendMessage(TranslatableCaption.of("border.bypass.exited")); | ||||||
|                 } |                 } | ||||||
|             } else if (((x1 = MathMan.roundInt(from.getX())) >= border && x2 <= border) || (x1 <= -border && x2 >= -border)) { |             } else if (((x1 = MathMan.roundInt(from.getX())) >= border && x2 <= border) || (x1 <= -border && x2 >= -border)) { | ||||||
|                 if (Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BYPASS_BORDER)) { |                 if (pp.hasPermission(Permission.PERMISSION_ADMIN_BYPASS_BORDER)) { | ||||||
|                     pp.sendMessage(TranslatableCaption.of("border.bypass.entered")); |                     pp.sendMessage(TranslatableCaption.of("border.bypass.entered")); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
| @@ -636,7 +823,8 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|             if (plot == null) { |             if (plot == null) { | ||||||
|                 try (final MetaDataAccess<Boolean> kickAccess = |                 try (final MetaDataAccess<Boolean> kickAccess = | ||||||
|                              pp.accessTemporaryMetaData(PlayerMetaDataKeys.TEMPORARY_KICK)) { |                              pp.accessTemporaryMetaData(PlayerMetaDataKeys.TEMPORARY_KICK)) { | ||||||
|                     if (lastPlot != null && !plotExit(pp, lastPlot) && this.tmpTeleport && !kickAccess.get().orElse(false)) { |                     if (lastPlot != null && !plotListener.plotExit(pp, lastPlot) && this.tmpTeleport && !kickAccess.get().orElse( | ||||||
|  |                             false)) { | ||||||
|                         pp.sendMessage( |                         pp.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission_event"), |                                 TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                                 TagResolver.resolver( |                                 TagResolver.resolver( | ||||||
| @@ -657,7 +845,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|                 } |                 } | ||||||
|             } else if (plot.equals(lastPlot)) { |             } else if (plot.equals(lastPlot)) { | ||||||
|                 ForceFieldListener.handleForcefield(player, pp, plot); |                 ForceFieldListener.handleForcefield(player, pp, plot); | ||||||
|             } else if (!plotEntry(pp, plot) && this.tmpTeleport) { |             } else if (!plotListener.plotEntry(pp, plot) && this.tmpTeleport) { | ||||||
|                 pp.sendMessage( |                 pp.sendMessage( | ||||||
|                         TranslatableCaption.of("deny.no_enter"), |                         TranslatableCaption.of("deny.no_enter"), | ||||||
|                         TagResolver.resolver("plot", Tag.inserting(Component.text(plot.toString()))) |                         TagResolver.resolver("plot", Tag.inserting(Component.text(plot.toString()))) | ||||||
| @@ -671,10 +859,10 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|                 this.tmpTeleport = true; |                 this.tmpTeleport = true; | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             int border = area.getBorder(); |             int border = area.getBorder(true); | ||||||
|             int z1; |             int z1; | ||||||
|             if (z2 > border && this.tmpTeleport) { |             if (z2 > border && this.tmpTeleport) { | ||||||
|                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BYPASS_BORDER)) { |                 if (!pp.hasPermission(Permission.PERMISSION_ADMIN_BYPASS_BORDER)) { | ||||||
|                     to.setZ(border - 1); |                     to.setZ(border - 1); | ||||||
|                     this.tmpTeleport = false; |                     this.tmpTeleport = false; | ||||||
|                     player.teleport(event.getTo()); |                     player.teleport(event.getTo()); | ||||||
| @@ -684,7 +872,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|                     pp.sendMessage(TranslatableCaption.of("border.bypass.exited")); |                     pp.sendMessage(TranslatableCaption.of("border.bypass.exited")); | ||||||
|                 } |                 } | ||||||
|             } else if (z2 < -border && this.tmpTeleport) { |             } else if (z2 < -border && this.tmpTeleport) { | ||||||
|                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BYPASS_BORDER)) { |                 if (!pp.hasPermission(Permission.PERMISSION_ADMIN_BYPASS_BORDER)) { | ||||||
|                     to.setZ(-border + 1); |                     to.setZ(-border + 1); | ||||||
|                     this.tmpTeleport = false; |                     this.tmpTeleport = false; | ||||||
|                     player.teleport(event.getTo()); |                     player.teleport(event.getTo()); | ||||||
| @@ -694,7 +882,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|                     pp.sendMessage(TranslatableCaption.of("border.bypass.exited")); |                     pp.sendMessage(TranslatableCaption.of("border.bypass.exited")); | ||||||
|                 } |                 } | ||||||
|             } else if (((z1 = MathMan.roundInt(from.getZ())) >= border && z2 <= border) || (z1 <= -border && z2 >= -border)) { |             } else if (((z1 = MathMan.roundInt(from.getZ())) >= border && z2 <= border) || (z1 <= -border && z2 >= -border)) { | ||||||
|                 if (Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BYPASS_BORDER)) { |                 if (pp.hasPermission(Permission.PERMISSION_ADMIN_BYPASS_BORDER)) { | ||||||
|                     pp.sendMessage(TranslatableCaption.of("border.bypass.entered")); |                     pp.sendMessage(TranslatableCaption.of("border.bypass.entered")); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
| @@ -702,6 +890,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     @EventHandler(priority = EventPriority.LOW) |     @EventHandler(priority = EventPriority.LOW) | ||||||
|  |     @SuppressWarnings("deprecation") // Paper deprecation | ||||||
|     public void onChat(AsyncPlayerChatEvent event) { |     public void onChat(AsyncPlayerChatEvent event) { | ||||||
|         if (event.isCancelled()) { |         if (event.isCancelled()) { | ||||||
|             return; |             return; | ||||||
| @@ -721,8 +910,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|                 || area.isForcingPlotChat())) { |                 || area.isForcingPlotChat())) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         if (plot.isDenied(plotPlayer.getUUID()) && !Permissions |         if (plot.isDenied(plotPlayer.getUUID()) && !plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_CHAT_BYPASS)) { | ||||||
|                 .hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_CHAT_BYPASS)) { |  | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         event.setCancelled(true); |         event.setCancelled(true); | ||||||
| @@ -777,40 +965,6 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) |  | ||||||
|     public void onWorldChanged(PlayerChangedWorldEvent event) { |  | ||||||
|         Player player = event.getPlayer(); |  | ||||||
|         BukkitPlayer pp = BukkitUtil.adapt(player); |  | ||||||
|         // Delete last location |  | ||||||
|         Plot plot; |  | ||||||
|         try (final MetaDataAccess<Plot> lastPlotAccess = |  | ||||||
|                      pp.accessTemporaryMetaData(PlayerMetaDataKeys.TEMPORARY_LAST_PLOT)) { |  | ||||||
|             plot = lastPlotAccess.remove(); |  | ||||||
|         } |  | ||||||
|         try (final MetaDataAccess<Location> lastLocationAccess = |  | ||||||
|                      pp.accessTemporaryMetaData(PlayerMetaDataKeys.TEMPORARY_LOCATION)) { |  | ||||||
|             lastLocationAccess.remove(); |  | ||||||
|         } |  | ||||||
|         if (plot != null) { |  | ||||||
|             plotExit(pp, plot); |  | ||||||
|         } |  | ||||||
|         if (this.worldEdit != null) { |  | ||||||
|             if (!Permissions.hasPermission(pp, Permission.PERMISSION_WORLDEDIT_BYPASS)) { |  | ||||||
|                 if (pp.getAttribute("worldedit")) { |  | ||||||
|                     pp.removeAttribute("worldedit"); |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         Location location = pp.getLocation(); |  | ||||||
|         PlotArea area = location.getPlotArea(); |  | ||||||
|         if (location.isPlotArea()) { |  | ||||||
|             plot = location.getPlot(); |  | ||||||
|             if (plot != null) { |  | ||||||
|                 plotEntry(pp, plot); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @SuppressWarnings("deprecation") |     @SuppressWarnings("deprecation") | ||||||
|     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) |     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) | ||||||
|     public void onInventoryClick(InventoryClickEvent event) { |     public void onInventoryClick(InventoryClickEvent event) { | ||||||
| @@ -851,8 +1005,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|             final Plot plot = pp.getCurrentPlot(); |             final Plot plot = pp.getCurrentPlot(); | ||||||
|             if (plot != null) { |             if (plot != null) { | ||||||
|                 if (plot.getFlag(PreventCreativeCopyFlag.class) && !plot |                 if (plot.getFlag(PreventCreativeCopyFlag.class) && !plot | ||||||
|                         .isAdded(player.getUniqueId()) && !Permissions |                         .isAdded(player.getUniqueId()) && !pp.hasPermission(Permission.PERMISSION_ADMIN_INTERACT_OTHER)) { | ||||||
|                         .hasPermission(pp, Permission.PERMISSION_ADMIN_INTERACT_OTHER)) { |  | ||||||
|                     final ItemStack newStack = |                     final ItemStack newStack = | ||||||
|                             new ItemStack(newItem.getType(), newItem.getAmount()); |                             new ItemStack(newItem.getType(), newItem.getAmount()); | ||||||
|                     event.setCursor(newStack); |                     event.setCursor(newStack); | ||||||
| @@ -861,8 +1014,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|                 } |                 } | ||||||
|             } else { |             } else { | ||||||
|                 PlotArea area = pp.getPlotAreaAbs(); |                 PlotArea area = pp.getPlotAreaAbs(); | ||||||
|                 if (area != null && area.isRoadFlags() && area |                 if (area != null && PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, PreventCreativeCopyFlag.class, true)) { | ||||||
|                         .getRoadFlag(PreventCreativeCopyFlag.class)) { |  | ||||||
|                     final ItemStack newStack = |                     final ItemStack newStack = | ||||||
|                             new ItemStack(newItem.getType(), newItem.getAmount()); |                             new ItemStack(newItem.getType(), newItem.getAmount()); | ||||||
|                     event.setCursor(newStack); |                     event.setCursor(newStack); | ||||||
| @@ -915,7 +1067,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|         Plot plot = area.getPlotAbs(location); |         Plot plot = area.getPlotAbs(location); | ||||||
|         boolean cancelled = false; |         boolean cancelled = false; | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_INTERACT_ROAD)) { |             if (!pp.hasPermission(Permission.PERMISSION_ADMIN_INTERACT_ROAD)) { | ||||||
|                 pp.sendMessage( |                 pp.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission_event"), |                         TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                         TagResolver.resolver( |                         TagResolver.resolver( | ||||||
| @@ -926,7 +1078,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|                 cancelled = true; |                 cancelled = true; | ||||||
|             } |             } | ||||||
|         } else if (!plot.hasOwner()) { |         } else if (!plot.hasOwner()) { | ||||||
|             if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_INTERACT_UNOWNED)) { |             if (!pp.hasPermission(Permission.PERMISSION_ADMIN_INTERACT_UNOWNED)) { | ||||||
|                 pp.sendMessage( |                 pp.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission_event"), |                         TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                         TagResolver.resolver( |                         TagResolver.resolver( | ||||||
| @@ -939,7 +1091,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|         } else { |         } else { | ||||||
|             UUID uuid = pp.getUUID(); |             UUID uuid = pp.getUUID(); | ||||||
|             if (!plot.isAdded(uuid)) { |             if (!plot.isAdded(uuid)) { | ||||||
|                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_INTERACT_OTHER)) { |                 if (!pp.hasPermission(Permission.PERMISSION_ADMIN_INTERACT_OTHER)) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             TagResolver.resolver( | ||||||
| @@ -979,8 +1131,9 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|         Plot plot = location.getPlotAbs(); |         Plot plot = location.getPlotAbs(); | ||||||
|         BukkitPlayer pp = BukkitUtil.adapt(e.getPlayer()); |         BukkitPlayer pp = BukkitUtil.adapt(e.getPlayer()); | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             if (!area.isRoadFlags() && !area.getRoadFlag(MiscInteractFlag.class) && !Permissions |             if (!PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, MiscInteractFlag.class, true) && !pp.hasPermission( | ||||||
|                     .hasPermission(pp, Permission.PERMISSION_ADMIN_INTERACT_ROAD)) { |                     Permission.PERMISSION_ADMIN_INTERACT_ROAD | ||||||
|  |             )) { | ||||||
|                 pp.sendMessage( |                 pp.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission_event"), |                         TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                         TagResolver.resolver( |                         TagResolver.resolver( | ||||||
| @@ -992,16 +1145,14 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|             } |             } | ||||||
|         } else { |         } else { | ||||||
|             if (Settings.Done.RESTRICT_BUILDING && DoneFlag.isDone(plot)) { |             if (Settings.Done.RESTRICT_BUILDING && DoneFlag.isDone(plot)) { | ||||||
|                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_OTHER)) { |                 if (!pp.hasPermission(Permission.PERMISSION_ADMIN_BUILD_OTHER)) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage(TranslatableCaption.of("done.building_restricted")); | ||||||
|                             TranslatableCaption.of("done.building_restricted") |  | ||||||
|                     ); |  | ||||||
|                     e.setCancelled(true); |                     e.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             if (!plot.hasOwner()) { |             if (!plot.hasOwner()) { | ||||||
|                 if (!Permissions.hasPermission(pp, "plots.admin.interact.unowned")) { |                 if (!pp.hasPermission("plots.admin.interact.unowned")) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             TagResolver.resolver( | ||||||
| @@ -1019,7 +1170,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|                 if (plot.getFlag(MiscInteractFlag.class)) { |                 if (plot.getFlag(MiscInteractFlag.class)) { | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_INTERACT_OTHER)) { |                 if (!pp.hasPermission(Permission.PERMISSION_ADMIN_INTERACT_OTHER)) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             TagResolver.resolver( | ||||||
| @@ -1036,6 +1187,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     @EventHandler(priority = EventPriority.LOW) |     @EventHandler(priority = EventPriority.LOW) | ||||||
|  |     @SuppressWarnings("deprecation") // Paper deprecation | ||||||
|     public void onCancelledInteract(PlayerInteractEvent event) { |     public void onCancelledInteract(PlayerInteractEvent event) { | ||||||
|         if (event.isCancelled() && event.getAction() == Action.RIGHT_CLICK_AIR) { |         if (event.isCancelled() && event.getAction() == Action.RIGHT_CLICK_AIR) { | ||||||
|             Player player = event.getPlayer(); |             Player player = event.getPlayer(); | ||||||
| @@ -1089,18 +1241,18 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|         Location location = BukkitUtil.adapt(block.getLocation()); |         Location location = BukkitUtil.adapt(block.getLocation()); | ||||||
|         Action action = event.getAction(); |         Action action = event.getAction(); | ||||||
|         switch (action) { |         switch (action) { | ||||||
|             case PHYSICAL: { |             case PHYSICAL -> { | ||||||
|                 eventType = PlayerBlockEventType.TRIGGER_PHYSICAL; |                 eventType = PlayerBlockEventType.TRIGGER_PHYSICAL; | ||||||
|                 blocktype1 = BukkitAdapter.asBlockType(block.getType()); |                 blocktype1 = BukkitAdapter.asBlockType(block.getType()); | ||||||
|                 break; |  | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             //todo rearrange the right click code. it is all over the place. |             //todo rearrange the right click code. it is all over the place. | ||||||
|             case RIGHT_CLICK_BLOCK: { |             case RIGHT_CLICK_BLOCK -> { | ||||||
|                 Material blockType = block.getType(); |                 Material blockType = block.getType(); | ||||||
|                 eventType = PlayerBlockEventType.INTERACT_BLOCK; |                 eventType = PlayerBlockEventType.INTERACT_BLOCK; | ||||||
|                 blocktype1 = BukkitAdapter.asBlockType(block.getType()); |                 blocktype1 = BukkitAdapter.asBlockType(block.getType()); | ||||||
|  |  | ||||||
|                 if (blockType.isInteractable()) { |                 if (INTERACTABLE_MATERIALS != null ? INTERACTABLE_MATERIALS.contains(blockType.name()) : blockType.isInteractable()) { | ||||||
|                     if (!player.isSneaking()) { |                     if (!player.isSneaking()) { | ||||||
|                         break; |                         break; | ||||||
|                     } |                     } | ||||||
| @@ -1117,22 +1269,17 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|  |  | ||||||
|                 // in the following, lb needs to have the material of the item in hand i.e. type |                 // in the following, lb needs to have the material of the item in hand i.e. type | ||||||
|                 switch (type.toString()) { |                 switch (type.toString()) { | ||||||
|                     case "REDSTONE": |                     case "REDSTONE", "STRING", "PUMPKIN_SEEDS", "MELON_SEEDS", "COCOA_BEANS", "WHEAT_SEEDS", "BEETROOT_SEEDS", | ||||||
|                     case "STRING": |                             "SWEET_BERRIES", "GLOW_BERRIES" -> { | ||||||
|                     case "PUMPKIN_SEEDS": |  | ||||||
|                     case "MELON_SEEDS": |  | ||||||
|                     case "COCOA_BEANS": |  | ||||||
|                     case "WHEAT_SEEDS": |  | ||||||
|                     case "BEETROOT_SEEDS": |  | ||||||
|                     case "SWEET_BERRIES": |  | ||||||
|                     case "GLOW_BERRIES": |  | ||||||
|                         return; |                         return; | ||||||
|                     default: |                     } | ||||||
|  |                     default -> { | ||||||
|                         //eventType = PlayerBlockEventType.PLACE_BLOCK; |                         //eventType = PlayerBlockEventType.PLACE_BLOCK; | ||||||
|                         if (type.isBlock()) { |                         if (type.isBlock()) { | ||||||
|                             return; |                             return; | ||||||
|                         } |                         } | ||||||
|                     } |                     } | ||||||
|  |                 } | ||||||
|                 if (PaperLib.isPaper()) { |                 if (PaperLib.isPaper()) { | ||||||
|                     if (MaterialTags.SPAWN_EGGS.isTagged(type) || Material.EGG.equals(type)) { |                     if (MaterialTags.SPAWN_EGGS.isTagged(type) || Material.EGG.equals(type)) { | ||||||
|                         eventType = PlayerBlockEventType.SPAWN_MOB; |                         eventType = PlayerBlockEventType.SPAWN_MOB; | ||||||
| @@ -1145,7 +1292,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|                 if (type.isEdible()) { |                 if (type.isEdible()) { | ||||||
|                     //Allow all players to eat while also allowing the block place event ot be fired |                     //Allow all players to eat while also allowing the block place event to be fired | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 if (type == Material.ARMOR_STAND) { |                 if (type == Material.ARMOR_STAND) { | ||||||
| @@ -1164,9 +1311,8 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|                     eventType = PlayerBlockEventType.READ; |                     eventType = PlayerBlockEventType.READ; | ||||||
|                     break; |                     break; | ||||||
|                 } |                 } | ||||||
|                 break; |  | ||||||
|             } |             } | ||||||
|             case LEFT_CLICK_BLOCK: { |             case LEFT_CLICK_BLOCK -> { | ||||||
|                 Material blockType = block.getType(); |                 Material blockType = block.getType(); | ||||||
|  |  | ||||||
|                 // todo: when the code above is rearranged, it would be great to beautify this as well. |                 // todo: when the code above is rearranged, it would be great to beautify this as well. | ||||||
| @@ -1177,11 +1323,11 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|  |  | ||||||
|                 eventType = PlayerBlockEventType.INTERACT_BLOCK; |                 eventType = PlayerBlockEventType.INTERACT_BLOCK; | ||||||
|                 blocktype1 = BukkitAdapter.asBlockType(block.getType()); |                 blocktype1 = BukkitAdapter.asBlockType(block.getType()); | ||||||
|                 break; |  | ||||||
|             } |             } | ||||||
|             default: |             default -> { | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|  |         } | ||||||
|         if (this.worldEdit != null && pp.getAttribute("worldedit")) { |         if (this.worldEdit != null && pp.getAttribute("worldedit")) { | ||||||
|             if (event.getMaterial() == Material.getMaterial(this.worldEdit.getConfiguration().wandItem)) { |             if (event.getMaterial() == Material.getMaterial(this.worldEdit.getConfiguration().wandItem)) { | ||||||
|                 return; |                 return; | ||||||
| @@ -1247,7 +1393,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|         BukkitPlayer pp = BukkitUtil.adapt(event.getPlayer()); |         BukkitPlayer pp = BukkitUtil.adapt(event.getPlayer()); | ||||||
|         Plot plot = area.getPlot(location); |         Plot plot = area.getPlot(location); | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             if (Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_ROAD)) { |             if (pp.hasPermission(Permission.PERMISSION_ADMIN_BUILD_ROAD)) { | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             pp.sendMessage( |             pp.sendMessage( | ||||||
| @@ -1256,7 +1402,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|             ); |             ); | ||||||
|             event.setCancelled(true); |             event.setCancelled(true); | ||||||
|         } else if (!plot.hasOwner()) { |         } else if (!plot.hasOwner()) { | ||||||
|             if (Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_UNOWNED)) { |             if (pp.hasPermission(Permission.PERMISSION_ADMIN_BUILD_UNOWNED)) { | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             pp.sendMessage( |             pp.sendMessage( | ||||||
| @@ -1268,7 +1414,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|             ); |             ); | ||||||
|             event.setCancelled(true); |             event.setCancelled(true); | ||||||
|         } else if (!plot.isAdded(pp.getUUID())) { |         } else if (!plot.isAdded(pp.getUUID())) { | ||||||
|             if (Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_OTHER)) { |             if (pp.hasPermission(Permission.PERMISSION_ADMIN_BUILD_OTHER)) { | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             pp.sendMessage( |             pp.sendMessage( | ||||||
| @@ -1280,7 +1426,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|             ); |             ); | ||||||
|             event.setCancelled(true); |             event.setCancelled(true); | ||||||
|         } else if (Settings.Done.RESTRICT_BUILDING && DoneFlag.isDone(plot)) { |         } else if (Settings.Done.RESTRICT_BUILDING && DoneFlag.isDone(plot)) { | ||||||
|             if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_OTHER)) { |             if (!pp.hasPermission(Permission.PERMISSION_ADMIN_BUILD_OTHER)) { | ||||||
|                 pp.sendMessage( |                 pp.sendMessage( | ||||||
|                         TranslatableCaption.of("done.building_restricted") |                         TranslatableCaption.of("done.building_restricted") | ||||||
|                 ); |                 ); | ||||||
| @@ -1303,7 +1449,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|         TaskManager.removeFromTeleportQueue(event.getPlayer().getName()); |         TaskManager.removeFromTeleportQueue(event.getPlayer().getName()); | ||||||
|         BukkitPlayer pp = BukkitUtil.adapt(event.getPlayer()); |         BukkitPlayer pp = BukkitUtil.adapt(event.getPlayer()); | ||||||
|         pp.unregister(); |         pp.unregister(); | ||||||
|         this.logout(pp.getUUID()); |         plotListener.logout(pp.getUUID()); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) |     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) | ||||||
| @@ -1318,7 +1464,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|         BukkitPlayer plotPlayer = BukkitUtil.adapt(player); |         BukkitPlayer plotPlayer = BukkitUtil.adapt(player); | ||||||
|         Plot plot = area.getPlot(location); |         Plot plot = area.getPlot(location); | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             if (Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_BUILD_ROAD)) { |             if (plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_BUILD_ROAD)) { | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             plotPlayer.sendMessage( |             plotPlayer.sendMessage( | ||||||
| @@ -1327,7 +1473,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|             ); |             ); | ||||||
|             event.setCancelled(true); |             event.setCancelled(true); | ||||||
|         } else if (!plot.hasOwner()) { |         } else if (!plot.hasOwner()) { | ||||||
|             if (Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_BUILD_UNOWNED)) { |             if (plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_BUILD_UNOWNED)) { | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             plotPlayer.sendMessage( |             plotPlayer.sendMessage( | ||||||
| @@ -1339,7 +1485,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|             ); |             ); | ||||||
|             event.setCancelled(true); |             event.setCancelled(true); | ||||||
|         } else if (!plot.isAdded(plotPlayer.getUUID())) { |         } else if (!plot.isAdded(plotPlayer.getUUID())) { | ||||||
|             if (Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_BUILD_OTHER)) { |             if (plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_BUILD_OTHER)) { | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             plotPlayer.sendMessage( |             plotPlayer.sendMessage( | ||||||
| @@ -1351,7 +1497,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|             ); |             ); | ||||||
|             event.setCancelled(true); |             event.setCancelled(true); | ||||||
|         } else if (Settings.Done.RESTRICT_BUILDING && DoneFlag.isDone(plot)) { |         } else if (Settings.Done.RESTRICT_BUILDING && DoneFlag.isDone(plot)) { | ||||||
|             if (!Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_BUILD_OTHER)) { |             if (!plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_BUILD_OTHER)) { | ||||||
|                 plotPlayer.sendMessage( |                 plotPlayer.sendMessage( | ||||||
|                         TranslatableCaption.of("done.building_restricted") |                         TranslatableCaption.of("done.building_restricted") | ||||||
|                 ); |                 ); | ||||||
| @@ -1376,7 +1522,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|         BukkitPlayer pp = BukkitUtil.adapt(p); |         BukkitPlayer pp = BukkitUtil.adapt(p); | ||||||
|         Plot plot = area.getPlot(location); |         Plot plot = area.getPlot(location); | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_ROAD)) { |             if (!pp.hasPermission(Permission.PERMISSION_ADMIN_BUILD_ROAD)) { | ||||||
|                 pp.sendMessage( |                 pp.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission_event"), |                         TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                         TagResolver.resolver( |                         TagResolver.resolver( | ||||||
| @@ -1388,7 +1534,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|             } |             } | ||||||
|         } else { |         } else { | ||||||
|             if (!plot.hasOwner()) { |             if (!plot.hasOwner()) { | ||||||
|                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_UNOWNED)) { |                 if (!pp.hasPermission(Permission.PERMISSION_ADMIN_BUILD_UNOWNED)) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             TagResolver.resolver( | ||||||
| @@ -1402,7 +1548,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|             } |             } | ||||||
|             if (!plot.isAdded(pp.getUUID())) { |             if (!plot.isAdded(pp.getUUID())) { | ||||||
|                 if (!plot.getFlag(HangingPlaceFlag.class)) { |                 if (!plot.getFlag(HangingPlaceFlag.class)) { | ||||||
|                     if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_OTHER)) { |                     if (!pp.hasPermission(Permission.PERMISSION_ADMIN_BUILD_OTHER)) { | ||||||
|                         pp.sendMessage( |                         pp.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission_event"), |                                 TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                                 TagResolver.resolver( |                                 TagResolver.resolver( | ||||||
| @@ -1434,7 +1580,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|             BukkitPlayer pp = BukkitUtil.adapt(p); |             BukkitPlayer pp = BukkitUtil.adapt(p); | ||||||
|             Plot plot = area.getPlot(location); |             Plot plot = area.getPlot(location); | ||||||
|             if (plot == null) { |             if (plot == null) { | ||||||
|                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_DESTROY_ROAD)) { |                 if (!pp.hasPermission(Permission.PERMISSION_ADMIN_DESTROY_ROAD)) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             TagResolver.resolver( | ||||||
| @@ -1445,7 +1591,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                 } |                 } | ||||||
|             } else if (!plot.hasOwner()) { |             } else if (!plot.hasOwner()) { | ||||||
|                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_DESTROY_UNOWNED)) { |                 if (!pp.hasPermission(Permission.PERMISSION_ADMIN_DESTROY_UNOWNED)) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             TagResolver.resolver( | ||||||
| @@ -1459,7 +1605,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|                 if (plot.getFlag(HangingBreakFlag.class)) { |                 if (plot.getFlag(HangingBreakFlag.class)) { | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_DESTROY_OTHER)) { |                 if (!pp.hasPermission(Permission.PERMISSION_ADMIN_DESTROY_OTHER)) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             TagResolver.resolver( | ||||||
| @@ -1483,8 +1629,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|                 Plot plot = area.getPlot(BukkitUtil.adapt(event.getEntity().getLocation())); |                 Plot plot = area.getPlot(BukkitUtil.adapt(event.getEntity().getLocation())); | ||||||
|                 if (plot != null) { |                 if (plot != null) { | ||||||
|                     if (!plot.hasOwner()) { |                     if (!plot.hasOwner()) { | ||||||
|                         if (!Permissions |                         if (!player.hasPermission(Permission.PERMISSION_ADMIN_DESTROY_UNOWNED)) { | ||||||
|                                 .hasPermission(player, Permission.PERMISSION_ADMIN_DESTROY_UNOWNED)) { |  | ||||||
|                             player.sendMessage( |                             player.sendMessage( | ||||||
|                                     TranslatableCaption.of("permission.no_permission_event"), |                                     TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                                     TagResolver.resolver( |                                     TagResolver.resolver( | ||||||
| @@ -1496,8 +1641,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|                         } |                         } | ||||||
|                     } else if (!plot.isAdded(player.getUUID())) { |                     } else if (!plot.isAdded(player.getUUID())) { | ||||||
|                         if (!plot.getFlag(HangingBreakFlag.class)) { |                         if (!plot.getFlag(HangingBreakFlag.class)) { | ||||||
|                             if (!Permissions |                             if (!player.hasPermission(Permission.PERMISSION_ADMIN_DESTROY_OTHER)) { | ||||||
|                                     .hasPermission(player, Permission.PERMISSION_ADMIN_DESTROY_OTHER)) { |  | ||||||
|                                 player.sendMessage( |                                 player.sendMessage( | ||||||
|                                         TranslatableCaption.of("permission.no_permission_event"), |                                         TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                                         TagResolver.resolver( |                                         TagResolver.resolver( | ||||||
| @@ -1532,7 +1676,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|         BukkitPlayer pp = BukkitUtil.adapt(p); |         BukkitPlayer pp = BukkitUtil.adapt(p); | ||||||
|         Plot plot = area.getPlot(location); |         Plot plot = area.getPlot(location); | ||||||
|         if (plot == null && !area.isRoadFlags()) { |         if (plot == null && !area.isRoadFlags()) { | ||||||
|             if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_INTERACT_ROAD)) { |             if (!pp.hasPermission(Permission.PERMISSION_ADMIN_INTERACT_ROAD)) { | ||||||
|                 pp.sendMessage( |                 pp.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission_event"), |                         TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                         TagResolver.resolver( |                         TagResolver.resolver( | ||||||
| @@ -1543,7 +1687,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } |             } | ||||||
|         } else if (plot != null && !plot.hasOwner()) { |         } else if (plot != null && !plot.hasOwner()) { | ||||||
|             if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_INTERACT_UNOWNED)) { |             if (!pp.hasPermission(Permission.PERMISSION_ADMIN_INTERACT_UNOWNED)) { | ||||||
|                 pp.sendMessage( |                 pp.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission_event"), |                         TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                         TagResolver.resolver( |                         TagResolver.resolver( | ||||||
| @@ -1604,7 +1748,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_INTERACT_OTHER)) { |             if (!pp.hasPermission(Permission.PERMISSION_ADMIN_INTERACT_OTHER)) { | ||||||
|                 pp.sendMessage( |                 pp.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission_event"), |                         TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                         TagResolver.resolver( |                         TagResolver.resolver( | ||||||
| @@ -1629,7 +1773,9 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|             BukkitPlayer pp = BukkitUtil.adapt(p); |             BukkitPlayer pp = BukkitUtil.adapt(p); | ||||||
|             Plot plot = area.getPlot(location); |             Plot plot = area.getPlot(location); | ||||||
|             if (plot == null) { |             if (plot == null) { | ||||||
|                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_DESTROY_VEHICLE_ROAD)) { |                 if (!PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, VehicleBreakFlag.class, true) && !pp.hasPermission( | ||||||
|  |                         Permission.PERMISSION_ADMIN_DESTROY_VEHICLE_ROAD | ||||||
|  |                 )) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             TagResolver.resolver( | ||||||
| @@ -1641,7 +1787,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|                 } |                 } | ||||||
|             } else { |             } else { | ||||||
|                 if (!plot.hasOwner()) { |                 if (!plot.hasOwner()) { | ||||||
|                     if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_DESTROY_VEHICLE_UNOWNED)) { |                     if (!pp.hasPermission(Permission.PERMISSION_ADMIN_DESTROY_VEHICLE_UNOWNED)) { | ||||||
|                         pp.sendMessage( |                         pp.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission_event"), |                                 TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                                 TagResolver.resolver( |                                 TagResolver.resolver( | ||||||
| @@ -1658,7 +1804,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|                     if (plot.getFlag(VehicleBreakFlag.class)) { |                     if (plot.getFlag(VehicleBreakFlag.class)) { | ||||||
|                         return; |                         return; | ||||||
|                     } |                     } | ||||||
|                     if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_DESTROY_VEHICLE_OTHER)) { |                     if (!pp.hasPermission(Permission.PERMISSION_ADMIN_DESTROY_VEHICLE_OTHER)) { | ||||||
|                         pp.sendMessage( |                         pp.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission_event"), |                                 TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                                 TagResolver.resolver( |                                 TagResolver.resolver( | ||||||
| @@ -1686,7 +1832,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|         } |         } | ||||||
|         Plot plot = location.getOwnedPlot(); |         Plot plot = location.getOwnedPlot(); | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             if (area.isRoadFlags() && !area.getRoadFlag(ItemDropFlag.class)) { |             if (PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, ItemDropFlag.class, false)) { | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } |             } | ||||||
|             return; |             return; | ||||||
| @@ -1712,7 +1858,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|             } |             } | ||||||
|             Plot plot = location.getOwnedPlot(); |             Plot plot = location.getOwnedPlot(); | ||||||
|             if (plot == null) { |             if (plot == null) { | ||||||
|                 if (area.isRoadFlags() && area.getRoadFlag(DropProtectionFlag.class)) { |                 if (PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, DropProtectionFlag.class, true)) { | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                 } |                 } | ||||||
|                 return; |                 return; | ||||||
| @@ -1734,19 +1880,17 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|         } |         } | ||||||
|         Plot plot = location.getOwnedPlot(); |         Plot plot = location.getOwnedPlot(); | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             if (area.isRoadFlags() && area.getRoadFlag(KeepInventoryFlag.class)) { |             if (PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, KeepInventoryFlag.class, true)) { | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } |             } | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         if (plot.getFlag(KeepInventoryFlag.class)) { |  | ||||||
|         if (plot.getFlag(KeepInventoryFlag.class)) { |         if (plot.getFlag(KeepInventoryFlag.class)) { | ||||||
|             plot.debug(event.getEntity().getName() + " kept their inventory because of keep-inventory = true"); |             plot.debug(event.getEntity().getName() + " kept their inventory because of keep-inventory = true"); | ||||||
|             event.getDrops().clear(); |             event.getDrops().clear(); | ||||||
|             event.setKeepInventory(true); |             event.setKeepInventory(true); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @SuppressWarnings("deprecation") // #getLocate is needed for Spigot compatibility |     @SuppressWarnings("deprecation") // #getLocate is needed for Spigot compatibility | ||||||
|     @EventHandler |     @EventHandler | ||||||
| @@ -1769,18 +1913,16 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|         } |         } | ||||||
|         Plot plot = location.getOwnedPlot(); |         Plot plot = location.getOwnedPlot(); | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             if (area.isRoadFlags() && area.getRoadFlag(DenyPortalTravelFlag.class)) { |             if (PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, DenyPortalTravelFlag.class, true)) { | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } |             } | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         if (plot.getFlag(DenyPortalTravelFlag.class)) { |  | ||||||
|         if (plot.getFlag(DenyPortalTravelFlag.class)) { |         if (plot.getFlag(DenyPortalTravelFlag.class)) { | ||||||
|             plot.debug(event.getPlayer().getName() + " did not travel thru a portal because of deny-portal-travel = true"); |             plot.debug(event.getPlayer().getName() + " did not travel thru a portal because of deny-portal-travel = true"); | ||||||
|             event.setCancelled(true); |             event.setCancelled(true); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @EventHandler |     @EventHandler | ||||||
|     public void onPortalCreation(PortalCreateEvent event) { |     public void onPortalCreation(PortalCreateEvent event) { | ||||||
| @@ -1788,6 +1930,7 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|         if (PlotSquared.get().getPlotAreaManager().getPlotAreasSet(world).size() == 0) { |         if (PlotSquared.get().getPlotAreaManager().getPlotAreasSet(world).size() == 0) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|  |         BukkitPlayer pp = (event.getEntity() instanceof Player player) ? BukkitUtil.adapt(player) : null; | ||||||
|         int minX = Integer.MAX_VALUE; |         int minX = Integer.MAX_VALUE; | ||||||
|         int maxX = Integer.MIN_VALUE; |         int maxX = Integer.MIN_VALUE; | ||||||
|         int minZ = Integer.MAX_VALUE; |         int minZ = Integer.MAX_VALUE; | ||||||
| @@ -1799,19 +1942,23 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|             maxZ = Math.max(state.getZ(), maxZ); |             maxZ = Math.max(state.getZ(), maxZ); | ||||||
|         } |         } | ||||||
|         int y = event.getBlocks().get(0).getY(); // Don't need to worry about this too much |         int y = event.getBlocks().get(0).getY(); // Don't need to worry about this too much | ||||||
|         for (Location location : Set.of( // Use Set to lazily avoid duplicate locations |         for (Location location : List.of( // We don't care about duplicate locations | ||||||
|                 Location.at(world, minX, y, maxX), |                 Location.at(world, minX, y, minZ), | ||||||
|                 Location.at(world, minZ, y, maxZ), |  | ||||||
|                 Location.at(world, minX, y, maxZ), |                 Location.at(world, minX, y, maxZ), | ||||||
|                 Location.at(world, minZ, y, maxX) |                 Location.at(world, maxX, y, minZ), | ||||||
|  |                 Location.at(world, maxX, y, maxZ) | ||||||
|         )) { |         )) { | ||||||
|             PlotArea area = location.getPlotArea(); |             PlotArea area = location.getPlotArea(); | ||||||
|             if (area == null) { |             if (area == null) { | ||||||
|                 continue; |                 continue; | ||||||
|             } |             } | ||||||
|  |             if (area.notifyIfOutsideBuildArea(pp, location.getY())) { | ||||||
|  |                 event.setCancelled(true); | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|             Plot plot = location.getOwnedPlot(); |             Plot plot = location.getOwnedPlot(); | ||||||
|             if (plot == null) { |             if (plot == null) { | ||||||
|                 if (area.isRoadFlags() && area.getRoadFlag(DenyPortalsFlag.class)) { |                 if (PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, DenyPortalsFlag.class, true)) { | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
| @@ -1833,19 +1980,21 @@ public class PlayerEventListener extends PlotListener implements Listener { | |||||||
|  |  | ||||||
|     @EventHandler |     @EventHandler | ||||||
|     public void onPlayerTakeLecternBook(PlayerTakeLecternBookEvent event) { |     public void onPlayerTakeLecternBook(PlayerTakeLecternBookEvent event) { | ||||||
|         Location location = BukkitUtil.adapt(event.getPlayer().getLocation()); |         Player player = event.getPlayer(); | ||||||
|  |         BukkitPlayer pp = BukkitUtil.adapt(player); | ||||||
|  |         Location location = pp.getLocation(); | ||||||
|         PlotArea area = location.getPlotArea(); |         PlotArea area = location.getPlotArea(); | ||||||
|         if (area == null) { |         if (area == null) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         Plot plot = location.getOwnedPlot(); |         Plot plot = location.getOwnedPlot(); | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             if (area.isRoadFlags() && area.getRoadFlag(LecternReadBookFlag.class)) { |             if (PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, LecternReadBookFlag.class, true)) { | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } |             } | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         if (plot.getFlag(LecternReadBookFlag.class)) { |         if (!plot.isAdded(pp.getUUID())) { | ||||||
|             if (plot.getFlag(LecternReadBookFlag.class)) { |             if (plot.getFlag(LecternReadBookFlag.class)) { | ||||||
|                 plot.debug(event.getPlayer().getName() + " could not take the book because of lectern-read-book = true"); |                 plot.debug(event.getPlayer().getName() + " could not take the book because of lectern-read-book = true"); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|   | |||||||
| @@ -0,0 +1,66 @@ | |||||||
|  | /* | ||||||
|  |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  |  * | ||||||
|  |  * This program is free software: you can redistribute it and/or modify | ||||||
|  |  * it under the terms of the GNU General Public License as published by | ||||||
|  |  * the Free Software Foundation, either version 3 of the License, or | ||||||
|  |  * (at your option) any later version. | ||||||
|  |  * | ||||||
|  |  * This program is distributed in the hope that it will be useful, | ||||||
|  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||||
|  |  * GNU General Public License for more details. | ||||||
|  |  * | ||||||
|  |  * You should have received a copy of the GNU General Public License | ||||||
|  |  * along with this program.  If not, see <https://www.gnu.org/licenses/>. | ||||||
|  |  */ | ||||||
|  | package com.plotsquared.bukkit.listener; | ||||||
|  |  | ||||||
|  | import com.plotsquared.bukkit.util.BukkitUtil; | ||||||
|  | import com.plotsquared.core.location.Location; | ||||||
|  | import com.plotsquared.core.permissions.Permission; | ||||||
|  | import com.plotsquared.core.plot.Plot; | ||||||
|  | import com.plotsquared.core.plot.PlotArea; | ||||||
|  | import com.plotsquared.core.plot.flag.implementations.EditSignFlag; | ||||||
|  | import com.plotsquared.core.util.PlotFlagUtil; | ||||||
|  | import org.bukkit.block.Sign; | ||||||
|  | import org.bukkit.event.EventHandler; | ||||||
|  | import org.bukkit.event.Listener; | ||||||
|  | import org.bukkit.event.player.PlayerSignOpenEvent; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * For events since 1.20.1 | ||||||
|  |  * @since 7.2.1 | ||||||
|  |  */ | ||||||
|  | public class PlayerEventListener1201 implements Listener { | ||||||
|  |  | ||||||
|  |     @EventHandler(ignoreCancelled = true) | ||||||
|  |     @SuppressWarnings({"removal", "UnstableApiUsage"}) // thanks Paper, thanks Spigot | ||||||
|  |     public void onPlayerSignOpenEvent(PlayerSignOpenEvent event) { | ||||||
|  |         Sign sign = event.getSign(); | ||||||
|  |         Location location = BukkitUtil.adapt(sign.getLocation()); | ||||||
|  |         PlotArea area = location.getPlotArea(); | ||||||
|  |         if (area == null) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |         Plot plot = location.getOwnedPlot(); | ||||||
|  |         if (plot == null) { | ||||||
|  |             if (PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, EditSignFlag.class, false) | ||||||
|  |                     && !event.getPlayer().hasPermission(Permission.PERMISSION_ADMIN_INTERACT_ROAD.toString())) { | ||||||
|  |                 event.setCancelled(true); | ||||||
|  |             } | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |         if (plot.isAdded(event.getPlayer().getUniqueId())) { | ||||||
|  |             return; // allow for added players | ||||||
|  |         } | ||||||
|  |         if (!plot.getFlag(EditSignFlag.class) | ||||||
|  |                 && !event.getPlayer().hasPermission(Permission.PERMISSION_ADMIN_INTERACT_OTHER.toString())) { | ||||||
|  |             plot.debug(event.getPlayer().getName() + " could not edit the sign because of edit-sign = false"); | ||||||
|  |             event.setCancelled(true); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -28,13 +28,14 @@ import com.plotsquared.core.player.PlotPlayer; | |||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
| import com.plotsquared.core.plot.PlotHandler; | import com.plotsquared.core.plot.PlotHandler; | ||||||
|  | import com.plotsquared.core.plot.flag.implementations.FishingFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.ProjectilesFlag; | import com.plotsquared.core.plot.flag.implementations.ProjectilesFlag; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
| import com.plotsquared.core.util.Permissions; | import com.plotsquared.core.util.PlotFlagUtil; | ||||||
| import net.kyori.adventure.text.Component; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; | import net.kyori.adventure.text.minimessage.tag.Tag; | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | ||||||
| import org.bukkit.entity.Entity; | import org.bukkit.entity.Entity; | ||||||
|  | import org.bukkit.entity.EntityType; | ||||||
| import org.bukkit.entity.LivingEntity; | import org.bukkit.entity.LivingEntity; | ||||||
| import org.bukkit.entity.Player; | import org.bukkit.entity.Player; | ||||||
| import org.bukkit.entity.Projectile; | import org.bukkit.entity.Projectile; | ||||||
| @@ -91,7 +92,7 @@ public class ProjectileEventListener implements Listener { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @EventHandler |     @EventHandler(ignoreCancelled = true) | ||||||
|     public void onProjectileLaunch(ProjectileLaunchEvent event) { |     public void onProjectileLaunch(ProjectileLaunchEvent event) { | ||||||
|         Projectile entity = event.getEntity(); |         Projectile entity = event.getEntity(); | ||||||
|         ProjectileSource shooter = entity.getShooter(); |         ProjectileSource shooter = entity.getShooter(); | ||||||
| @@ -99,14 +100,17 @@ public class ProjectileEventListener implements Listener { | |||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         Location location = BukkitUtil.adapt(entity.getLocation()); |         Location location = BukkitUtil.adapt(entity.getLocation()); | ||||||
|         if (!this.plotAreaManager.hasPlotArea(location.getWorldName())) { |         PlotArea area = location.getPlotArea(); | ||||||
|  |         if (area == null) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         PlotPlayer<Player> pp = BukkitUtil.adapt((Player) shooter); |         PlotPlayer<Player> pp = BukkitUtil.adapt((Player) shooter); | ||||||
|         Plot plot = location.getOwnedPlot(); |         Plot plot = location.getOwnedPlot(); | ||||||
|  |  | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_PROJECTILE_ROAD)) { |             if (!PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, ProjectilesFlag.class, true) && !pp.hasPermission( | ||||||
|  |                     Permission.PERMISSION_ADMIN_PROJECTILE_ROAD | ||||||
|  |             )) { | ||||||
|                 pp.sendMessage( |                 pp.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission_event"), |                         TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                         TagResolver.resolver( |                         TagResolver.resolver( | ||||||
| @@ -118,7 +122,7 @@ public class ProjectileEventListener implements Listener { | |||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } |             } | ||||||
|         } else if (!plot.hasOwner()) { |         } else if (!plot.hasOwner()) { | ||||||
|             if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_PROJECTILE_UNOWNED)) { |             if (!pp.hasPermission(Permission.PERMISSION_ADMIN_PROJECTILE_UNOWNED)) { | ||||||
|                 pp.sendMessage( |                 pp.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission_event"), |                         TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                         TagResolver.resolver( |                         TagResolver.resolver( | ||||||
| @@ -130,8 +134,13 @@ public class ProjectileEventListener implements Listener { | |||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } |             } | ||||||
|         } else if (!plot.isAdded(pp.getUUID())) { |         } else if (!plot.isAdded(pp.getUUID())) { | ||||||
|  |             if (entity.getType().equals(EntityType.FISHING_HOOK)) { | ||||||
|  |                 if (plot.getFlag(FishingFlag.class)) { | ||||||
|  |                     return; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|             if (!plot.getFlag(ProjectilesFlag.class)) { |             if (!plot.getFlag(ProjectilesFlag.class)) { | ||||||
|                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_PROJECTILE_OTHER)) { |                 if (!pp.hasPermission(Permission.PERMISSION_ADMIN_PROJECTILE_OTHER)) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             TagResolver.resolver( | ||||||
| @@ -160,16 +169,33 @@ public class ProjectileEventListener implements Listener { | |||||||
|         Plot plot = area.getPlot(location); |         Plot plot = area.getPlot(location); | ||||||
|         ProjectileSource shooter = entity.getShooter(); |         ProjectileSource shooter = entity.getShooter(); | ||||||
|         if (shooter instanceof Player) { |         if (shooter instanceof Player) { | ||||||
|  |             if (!((Player) shooter).isOnline()) { | ||||||
|  |                 if (plot != null) { | ||||||
|  |                     if (plot.isAdded(((Player) shooter).getUniqueId()) || plot.getFlag(ProjectilesFlag.class)) { | ||||||
|  |                         return; | ||||||
|  |                     } | ||||||
|  |                 } else if (PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, ProjectilesFlag.class, true)) { | ||||||
|  |                     return; | ||||||
|  |                 } | ||||||
|  |  | ||||||
|  |                 entity.remove(); | ||||||
|  |                 event.setCancelled(true); | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|  |  | ||||||
|             PlotPlayer<?> pp = BukkitUtil.adapt((Player) shooter); |             PlotPlayer<?> pp = BukkitUtil.adapt((Player) shooter); | ||||||
|             if (plot == null) { |             if (plot == null) { | ||||||
|                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_PROJECTILE_UNOWNED)) { |                 if (!PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, ProjectilesFlag.class, true) && !pp.hasPermission( | ||||||
|  |                         Permission.PERMISSION_ADMIN_PROJECTILE_UNOWNED | ||||||
|  |                 )) { | ||||||
|                     entity.remove(); |                     entity.remove(); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                 } |                 } | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             if (plot.isAdded(pp.getUUID()) || Permissions |             if (plot.isAdded(pp.getUUID()) || pp.hasPermission(Permission.PERMISSION_ADMIN_PROJECTILE_OTHER) || plot.getFlag( | ||||||
|                     .hasPermission(pp, Permission.PERMISSION_ADMIN_PROJECTILE_OTHER) || plot.getFlag(ProjectilesFlag.class)) { |                     ProjectilesFlag.class) || (entity.getType().equals(EntityType.FISHING_HOOK) && plot.getFlag( | ||||||
|  |                     FishingFlag.class))) { | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             entity.remove(); |             entity.remove(); | ||||||
| @@ -193,7 +219,6 @@ public class ProjectileEventListener implements Listener { | |||||||
|             if (sPlot == null || !PlotHandler.sameOwners(plot, sPlot)) { |             if (sPlot == null || !PlotHandler.sameOwners(plot, sPlot)) { | ||||||
|                 entity.remove(); |                 entity.remove(); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|                 return; |  | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -21,9 +21,14 @@ package com.plotsquared.bukkit.listener; | |||||||
| import com.google.inject.Inject; | import com.google.inject.Inject; | ||||||
| import com.plotsquared.bukkit.BukkitPlatform; | import com.plotsquared.bukkit.BukkitPlatform; | ||||||
| import com.plotsquared.bukkit.placeholder.MVdWPlaceholders; | import com.plotsquared.bukkit.placeholder.MVdWPlaceholders; | ||||||
|  | import com.plotsquared.bukkit.util.BukkitEconHandler; | ||||||
|  | import com.plotsquared.core.PlotSquared; | ||||||
| import com.plotsquared.core.configuration.Settings; | import com.plotsquared.core.configuration.Settings; | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.player.ConsolePlayer; | import com.plotsquared.core.player.ConsolePlayer; | ||||||
|  | import com.plotsquared.core.util.EconHandler; | ||||||
|  | import org.apache.logging.log4j.LogManager; | ||||||
|  | import org.apache.logging.log4j.Logger; | ||||||
| import org.bukkit.Bukkit; | import org.bukkit.Bukkit; | ||||||
| import org.bukkit.event.EventHandler; | import org.bukkit.event.EventHandler; | ||||||
| import org.bukkit.event.Listener; | import org.bukkit.event.Listener; | ||||||
| @@ -32,6 +37,8 @@ import org.checkerframework.checker.nullness.qual.NonNull; | |||||||
|  |  | ||||||
| public class ServerListener implements Listener { | public class ServerListener implements Listener { | ||||||
|  |  | ||||||
|  |     private static final Logger LOGGER = LogManager.getLogger("PlotSquared/" + ServerListener.class.getSimpleName()); | ||||||
|  |  | ||||||
|     private final BukkitPlatform plugin; |     private final BukkitPlatform plugin; | ||||||
|  |  | ||||||
|     @Inject |     @Inject | ||||||
| @@ -45,6 +52,29 @@ public class ServerListener implements Listener { | |||||||
|             new MVdWPlaceholders(this.plugin, this.plugin.placeholderRegistry()); |             new MVdWPlaceholders(this.plugin, this.plugin.placeholderRegistry()); | ||||||
|             ConsolePlayer.getConsole().sendMessage(TranslatableCaption.of("placeholder.hooked")); |             ConsolePlayer.getConsole().sendMessage(TranslatableCaption.of("placeholder.hooked")); | ||||||
|         } |         } | ||||||
|  |         if (Settings.Enabled_Components.ECONOMY && Bukkit.getPluginManager().isPluginEnabled("Vault")) { | ||||||
|  |             EconHandler econHandler = new BukkitEconHandler(); | ||||||
|  |             try { | ||||||
|  |                 if (!econHandler.init()) { | ||||||
|  |                     LOGGER.warn("Economy is enabled but no plugin is providing an economy service. Falling back..."); | ||||||
|  |                     econHandler = EconHandler.nullEconHandler(); | ||||||
|  |                 } | ||||||
|  |             } catch (final Exception ignored) { | ||||||
|  |                 econHandler = EconHandler.nullEconHandler(); | ||||||
|  |             } | ||||||
|  |             if (PlotSquared.platform().econHandler() instanceof MutableEconHandler meh) { | ||||||
|  |                 meh.setImplementation(econHandler); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Internal use only. Required to implement lazy econ loading using Guice. | ||||||
|  |      * | ||||||
|  |      * @since 7.2.0 | ||||||
|  |      */ | ||||||
|  |     public interface MutableEconHandler { | ||||||
|  |         void setImplementation(EconHandler econHandler); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -31,45 +31,39 @@ import org.bukkit.event.Listener; | |||||||
| import org.bukkit.event.world.ChunkEvent; | import org.bukkit.event.world.ChunkEvent; | ||||||
| import org.bukkit.event.world.ChunkLoadEvent; | import org.bukkit.event.world.ChunkLoadEvent; | ||||||
|  |  | ||||||
| import java.lang.reflect.Field; |  | ||||||
| import java.lang.reflect.Method; | import java.lang.reflect.Method; | ||||||
|  |  | ||||||
| import static com.plotsquared.core.util.ReflectionUtils.getRefClass; | import static com.plotsquared.core.util.ReflectionUtils.getRefClass; | ||||||
|  |  | ||||||
| public class SingleWorldListener implements Listener { | public class SingleWorldListener implements Listener { | ||||||
|  |  | ||||||
|     private final Method methodGetHandleChunk; |     private final Method methodSetUnsaved; | ||||||
|     private Field shouldSave = null; |     private Method methodGetHandleChunk; | ||||||
|  |     private Object objChunkStatusFull = null; | ||||||
|  |  | ||||||
|     public SingleWorldListener() throws Exception { |     public SingleWorldListener() throws Exception { | ||||||
|         ReflectionUtils.RefClass classCraftChunk = getRefClass("{cb}.CraftChunk"); |         ReflectionUtils.RefClass classCraftChunk = getRefClass("{cb}.CraftChunk"); | ||||||
|         this.methodGetHandleChunk = classCraftChunk.getMethod("getHandle").getRealMethod(); |         ReflectionUtils.RefClass classChunkAccess = getRefClass("net.minecraft.world.level.chunk.IChunkAccess"); | ||||||
|  |         this.methodSetUnsaved = classChunkAccess.getMethod("a", boolean.class).getRealMethod(); | ||||||
|         try { |         try { | ||||||
|             if (PlotSquared.platform().serverVersion()[1] < 17) { |             this.methodGetHandleChunk = classCraftChunk.getMethod("getHandle").getRealMethod(); | ||||||
|                 ReflectionUtils.RefClass classChunk = getRefClass("{nms}.Chunk"); |         } catch (NoSuchMethodException ignored) { | ||||||
|                 if (PlotSquared.platform().serverVersion()[1] == 13) { |             try { | ||||||
|                     this.shouldSave = classChunk.getField("mustSave").getRealField(); |                 ReflectionUtils.RefClass classChunkStatus = getRefClass("net.minecraft.world.level.chunk.ChunkStatus"); | ||||||
|                 } else { |                 this.objChunkStatusFull = classChunkStatus.getRealClass().getField("n").get(null); | ||||||
|                     this.shouldSave = classChunk.getField("s").getRealField(); |                 this.methodGetHandleChunk = classCraftChunk.getMethod("getHandle", classChunkStatus.getRealClass()).getRealMethod(); | ||||||
|  |             } catch (NoSuchMethodException ex) { | ||||||
|  |                 throw new RuntimeException(ex); | ||||||
|             } |             } | ||||||
|             } else if (PlotSquared.platform().serverVersion()[1] == 17) { |  | ||||||
|                 ReflectionUtils.RefClass classChunk = getRefClass("net.minecraft.world.level.chunk.Chunk"); |  | ||||||
|                 this.shouldSave = classChunk.getField("r").getRealField(); |  | ||||||
|             } else if (PlotSquared.platform().serverVersion()[1] == 18) { |  | ||||||
|                 ReflectionUtils.RefClass classChunk = getRefClass("net.minecraft.world.level.chunk.IChunkAccess"); |  | ||||||
|                 this.shouldSave = classChunk.getField("b").getRealField(); |  | ||||||
|             } |  | ||||||
|         } catch (NoSuchFieldException e) { |  | ||||||
|             e.printStackTrace(); |  | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public void markChunkAsClean(Chunk chunk) { |     public void markChunkAsClean(Chunk chunk) { | ||||||
|         try { |         try { | ||||||
|             Object nmsChunk = methodGetHandleChunk.invoke(chunk); |             Object nmsChunk = objChunkStatusFull != null | ||||||
|             if (shouldSave != null) { |                     ? this.methodGetHandleChunk.invoke(chunk, objChunkStatusFull) | ||||||
|                 this.shouldSave.set(nmsChunk, false); |                     : this.methodGetHandleChunk.invoke(chunk); | ||||||
|             } |             methodSetUnsaved.invoke(nmsChunk, false); | ||||||
|         } catch (Throwable e) { |         } catch (Throwable e) { | ||||||
|             e.printStackTrace(); |             e.printStackTrace(); | ||||||
|         } |         } | ||||||
| @@ -85,7 +79,12 @@ public class SingleWorldListener implements Listener { | |||||||
|         if (!SinglePlotArea.isSinglePlotWorld(name)) { |         if (!SinglePlotArea.isSinglePlotWorld(name)) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|  |         int x = event.getChunk().getX(); | ||||||
|  |         int z = event.getChunk().getZ(); | ||||||
|  |         if (x < 16 && x > -16 && z < 16 && z > -16) { | ||||||
|  |             // Allow spawn to generate | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|         markChunkAsClean(event.getChunk()); |         markChunkAsClean(event.getChunk()); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -96,7 +95,8 @@ public class SingleWorldListener implements Listener { | |||||||
|  |  | ||||||
|     @EventHandler(priority = EventPriority.LOWEST) |     @EventHandler(priority = EventPriority.LOWEST) | ||||||
|     public void onChunkLoad(ChunkLoadEvent event) { |     public void onChunkLoad(ChunkLoadEvent event) { | ||||||
|         handle(event); |         // disable this for now, should address https://github.com/IntellectualSites/PlotSquared/issues/4413 | ||||||
|  |         // handle(event); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -0,0 +1,57 @@ | |||||||
|  | /* | ||||||
|  |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  |  * | ||||||
|  |  * This program is free software: you can redistribute it and/or modify | ||||||
|  |  * it under the terms of the GNU General Public License as published by | ||||||
|  |  * the Free Software Foundation, either version 3 of the License, or | ||||||
|  |  * (at your option) any later version. | ||||||
|  |  * | ||||||
|  |  * This program is distributed in the hope that it will be useful, | ||||||
|  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||||
|  |  * GNU General Public License for more details. | ||||||
|  |  * | ||||||
|  |  * You should have received a copy of the GNU General Public License | ||||||
|  |  * along with this program.  If not, see <https://www.gnu.org/licenses/>. | ||||||
|  |  */ | ||||||
|  | package com.plotsquared.bukkit.listener; | ||||||
|  |  | ||||||
|  | import com.plotsquared.bukkit.util.BukkitUtil; | ||||||
|  | import com.plotsquared.core.location.Location; | ||||||
|  | import com.plotsquared.core.plot.Plot; | ||||||
|  | import com.plotsquared.core.plot.flag.FlagContainer; | ||||||
|  | import com.plotsquared.core.plot.flag.implementations.BeaconEffectsFlag; | ||||||
|  | import org.bukkit.entity.Entity; | ||||||
|  | import org.bukkit.event.EventHandler; | ||||||
|  | import org.bukkit.event.Listener; | ||||||
|  | import org.bukkit.event.entity.EntityPotionEffectEvent; | ||||||
|  | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Fallback listener for paper events on spigot | ||||||
|  |  */ | ||||||
|  | public class SpigotListener implements Listener { | ||||||
|  |  | ||||||
|  |     @EventHandler(ignoreCancelled = true) | ||||||
|  |     public void onEffect(@NonNull EntityPotionEffectEvent event) { | ||||||
|  |         if (event.getCause() != EntityPotionEffectEvent.Cause.BEACON) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         Entity entity = event.getEntity(); | ||||||
|  |         Location location = BukkitUtil.adapt(entity.getLocation()); | ||||||
|  |         Plot plot = location.getPlot(); | ||||||
|  |         if (plot == null) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         FlagContainer container = plot.getFlagContainer(); | ||||||
|  |         BeaconEffectsFlag effectsEnabled = container.getFlag(BeaconEffectsFlag.class); | ||||||
|  |         if (effectsEnabled != null && !effectsEnabled.getValue()) { | ||||||
|  |             event.setCancelled(true); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -1,63 +0,0 @@ | |||||||
| /* |  | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  | ||||||
|  * |  | ||||||
|  * This program is free software: you can redistribute it and/or modify |  | ||||||
|  * it under the terms of the GNU General Public License as published by |  | ||||||
|  * the Free Software Foundation, either version 3 of the License, or |  | ||||||
|  * (at your option) any later version. |  | ||||||
|  * |  | ||||||
|  * This program is distributed in the hope that it will be useful, |  | ||||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of |  | ||||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the |  | ||||||
|  * GNU General Public License for more details. |  | ||||||
|  * |  | ||||||
|  * You should have received a copy of the GNU General Public License |  | ||||||
|  * along with this program.  If not, see <https://www.gnu.org/licenses/>. |  | ||||||
|  */ |  | ||||||
| package com.plotsquared.bukkit.managers; |  | ||||||
|  |  | ||||||
| /* |  | ||||||
| import com.google.inject.Singleton; |  | ||||||
| import org.bukkit.World; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; |  | ||||||
| import org.checkerframework.checker.nullness.qual.Nullable; |  | ||||||
| import se.hyperver.hyperverse.Hyperverse; |  | ||||||
| import se.hyperver.hyperverse.world.WorldConfiguration; |  | ||||||
| import se.hyperver.hyperverse.world.WorldConfigurationBuilder; |  | ||||||
| import se.hyperver.hyperverse.world.WorldFeatures; |  | ||||||
| import se.hyperver.hyperverse.world.WorldType; |  | ||||||
|  |  | ||||||
| Hyperverse implementation is currently put on ice until Hyperverse is released on a stable line and deployed to the central |  | ||||||
| repository. |  | ||||||
|  |  | ||||||
| @Singleton |  | ||||||
| public class HyperverseWorldManager extends BukkitWorldManager { |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public @Nullable World handleWorldCreation(@NonNull String worldName, @Nullable String generator) { |  | ||||||
|         // First let Bukkit register the world |  | ||||||
|         this.setGenerator(worldName, generator); |  | ||||||
|         // Create the world |  | ||||||
|         final WorldConfigurationBuilder worldConfigurationBuilder = WorldConfiguration.builder() |  | ||||||
|                 .setName(worldName).setType(WorldType.OVER_WORLD); |  | ||||||
|         if (generator != null) { |  | ||||||
|             worldConfigurationBuilder.setGenerator(generator).setWorldFeatures(WorldFeatures.FLATLAND); |  | ||||||
|         } |  | ||||||
|         try { |  | ||||||
|             return Hyperverse.getApi().createWorld(worldConfigurationBuilder.createWorldConfiguration()) |  | ||||||
|                     .getBukkitWorld(); |  | ||||||
|         } catch (final Exception e) { |  | ||||||
|             e.printStackTrace(); |  | ||||||
|         } |  | ||||||
|         return null; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public String getName() { |  | ||||||
|         return "bukkit-hyperverse"; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } |  | ||||||
|  */ |  | ||||||
| @@ -30,8 +30,9 @@ import org.checkerframework.checker.nullness.qual.Nullable; | |||||||
|  * |  * | ||||||
|  * @deprecated Deprecated and scheduled for removal without replacement |  * @deprecated Deprecated and scheduled for removal without replacement | ||||||
|  *         in favor of the build in setup wizard. |  *         in favor of the build in setup wizard. | ||||||
|  |  *         However, this class will be kept around for a while, given it's not a maintenance burden. | ||||||
|  */ |  */ | ||||||
| @Deprecated(forRemoval = true, since = "6.0.0") | @Deprecated | ||||||
| @Singleton | @Singleton | ||||||
| public class MultiverseWorldManager extends BukkitWorldManager { | public class MultiverseWorldManager extends BukkitWorldManager { | ||||||
|  |  | ||||||
|   | |||||||
| @@ -52,7 +52,7 @@ public class MVdWPlaceholders { | |||||||
|  |  | ||||||
|     @Subscribe |     @Subscribe | ||||||
|     public void onNewPlaceholder(final PlaceholderRegistry.@NonNull PlaceholderAddedEvent event) { |     public void onNewPlaceholder(final PlaceholderRegistry.@NonNull PlaceholderAddedEvent event) { | ||||||
|         this.addPlaceholder(event.getPlaceholder()); |         this.addPlaceholder(event.placeholder()); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private void addPlaceholder(final @NonNull Placeholder placeholder) { |     private void addPlaceholder(final @NonNull Placeholder placeholder) { | ||||||
|   | |||||||
| @@ -20,6 +20,8 @@ package com.plotsquared.bukkit.placeholder; | |||||||
|  |  | ||||||
| import com.plotsquared.core.PlotSquared; | import com.plotsquared.core.PlotSquared; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
|  | import com.plotsquared.core.plot.flag.implementations.DoneFlag; | ||||||
|  | import com.plotsquared.core.util.query.PlotQuery; | ||||||
| import me.clip.placeholderapi.PlaceholderAPIPlugin; | import me.clip.placeholderapi.PlaceholderAPIPlugin; | ||||||
| import me.clip.placeholderapi.expansion.PlaceholderExpansion; | import me.clip.placeholderapi.expansion.PlaceholderExpansion; | ||||||
| import org.bukkit.entity.Player; | import org.bukkit.entity.Player; | ||||||
| @@ -83,6 +85,20 @@ public class PAPIPlaceholders extends PlaceholderExpansion { | |||||||
|             return String.valueOf(pl.getPlotCount(identifier)); |             return String.valueOf(pl.getPlotCount(identifier)); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |         if (identifier.startsWith("base_plot_count_")) { | ||||||
|  |             identifier = identifier.substring("base_plot_count_".length()); | ||||||
|  |             if (identifier.isEmpty()) { | ||||||
|  |                 return ""; | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             return String.valueOf(PlotQuery.newQuery() | ||||||
|  |                     .ownedBy(pl) | ||||||
|  |                     .inWorld(identifier) | ||||||
|  |                     .whereBasePlot() | ||||||
|  |                     .thatPasses(plot -> !DoneFlag.isDone(plot)) | ||||||
|  |                     .count()); | ||||||
|  |         } | ||||||
|  |  | ||||||
|         // PlotSquared placeholders |         // PlotSquared placeholders | ||||||
|         return PlotSquared.platform().placeholderRegistry().getPlaceholderValue(identifier, pl); |         return PlotSquared.platform().placeholderRegistry().getPlaceholderValue(identifier, pl); | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -87,4 +87,9 @@ public class BukkitOfflinePlayer implements OfflinePlotPlayer { | |||||||
|         ); |         ); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public boolean hasPermission(@NonNull final String permission, final boolean notify) { | ||||||
|  |         return hasPermission(permission); | ||||||
|  |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -32,6 +32,7 @@ import com.plotsquared.core.plot.PlotWeather; | |||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
| import com.plotsquared.core.util.EventDispatcher; | import com.plotsquared.core.util.EventDispatcher; | ||||||
| import com.plotsquared.core.util.MathMan; | import com.plotsquared.core.util.MathMan; | ||||||
|  | import com.plotsquared.core.util.WorldUtil; | ||||||
| import com.sk89q.worldedit.bukkit.BukkitAdapter; | import com.sk89q.worldedit.bukkit.BukkitAdapter; | ||||||
| import com.sk89q.worldedit.extension.platform.Actor; | import com.sk89q.worldedit.extension.platform.Actor; | ||||||
| import com.sk89q.worldedit.world.item.ItemType; | import com.sk89q.worldedit.world.item.ItemType; | ||||||
| @@ -40,6 +41,7 @@ import io.papermc.lib.PaperLib; | |||||||
| import net.kyori.adventure.audience.Audience; | import net.kyori.adventure.audience.Audience; | ||||||
| import org.bukkit.GameMode; | import org.bukkit.GameMode; | ||||||
| import org.bukkit.Sound; | import org.bukkit.Sound; | ||||||
|  | import org.bukkit.SoundCategory; | ||||||
| import org.bukkit.WeatherType; | import org.bukkit.WeatherType; | ||||||
| import org.bukkit.entity.Player; | import org.bukkit.entity.Player; | ||||||
| import org.bukkit.event.Event; | import org.bukkit.event.Event; | ||||||
| @@ -47,13 +49,12 @@ import org.bukkit.event.EventException; | |||||||
| import org.bukkit.event.player.PlayerTeleportEvent; | import org.bukkit.event.player.PlayerTeleportEvent; | ||||||
| import org.bukkit.permissions.PermissionAttachmentInfo; | import org.bukkit.permissions.PermissionAttachmentInfo; | ||||||
| import org.bukkit.plugin.RegisteredListener; | import org.bukkit.plugin.RegisteredListener; | ||||||
|  | import org.bukkit.potion.PotionEffectType; | ||||||
| import org.checkerframework.checker.index.qual.NonNegative; | import org.checkerframework.checker.index.qual.NonNegative; | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.util.Arrays; |  | ||||||
| import java.util.Set; | import java.util.Set; | ||||||
| import java.util.UUID; | import java.util.UUID; | ||||||
| import java.util.stream.Collectors; |  | ||||||
|  |  | ||||||
| import static com.sk89q.worldedit.world.gamemode.GameModes.ADVENTURE; | import static com.sk89q.worldedit.world.gamemode.GameModes.ADVENTURE; | ||||||
| import static com.sk89q.worldedit.world.gamemode.GameModes.CREATIVE; | import static com.sk89q.worldedit.world.gamemode.GameModes.CREATIVE; | ||||||
| @@ -67,24 +68,15 @@ public class BukkitPlayer extends PlotPlayer<Player> { | |||||||
|     private String name; |     private String name; | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * <p>Please do not use this method. Instead use |  | ||||||
|      * BukkitUtil.getPlayer(Player), as it caches player objects.</p> |  | ||||||
|      * |  | ||||||
|      * @param plotAreaManager   PlotAreaManager instance |      * @param plotAreaManager   PlotAreaManager instance | ||||||
|      * @param eventDispatcher   EventDispatcher instance |      * @param eventDispatcher   EventDispatcher instance | ||||||
|      * @param player            Bukkit player instance |      * @param player            Bukkit player instance | ||||||
|      * @param permissionHandler PermissionHandler instance |      * @param permissionHandler PermissionHandler instance | ||||||
|      */ |      */ | ||||||
|     public BukkitPlayer( |     BukkitPlayer( | ||||||
|             final @NonNull PlotAreaManager plotAreaManager, final @NonNull EventDispatcher eventDispatcher, |             final @NonNull PlotAreaManager plotAreaManager, | ||||||
|             final @NonNull Player player, final @NonNull PermissionHandler permissionHandler |             final @NonNull EventDispatcher eventDispatcher, | ||||||
|     ) { |             final @NonNull Player player, | ||||||
|         this(plotAreaManager, eventDispatcher, player, false, permissionHandler); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public BukkitPlayer( |  | ||||||
|             final @NonNull PlotAreaManager plotAreaManager, final @NonNull |  | ||||||
|             EventDispatcher eventDispatcher, final @NonNull Player player, |  | ||||||
|             final boolean realPlayer, |             final boolean realPlayer, | ||||||
|             final @NonNull PermissionHandler permissionHandler |             final @NonNull PermissionHandler permissionHandler | ||||||
|     ) { |     ) { | ||||||
| @@ -129,6 +121,9 @@ public class BukkitPlayer extends PlotPlayer<Player> { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean canTeleport(final @NonNull Location location) { |     public boolean canTeleport(final @NonNull Location location) { | ||||||
|  |         if (!WorldUtil.isValidLocation(location)) { | ||||||
|  |             return false; | ||||||
|  |         } | ||||||
|         final org.bukkit.Location to = BukkitUtil.adapt(location); |         final org.bukkit.Location to = BukkitUtil.adapt(location); | ||||||
|         final org.bukkit.Location from = player.getLocation(); |         final org.bukkit.Location from = player.getLocation(); | ||||||
|         PlayerTeleportEvent event = new PlayerTeleportEvent(player, from, to); |         PlayerTeleportEvent event = new PlayerTeleportEvent(player, from, to); | ||||||
| @@ -167,6 +162,7 @@ public class BukkitPlayer extends PlotPlayer<Player> { | |||||||
|         } |         } | ||||||
|         final String[] nodes = stub.split("\\."); |         final String[] nodes = stub.split("\\."); | ||||||
|         final StringBuilder n = new StringBuilder(); |         final StringBuilder n = new StringBuilder(); | ||||||
|  |         // Wildcard check from less specific permission to more specific permission | ||||||
|         for (int i = 0; i < (nodes.length - 1); i++) { |         for (int i = 0; i < (nodes.length - 1); i++) { | ||||||
|             n.append(nodes[i]).append("."); |             n.append(nodes[i]).append("."); | ||||||
|             if (!stub.equals(n + Permission.PERMISSION_STAR.toString())) { |             if (!stub.equals(n + Permission.PERMISSION_STAR.toString())) { | ||||||
| @@ -175,9 +171,11 @@ public class BukkitPlayer extends PlotPlayer<Player> { | |||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |         // Wildcard check for the full permission | ||||||
|         if (hasPermission(stub + ".*")) { |         if (hasPermission(stub + ".*")) { | ||||||
|             return Integer.MAX_VALUE; |             return Integer.MAX_VALUE; | ||||||
|         } |         } | ||||||
|  |         // Permission value cache for iterative check | ||||||
|         int max = 0; |         int max = 0; | ||||||
|         if (CHECK_EFFECTIVE) { |         if (CHECK_EFFECTIVE) { | ||||||
|             boolean hasAny = false; |             boolean hasAny = false; | ||||||
| @@ -185,6 +183,10 @@ public class BukkitPlayer extends PlotPlayer<Player> { | |||||||
|             final Set<PermissionAttachmentInfo> effective = player.getEffectivePermissions(); |             final Set<PermissionAttachmentInfo> effective = player.getEffectivePermissions(); | ||||||
|             if (!effective.isEmpty()) { |             if (!effective.isEmpty()) { | ||||||
|                 for (PermissionAttachmentInfo attach : effective) { |                 for (PermissionAttachmentInfo attach : effective) { | ||||||
|  |                     // Ignore all "false" permissions | ||||||
|  |                     if (!attach.getValue()) { | ||||||
|  |                         continue; | ||||||
|  |                     } | ||||||
|                     String permStr = attach.getPermission(); |                     String permStr = attach.getPermission(); | ||||||
|                     if (permStr.startsWith(stubPlus)) { |                     if (permStr.startsWith(stubPlus)) { | ||||||
|                         hasAny = true; |                         hasAny = true; | ||||||
| @@ -223,7 +225,7 @@ public class BukkitPlayer extends PlotPlayer<Player> { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public void teleport(final @NonNull Location location, final @NonNull TeleportCause cause) { |     public void teleport(final @NonNull Location location, final @NonNull TeleportCause cause) { | ||||||
|         if (Math.abs(location.getX()) >= 30000000 || Math.abs(location.getZ()) >= 30000000) { |         if (!WorldUtil.isValidLocation(location)) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         final org.bukkit.Location bukkitLocation = |         final org.bukkit.Location bukkitLocation = | ||||||
| @@ -311,19 +313,22 @@ public class BukkitPlayer extends PlotPlayer<Player> { | |||||||
|     @Override |     @Override | ||||||
|     public void playMusic(final @NonNull Location location, final @NonNull ItemType id) { |     public void playMusic(final @NonNull Location location, final @NonNull ItemType id) { | ||||||
|         if (id == ItemTypes.AIR) { |         if (id == ItemTypes.AIR) { | ||||||
|             // Let's just stop all the discs because why not? |             if (PlotSquared.platform().serverVersion()[1] >= 19) { | ||||||
|             for (final Sound sound : Arrays.stream(Sound.values()) |                 player.stopSound(SoundCategory.MUSIC); | ||||||
|                     .filter(sound -> sound.name().contains("DISC")).toList()) { |                 return; | ||||||
|                 player.stopSound(sound); |  | ||||||
|             } |             } | ||||||
|             // this.player.playEffect(BukkitUtil.getLocation(location), Effect.RECORD_PLAY, Material.AIR); |             // 1.18 and downwards require a specific Sound to stop (even tho the packet does not??) | ||||||
|         } else { |             for (final Sound sound : Sound.values()) { | ||||||
|             // this.player.playEffect(BukkitUtil.getLocation(location), Effect.RECORD_PLAY, id.to(Material.class)); |                 if (sound.name().startsWith("MUSIC_DISC")) { | ||||||
|             this.player.playSound(BukkitUtil.adapt(location), |                     this.player.stopSound(sound, SoundCategory.MUSIC); | ||||||
|                     Sound.valueOf(BukkitAdapter.adapt(id).name()), Float.MAX_VALUE, 1f |                 } | ||||||
|  |             } | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |         this.player.playSound(BukkitUtil.adapt(location), Sound.valueOf(BukkitAdapter.adapt(id).name()), | ||||||
|  |                 SoundCategory.MUSIC, Float.MAX_VALUE, 1f | ||||||
|         ); |         ); | ||||||
|     } |     } | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @SuppressWarnings("deprecation") // Needed for Spigot compatibility |     @SuppressWarnings("deprecation") // Needed for Spigot compatibility | ||||||
|     @Override |     @Override | ||||||
| @@ -348,6 +353,14 @@ public class BukkitPlayer extends PlotPlayer<Player> { | |||||||
|         return BukkitUtil.BUKKIT_AUDIENCES.player(this.player); |         return BukkitUtil.BUKKIT_AUDIENCES.player(this.player); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public void removeEffect(@NonNull String name) { | ||||||
|  |         PotionEffectType type = PotionEffectType.getByName(name); | ||||||
|  |         if (type != null) { | ||||||
|  |             player.removePotionEffect(type); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean canSee(final PlotPlayer<?> other) { |     public boolean canSee(final PlotPlayer<?> other) { | ||||||
|         if (other instanceof ConsolePlayer) { |         if (other instanceof ConsolePlayer) { | ||||||
|   | |||||||
| @@ -70,7 +70,7 @@ public class BukkitPlayerManager extends PlayerManager<BukkitPlayer, Player> { | |||||||
|         if (player == null || !player.isOnline()) { |         if (player == null || !player.isOnline()) { | ||||||
|             throw new NoSuchPlayerException(uuid); |             throw new NoSuchPlayerException(uuid); | ||||||
|         } |         } | ||||||
|         return new BukkitPlayer(this.plotAreaManager, this.eventDispatcher, player, this.permissionHandler); |         return new BukkitPlayer(this.plotAreaManager, this.eventDispatcher, player, false, this.permissionHandler); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Nullable |     @Nullable | ||||||
|   | |||||||
| @@ -239,9 +239,11 @@ public final class BukkitChunkCoordinator extends ChunkCoordinator { | |||||||
|      * server's main thread. |      * server's main thread. | ||||||
|      */ |      */ | ||||||
|     private void processChunk(final @NonNull Chunk chunk) { |     private void processChunk(final @NonNull Chunk chunk) { | ||||||
|  |         /* Chunk#isLoaded does not necessarily return true shortly after PaperLib#getChunkAtAsync completes, but the chunk is | ||||||
|  |         still loaded. | ||||||
|         if (!chunk.isLoaded()) { |         if (!chunk.isLoaded()) { | ||||||
|             throw new IllegalArgumentException(String.format("Chunk %d;%d is is not loaded", chunk.getX(), chunk.getZ())); |             throw new IllegalArgumentException(String.format("Chunk %d;%d is is not loaded", chunk.getX(), chunk.getZ()); | ||||||
|         } |         }*/ | ||||||
|         if (finished) { |         if (finished) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -19,12 +19,12 @@ | |||||||
| package com.plotsquared.bukkit.queue; | package com.plotsquared.bukkit.queue; | ||||||
|  |  | ||||||
| import com.google.common.base.Preconditions; | import com.google.common.base.Preconditions; | ||||||
|  | import com.intellectualsites.annotations.DoNotUse; | ||||||
| import com.plotsquared.bukkit.util.BukkitBlockUtil; | import com.plotsquared.bukkit.util.BukkitBlockUtil; | ||||||
| import com.plotsquared.bukkit.util.BukkitUtil; | import com.plotsquared.bukkit.util.BukkitUtil; | ||||||
| import com.plotsquared.core.location.ChunkWrapper; | import com.plotsquared.core.location.ChunkWrapper; | ||||||
| import com.plotsquared.core.location.Location; | import com.plotsquared.core.location.Location; | ||||||
| import com.plotsquared.core.queue.ZeroedDelegateScopedQueueCoordinator; | import com.plotsquared.core.queue.ZeroedDelegateScopedQueueCoordinator; | ||||||
| import com.plotsquared.core.util.AnnotationHelper; |  | ||||||
| import com.plotsquared.core.util.ChunkUtil; | import com.plotsquared.core.util.ChunkUtil; | ||||||
| import com.plotsquared.core.util.PatternUtil; | import com.plotsquared.core.util.PatternUtil; | ||||||
| import com.sk89q.worldedit.bukkit.BukkitAdapter; | import com.sk89q.worldedit.bukkit.BukkitAdapter; | ||||||
| @@ -44,7 +44,10 @@ import org.checkerframework.checker.nullness.qual.Nullable; | |||||||
|  |  | ||||||
| import java.util.Arrays; | import java.util.Arrays; | ||||||
|  |  | ||||||
| @AnnotationHelper.ApiDescription(info = "Internal use only. Subject to changes at any time.") | /** | ||||||
|  |  * Internal use only. Subject to changes at any time. | ||||||
|  |  */ | ||||||
|  | @DoNotUse | ||||||
| public class GenChunk extends ZeroedDelegateScopedQueueCoordinator { | public class GenChunk extends ZeroedDelegateScopedQueueCoordinator { | ||||||
|  |  | ||||||
|     public final Biome[] biomes; |     public final Biome[] biomes; | ||||||
| @@ -59,7 +62,6 @@ public class GenChunk extends ZeroedDelegateScopedQueueCoordinator { | |||||||
|     /** |     /** | ||||||
|      * @param minY minimum world Y, inclusive |      * @param minY minimum world Y, inclusive | ||||||
|      * @param maxY maximum world Y, inclusive |      * @param maxY maximum world Y, inclusive | ||||||
|      * |  | ||||||
|      * @since 6.6.0 |      * @since 6.6.0 | ||||||
|      */ |      */ | ||||||
|     public GenChunk(int minY, int maxY) { |     public GenChunk(int minY, int maxY) { | ||||||
| @@ -107,9 +109,9 @@ public class GenChunk extends ZeroedDelegateScopedQueueCoordinator { | |||||||
|      */ |      */ | ||||||
|     public void setChunk(@NonNull ChunkWrapper wrap) { |     public void setChunk(@NonNull ChunkWrapper wrap) { | ||||||
|         chunk = null; |         chunk = null; | ||||||
|         world = wrap.world; |         world = wrap.world(); | ||||||
|         chunkX = wrap.x; |         chunkX = wrap.x(); | ||||||
|         chunkZ = wrap.z; |         chunkZ = wrap.z(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
| @@ -183,7 +185,11 @@ public class GenChunk extends ZeroedDelegateScopedQueueCoordinator { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean setBlock(int x, int y, int z, @NonNull Pattern pattern) { |     public boolean setBlock(int x, int y, int z, @NonNull Pattern pattern) { | ||||||
|         return setBlock(x, y, z, PatternUtil.apply(Preconditions.checkNotNull(pattern, "Pattern may not be null"), x, y, z)); |         final BaseBlock block = PatternUtil.apply(Preconditions.checkNotNull( | ||||||
|  |                 pattern, | ||||||
|  |                 "Pattern may not be null" | ||||||
|  |         ), x + (chunkX << 4), y, z + (chunkZ << 4)); | ||||||
|  |         return setBlock(x, y, z, block); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|   | |||||||
| @@ -44,6 +44,7 @@ public class LimitedRegionWrapperQueue extends DelegateQueueCoordinator { | |||||||
|     private static final Logger LOGGER = LogManager.getLogger("PlotSquared/" + LimitedRegionWrapperQueue.class.getSimpleName()); |     private static final Logger LOGGER = LogManager.getLogger("PlotSquared/" + LimitedRegionWrapperQueue.class.getSimpleName()); | ||||||
|  |  | ||||||
|     private final LimitedRegion limitedRegion; |     private final LimitedRegion limitedRegion; | ||||||
|  |     private boolean useOtherRestoreTagMethod = false; | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * @since 6.9.0 |      * @since 6.9.0 | ||||||
| @@ -65,10 +66,18 @@ public class LimitedRegionWrapperQueue extends DelegateQueueCoordinator { | |||||||
|             CompoundTag tag = id.getNbtData(); |             CompoundTag tag = id.getNbtData(); | ||||||
|             StateWrapper sw = new StateWrapper(tag); |             StateWrapper sw = new StateWrapper(tag); | ||||||
|             try { |             try { | ||||||
|  |                 if (useOtherRestoreTagMethod && getWorld() != null) { | ||||||
|  |                     sw.restoreTag(getWorld().getName(), x, y, z); | ||||||
|  |                 } else { | ||||||
|                     sw.restoreTag(limitedRegion.getBlockState(x, y, z).getBlock()); |                     sw.restoreTag(limitedRegion.getBlockState(x, y, z).getBlock()); | ||||||
|  |                 } | ||||||
|             } catch (IllegalArgumentException e) { |             } catch (IllegalArgumentException e) { | ||||||
|                 LOGGER.error("Error attempting to populate tile entity into the world at location {},{},{}", x, y, z, e); |                 LOGGER.error("Error attempting to populate tile entity into the world at location {},{},{}", x, y, z, e); | ||||||
|                 return false; |                 return false; | ||||||
|  |             } catch (IllegalStateException e) { | ||||||
|  |                 useOtherRestoreTagMethod = true; | ||||||
|  |                 LOGGER.warn("IllegalStateException attempting to populate tile entity into the world at location {},{},{}. " + | ||||||
|  |                         "Possibly on <=1.17.1, switching to secondary method.", x, y, z, e); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         return result; |         return result; | ||||||
|   | |||||||
| @@ -18,6 +18,8 @@ | |||||||
|  */ |  */ | ||||||
| package com.plotsquared.bukkit.schematic; | package com.plotsquared.bukkit.schematic; | ||||||
|  |  | ||||||
|  | import com.destroystokyo.paper.profile.PlayerProfile; | ||||||
|  | import com.destroystokyo.paper.profile.ProfileProperty; | ||||||
| import com.plotsquared.bukkit.util.BukkitUtil; | import com.plotsquared.bukkit.util.BukkitUtil; | ||||||
| import com.sk89q.jnbt.ByteTag; | import com.sk89q.jnbt.ByteTag; | ||||||
| import com.sk89q.jnbt.CompoundTag; | import com.sk89q.jnbt.CompoundTag; | ||||||
| @@ -28,16 +30,22 @@ import com.sk89q.jnbt.Tag; | |||||||
| import com.sk89q.worldedit.blocks.BaseItemStack; | import com.sk89q.worldedit.blocks.BaseItemStack; | ||||||
| import com.sk89q.worldedit.bukkit.BukkitAdapter; | import com.sk89q.worldedit.bukkit.BukkitAdapter; | ||||||
| import com.sk89q.worldedit.world.item.ItemType; | import com.sk89q.worldedit.world.item.ItemType; | ||||||
|  | import io.papermc.lib.PaperLib; | ||||||
|  | import org.apache.logging.log4j.LogManager; | ||||||
|  | import org.apache.logging.log4j.Logger; | ||||||
| import org.bukkit.Bukkit; | import org.bukkit.Bukkit; | ||||||
| import org.bukkit.ChatColor; | import org.bukkit.ChatColor; | ||||||
|  | import org.bukkit.DyeColor; | ||||||
| import org.bukkit.World; | import org.bukkit.World; | ||||||
|  | import org.bukkit.block.Banner; | ||||||
| import org.bukkit.block.Block; | import org.bukkit.block.Block; | ||||||
| import org.bukkit.block.Container; | import org.bukkit.block.Container; | ||||||
| import org.bukkit.block.Sign; | import org.bukkit.block.Sign; | ||||||
| import org.bukkit.block.Skull; | import org.bukkit.block.Skull; | ||||||
|  | import org.bukkit.block.banner.Pattern; | ||||||
|  | import org.bukkit.block.banner.PatternType; | ||||||
| import org.bukkit.enchantments.Enchantment; | import org.bukkit.enchantments.Enchantment; | ||||||
| import org.bukkit.inventory.Inventory; | import org.bukkit.inventory.Inventory; | ||||||
| import org.bukkit.inventory.InventoryHolder; |  | ||||||
| import org.bukkit.inventory.ItemStack; | import org.bukkit.inventory.ItemStack; | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| @@ -46,20 +54,15 @@ import java.util.HashMap; | |||||||
| import java.util.List; | import java.util.List; | ||||||
| import java.util.Map; | import java.util.Map; | ||||||
| import java.util.Map.Entry; | import java.util.Map.Entry; | ||||||
|  | import java.util.Objects; | ||||||
|  | import java.util.UUID; | ||||||
|  |  | ||||||
| public class StateWrapper { | public class StateWrapper { | ||||||
|  |  | ||||||
|     public org.bukkit.block.BlockState state = null; |     public CompoundTag tag; | ||||||
|     public CompoundTag tag = null; |  | ||||||
|  |  | ||||||
|     /** |     private boolean paperErrorTextureSent = false; | ||||||
|      * @deprecated in favour of using WE methods for obtaining NBT, specifically by obtaining a |     private static final Logger LOGGER = LogManager.getLogger("PlotSquared/" + StateWrapper.class.getSimpleName()); | ||||||
|      *         {@link com.sk89q.worldedit.world.block.BaseBlock} and then using {@link com.sk89q.worldedit.world.block.BaseBlock#getNbtData()} |  | ||||||
|      */ |  | ||||||
|     @Deprecated(forRemoval = true, since = "6.9.0") |  | ||||||
|     public StateWrapper(org.bukkit.block.BlockState state) { |  | ||||||
|         this.state = state; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public StateWrapper(CompoundTag tag) { |     public StateWrapper(CompoundTag tag) { | ||||||
|         this.tag = tag; |         this.tag = tag; | ||||||
| @@ -237,9 +240,8 @@ public class StateWrapper { | |||||||
|                         return true; |                         return true; | ||||||
|                     } |                     } | ||||||
|                     String player = skullOwner.getString("Name"); |                     String player = skullOwner.getString("Name"); | ||||||
|                     if (player == null || player.isEmpty()) { |  | ||||||
|                         return false; |                     if (player != null && !player.isEmpty()) { | ||||||
|                     } |  | ||||||
|                         try { |                         try { | ||||||
|                             skull.setOwningPlayer(Bukkit.getOfflinePlayer(player)); |                             skull.setOwningPlayer(Bukkit.getOfflinePlayer(player)); | ||||||
|                             skull.update(true); |                             skull.update(true); | ||||||
| @@ -248,31 +250,61 @@ public class StateWrapper { | |||||||
|                         } |                         } | ||||||
|                         return true; |                         return true; | ||||||
|                     } |                     } | ||||||
|                 return false; |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         return false; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |                     final CompoundTag properties = (CompoundTag) skullOwner.getValue().get("Properties"); | ||||||
|      * Get a CompoundTag of the contents of a block's inventory (chest, furnace, etc.). |                     if (properties == null) { | ||||||
|      * |                         return false; | ||||||
|      * @deprecated in favour of using WorldEdit methods for obtaining NBT, specifically by obtaining a |  | ||||||
|      *         {@link com.sk89q.worldedit.world.block.BaseBlock} and then using {@link com.sk89q.worldedit.world.block.BaseBlock#getNbtData()} |  | ||||||
|      */ |  | ||||||
|     @Deprecated(forRemoval = true, since = "6.9.0") |  | ||||||
|     public CompoundTag getTag() { |  | ||||||
|         if (this.tag != null) { |  | ||||||
|             return this.tag; |  | ||||||
|                     } |                     } | ||||||
|         if (this.state instanceof InventoryHolder inv) { |                     final ListTag textures = properties.getListTag("textures"); | ||||||
|             ItemStack[] contents = inv.getInventory().getContents(); |                     if (textures.getValue().isEmpty()) { | ||||||
|             Map<String, Tag> values = new HashMap<>(); |                         return false; | ||||||
|             values.put("Items", new ListTag(CompoundTag.class, serializeInventory(contents))); |  | ||||||
|             return new CompoundTag(values); |  | ||||||
|                     } |                     } | ||||||
|  |                     final CompoundTag textureCompound = (CompoundTag) textures.getValue().get(0); | ||||||
|  |                     if (textureCompound == null) { | ||||||
|  |                         return false; | ||||||
|  |                     } | ||||||
|  |                     String textureValue = textureCompound.getString("Value"); | ||||||
|  |                     if (textureValue == null) { | ||||||
|  |                         return false; | ||||||
|  |                     } | ||||||
|  |                     if (!PaperLib.isPaper()) { | ||||||
|  |                         if (!paperErrorTextureSent) { | ||||||
|  |                             paperErrorTextureSent = true; | ||||||
|  |                             LOGGER.error("Failed to populate skull data in your road schematic - This is a Spigot limitation."); | ||||||
|  |                         } | ||||||
|  |                         return false; | ||||||
|  |                     } | ||||||
|  |                     final PlayerProfile profile = Bukkit.createProfile(UUID.randomUUID()); | ||||||
|  |                     profile.setProperty(new ProfileProperty("textures", textureValue)); | ||||||
|  |                     skull.setPlayerProfile(profile); | ||||||
|  |                     skull.update(true); | ||||||
|  |                     return true; | ||||||
|  |  | ||||||
|  |                 } | ||||||
|  |                 return false; | ||||||
|  |             } | ||||||
|  |             case "banner" -> { | ||||||
|  |                 if (state instanceof Banner banner) { | ||||||
|  |                     List<Tag> patterns = this.tag.getListTag("Patterns").getValue(); | ||||||
|  |                     if (patterns == null || patterns.isEmpty()) { | ||||||
|  |                         return false; | ||||||
|  |                     } | ||||||
|  |                     banner.setPatterns(patterns.stream().map(t -> (CompoundTag) t).map(compoundTag -> { | ||||||
|  |                         DyeColor color = DyeColor.getByWoolData((byte) compoundTag.getInt("Color")); | ||||||
|  |                         PatternType patternType = PatternType.getByIdentifier(compoundTag.getString("Pattern")); | ||||||
|  |                         if (color == null || patternType == null) { | ||||||
|                             return null; |                             return null; | ||||||
|                         } |                         } | ||||||
|  |                         return new Pattern(color, patternType); | ||||||
|  |                     }).filter(Objects::nonNull).toList()); | ||||||
|  |                     banner.update(true); | ||||||
|  |                     return true; | ||||||
|  |                 } | ||||||
|  |                 return false; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         return false; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     public String getId() { |     public String getId() { | ||||||
|         String tileid = this.tag.getString("id").toLowerCase(); |         String tileid = this.tag.getString("id").toLowerCase(); | ||||||
|   | |||||||
| @@ -40,7 +40,6 @@ import com.plotsquared.core.plot.flag.implementations.PvpFlag; | |||||||
| import com.plotsquared.core.plot.flag.implementations.TamedAttackFlag; | import com.plotsquared.core.plot.flag.implementations.TamedAttackFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.VehicleCapFlag; | import com.plotsquared.core.plot.flag.implementations.VehicleCapFlag; | ||||||
| import com.plotsquared.core.util.EntityUtil; | import com.plotsquared.core.util.EntityUtil; | ||||||
| import com.plotsquared.core.util.Permissions; |  | ||||||
| import com.plotsquared.core.util.entity.EntityCategories; | import com.plotsquared.core.util.entity.EntityCategories; | ||||||
| import com.sk89q.worldedit.bukkit.BukkitAdapter; | import com.sk89q.worldedit.bukkit.BukkitAdapter; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| @@ -170,8 +169,7 @@ public class BukkitEntityUtil { | |||||||
|                 if (plot != null && (plot.getFlag(HangingBreakFlag.class) || plot |                 if (plot != null && (plot.getFlag(HangingBreakFlag.class) || plot | ||||||
|                         .isAdded(plotPlayer.getUUID()))) { |                         .isAdded(plotPlayer.getUUID()))) { | ||||||
|                     if (Settings.Done.RESTRICT_BUILDING && DoneFlag.isDone(plot)) { |                     if (Settings.Done.RESTRICT_BUILDING && DoneFlag.isDone(plot)) { | ||||||
|                         if (!Permissions |                         if (!plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_BUILD_OTHER)) { | ||||||
|                                 .hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_BUILD_OTHER)) { |  | ||||||
|                             plotPlayer.sendMessage( |                             plotPlayer.sendMessage( | ||||||
|                                     TranslatableCaption.of("done.building_restricted") |                                     TranslatableCaption.of("done.building_restricted") | ||||||
|                             ); |                             ); | ||||||
| @@ -180,7 +178,7 @@ public class BukkitEntityUtil { | |||||||
|                     } |                     } | ||||||
|                     return true; |                     return true; | ||||||
|                 } |                 } | ||||||
|                 if (!Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_DESTROY + "." + stub)) { |                 if (!plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_DESTROY + "." + stub)) { | ||||||
|                     plotPlayer.sendMessage( |                     plotPlayer.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             TagResolver.resolver( | ||||||
| @@ -195,7 +193,7 @@ public class BukkitEntityUtil { | |||||||
|                         .isAdded(plotPlayer.getUUID()))) { |                         .isAdded(plotPlayer.getUUID()))) { | ||||||
|                     return true; |                     return true; | ||||||
|                 } |                 } | ||||||
|                 if (!Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_DESTROY + "." + stub)) { |                 if (!plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_DESTROY + "." + stub)) { | ||||||
|                     plotPlayer.sendMessage( |                     plotPlayer.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             TagResolver.resolver( | ||||||
| @@ -219,7 +217,7 @@ public class BukkitEntityUtil { | |||||||
|                         .getFlag(PveFlag.class))) { |                         .getFlag(PveFlag.class))) { | ||||||
|                     return true; |                     return true; | ||||||
|                 } |                 } | ||||||
|                 if (!Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_PVE + "." + stub)) { |                 if (!plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_PVE + "." + stub)) { | ||||||
|                     plotPlayer.sendMessage( |                     plotPlayer.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             TagResolver.resolver( | ||||||
| @@ -243,7 +241,7 @@ public class BukkitEntityUtil { | |||||||
|                         .getFlag(PveFlag.class))) { |                         .getFlag(PveFlag.class))) { | ||||||
|                     return true; |                     return true; | ||||||
|                 } |                 } | ||||||
|                 if (!Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_PVE + "." + stub)) { |                 if (!plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_PVE + "." + stub)) { | ||||||
|                     plotPlayer.sendMessage( |                     plotPlayer.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             TagResolver.resolver( | ||||||
| @@ -259,8 +257,7 @@ public class BukkitEntityUtil { | |||||||
|                 } |                 } | ||||||
|             } else if (EntityCategories.PLAYER.contains(entityType)) { |             } else if (EntityCategories.PLAYER.contains(entityType)) { | ||||||
|                 if (isPlot) { |                 if (isPlot) { | ||||||
|                     if (!plot.getFlag(PvpFlag.class) && !Permissions |                     if (!plot.getFlag(PvpFlag.class) && !plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_PVP + "." + stub)) { | ||||||
|                             .hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_PVP + "." + stub)) { |  | ||||||
|                         plotPlayer.sendMessage( |                         plotPlayer.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission_event"), |                                 TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                                 TagResolver.resolver( |                                 TagResolver.resolver( | ||||||
| @@ -277,7 +274,7 @@ public class BukkitEntityUtil { | |||||||
|                 } else if (roadFlags && area.getRoadFlag(PvpFlag.class)) { |                 } else if (roadFlags && area.getRoadFlag(PvpFlag.class)) { | ||||||
|                     return true; |                     return true; | ||||||
|                 } |                 } | ||||||
|                 if (!Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_PVP + "." + stub)) { |                 if (!plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_PVP + "." + stub)) { | ||||||
|                     plotPlayer.sendMessage( |                     plotPlayer.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             TagResolver.resolver( | ||||||
| @@ -297,7 +294,7 @@ public class BukkitEntityUtil { | |||||||
|                         .getFlag(PveFlag.class))) { |                         .getFlag(PveFlag.class))) { | ||||||
|                     return true; |                     return true; | ||||||
|                 } |                 } | ||||||
|                 if (!Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_PVE + "." + stub)) { |                 if (!plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_PVE + "." + stub)) { | ||||||
|                     plotPlayer.sendMessage( |                     plotPlayer.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             TagResolver.resolver( | ||||||
| @@ -322,7 +319,7 @@ public class BukkitEntityUtil { | |||||||
|                 } else if (roadFlags && area.getRoadFlag(PveFlag.class)) { |                 } else if (roadFlags && area.getRoadFlag(PveFlag.class)) { | ||||||
|                     return true; |                     return true; | ||||||
|                 } |                 } | ||||||
|                 if (!Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_PVE + "." + stub)) { |                 if (!plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_PVE + "." + stub)) { | ||||||
|                     plotPlayer.sendMessage( |                     plotPlayer.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             TagResolver.resolver( |                             TagResolver.resolver( | ||||||
|   | |||||||
| @@ -44,6 +44,7 @@ import java.util.stream.IntStream; | |||||||
| @Singleton | @Singleton | ||||||
| public class BukkitInventoryUtil extends InventoryUtil { | public class BukkitInventoryUtil extends InventoryUtil { | ||||||
|  |  | ||||||
|  |     @SuppressWarnings("deprecation") // Paper deprecation | ||||||
|     private static @Nullable ItemStack getItem(PlotItemStack item) { |     private static @Nullable ItemStack getItem(PlotItemStack item) { | ||||||
|         if (item == null) { |         if (item == null) { | ||||||
|             return null; |             return null; | ||||||
|   | |||||||
| @@ -67,6 +67,7 @@ public class BukkitSetupUtils extends SetupUtils { | |||||||
|         this.worldFile = worldFile; |         this.worldFile = worldFile; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @SuppressWarnings("deprecation") // Paper deprecation | ||||||
|     @Override |     @Override | ||||||
|     public void updateGenerators(final boolean force) { |     public void updateGenerators(final boolean force) { | ||||||
|         if (loaded && !SetupUtils.generators.isEmpty() && !force) { |         if (loaded && !SetupUtils.generators.isEmpty() && !force) { | ||||||
| @@ -124,7 +125,7 @@ public class BukkitSetupUtils extends SetupUtils { | |||||||
|     public String setupWorld(PlotAreaBuilder builder) { |     public String setupWorld(PlotAreaBuilder builder) { | ||||||
|         this.updateGenerators(false); |         this.updateGenerators(false); | ||||||
|         ConfigurationNode[] steps = builder.settingsNodesWrapper() == null ? |         ConfigurationNode[] steps = builder.settingsNodesWrapper() == null ? | ||||||
|                 new ConfigurationNode[0] : builder.settingsNodesWrapper().getSettingsNodes(); |                 new ConfigurationNode[0] : builder.settingsNodesWrapper().settingsNodes(); | ||||||
|         String world = builder.worldName(); |         String world = builder.worldName(); | ||||||
|         PlotAreaType type = builder.plotAreaType(); |         PlotAreaType type = builder.plotAreaType(); | ||||||
|         String worldPath = "worlds." + builder.worldName(); |         String worldPath = "worlds." + builder.worldName(); | ||||||
|   | |||||||
| @@ -58,6 +58,7 @@ import org.bukkit.block.BlockFace; | |||||||
| import org.bukkit.block.Sign; | import org.bukkit.block.Sign; | ||||||
| import org.bukkit.block.data.Directional; | import org.bukkit.block.data.Directional; | ||||||
| import org.bukkit.block.data.type.WallSign; | import org.bukkit.block.data.type.WallSign; | ||||||
|  | import org.bukkit.entity.Allay; | ||||||
| import org.bukkit.entity.Ambient; | import org.bukkit.entity.Ambient; | ||||||
| import org.bukkit.entity.Animals; | import org.bukkit.entity.Animals; | ||||||
| import org.bukkit.entity.AreaEffectCloud; | import org.bukkit.entity.AreaEffectCloud; | ||||||
| @@ -438,6 +439,9 @@ public class BukkitUtil extends WorldUtil { | |||||||
|                 allowedInterfaces.add(Animals.class); |                 allowedInterfaces.add(Animals.class); | ||||||
|                 allowedInterfaces.add(WaterMob.class); |                 allowedInterfaces.add(WaterMob.class); | ||||||
|                 allowedInterfaces.add(Ambient.class); |                 allowedInterfaces.add(Ambient.class); | ||||||
|  |                 if (PlotSquared.platform().serverVersion()[1] >= 19) { | ||||||
|  |                     allowedInterfaces.add(Allay.class); | ||||||
|  |                 } | ||||||
|             } |             } | ||||||
|             case "tameable" -> allowedInterfaces.add(Tameable.class); |             case "tameable" -> allowedInterfaces.add(Tameable.class); | ||||||
|             case "vehicle" -> allowedInterfaces.add(Vehicle.class); |             case "vehicle" -> allowedInterfaces.add(Vehicle.class); | ||||||
|   | |||||||
| @@ -23,11 +23,15 @@ import com.plotsquared.core.location.World; | |||||||
| import org.bukkit.Bukkit; | import org.bukkit.Bukkit; | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
|  | import java.lang.ref.SoftReference; | ||||||
|  | import java.lang.ref.WeakReference; | ||||||
| import java.util.Map; | import java.util.Map; | ||||||
|  |  | ||||||
| public class BukkitWorld implements World<org.bukkit.World> { | public class BukkitWorld implements World<org.bukkit.World> { | ||||||
|  |  | ||||||
|     private static final Map<String, BukkitWorld> worldMap = Maps.newHashMap(); |     // Upon world unload we should probably have the P2 BukkitWorld be GCed relatively eagerly, thus freeing the bukkit world. | ||||||
|  |     //  We also want to avoid circumstances where a bukkit world has been GCed, but a P2 BukkitWorld has not | ||||||
|  |     private static final Map<String, WeakReference<BukkitWorld>> worldMap = Maps.newHashMap(); | ||||||
|     private static final boolean HAS_MIN_Y; |     private static final boolean HAS_MIN_Y; | ||||||
|  |  | ||||||
|     static { |     static { | ||||||
| @@ -41,10 +45,11 @@ public class BukkitWorld implements World<org.bukkit.World> { | |||||||
|         HAS_MIN_Y = temp; |         HAS_MIN_Y = temp; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private final org.bukkit.World world; |     // We want to allow GC to remove bukkit worlds, but not too eagerly | ||||||
|  |     private final SoftReference<org.bukkit.World> world; | ||||||
|  |  | ||||||
|     private BukkitWorld(final org.bukkit.World world) { |     private BukkitWorld(final org.bukkit.World world) { | ||||||
|         this.world = world; |         this.world = new SoftReference<>(world); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
| @@ -68,12 +73,13 @@ public class BukkitWorld implements World<org.bukkit.World> { | |||||||
|      * @return World instance |      * @return World instance | ||||||
|      */ |      */ | ||||||
|     public static @NonNull BukkitWorld of(final org.bukkit.World world) { |     public static @NonNull BukkitWorld of(final org.bukkit.World world) { | ||||||
|         BukkitWorld bukkitWorld = worldMap.get(world.getName()); |         WeakReference<BukkitWorld> bukkitWorldRef = worldMap.get(world.getName()); | ||||||
|         if (bukkitWorld != null && bukkitWorld.getPlatformWorld().equals(world)) { |         BukkitWorld bukkitWorld; | ||||||
|  |         if (bukkitWorldRef != null && (bukkitWorld = bukkitWorldRef.get()) != null && world.equals(bukkitWorld.world.get())) { | ||||||
|             return bukkitWorld; |             return bukkitWorld; | ||||||
|         } |         } | ||||||
|         bukkitWorld = new BukkitWorld(world); |         bukkitWorld = new BukkitWorld(world); | ||||||
|         worldMap.put(world.getName(), bukkitWorld); |         worldMap.put(world.getName(), new WeakReference<>(bukkitWorld)); | ||||||
|         return bukkitWorld; |         return bukkitWorld; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -97,22 +103,26 @@ public class BukkitWorld implements World<org.bukkit.World> { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public org.bukkit.World getPlatformWorld() { |     public org.bukkit.World getPlatformWorld() { | ||||||
|         return this.world; |         org.bukkit.World world = this.world.get(); | ||||||
|  |         if (world == null) { | ||||||
|  |             throw new IllegalStateException("Bukkit platform world was unloaded from memory"); | ||||||
|  |         } | ||||||
|  |         return world; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public @NonNull String getName() { |     public @NonNull String getName() { | ||||||
|         return this.world.getName(); |         return this.getPlatformWorld().getName(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public int getMinHeight() { |     public int getMinHeight() { | ||||||
|         return getMinWorldHeight(world); |         return getMinWorldHeight(getPlatformWorld()); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public int getMaxHeight() { |     public int getMaxHeight() { | ||||||
|         return getMaxWorldHeight(world) - 1; |         return getMaxWorldHeight(getPlatformWorld()) - 1; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|   | |||||||
| @@ -0,0 +1,98 @@ | |||||||
|  | /* | ||||||
|  |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  |  * | ||||||
|  |  * This program is free software: you can redistribute it and/or modify | ||||||
|  |  * it under the terms of the GNU General Public License as published by | ||||||
|  |  * the Free Software Foundation, either version 3 of the License, or | ||||||
|  |  * (at your option) any later version. | ||||||
|  |  * | ||||||
|  |  * This program is distributed in the hope that it will be useful, | ||||||
|  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||||
|  |  * GNU General Public License for more details. | ||||||
|  |  * | ||||||
|  |  * You should have received a copy of the GNU General Public License | ||||||
|  |  * along with this program.  If not, see <https://www.gnu.org/licenses/>. | ||||||
|  |  */ | ||||||
|  | package com.plotsquared.bukkit.util; | ||||||
|  |  | ||||||
|  | import com.intellectualsites.annotations.NotPublic; | ||||||
|  | import com.plotsquared.core.PlotSquared; | ||||||
|  |  | ||||||
|  | import java.io.IOException; | ||||||
|  | import java.nio.file.Files; | ||||||
|  | import java.nio.file.Path; | ||||||
|  | import java.nio.file.Paths; | ||||||
|  | import java.util.stream.Stream; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * This is a helper class which replaces older syntax no longer supported by MiniMessage with replacements in messages_%.json. | ||||||
|  |  * MiniMessage changed the syntax between major releases. To warrant a smooth upgrade, we attempt to replace any occurrences | ||||||
|  |  * while loading PlotSquared. | ||||||
|  |  * | ||||||
|  |  * @since 7.0.0 | ||||||
|  |  */ | ||||||
|  | @NotPublic | ||||||
|  | public class TranslationUpdateManager { | ||||||
|  |  | ||||||
|  |     public static void upgradeTranslationFile() throws IOException { | ||||||
|  |         String suggestCommand = "suggest_command"; | ||||||
|  |         String suggestCommandReplacement = "run_command"; | ||||||
|  |         String minHeight = "minHeight"; | ||||||
|  |         String minheightReplacement = "minheight"; | ||||||
|  |         String maxHeight = "maxHeight"; | ||||||
|  |         String maxheightReplacement = "maxheight"; | ||||||
|  |         String usedGrants = "usedGrants"; | ||||||
|  |         String usedGrantsReplacement = "used_grants"; | ||||||
|  |         String remainingGrants = "remainingGrants"; | ||||||
|  |         String remainingGrantsReplacement = "remaining_grants"; | ||||||
|  |         String minimumRadius = "minimumRadius"; | ||||||
|  |         String minimumRadiusReplacement = "minimum_radius"; | ||||||
|  |         String maximumMoves = "maximumMoves"; | ||||||
|  |         String maximumMovesReplacement = "maximum_moves"; | ||||||
|  |         String userMove = "userMove"; | ||||||
|  |         String userMoveReplacement = "user_move"; | ||||||
|  |  | ||||||
|  |         // tag opening / closing characters are important, as the locale keys exist as well, which should not be replaced | ||||||
|  |         String listInfoUnknown = "<info.unknown>"; | ||||||
|  |         String listInfoUnknownReplacement = "<unknown>"; | ||||||
|  |         String listInfoServer = "<info.server>"; | ||||||
|  |         String listInfoServerReplacement = "<server>"; | ||||||
|  |         String listInfoEveryone = "<info.everyone>"; | ||||||
|  |         String listInfoEveryoneReplacement = "<everyone>"; | ||||||
|  |  | ||||||
|  |         try (Stream<Path> paths = Files.walk(Paths.get(PlotSquared.platform().getDirectory().toPath().resolve("lang").toUri()))) { | ||||||
|  |             paths | ||||||
|  |                     .filter(Files::isRegularFile) | ||||||
|  |                     .filter(p -> p.getFileName().toString().matches("messages_[a-z]{2}\\.json")) | ||||||
|  |                     .forEach(p -> { | ||||||
|  |                         replaceInFile(p, suggestCommand, suggestCommandReplacement); | ||||||
|  |                         replaceInFile(p, minHeight, minheightReplacement); | ||||||
|  |                         replaceInFile(p, maxHeight, maxheightReplacement); | ||||||
|  |                         replaceInFile(p, usedGrants, usedGrantsReplacement); | ||||||
|  |                         replaceInFile(p, remainingGrants, remainingGrantsReplacement); | ||||||
|  |                         replaceInFile(p, minimumRadius, minimumRadiusReplacement); | ||||||
|  |                         replaceInFile(p, maximumMoves, maximumMovesReplacement); | ||||||
|  |                         replaceInFile(p, userMove, userMoveReplacement); | ||||||
|  |                         replaceInFile(p, listInfoUnknown, listInfoUnknownReplacement); | ||||||
|  |                         replaceInFile(p, listInfoServer, listInfoServerReplacement); | ||||||
|  |                         replaceInFile(p, listInfoEveryone, listInfoEveryoneReplacement); | ||||||
|  |                     }); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private static void replaceInFile(Path path, String searchText, String replacementText) { | ||||||
|  |         try { | ||||||
|  |             String content = Files.readString(path); | ||||||
|  |             if (content.contains(searchText)) { | ||||||
|  |                 content = content.replaceAll(searchText, replacementText); | ||||||
|  |                 Files.writeString(path, content); | ||||||
|  |             } | ||||||
|  |         } catch (IOException e) { | ||||||
|  |             e.printStackTrace(); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -35,7 +35,7 @@ import org.bukkit.scheduler.BukkitTask; | |||||||
| import javax.net.ssl.HttpsURLConnection; | import javax.net.ssl.HttpsURLConnection; | ||||||
| import java.io.IOException; | import java.io.IOException; | ||||||
| import java.io.InputStreamReader; | import java.io.InputStreamReader; | ||||||
| import java.net.URL; | import java.net.URI; | ||||||
|  |  | ||||||
| public class UpdateUtility implements Listener { | public class UpdateUtility implements Listener { | ||||||
|  |  | ||||||
| @@ -54,12 +54,14 @@ public class UpdateUtility implements Listener { | |||||||
|         internalVersion = PlotSquared.get().getVersion(); |         internalVersion = PlotSquared.get().getVersion(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @SuppressWarnings({"deprecation", "DefaultCharset"}) // Suppress Json deprecation, we can't use features from gson 2.8.1 and newer yet |     @SuppressWarnings({"deprecation", "DefaultCharset"}) | ||||||
|  |     // Suppress Json deprecation, we can't use features from gson 2.8.1 and newer yet | ||||||
|     public void updateChecker() { |     public void updateChecker() { | ||||||
|         task = Bukkit.getScheduler().runTaskTimerAsynchronously(this.javaPlugin, () -> { |         task = Bukkit.getScheduler().runTaskTimerAsynchronously(this.javaPlugin, () -> { | ||||||
|             try { |             try { | ||||||
|                 HttpsURLConnection connection = (HttpsURLConnection) new URL( |                 HttpsURLConnection connection = (HttpsURLConnection) URI.create( | ||||||
|                         "https://api.spigotmc.org/simple/0.1/index.php?action=getResource&id=77506") |                         "https://api.spigotmc.org/simple/0.2/index.php?action=getResource&id=77506") | ||||||
|  |                         .toURL() | ||||||
|                         .openConnection(); |                         .openConnection(); | ||||||
|                 connection.setRequestMethod("GET"); |                 connection.setRequestMethod("GET"); | ||||||
|                 JsonObject result = new JsonParser() |                 JsonObject result = new JsonParser() | ||||||
|   | |||||||
| @@ -36,9 +36,10 @@ import com.sk89q.worldedit.function.pattern.Pattern; | |||||||
| import com.sk89q.worldedit.regions.CuboidRegion; | import com.sk89q.worldedit.regions.CuboidRegion; | ||||||
| import com.sk89q.worldedit.world.biome.BiomeType; | import com.sk89q.worldedit.world.biome.BiomeType; | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  | import org.checkerframework.checker.nullness.qual.Nullable; | ||||||
| import org.jetbrains.annotations.NotNull; | import org.jetbrains.annotations.NotNull; | ||||||
| import org.jetbrains.annotations.Nullable; |  | ||||||
|  |  | ||||||
|  | import java.util.Objects; | ||||||
| import java.util.Set; | import java.util.Set; | ||||||
|  |  | ||||||
| public class FaweRegionManager extends BukkitRegionManager { | public class FaweRegionManager extends BukkitRegionManager { | ||||||
| @@ -46,10 +47,7 @@ public class FaweRegionManager extends BukkitRegionManager { | |||||||
|     private final FaweDelegateRegionManager delegate = new FaweDelegateRegionManager(); |     private final FaweDelegateRegionManager delegate = new FaweDelegateRegionManager(); | ||||||
|  |  | ||||||
|     @Inject |     @Inject | ||||||
|     public FaweRegionManager( |     public FaweRegionManager(WorldUtil worldUtil, GlobalBlockQueue blockQueue, ProgressSubscriberFactory subscriberFactory) { | ||||||
|             @NonNull WorldUtil worldUtil, @NonNull GlobalBlockQueue blockQueue, @NonNull |  | ||||||
|             ProgressSubscriberFactory subscriberFactory |  | ||||||
|     ) { |  | ||||||
|         super(worldUtil, blockQueue, subscriberFactory); |         super(worldUtil, blockQueue, subscriberFactory); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -63,7 +61,10 @@ public class FaweRegionManager extends BukkitRegionManager { | |||||||
|             @Nullable PlotPlayer<?> actor, |             @Nullable PlotPlayer<?> actor, | ||||||
|             @Nullable QueueCoordinator queue |             @Nullable QueueCoordinator queue | ||||||
|     ) { |     ) { | ||||||
|         return delegate.setCuboids(area, regions, blocks, minY, maxY, queue.getCompleteTask()); |         return delegate.setCuboids( | ||||||
|  |                 area, regions, blocks, minY, maxY, | ||||||
|  |                 Objects.requireNonNullElseGet(queue, area::getQueue).getCompleteTask() | ||||||
|  |         ); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
| @@ -76,9 +77,9 @@ public class FaweRegionManager extends BukkitRegionManager { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean handleClear( |     public boolean handleClear( | ||||||
|             @NotNull Plot plot, |             @NonNull Plot plot, | ||||||
|             @Nullable Runnable whenDone, |             @Nullable Runnable whenDone, | ||||||
|             @NotNull PlotManager manager, |             @NonNull PlotManager manager, | ||||||
|             final @Nullable PlotPlayer<?> player |             final @Nullable PlotPlayer<?> player | ||||||
|     ) { |     ) { | ||||||
|         if (!Settings.FAWE_Components.CLEAR || !(manager instanceof HybridPlotManager)) { |         if (!Settings.FAWE_Components.CLEAR || !(manager instanceof HybridPlotManager)) { | ||||||
| @@ -115,7 +116,7 @@ public class FaweRegionManager extends BukkitRegionManager { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean regenerateRegion(final Location pos1, final Location pos2, boolean ignore, final Runnable whenDone) { |     public boolean regenerateRegion(final @NotNull Location pos1, final @NotNull Location pos2, boolean ignore, final Runnable whenDone) { | ||||||
|         return delegate.regenerateRegion(pos1, pos2, ignore, whenDone); |         return delegate.regenerateRegion(pos1, pos2, ignore, whenDone); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -29,7 +29,7 @@ import com.plotsquared.core.util.SchematicHandler; | |||||||
| import com.plotsquared.core.util.WorldUtil; | import com.plotsquared.core.util.WorldUtil; | ||||||
| import com.plotsquared.core.util.task.RunnableVal; | import com.plotsquared.core.util.task.RunnableVal; | ||||||
| import com.sk89q.jnbt.CompoundTag; | import com.sk89q.jnbt.CompoundTag; | ||||||
| import org.jetbrains.annotations.NotNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.io.InputStream; | import java.io.InputStream; | ||||||
| import java.net.URL; | import java.net.URL; | ||||||
| @@ -40,7 +40,7 @@ public class FaweSchematicHandler extends SchematicHandler { | |||||||
|     private final FaweDelegateSchematicHandler delegate = new FaweDelegateSchematicHandler(); |     private final FaweDelegateSchematicHandler delegate = new FaweDelegateSchematicHandler(); | ||||||
|  |  | ||||||
|     @Inject |     @Inject | ||||||
|     public FaweSchematicHandler(@NotNull WorldUtil worldUtil, @NotNull ProgressSubscriberFactory subscriberFactory) { |     public FaweSchematicHandler(WorldUtil worldUtil, ProgressSubscriberFactory subscriberFactory) { | ||||||
|         super(worldUtil, subscriberFactory); |         super(worldUtil, subscriberFactory); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -75,9 +75,8 @@ public class FaweSchematicHandler extends SchematicHandler { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public Schematic getSchematic(@NotNull InputStream is) { |     public Schematic getSchematic(@NonNull InputStream is) { | ||||||
|         return delegate.getSchematic(is); |         return delegate.getSchematic(is); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -111,8 +111,8 @@ public class SQLiteUUIDService implements UUIDService, Consumer<List<UUIDMapping | |||||||
|         try (final PreparedStatement statement = getConnection() |         try (final PreparedStatement statement = getConnection() | ||||||
|                 .prepareStatement("INSERT OR REPLACE INTO `usercache` (`uuid`, `username`) VALUES(?, ?)")) { |                 .prepareStatement("INSERT OR REPLACE INTO `usercache` (`uuid`, `username`) VALUES(?, ?)")) { | ||||||
|             for (final UUIDMapping mapping : uuidWrappers) { |             for (final UUIDMapping mapping : uuidWrappers) { | ||||||
|                 statement.setString(1, mapping.getUuid().toString()); |                 statement.setString(1, mapping.uuid().toString()); | ||||||
|                 statement.setString(2, mapping.getUsername()); |                 statement.setString(2, mapping.username()); | ||||||
|                 statement.executeUpdate(); |                 statement.executeUpdate(); | ||||||
|             } |             } | ||||||
|         } catch (SQLException e) { |         } catch (SQLException e) { | ||||||
|   | |||||||
| @@ -4,16 +4,16 @@ api-version: "1.13" | |||||||
| version: "${version}" | version: "${version}" | ||||||
| load: STARTUP | load: STARTUP | ||||||
| description: "Easy, yet powerful Plot World generation and management." | description: "Easy, yet powerful Plot World generation and management." | ||||||
| authors: [Citymonstret, Empire92, MattBDev, dordsor21, NotMyFault, SirYwell] | authors: [ Citymonstret, Empire92, MattBDev, dordsor21, NotMyFault, SirYwell ] | ||||||
| website: https://www.spigotmc.org/resources/77506/ | website: https://www.spigotmc.org/resources/77506/ | ||||||
| softdepend: [Vault, PlaceholderAPI, Essentials, LuckPerms, BungeePerms, MVdWPlaceholderAPI] | softdepend: [ Vault, PlaceholderAPI, Essentials, LuckPerms, BungeePerms, MVdWPlaceholderAPI ] | ||||||
| loadbefore: [MultiWorld, Multiverse-Core] | loadbefore: [ MultiWorld, Multiverse-Core ] | ||||||
| depend: [WorldEdit] | depend: [ WorldEdit ] | ||||||
| database: false | database: false | ||||||
| commands: | commands: | ||||||
|   plots: |   plots: | ||||||
|     description: Plot command. |     description: Plot command. | ||||||
|     aliases: [p,plot,ps,plotsquared,p2,2,plotme] |     aliases: [ p,plot,ps,plotsquared,p2,2,plotme ] | ||||||
|     permission: plots.use |     permission: plots.use | ||||||
|     permission-message: "You are lacking the permission node 'plots.use'" |     permission-message: "You are lacking the permission node 'plots.use'" | ||||||
| permissions: | permissions: | ||||||
|   | |||||||
| @@ -1,76 +0,0 @@ | |||||||
| # Contributor Covenant Code of Conduct |  | ||||||
|  |  | ||||||
| ## Our Pledge |  | ||||||
|  |  | ||||||
| In the interest of fostering an open and welcoming environment, we as |  | ||||||
| contributors and maintainers pledge to making participation in our project and |  | ||||||
| our community a harassment-free experience for everyone, regardless of age, body |  | ||||||
| size, disability, ethnicity, sex characteristics, gender identity and expression, |  | ||||||
| level of experience, education, socio-economic status, nationality, personal |  | ||||||
| appearance, race, religion, or sexual identity and orientation. |  | ||||||
|  |  | ||||||
| ## Our Standards |  | ||||||
|  |  | ||||||
| Examples of behavior that contributes to creating a positive environment |  | ||||||
| include: |  | ||||||
|  |  | ||||||
| * Using welcoming and inclusive language |  | ||||||
| * Being respectful of differing viewpoints and experiences |  | ||||||
| * Gracefully accepting constructive criticism |  | ||||||
| * Focusing on what is best for the community |  | ||||||
| * Showing empathy towards other community members |  | ||||||
|  |  | ||||||
| Examples of unacceptable behavior by participants include: |  | ||||||
|  |  | ||||||
| * The use of sexualized language or imagery and unwelcome sexual attention or |  | ||||||
|  advances |  | ||||||
| * Trolling, insulting/derogatory comments, and personal or political attacks |  | ||||||
| * Public or private harassment |  | ||||||
| * Publishing others' private information, such as a physical or electronic |  | ||||||
|  address, without explicit permission |  | ||||||
| * Other conduct which could reasonably be considered inappropriate in a |  | ||||||
|  professional setting |  | ||||||
|  |  | ||||||
| ## Our Responsibilities |  | ||||||
|  |  | ||||||
| Project maintainers are responsible for clarifying the standards of acceptable |  | ||||||
| behavior and are expected to take appropriate and fair corrective action in |  | ||||||
| response to any instances of unacceptable behavior. |  | ||||||
|  |  | ||||||
| Project maintainers have the right and responsibility to remove, edit, or |  | ||||||
| reject comments, commits, code, wiki edits, issues, and other contributions |  | ||||||
| that are not aligned to this Code of Conduct, or to ban temporarily or |  | ||||||
| permanently any contributor for other behaviors that they deem inappropriate, |  | ||||||
| threatening, offensive, or harmful. |  | ||||||
|  |  | ||||||
| ## Scope |  | ||||||
|  |  | ||||||
| This Code of Conduct applies both within project spaces and in public spaces |  | ||||||
| when an individual is representing the project or its community. Examples of |  | ||||||
| representing a project or community include using an official project e-mail |  | ||||||
| address, posting via an official social media account, or acting as an appointed |  | ||||||
| representative at an online or offline event. Representation of a project may be |  | ||||||
| further defined and clarified by project maintainers. |  | ||||||
|  |  | ||||||
| ## Enforcement |  | ||||||
|  |  | ||||||
| Instances of abusive, harassing, or otherwise unacceptable behavior may be |  | ||||||
| reported by contacting the project team at contact@intellectualsites.com. All |  | ||||||
| complaints will be reviewed and investigated and will result in a response that |  | ||||||
| is deemed necessary and appropriate to the circumstances. The project team is |  | ||||||
| obligated to maintain confidentiality with regard to the reporter of an incident. |  | ||||||
| Further details of specific enforcement policies may be posted separately. |  | ||||||
|  |  | ||||||
| Project maintainers who do not follow or enforce the Code of Conduct in good |  | ||||||
| faith may face temporary or permanent repercussions as determined by other |  | ||||||
| members of the project's leadership. |  | ||||||
|  |  | ||||||
| ## Attribution |  | ||||||
|  |  | ||||||
| This Code of Conduct is adapted from the [Contributor Covenant][homepage], version 1.4, |  | ||||||
| available at https://www.contributor-covenant.org/version/1/4/code-of-conduct.html |  | ||||||
|  |  | ||||||
| [homepage]: https://www.contributor-covenant.org |  | ||||||
|  |  | ||||||
| For answers to common questions about this code of conduct, see |  | ||||||
| https://www.contributor-covenant.org/faq |  | ||||||
| @@ -2,18 +2,18 @@ import java.time.format.DateTimeFormatter | |||||||
|  |  | ||||||
| dependencies { | dependencies { | ||||||
|     // Expected everywhere. |     // Expected everywhere. | ||||||
|     compileOnlyApi("org.checkerframework:checker-qual") |     compileOnlyApi(libs.checkerqual) | ||||||
|  |  | ||||||
|     // Minecraft expectations |     // Minecraft expectations | ||||||
|     compileOnlyApi("com.google.code.gson:gson") |     compileOnlyApi(libs.gson) | ||||||
|     compileOnly("com.google.guava:guava") |     compileOnly(libs.guava) | ||||||
|  |  | ||||||
|     // Platform expectations |     // Platform expectations | ||||||
|     compileOnlyApi("org.yaml:snakeyaml") |     compileOnlyApi(libs.snakeyaml) | ||||||
|  |  | ||||||
|     // Adventure |     // Adventure | ||||||
|     api("net.kyori:adventure-api") |     api(libs.adventureApi) | ||||||
|     api("net.kyori:adventure-text-minimessage") |     api(libs.adventureMiniMessage) | ||||||
|  |  | ||||||
|     // Guice |     // Guice | ||||||
|     api(libs.guice) { |     api(libs.guice) { | ||||||
| @@ -31,18 +31,19 @@ dependencies { | |||||||
|         exclude(group = "dummypermscompat") |         exclude(group = "dummypermscompat") | ||||||
|     } |     } | ||||||
|     testImplementation(libs.worldeditCore) |     testImplementation(libs.worldeditCore) | ||||||
|     compileOnly("com.fastasyncworldedit:FastAsyncWorldEdit-Core") { isTransitive = false } |     compileOnly(libs.faweBukkit) { isTransitive = false } | ||||||
|     testImplementation("com.fastasyncworldedit:FastAsyncWorldEdit-Core") { isTransitive = false } |     testImplementation(libs.faweCore) { isTransitive = false } | ||||||
|  |  | ||||||
|     // Logging |     // Logging | ||||||
|     compileOnlyApi("org.apache.logging.log4j:log4j-api") |     compileOnlyApi(libs.log4j) | ||||||
|  |  | ||||||
|     // Other libraries |     // Other libraries | ||||||
|     api(libs.prtree) |     api(libs.prtree) | ||||||
|     api(libs.aopalliance) |     api(libs.aopalliance) | ||||||
|     api(libs.cloudServices) |     api(libs.cloudServices) | ||||||
|     api(libs.arkitektonika) |     api(libs.arkitektonika) | ||||||
|     api("com.intellectualsites.paster:Paster") |     api(libs.paster) | ||||||
|  |     api(libs.informativeAnnotations) | ||||||
| } | } | ||||||
|  |  | ||||||
| tasks.processResources { | tasks.processResources { | ||||||
| @@ -53,14 +54,30 @@ tasks.processResources { | |||||||
|                 "date" to rootProject.grgit.head().dateTime.format(DateTimeFormatter.ofPattern("yy.MM.dd")) |                 "date" to rootProject.grgit.head().dateTime.format(DateTimeFormatter.ofPattern("yy.MM.dd")) | ||||||
|         ) |         ) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     doLast { | ||||||
|  |         copy { | ||||||
|  |             from(layout.buildDirectory.file("$rootDir/LICENSE")) | ||||||
|  |             into(layout.buildDirectory.dir("resources/main")) | ||||||
|  |         } | ||||||
|  |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| tasks { | tasks { | ||||||
|     withType<Javadoc> { |     withType<Javadoc> { | ||||||
|  |         val isRelease = if (rootProject.version.toString().endsWith("-SNAPSHOT")) "TODO" else rootProject.version.toString() | ||||||
|         val opt = options as StandardJavadocDocletOptions |         val opt = options as StandardJavadocDocletOptions | ||||||
|         opt.links("https://docs.enginehub.org/javadoc/com.sk89q.worldedit/worldedit-core/" + libs.worldeditCore.get().versionConstraint.toString()) |         opt.links("https://docs.enginehub.org/javadoc/com.sk89q.worldedit/worldedit-core/" + libs.worldeditCore.get().versionConstraint.toString()) | ||||||
|         opt.links("https://jd.adventure.kyori.net/api/4.9.3/") |         opt.links("https://jd.advntr.dev/api/4.14.0/") | ||||||
|  |         opt.links("https://jd.advntr.dev/text-minimessage/4.14.0/") | ||||||
|         opt.links("https://google.github.io/guice/api-docs/" + libs.guice.get().versionConstraint.toString() + "/javadoc/") |         opt.links("https://google.github.io/guice/api-docs/" + libs.guice.get().versionConstraint.toString() + "/javadoc/") | ||||||
|         opt.links("https://checkerframework.org/api/") |         opt.links("https://checkerframework.org/api/") | ||||||
|  |         opt.isLinkSource = true | ||||||
|  |         opt.bottom(File("$rootDir/javadocfooter.html").readText()) | ||||||
|  |         opt.isUse = true | ||||||
|  |         opt.encoding("UTF-8") | ||||||
|  |         opt.keyWords() | ||||||
|  |         opt.addStringOption("-since", isRelease) | ||||||
|  |         opt.noTimestamp() | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -22,6 +22,7 @@ import cloud.commandframework.services.ServicePipeline; | |||||||
| import com.google.inject.Injector; | import com.google.inject.Injector; | ||||||
| import com.google.inject.Key; | import com.google.inject.Key; | ||||||
| import com.google.inject.TypeLiteral; | import com.google.inject.TypeLiteral; | ||||||
|  | import com.intellectualsites.annotations.DoNotUse; | ||||||
| import com.plotsquared.core.backup.BackupManager; | import com.plotsquared.core.backup.BackupManager; | ||||||
| import com.plotsquared.core.configuration.caption.LocaleHolder; | import com.plotsquared.core.configuration.caption.LocaleHolder; | ||||||
| import com.plotsquared.core.generator.GeneratorWrapper; | import com.plotsquared.core.generator.GeneratorWrapper; | ||||||
| @@ -31,9 +32,9 @@ import com.plotsquared.core.inject.annotations.DefaultGenerator; | |||||||
| import com.plotsquared.core.location.World; | import com.plotsquared.core.location.World; | ||||||
| import com.plotsquared.core.permissions.PermissionHandler; | import com.plotsquared.core.permissions.PermissionHandler; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
|  | import com.plotsquared.core.plot.expiration.ExpireManager; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
| import com.plotsquared.core.queue.GlobalBlockQueue; | import com.plotsquared.core.queue.GlobalBlockQueue; | ||||||
| import com.plotsquared.core.util.AnnotationHelper; |  | ||||||
| import com.plotsquared.core.util.ChunkManager; | import com.plotsquared.core.util.ChunkManager; | ||||||
| import com.plotsquared.core.util.EconHandler; | import com.plotsquared.core.util.EconHandler; | ||||||
| import com.plotsquared.core.util.PlatformWorldManager; | import com.plotsquared.core.util.PlatformWorldManager; | ||||||
| @@ -75,6 +76,11 @@ public interface PlotPlatform<P> extends LocaleHolder { | |||||||
|      */ |      */ | ||||||
|     void shutdown(); |     void shutdown(); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Completely shuts down the server. | ||||||
|  |      */ | ||||||
|  |     void shutdownServer(); | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Get the name of the plugin |      * Get the name of the plugin | ||||||
|      * |      * | ||||||
| @@ -279,6 +285,16 @@ public interface PlotPlatform<P> extends LocaleHolder { | |||||||
|         return injector().getInstance(ChunkManager.class); |         return injector().getInstance(ChunkManager.class); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Get the {@link ExpireManager} implementation for the platform | ||||||
|  |      * | ||||||
|  |      * @return Expire manager | ||||||
|  |      * @since 6.10.2 | ||||||
|  |      */ | ||||||
|  |     default @NonNull ExpireManager expireManager() { | ||||||
|  |         return injector().getInstance(ExpireManager.class); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Get the {@link PlotAreaManager} implementation. |      * Get the {@link PlotAreaManager} implementation. | ||||||
|      * |      * | ||||||
| @@ -308,7 +324,7 @@ public interface PlotPlatform<P> extends LocaleHolder { | |||||||
|      * @return worldedit implementations |      * @return worldedit implementations | ||||||
|      * @since 6.3.0 |      * @since 6.3.0 | ||||||
|      */ |      */ | ||||||
|     @AnnotationHelper.ApiDescription(info = "Internal use only") |     @DoNotUse | ||||||
|     @NonNull String worldEditImplementations(); |     @NonNull String worldEditImplementations(); | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|   | |||||||
| @@ -84,7 +84,7 @@ import java.io.InputStream; | |||||||
| import java.io.InputStreamReader; | import java.io.InputStreamReader; | ||||||
| import java.io.ObjectInputStream; | import java.io.ObjectInputStream; | ||||||
| import java.io.ObjectOutputStream; | import java.io.ObjectOutputStream; | ||||||
| import java.net.MalformedURLException; | import java.net.URI; | ||||||
| import java.net.URISyntaxException; | import java.net.URISyntaxException; | ||||||
| import java.net.URL; | import java.net.URL; | ||||||
| import java.nio.file.Files; | import java.nio.file.Files; | ||||||
| @@ -197,6 +197,9 @@ public class PlotSquared { | |||||||
|             this.loadCaptionMap(); |             this.loadCaptionMap(); | ||||||
|         } catch (final Exception e) { |         } catch (final Exception e) { | ||||||
|             LOGGER.error("Failed to load caption map", e); |             LOGGER.error("Failed to load caption map", e); | ||||||
|  |             LOGGER.error("Shutting down server to prevent further issues"); | ||||||
|  |             this.platform.shutdownServer(); | ||||||
|  |             throw new RuntimeException("Abort loading PlotSquared"); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         // Setup the global flag container |         // Setup the global flag container | ||||||
| @@ -207,9 +210,10 @@ public class PlotSquared { | |||||||
|             try { |             try { | ||||||
|                 URL logurl = PlotSquared.class.getProtectionDomain().getCodeSource().getLocation(); |                 URL logurl = PlotSquared.class.getProtectionDomain().getCodeSource().getLocation(); | ||||||
|                 this.jarFile = new File( |                 this.jarFile = new File( | ||||||
|                         new URL(logurl.toURI().toString().split("\\!")[0].replaceAll("jar:file", "file")) |                         URI.create( | ||||||
|                                 .toURI().getPath()); |                                 logurl.toURI().toString().split("\\!")[0].replaceAll("jar:file", "file")) | ||||||
|             } catch (MalformedURLException | URISyntaxException | SecurityException e) { |                                 .getPath()); | ||||||
|  |             } catch (URISyntaxException | SecurityException e) { | ||||||
|                 e.printStackTrace(); |                 e.printStackTrace(); | ||||||
|                 this.jarFile = new File(this.platform.getDirectory().getParentFile(), "PlotSquared.jar"); |                 this.jarFile = new File(this.platform.getDirectory().getParentFile(), "PlotSquared.jar"); | ||||||
|                 if (!this.jarFile.exists()) { |                 if (!this.jarFile.exists()) { | ||||||
| @@ -267,7 +271,11 @@ public class PlotSquared { | |||||||
|             captionMap = this.captionLoader.loadAll(this.platform.getDirectory().toPath().resolve("lang")); |             captionMap = this.captionLoader.loadAll(this.platform.getDirectory().toPath().resolve("lang")); | ||||||
|         } else { |         } else { | ||||||
|             String fileName = "messages_" + Settings.Enabled_Components.DEFAULT_LOCALE + ".json"; |             String fileName = "messages_" + Settings.Enabled_Components.DEFAULT_LOCALE + ".json"; | ||||||
|             captionMap = this.captionLoader.loadSingle(this.platform.getDirectory().toPath().resolve("lang").resolve(fileName)); |             captionMap = this.captionLoader.loadOrCreateSingle(this.platform | ||||||
|  |                     .getDirectory() | ||||||
|  |                     .toPath() | ||||||
|  |                     .resolve("lang") | ||||||
|  |                     .resolve(fileName)); | ||||||
|         } |         } | ||||||
|         this.captionMaps.put(TranslatableCaption.DEFAULT_NAMESPACE, captionMap); |         this.captionMaps.put(TranslatableCaption.DEFAULT_NAMESPACE, captionMap); | ||||||
|         LOGGER.info( |         LOGGER.info( | ||||||
| @@ -287,11 +295,11 @@ public class PlotSquared { | |||||||
|  |  | ||||||
|     public void startExpiryTasks() { |     public void startExpiryTasks() { | ||||||
|         if (Settings.Enabled_Components.PLOT_EXPIRY) { |         if (Settings.Enabled_Components.PLOT_EXPIRY) { | ||||||
|             ExpireManager.IMP = new ExpireManager(this.eventDispatcher); |             ExpireManager expireManager = PlotSquared.platform().expireManager(); | ||||||
|             ExpireManager.IMP.runAutomatedTask(); |             expireManager.runAutomatedTask(); | ||||||
|             for (Settings.Auto_Clear settings : Settings.AUTO_CLEAR.getInstances()) { |             for (Settings.Auto_Clear settings : Settings.AUTO_CLEAR.getInstances()) { | ||||||
|                 ExpiryTask task = new ExpiryTask(settings, this.getPlotAreaManager()); |                 ExpiryTask task = new ExpiryTask(settings, this.getPlotAreaManager()); | ||||||
|                 ExpireManager.IMP.addTask(task); |                 expireManager.addTask(task); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| @@ -642,7 +650,8 @@ public class PlotSquared { | |||||||
|         } else { |         } else { | ||||||
|             list = new ArrayList<>(input); |             list = new ArrayList<>(input); | ||||||
|         } |         } | ||||||
|         list.sort(Comparator.comparingLong(a -> ExpireManager.IMP.getTimestamp(a.getOwnerAbs()))); |         ExpireManager expireManager = PlotSquared.platform().expireManager(); | ||||||
|  |         list.sort(Comparator.comparingLong(a -> expireManager.getTimestamp(a.getOwnerAbs()))); | ||||||
|         return list; |         return list; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -1007,7 +1016,7 @@ public class PlotSquared { | |||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Setup the configuration for a plot world based on world arguments. |      * Setup the configuration for a plot world based on world arguments. | ||||||
|      * |      * <p> | ||||||
|      * |      * | ||||||
|      * <i>e.g. /mv create <world> normal -g PlotSquared:<args></i> |      * <i>e.g. /mv create <world> normal -g PlotSquared:<args></i> | ||||||
|      * |      * | ||||||
| @@ -1273,7 +1282,7 @@ public class PlotSquared { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Setup the database connection. |      * Set up the database connection. | ||||||
|      */ |      */ | ||||||
|     public void setupDatabase() { |     public void setupDatabase() { | ||||||
|         try { |         try { | ||||||
|   | |||||||
| @@ -136,13 +136,9 @@ public class SimpleBackupManager implements BackupManager { | |||||||
|         return this.backupLimit; |         return this.backupLimit; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private static final class PlotCacheKey { |     private record PlotCacheKey( | ||||||
|  |             Plot plot | ||||||
|         private final Plot plot; |     ) { | ||||||
|  |  | ||||||
|         private PlotCacheKey(Plot plot) { |  | ||||||
|             this.plot = plot; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         @Override |         @Override | ||||||
|         public boolean equals(final Object o) { |         public boolean equals(final Object o) { | ||||||
|   | |||||||
| @@ -19,6 +19,7 @@ | |||||||
| package com.plotsquared.core.command; | package com.plotsquared.core.command; | ||||||
|  |  | ||||||
| import com.google.inject.Inject; | import com.google.inject.Inject; | ||||||
|  | import com.plotsquared.core.PlotSquared; | ||||||
| import com.plotsquared.core.configuration.Settings; | import com.plotsquared.core.configuration.Settings; | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.database.DBFunc; | import com.plotsquared.core.database.DBFunc; | ||||||
| @@ -26,7 +27,6 @@ import com.plotsquared.core.permissions.Permission; | |||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import com.plotsquared.core.util.EventDispatcher; | import com.plotsquared.core.util.EventDispatcher; | ||||||
| import com.plotsquared.core.util.Permissions; |  | ||||||
| import com.plotsquared.core.util.PlayerManager; | import com.plotsquared.core.util.PlayerManager; | ||||||
| import com.plotsquared.core.util.TabCompletions; | import com.plotsquared.core.util.TabCompletions; | ||||||
| import com.plotsquared.core.util.task.RunnableVal2; | import com.plotsquared.core.util.task.RunnableVal2; | ||||||
| @@ -60,18 +60,20 @@ public class Add extends Command { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public CompletableFuture<Boolean> execute( |     public CompletableFuture<Boolean> execute( | ||||||
|             final PlotPlayer<?> player, String[] args, |             final PlotPlayer<?> player, | ||||||
|  |             String[] args, | ||||||
|             RunnableVal3<Command, Runnable, Runnable> confirm, |             RunnableVal3<Command, Runnable, Runnable> confirm, | ||||||
|             RunnableVal2<Command, CommandResult> whenDone |             RunnableVal2<Command, CommandResult> whenDone | ||||||
|     ) throws CommandException { |     ) throws CommandException { | ||||||
|         final Plot plot = check(player.getCurrentPlot(), TranslatableCaption.of("errors.not_in_plot")); |         final Plot plot = check(player.getCurrentPlot(), TranslatableCaption.of("errors.not_in_plot")); | ||||||
|         checkTrue(plot.hasOwner(), TranslatableCaption.of("info.plot_unowned")); |         checkTrue(plot.hasOwner(), TranslatableCaption.of("info.plot_unowned")); | ||||||
|         checkTrue( |         checkTrue( | ||||||
|                 plot.isOwner(player.getUUID()) || Permissions |                 plot.isOwner(player.getUUID()) || player.hasPermission(Permission.PERMISSION_ADMIN_COMMAND_TRUST), | ||||||
|                         .hasPermission(player, Permission.PERMISSION_ADMIN_COMMAND_TRUST), |  | ||||||
|                 TranslatableCaption.of("permission.no_plot_perms") |                 TranslatableCaption.of("permission.no_plot_perms") | ||||||
|         ); |         ); | ||||||
|         checkTrue(args.length == 1, TranslatableCaption.of("commandconfig.command_syntax"), |         checkTrue( | ||||||
|  |                 args.length == 1, | ||||||
|  |                 TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                 TagResolver.resolver("value", Tag.inserting(Component.text("/plot add <player | *>"))) |                 TagResolver.resolver("value", Tag.inserting(Component.text("/plot add <player | *>"))) | ||||||
|         ); |         ); | ||||||
|         final CompletableFuture<Boolean> future = new CompletableFuture<>(); |         final CompletableFuture<Boolean> future = new CompletableFuture<>(); | ||||||
| @@ -96,13 +98,17 @@ public class Add extends Command { | |||||||
|                     int size = plot.getTrusted().size() + plot.getMembers().size(); |                     int size = plot.getTrusted().size() + plot.getMembers().size(); | ||||||
|                     while (iterator.hasNext()) { |                     while (iterator.hasNext()) { | ||||||
|                         UUID uuid = iterator.next(); |                         UUID uuid = iterator.next(); | ||||||
|                         if (uuid == DBFunc.EVERYONE && !( |                         if (uuid == DBFunc.EVERYONE && !(player.hasPermission(Permission.PERMISSION_TRUST_EVERYONE) || player.hasPermission( | ||||||
|                                 Permissions.hasPermission(player, Permission.PERMISSION_TRUST_EVERYONE) || Permissions |                                 Permission.PERMISSION_ADMIN_COMMAND_TRUST))) { | ||||||
|                                         .hasPermission(player, Permission.PERMISSION_ADMIN_COMMAND_TRUST))) { |  | ||||||
|                             player.sendMessage( |                             player.sendMessage( | ||||||
|                                     TranslatableCaption.of("errors.invalid_player"), |                                     TranslatableCaption.of("errors.invalid_player"), | ||||||
|                                     TagResolver.resolver("value", Tag.inserting( |                                     PlotSquared | ||||||
|                                             PlayerManager.resolveName(uuid).toComponent(player) |                                             .platform() | ||||||
|  |                                             .playerManager() | ||||||
|  |                                             .getUsernameCaption(uuid) | ||||||
|  |                                             .thenApply(caption -> TagResolver.resolver( | ||||||
|  |                                                     "value", | ||||||
|  |                                                     Tag.inserting(caption.toComponent(player)) | ||||||
|                                             )) |                                             )) | ||||||
|                             ); |                             ); | ||||||
|                             iterator.remove(); |                             iterator.remove(); | ||||||
| @@ -111,8 +117,10 @@ public class Add extends Command { | |||||||
|                         if (plot.isOwner(uuid)) { |                         if (plot.isOwner(uuid)) { | ||||||
|                             player.sendMessage( |                             player.sendMessage( | ||||||
|                                     TranslatableCaption.of("member.already_added"), |                                     TranslatableCaption.of("member.already_added"), | ||||||
|                                     TagResolver.resolver("player", Tag.inserting( |                                     PlotSquared.platform().playerManager().getUsernameCaption(uuid) | ||||||
|                                             PlayerManager.resolveName(uuid).toComponent(player) |                                             .thenApply(caption -> TagResolver.resolver( | ||||||
|  |                                                     "player", | ||||||
|  |                                                     Tag.inserting(caption.toComponent(player)) | ||||||
|                                             )) |                                             )) | ||||||
|                             ); |                             ); | ||||||
|                             iterator.remove(); |                             iterator.remove(); | ||||||
| @@ -121,8 +129,10 @@ public class Add extends Command { | |||||||
|                         if (plot.getMembers().contains(uuid)) { |                         if (plot.getMembers().contains(uuid)) { | ||||||
|                             player.sendMessage( |                             player.sendMessage( | ||||||
|                                     TranslatableCaption.of("member.already_added"), |                                     TranslatableCaption.of("member.already_added"), | ||||||
|                                     TagResolver.resolver("player", Tag.inserting( |                                     PlotSquared.platform().playerManager().getUsernameCaption(uuid) | ||||||
|                                             PlayerManager.resolveName(uuid).toComponent(player) |                                             .thenApply(caption -> TagResolver.resolver( | ||||||
|  |                                                     "player", | ||||||
|  |                                                     Tag.inserting(caption.toComponent(player)) | ||||||
|                                             )) |                                             )) | ||||||
|                             ); |                             ); | ||||||
|                             iterator.remove(); |                             iterator.remove(); | ||||||
| @@ -132,7 +142,7 @@ public class Add extends Command { | |||||||
|                     } |                     } | ||||||
|                     checkTrue(!uuids.isEmpty(), null); |                     checkTrue(!uuids.isEmpty(), null); | ||||||
|                     int localAddSize = plot.getMembers().size(); |                     int localAddSize = plot.getMembers().size(); | ||||||
|                     int maxAddSize = Permissions.hasPermissionRange(player, Permission.PERMISSION_ADD, Settings.Limit.MAX_PLOTS); |                     int maxAddSize = player.hasPermissionRange(Permission.PERMISSION_ADD, Settings.Limit.MAX_PLOTS); | ||||||
|                     if (localAddSize >= maxAddSize) { |                     if (localAddSize >= maxAddSize) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("members.plot_max_members_added"), |                                 TranslatableCaption.of("members.plot_max_members_added"), | ||||||
|   | |||||||
| @@ -26,7 +26,6 @@ import com.plotsquared.core.permissions.Permission; | |||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import com.plotsquared.core.util.MathMan; | import com.plotsquared.core.util.MathMan; | ||||||
| import com.plotsquared.core.util.Permissions; |  | ||||||
| import com.plotsquared.core.util.query.PlotQuery; | import com.plotsquared.core.util.query.PlotQuery; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; | import net.kyori.adventure.text.minimessage.tag.Tag; | ||||||
| @@ -205,7 +204,7 @@ public class Alias extends SubCommand { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     private boolean isPermitted(PlotPlayer<?> player, Permission permission) { |     private boolean isPermitted(PlotPlayer<?> player, Permission permission) { | ||||||
|         return Permissions.hasPermission(player, permission); |         return player.hasPermission(permission); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -47,7 +47,6 @@ import com.plotsquared.core.queue.QueueCoordinator; | |||||||
| import com.plotsquared.core.setup.PlotAreaBuilder; | import com.plotsquared.core.setup.PlotAreaBuilder; | ||||||
| import com.plotsquared.core.util.FileUtils; | import com.plotsquared.core.util.FileUtils; | ||||||
| import com.plotsquared.core.util.MathMan; | import com.plotsquared.core.util.MathMan; | ||||||
| import com.plotsquared.core.util.Permissions; |  | ||||||
| import com.plotsquared.core.util.RegionUtil; | import com.plotsquared.core.util.RegionUtil; | ||||||
| import com.plotsquared.core.util.SchematicHandler; | import com.plotsquared.core.util.SchematicHandler; | ||||||
| import com.plotsquared.core.util.SetupUtils; | import com.plotsquared.core.util.SetupUtils; | ||||||
| @@ -56,6 +55,7 @@ import com.plotsquared.core.util.TabCompletions; | |||||||
| import com.plotsquared.core.util.WorldUtil; | import com.plotsquared.core.util.WorldUtil; | ||||||
| import com.plotsquared.core.util.task.RunnableVal3; | import com.plotsquared.core.util.task.RunnableVal3; | ||||||
| import com.sk89q.worldedit.EditSession; | import com.sk89q.worldedit.EditSession; | ||||||
|  | import com.sk89q.worldedit.EditSessionBuilder; | ||||||
| import com.sk89q.worldedit.LocalSession; | import com.sk89q.worldedit.LocalSession; | ||||||
| import com.sk89q.worldedit.WorldEdit; | import com.sk89q.worldedit.WorldEdit; | ||||||
| import com.sk89q.worldedit.entity.Player; | import com.sk89q.worldedit.entity.Player; | ||||||
| @@ -139,7 +139,7 @@ public class Area extends SubCommand { | |||||||
|                     player.sendMessage(RequiredType.CONSOLE.getErrorMessage()); |                     player.sendMessage(RequiredType.CONSOLE.getErrorMessage()); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 if (!Permissions.hasPermission(player, Permission.PERMISSION_AREA_CREATE)) { |                 if (!player.hasPermission(Permission.PERMISSION_AREA_CREATE)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver( |                             TagResolver.resolver( | ||||||
| @@ -233,10 +233,9 @@ public class Area extends SubCommand { | |||||||
|                 try (final ClipboardWriter clipboardWriter = BuiltInClipboardFormat.SPONGE_SCHEMATIC.getWriter(new FileOutputStream( |                 try (final ClipboardWriter clipboardWriter = BuiltInClipboardFormat.SPONGE_SCHEMATIC.getWriter(new FileOutputStream( | ||||||
|                         file))) { |                         file))) { | ||||||
|                     final BlockArrayClipboard clipboard = new BlockArrayClipboard(selectedRegion); |                     final BlockArrayClipboard clipboard = new BlockArrayClipboard(selectedRegion); | ||||||
|                     final EditSession editSession = WorldEdit |                     EditSessionBuilder editSessionBuilder = WorldEdit.getInstance().newEditSessionBuilder(); | ||||||
|                             .getInstance() |                     editSessionBuilder.world(selectedRegion.getWorld()); | ||||||
|                             .getEditSessionFactory() |                     final EditSession editSession = editSessionBuilder.build(); | ||||||
|                             .getEditSession(selectedRegion.getWorld(), -1); |  | ||||||
|                     final ForwardExtentCopy forwardExtentCopy = |                     final ForwardExtentCopy forwardExtentCopy = | ||||||
|                             new ForwardExtentCopy(editSession, selectedRegion, clipboard, selectedRegion.getMinimumPoint()); |                             new ForwardExtentCopy(editSession, selectedRegion, clipboard, selectedRegion.getMinimumPoint()); | ||||||
|                     forwardExtentCopy.setCopyingBiomes(true); |                     forwardExtentCopy.setCopyingBiomes(true); | ||||||
| @@ -292,7 +291,7 @@ public class Area extends SubCommand { | |||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|             case "c", "setup", "create" -> { |             case "c", "setup", "create" -> { | ||||||
|                 if (!Permissions.hasPermission(player, Permission.PERMISSION_AREA_CREATE)) { |                 if (!player.hasPermission(Permission.PERMISSION_AREA_CREATE)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver( |                             TagResolver.resolver( | ||||||
| @@ -618,7 +617,7 @@ public class Area extends SubCommand { | |||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|             case "i", "info" -> { |             case "i", "info" -> { | ||||||
|                 if (!Permissions.hasPermission(player, Permission.PERMISSION_AREA_INFO)) { |                 if (!player.hasPermission(Permission.PERMISSION_AREA_INFO)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver( |                             TagResolver.resolver( | ||||||
| @@ -694,7 +693,7 @@ public class Area extends SubCommand { | |||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|             case "l", "list" -> { |             case "l", "list" -> { | ||||||
|                 if (!Permissions.hasPermission(player, Permission.PERMISSION_AREA_LIST)) { |                 if (!player.hasPermission(Permission.PERMISSION_AREA_LIST)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver( |                             TagResolver.resolver( | ||||||
| @@ -772,7 +771,7 @@ public class Area extends SubCommand { | |||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|             case "regen", "clear", "reset", "regenerate" -> { |             case "regen", "clear", "reset", "regenerate" -> { | ||||||
|                 if (!Permissions.hasPermission(player, Permission.PERMISSION_AREA_REGEN)) { |                 if (!player.hasPermission(Permission.PERMISSION_AREA_REGEN)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver( |                             TagResolver.resolver( | ||||||
| @@ -807,7 +806,7 @@ public class Area extends SubCommand { | |||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|             case "goto", "v", "teleport", "visit", "tp" -> { |             case "goto", "v", "teleport", "visit", "tp" -> { | ||||||
|                 if (!Permissions.hasPermission(player, Permission.PERMISSION_AREA_TP)) { |                 if (!player.hasPermission(Permission.PERMISSION_AREA_TP)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver("node", Tag.inserting(Permission.PERMISSION_AREA_TP)) |                             TagResolver.resolver("node", Tag.inserting(Permission.PERMISSION_AREA_TP)) | ||||||
| @@ -866,19 +865,19 @@ public class Area extends SubCommand { | |||||||
|     public Collection<Command> tab(final PlotPlayer<?> player, final String[] args, final boolean space) { |     public Collection<Command> tab(final PlotPlayer<?> player, final String[] args, final boolean space) { | ||||||
|         if (args.length == 1) { |         if (args.length == 1) { | ||||||
|             final List<String> completions = new LinkedList<>(); |             final List<String> completions = new LinkedList<>(); | ||||||
|             if (Permissions.hasPermission(player, Permission.PERMISSION_AREA_CREATE)) { |             if (player.hasPermission(Permission.PERMISSION_AREA_CREATE)) { | ||||||
|                 completions.add("create"); |                 completions.add("create"); | ||||||
|             } |             } | ||||||
|             if (Permissions.hasPermission(player, Permission.PERMISSION_AREA_CREATE)) { |             if (player.hasPermission(Permission.PERMISSION_AREA_CREATE)) { | ||||||
|                 completions.add("single"); |                 completions.add("single"); | ||||||
|             } |             } | ||||||
|             if (Permissions.hasPermission(player, Permission.PERMISSION_AREA_LIST)) { |             if (player.hasPermission(Permission.PERMISSION_AREA_LIST)) { | ||||||
|                 completions.add("list"); |                 completions.add("list"); | ||||||
|             } |             } | ||||||
|             if (Permissions.hasPermission(player, Permission.PERMISSION_AREA_INFO)) { |             if (player.hasPermission(Permission.PERMISSION_AREA_INFO)) { | ||||||
|                 completions.add("info"); |                 completions.add("info"); | ||||||
|             } |             } | ||||||
|             if (Permissions.hasPermission(player, Permission.PERMISSION_AREA_TP)) { |             if (player.hasPermission(Permission.PERMISSION_AREA_TP)) { | ||||||
|                 completions.add("tp"); |                 completions.add("tp"); | ||||||
|             } |             } | ||||||
|             final List<Command> commands = completions.stream().filter(completion -> completion |             final List<Command> commands = completions.stream().filter(completion -> completion | ||||||
| @@ -893,7 +892,7 @@ public class Area extends SubCommand { | |||||||
|                             CommandCategory.ADMINISTRATION |                             CommandCategory.ADMINISTRATION | ||||||
|                     ) { |                     ) { | ||||||
|                     }).collect(Collectors.toCollection(LinkedList::new)); |                     }).collect(Collectors.toCollection(LinkedList::new)); | ||||||
|             if (Permissions.hasPermission(player, Permission.PERMISSION_AREA) && args[0].length() > 0) { |             if (player.hasPermission(Permission.PERMISSION_AREA) && args[0].length() > 0) { | ||||||
|                 commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); |                 commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); | ||||||
|             } |             } | ||||||
|             return commands; |             return commands; | ||||||
|   | |||||||
| @@ -35,10 +35,10 @@ import com.plotsquared.core.player.PlotPlayer; | |||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
|  | import com.plotsquared.core.services.plots.AutoQuery; | ||||||
| import com.plotsquared.core.services.plots.AutoService; | import com.plotsquared.core.services.plots.AutoService; | ||||||
| import com.plotsquared.core.util.EconHandler; | import com.plotsquared.core.util.EconHandler; | ||||||
| import com.plotsquared.core.util.EventDispatcher; | import com.plotsquared.core.util.EventDispatcher; | ||||||
| import com.plotsquared.core.util.Permissions; |  | ||||||
| import com.plotsquared.core.util.PlotExpression; | import com.plotsquared.core.util.PlotExpression; | ||||||
| import com.plotsquared.core.util.task.AutoClaimFinishTask; | import com.plotsquared.core.util.task.AutoClaimFinishTask; | ||||||
| import com.plotsquared.core.util.task.RunnableVal; | import com.plotsquared.core.util.task.RunnableVal; | ||||||
| @@ -131,8 +131,8 @@ public class Auto extends SubCommand { | |||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("economy.removed_granted_plot"), |                                 TranslatableCaption.of("economy.removed_granted_plot"), | ||||||
|                                 TagResolver.builder() |                                 TagResolver.builder() | ||||||
|                                         .tag("usedGrants", Tag.inserting(Component.text(grantedPlots - left))) |                                         .tag("used_grants", Tag.inserting(Component.text(grantedPlots - left))) | ||||||
|                                         .tag("remainingGrants", Tag.inserting(Component.text(left))) |                                         .tag("remaining_grants", Tag.inserting(Component.text(left))) | ||||||
|                                         .build() |                                         .build() | ||||||
|                         ); |                         ); | ||||||
|                     } |                     } | ||||||
| @@ -249,11 +249,12 @@ public class Auto extends SubCommand { | |||||||
|         sizeX = event.getSizeX(); |         sizeX = event.getSizeX(); | ||||||
|         sizeZ = event.getSizeZ(); |         sizeZ = event.getSizeZ(); | ||||||
|         schematic = event.getSchematic(); |         schematic = event.getSchematic(); | ||||||
|         if (!force && mega && !Permissions.hasPermission(player, Permission.PERMISSION_AUTO_MEGA)) { |         if (!force && mega && !player.hasPermission(Permission.PERMISSION_AUTO_MEGA)) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("permission.no_permission"), |                     TranslatableCaption.of("permission.no_permission"), | ||||||
|                     TagResolver.resolver("node", Tag.inserting(Permission.PERMISSION_AUTO_MEGA)) |                     TagResolver.resolver("node", Tag.inserting(Permission.PERMISSION_AUTO_MEGA)) | ||||||
|             ); |             ); | ||||||
|  |             return false; | ||||||
|         } |         } | ||||||
|         if (!force && sizeX * sizeZ > Settings.Claim.MAX_AUTO_AREA) { |         if (!force && sizeX * sizeZ > Settings.Claim.MAX_AUTO_AREA) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
| @@ -283,11 +284,9 @@ public class Auto extends SubCommand { | |||||||
|                 ); |                 ); | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|             if (!force && !Permissions.hasPermission( |             if (!force && !player.hasPermission( | ||||||
|                     player, |  | ||||||
|                     Permission.PERMISSION_CLAIM_SCHEMATIC.format(schematic) |                     Permission.PERMISSION_CLAIM_SCHEMATIC.format(schematic) | ||||||
|             ) && !Permissions |             ) && !player.hasPermission("plots.admin.command.schematic")) { | ||||||
|                     .hasPermission(player, "plots.admin.command.schematic")) { |  | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission"), |                         TranslatableCaption.of("permission.no_permission"), | ||||||
|                         TagResolver.resolver("node", Tag.inserting(Component.text("plots.claim.%s0"))) |                         TagResolver.resolver("node", Tag.inserting(Component.text("plots.claim.%s0"))) | ||||||
| @@ -295,12 +294,15 @@ public class Auto extends SubCommand { | |||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         if (this.econHandler != null && plotarea.useEconomy()) { |         if (this.econHandler != null && plotarea.useEconomy() && !player.hasPermission(Permission.PERMISSION_ADMIN_BYPASS_ECON)) { | ||||||
|             PlotExpression costExp = plotarea.getPrices().get("claim"); |             PlotExpression costExp = plotarea.getPrices().get("claim"); | ||||||
|  |             PlotExpression mergeCostExp = plotarea.getPrices().get("merge"); | ||||||
|  |             int size = sizeX * sizeZ; | ||||||
|  |             double mergeCost = size <= 1 || mergeCostExp == null ? 0d : mergeCostExp.evaluate(size); | ||||||
|             double cost = costExp.evaluate(Settings.Limit.GLOBAL ? |             double cost = costExp.evaluate(Settings.Limit.GLOBAL ? | ||||||
|                     player.getPlotCount() : |                     player.getPlotCount() : | ||||||
|                     player.getPlotCount(plotarea.getWorldName())); |                     player.getPlotCount(plotarea.getWorldName())); | ||||||
|             cost = (sizeX * sizeZ) * cost; |             cost = size * cost + mergeCost; | ||||||
|             if (cost > 0d) { |             if (cost > 0d) { | ||||||
|                 if (!this.econHandler.isSupported()) { |                 if (!this.econHandler.isSupported()) { | ||||||
|                     player.sendMessage(TranslatableCaption.of("economy.vault_or_consumer_null")); |                     player.sendMessage(TranslatableCaption.of("economy.vault_or_consumer_null")); | ||||||
| @@ -328,7 +330,7 @@ public class Auto extends SubCommand { | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         List<Plot> plots = this.servicePipeline |         List<Plot> plots = this.servicePipeline | ||||||
|                 .pump(new AutoService.AutoQuery(player, null, sizeX, sizeZ, plotarea)) |                 .pump(new AutoQuery(player, null, sizeX, sizeZ, plotarea)) | ||||||
|                 .through(AutoService.class) |                 .through(AutoService.class) | ||||||
|                 .getResult(); |                 .getResult(); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -27,7 +27,6 @@ import com.plotsquared.core.configuration.caption.TranslatableCaption; | |||||||
| import com.plotsquared.core.permissions.Permission; | import com.plotsquared.core.permissions.Permission; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import com.plotsquared.core.util.Permissions; |  | ||||||
| import com.plotsquared.core.util.task.RunnableVal2; | import com.plotsquared.core.util.task.RunnableVal2; | ||||||
| import com.plotsquared.core.util.task.RunnableVal3; | import com.plotsquared.core.util.task.RunnableVal3; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| @@ -150,8 +149,7 @@ public final class Backup extends Command { | |||||||
|                             TranslatableCaption.of("generic.generic_merged").toComponent(player) |                             TranslatableCaption.of("generic.generic_merged").toComponent(player) | ||||||
|                     )) |                     )) | ||||||
|             ); |             ); | ||||||
|         } else if (!plot.isOwner(player.getUUID()) && !Permissions |         } else if (!plot.isOwner(player.getUUID()) && !player.hasPermission(Permission.PERMISSION_ADMIN_BACKUP_OTHER)) { | ||||||
|                 .hasPermission(player, Permission.PERMISSION_ADMIN_BACKUP_OTHER)) { |  | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("permission.no_permission"), |                     TranslatableCaption.of("permission.no_permission"), | ||||||
|                     TagResolver.resolver( |                     TagResolver.resolver( | ||||||
| @@ -215,8 +213,7 @@ public final class Backup extends Command { | |||||||
|             ); |             ); | ||||||
|         } else if (plot.getVolume() > Integer.MAX_VALUE) { |         } else if (plot.getVolume() > Integer.MAX_VALUE) { | ||||||
|             player.sendMessage(TranslatableCaption.of("schematics.schematic_too_large")); |             player.sendMessage(TranslatableCaption.of("schematics.schematic_too_large")); | ||||||
|         } else if (!plot.isOwner(player.getUUID()) && !Permissions |         } else if (!plot.isOwner(player.getUUID()) && !player.hasPermission(Permission.PERMISSION_ADMIN_BACKUP_OTHER)) { | ||||||
|                 .hasPermission(player, Permission.PERMISSION_ADMIN_BACKUP_OTHER)) { |  | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("permission.no_permission"), |                     TranslatableCaption.of("permission.no_permission"), | ||||||
|                     TagResolver.resolver( |                     TagResolver.resolver( | ||||||
| @@ -301,8 +298,7 @@ public final class Backup extends Command { | |||||||
|             ); |             ); | ||||||
|         } else if (plot.getVolume() > Integer.MAX_VALUE) { |         } else if (plot.getVolume() > Integer.MAX_VALUE) { | ||||||
|             player.sendMessage(TranslatableCaption.of("schematics.schematic_too_large")); |             player.sendMessage(TranslatableCaption.of("schematics.schematic_too_large")); | ||||||
|         } else if (!plot.isOwner(player.getUUID()) && !Permissions |         } else if (!plot.isOwner(player.getUUID()) && !player.hasPermission(Permission.PERMISSION_ADMIN_BACKUP_OTHER)) { | ||||||
|                 .hasPermission(player, Permission.PERMISSION_ADMIN_BACKUP_OTHER)) { |  | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("permission.no_permission"), |                     TranslatableCaption.of("permission.no_permission"), | ||||||
|                     TagResolver.resolver( |                     TagResolver.resolver( | ||||||
|   | |||||||
| @@ -27,7 +27,6 @@ import com.sk89q.worldedit.command.util.SuggestionHelper; | |||||||
| import com.sk89q.worldedit.world.biome.BiomeType; | import com.sk89q.worldedit.world.biome.BiomeType; | ||||||
| import com.sk89q.worldedit.world.biome.BiomeTypes; | import com.sk89q.worldedit.world.biome.BiomeTypes; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| import net.kyori.adventure.text.TextComponent; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; | import net.kyori.adventure.text.minimessage.tag.Tag; | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -21,8 +21,9 @@ package com.plotsquared.core.command; | |||||||
| import com.google.inject.Inject; | import com.google.inject.Inject; | ||||||
| import com.plotsquared.core.PlotSquared; | import com.plotsquared.core.PlotSquared; | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.events.PlotFlagRemoveEvent; | import com.plotsquared.core.events.PlayerBuyPlotEvent; | ||||||
| import com.plotsquared.core.events.Result; | import com.plotsquared.core.events.Result; | ||||||
|  | import com.plotsquared.core.player.OfflinePlotPlayer; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
| @@ -88,22 +89,30 @@ public class Buy extends Command { | |||||||
|                 TranslatableCaption.of("permission.cant_claim_more_plots"), |                 TranslatableCaption.of("permission.cant_claim_more_plots"), | ||||||
|                 TagResolver.resolver("amount", Tag.inserting(Component.text(player.getAllowedPlots()))) |                 TagResolver.resolver("amount", Tag.inserting(Component.text(player.getAllowedPlots()))) | ||||||
|         ); |         ); | ||||||
|         double price = plot.getFlag(PriceFlag.class); |         double priceFlag = plot.getFlag(PriceFlag.class); | ||||||
|         if (price <= 0) { |         if (priceFlag <= 0) { | ||||||
|             throw new CommandException(TranslatableCaption.of("economy.not_for_sale")); |             throw new CommandException(TranslatableCaption.of("economy.not_for_sale")); | ||||||
|         } |         } | ||||||
|         checkTrue( |         checkTrue( | ||||||
|                 this.econHandler.isSupported(), |                 this.econHandler.isSupported(), | ||||||
|                 TranslatableCaption.of("economy.vault_or_consumer_null") |                 TranslatableCaption.of("economy.vault_or_consumer_null") | ||||||
|         ); |         ); | ||||||
|         checkTrue( |  | ||||||
|                 this.econHandler.getMoney(player) >= price, |         PlayerBuyPlotEvent event = this.eventDispatcher.callPlayerBuyPlot(player, plot, priceFlag); | ||||||
|  |         if (event.getEventResult() == Result.DENY) { | ||||||
|  |             throw new CommandException(TranslatableCaption.of("economy.cannot_buy_blocked")); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         double price = event.getEventResult() == Result.FORCE ? 0 : event.price(); | ||||||
|  |         if (this.econHandler.getMoney(player) < price) { | ||||||
|  |             throw new CommandException( | ||||||
|                     TranslatableCaption.of("economy.cannot_afford_plot"), |                     TranslatableCaption.of("economy.cannot_afford_plot"), | ||||||
|                     TagResolver.builder() |                     TagResolver.builder() | ||||||
|                             .tag("money", Tag.inserting(Component.text(this.econHandler.format(price)))) |                             .tag("money", Tag.inserting(Component.text(this.econHandler.format(price)))) | ||||||
|                             .tag("balance", Tag.inserting(Component.text(this.econHandler.format(this.econHandler.getMoney(player))))) |                             .tag("balance", Tag.inserting(Component.text(this.econHandler.format(this.econHandler.getMoney(player))))) | ||||||
|                             .build() |                             .build() | ||||||
|             ); |             ); | ||||||
|  |         } | ||||||
|         this.econHandler.withdrawMoney(player, price); |         this.econHandler.withdrawMoney(player, price); | ||||||
|         // Failure |         // Failure | ||||||
|         // Success |         // Success | ||||||
| @@ -113,7 +122,8 @@ public class Buy extends Command { | |||||||
|                     TagResolver.resolver("money", Tag.inserting(Component.text(this.econHandler.format(price)))) |                     TagResolver.resolver("money", Tag.inserting(Component.text(this.econHandler.format(price)))) | ||||||
|             ); |             ); | ||||||
|  |  | ||||||
|             this.econHandler.depositMoney(PlotSquared.platform().playerManager().getOfflinePlayer(plot.getOwnerAbs()), price); |             OfflinePlotPlayer previousOwner = PlotSquared.platform().playerManager().getOfflinePlayer(plot.getOwnerAbs()); | ||||||
|  |             this.econHandler.depositMoney(previousOwner, price); | ||||||
|  |  | ||||||
|             PlotPlayer<?> owner = PlotSquared.platform().playerManager().getPlayerIfExists(plot.getOwnerAbs()); |             PlotPlayer<?> owner = PlotSquared.platform().playerManager().getPlayerIfExists(plot.getOwnerAbs()); | ||||||
|             if (owner != null) { |             if (owner != null) { | ||||||
| @@ -127,15 +137,16 @@ public class Buy extends Command { | |||||||
|                 ); |                 ); | ||||||
|             } |             } | ||||||
|             PlotFlag<?, ?> plotFlag = plot.getFlagContainer().getFlag(PriceFlag.class); |             PlotFlag<?, ?> plotFlag = plot.getFlagContainer().getFlag(PriceFlag.class); | ||||||
|             PlotFlagRemoveEvent event = this.eventDispatcher.callFlagRemove(plotFlag, plot); |             if (this.eventDispatcher.callFlagRemove(plotFlag, plot).getEventResult() != Result.DENY) { | ||||||
|             if (event.getEventResult() != Result.DENY) { |                 plot.removeFlag(plotFlag); | ||||||
|                 plot.removeFlag(event.getFlag()); |  | ||||||
|             } |             } | ||||||
|             plot.setOwner(player.getUUID()); |             plot.setOwner(player.getUUID()); | ||||||
|  |             plot.getPlotModificationManager().setSign(player.getName()); | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("working.claimed"), |                     TranslatableCaption.of("working.claimed"), | ||||||
|                     TagResolver.resolver("plot", Tag.inserting(Component.text(plot.getId().toString()))) |                     TagResolver.resolver("plot", Tag.inserting(Component.text(plot.getId().toString()))) | ||||||
|             ); |             ); | ||||||
|  |             this.eventDispatcher.callPostPlayerBuyPlot(player, previousOwner, plot, price); | ||||||
|             whenDone.run(Buy.this, CommandResult.SUCCESS); |             whenDone.run(Buy.this, CommandResult.SUCCESS); | ||||||
|         }, () -> { |         }, () -> { | ||||||
|             this.econHandler.depositMoney(player, price); |             this.econHandler.depositMoney(player, price); | ||||||
|   | |||||||
| @@ -29,7 +29,6 @@ import com.plotsquared.core.plot.flag.implementations.HostileCapFlag; | |||||||
| import com.plotsquared.core.plot.flag.implementations.MiscCapFlag; | import com.plotsquared.core.plot.flag.implementations.MiscCapFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.MobCapFlag; | import com.plotsquared.core.plot.flag.implementations.MobCapFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.VehicleCapFlag; | import com.plotsquared.core.plot.flag.implementations.VehicleCapFlag; | ||||||
| import com.plotsquared.core.util.Permissions; |  | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| import net.kyori.adventure.text.ComponentLike; | import net.kyori.adventure.text.ComponentLike; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; | import net.kyori.adventure.text.minimessage.tag.Tag; | ||||||
| @@ -54,8 +53,7 @@ public class Caps extends SubCommand { | |||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         if (!plot.isAdded(player.getUUID()) && !Permissions |         if (!plot.isAdded(player.getUUID()) && !player.hasPermission(Permission.PERMISSION_ADMIN_CAPS_OTHER)) { | ||||||
|                 .hasPermission(player, Permission.PERMISSION_ADMIN_CAPS_OTHER)) { |  | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("permission.no_permission"), |                     TranslatableCaption.of("permission.no_permission"), | ||||||
|                     TagResolver.resolver("node", Tag.inserting(Permission.PERMISSION_ADMIN_CAPS_OTHER)) |                     TagResolver.resolver("node", Tag.inserting(Permission.PERMISSION_ADMIN_CAPS_OTHER)) | ||||||
|   | |||||||
| @@ -35,7 +35,6 @@ import com.plotsquared.core.plot.Plot; | |||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
| import com.plotsquared.core.util.EconHandler; | import com.plotsquared.core.util.EconHandler; | ||||||
| import com.plotsquared.core.util.EventDispatcher; | import com.plotsquared.core.util.EventDispatcher; | ||||||
| import com.plotsquared.core.util.Permissions; |  | ||||||
| import com.plotsquared.core.util.PlotExpression; | import com.plotsquared.core.util.PlotExpression; | ||||||
| import com.plotsquared.core.util.task.TaskManager; | import com.plotsquared.core.util.task.TaskManager; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| @@ -131,9 +130,8 @@ public class Claim extends SubCommand { | |||||||
|                                         .build() |                                         .build() | ||||||
|                         ); |                         ); | ||||||
|                     } |                     } | ||||||
|                     if (!Permissions.hasPermission(player, Permission.PERMISSION_CLAIM_SCHEMATIC |                     if (!player.hasPermission(Permission.PERMISSION_CLAIM_SCHEMATIC | ||||||
|                             .format(schematic)) && !Permissions.hasPermission( |                             .format(schematic)) && !player.hasPermission( | ||||||
|                             player, |  | ||||||
|                             "plots.admin.command.schematic" |                             "plots.admin.command.schematic" | ||||||
|                     ) && !force) { |                     ) && !force) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
| @@ -143,7 +141,7 @@ public class Claim extends SubCommand { | |||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             if (this.econHandler.isEnabled(area) && !force) { |             if (this.econHandler.isEnabled(area) && !force && !player.hasPermission(Permission.PERMISSION_ADMIN_BYPASS_ECON)) { | ||||||
|                 PlotExpression costExr = area.getPrices().get("claim"); |                 PlotExpression costExr = area.getPrices().get("claim"); | ||||||
|                 double cost = costExr.evaluate(currentPlots); |                 double cost = costExr.evaluate(currentPlots); | ||||||
|                 if (cost > 0d) { |                 if (cost > 0d) { | ||||||
| @@ -188,14 +186,14 @@ public class Claim extends SubCommand { | |||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("economy.removed_granted_plot"), |                         TranslatableCaption.of("economy.removed_granted_plot"), | ||||||
|                         TagResolver.builder() |                         TagResolver.builder() | ||||||
|                                 .tag("usedGrants", Tag.inserting(Component.text(grants - 1))) |                                 .tag("used_grants", Tag.inserting(Component.text(grants - 1))) | ||||||
|                                 .tag("remainingGrants", Tag.inserting(Component.text(grants))) |                                 .tag("remaining_grants", Tag.inserting(Component.text(grants))) | ||||||
|                                 .build() |                                 .build() | ||||||
|                 ); |                 ); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         if (!Permissions.hasPermission(player, Permission.PERMISSION_ADMIN_BYPASS_BORDER)) { |         if (!player.hasPermission(Permission.PERMISSION_ADMIN_BYPASS_BORDER)) { | ||||||
|             int border = area.getBorder(); |             int border = area.getBorder(false); | ||||||
|             if (border != Integer.MAX_VALUE && plot.getDistanceFromOrigin() > border && !force) { |             if (border != Integer.MAX_VALUE && plot.getDistanceFromOrigin() > border && !force) { | ||||||
|                 player.sendMessage(TranslatableCaption.of("border.denied")); |                 player.sendMessage(TranslatableCaption.of("border.denied")); | ||||||
|                 return false; |                 return false; | ||||||
|   | |||||||
| @@ -32,7 +32,6 @@ import com.plotsquared.core.plot.flag.implementations.AnalysisFlag; | |||||||
| import com.plotsquared.core.plot.flag.implementations.DoneFlag; | import com.plotsquared.core.plot.flag.implementations.DoneFlag; | ||||||
| import com.plotsquared.core.queue.GlobalBlockQueue; | import com.plotsquared.core.queue.GlobalBlockQueue; | ||||||
| import com.plotsquared.core.util.EventDispatcher; | import com.plotsquared.core.util.EventDispatcher; | ||||||
| import com.plotsquared.core.util.Permissions; |  | ||||||
| import com.plotsquared.core.util.task.RunnableVal2; | import com.plotsquared.core.util.task.RunnableVal2; | ||||||
| import com.plotsquared.core.util.task.RunnableVal3; | import com.plotsquared.core.util.task.RunnableVal3; | ||||||
| import com.plotsquared.core.util.task.TaskManager; | import com.plotsquared.core.util.task.TaskManager; | ||||||
| @@ -91,13 +90,14 @@ public class Clear extends Command { | |||||||
|         } |         } | ||||||
|         boolean force = eventResult == Result.FORCE; |         boolean force = eventResult == Result.FORCE; | ||||||
|         checkTrue( |         checkTrue( | ||||||
|                 force || plot.isOwner(player.getUUID()) || Permissions |                 force || plot.isOwner(player.getUUID()) || player.hasPermission("plots.admin.command.clear"), | ||||||
|                         .hasPermission(player, "plots.admin.command.clear"), |  | ||||||
|                 TranslatableCaption.of("permission.no_plot_perms") |                 TranslatableCaption.of("permission.no_plot_perms") | ||||||
|         ); |         ); | ||||||
|         checkTrue(plot.getRunning() == 0, TranslatableCaption.of("errors.wait_for_timer")); |         checkTrue(plot.getRunning() == 0, TranslatableCaption.of("errors.wait_for_timer")); | ||||||
|         checkTrue(force || !Settings.Done.RESTRICT_BUILDING || !DoneFlag.isDone(plot) || Permissions |         checkTrue( | ||||||
|                 .hasPermission(player, "plots.continue"), TranslatableCaption.of("done.done_already_done")); |                 force || !Settings.Done.RESTRICT_BUILDING || !DoneFlag.isDone(plot) || player.hasPermission("plots.continue"), | ||||||
|  |                 TranslatableCaption.of("done.done_already_done") | ||||||
|  |         ); | ||||||
|         confirm.run(this, () -> { |         confirm.run(this, () -> { | ||||||
|             if (Settings.Teleport.ON_CLEAR) { |             if (Settings.Teleport.ON_CLEAR) { | ||||||
|                 plot.getPlayersInPlot().forEach(playerInPlot -> plot.teleportPlayer(playerInPlot, TeleportCause.COMMAND_CLEAR, |                 plot.getPlayersInPlot().forEach(playerInPlot -> plot.teleportPlayer(playerInPlot, TeleportCause.COMMAND_CLEAR, | ||||||
| @@ -107,9 +107,7 @@ public class Clear extends Command { | |||||||
|             } |             } | ||||||
|             BackupManager.backup(player, plot, () -> { |             BackupManager.backup(player, plot, () -> { | ||||||
|                 final long start = System.currentTimeMillis(); |                 final long start = System.currentTimeMillis(); | ||||||
|                 boolean result = plot.getPlotModificationManager().clear(true, false, player, () -> { |                 boolean result = plot.getPlotModificationManager().clear(true, false, player, () -> TaskManager.runTask(() -> { | ||||||
|                     plot.getPlotModificationManager().unlink(); |  | ||||||
|                     TaskManager.runTask(() -> { |  | ||||||
|                     plot.removeRunning(); |                     plot.removeRunning(); | ||||||
|                     // If the state changes, then mark it as no longer done |                     // If the state changes, then mark it as no longer done | ||||||
|                     if (DoneFlag.isDone(plot)) { |                     if (DoneFlag.isDone(plot)) { | ||||||
| @@ -137,8 +135,8 @@ public class Clear extends Command { | |||||||
|                                     .tag("plot", Tag.inserting(Component.text(plot.getId().toString()))) |                                     .tag("plot", Tag.inserting(Component.text(plot.getId().toString()))) | ||||||
|                                     .build() |                                     .build() | ||||||
|                     ); |                     ); | ||||||
|                     }); |                     this.eventDispatcher.callPostPlotClear(player, plot); | ||||||
|                 }); |                 })); | ||||||
|                 if (!result) { |                 if (!result) { | ||||||
|                     player.sendMessage(TranslatableCaption.of("errors.wait_for_timer")); |                     player.sendMessage(TranslatableCaption.of("errors.wait_for_timer")); | ||||||
|                 } else { |                 } else { | ||||||
|   | |||||||
| @@ -33,7 +33,6 @@ import com.plotsquared.core.plot.PlotArea; | |||||||
| import com.plotsquared.core.plot.PlotCluster; | import com.plotsquared.core.plot.PlotCluster; | ||||||
| import com.plotsquared.core.plot.PlotId; | import com.plotsquared.core.plot.PlotId; | ||||||
| import com.plotsquared.core.util.ComponentHelper; | import com.plotsquared.core.util.ComponentHelper; | ||||||
| import com.plotsquared.core.util.Permissions; |  | ||||||
| import com.plotsquared.core.util.TabCompletions; | import com.plotsquared.core.util.TabCompletions; | ||||||
| import com.plotsquared.core.util.query.PlotQuery; | import com.plotsquared.core.util.query.PlotQuery; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| @@ -47,6 +46,7 @@ import java.util.Collections; | |||||||
| import java.util.HashSet; | import java.util.HashSet; | ||||||
| import java.util.LinkedList; | import java.util.LinkedList; | ||||||
| import java.util.List; | import java.util.List; | ||||||
|  | import java.util.Objects; | ||||||
| import java.util.Set; | import java.util.Set; | ||||||
| import java.util.UUID; | import java.util.UUID; | ||||||
| import java.util.concurrent.TimeoutException; | import java.util.concurrent.TimeoutException; | ||||||
| @@ -78,9 +78,8 @@ public class Cluster extends SubCommand { | |||||||
|         } |         } | ||||||
|         String sub = args[0].toLowerCase(); |         String sub = args[0].toLowerCase(); | ||||||
|         switch (sub) { |         switch (sub) { | ||||||
|             case "l": |             case "l", "list" -> { | ||||||
|             case "list": { |                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_LIST)) { | ||||||
|                 if (!Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_LIST)) { |  | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver( |                             TagResolver.resolver( | ||||||
| @@ -134,9 +133,8 @@ public class Cluster extends SubCommand { | |||||||
|                 } |                 } | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|             case "c": |             case "c", "create" -> { | ||||||
|             case "create": { |                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_CREATE)) { | ||||||
|                 if (!Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_CREATE)) { |  | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver( |                             TagResolver.resolver( | ||||||
| @@ -213,8 +211,7 @@ public class Cluster extends SubCommand { | |||||||
|                 } |                 } | ||||||
|                 Set<Plot> plots = area.getPlotSelectionOwned(pos1, pos2); |                 Set<Plot> plots = area.getPlotSelectionOwned(pos1, pos2); | ||||||
|                 if (!plots.isEmpty()) { |                 if (!plots.isEmpty()) { | ||||||
|                     if (!Permissions |                     if (!player.hasPermission(Permission.PERMISSION_CLUSTER_CREATE_OTHER)) { | ||||||
|                             .hasPermission(player, Permission.PERMISSION_CLUSTER_CREATE_OTHER)) { |  | ||||||
|                         UUID uuid = player.getUUID(); |                         UUID uuid = player.getUUID(); | ||||||
|                         for (Plot plot : plots) { |                         for (Plot plot : plots) { | ||||||
|                             if (!plot.isOwner(uuid)) { |                             if (!plot.isOwner(uuid)) { | ||||||
| @@ -238,8 +235,8 @@ public class Cluster extends SubCommand { | |||||||
|                 } else { |                 } else { | ||||||
|                     current = player.getPlayerClusterCount(player.getLocation().getWorldName()); |                     current = player.getPlayerClusterCount(player.getLocation().getWorldName()); | ||||||
|                 } |                 } | ||||||
|                 int allowed = Permissions |                 int allowed = player.hasPermissionRange( | ||||||
|                         .hasPermissionRange(player, Permission.PERMISSION_CLUSTER_SIZE, |                         Permission.PERMISSION_CLUSTER_SIZE, | ||||||
|                         Settings.Limit.MAX_PLOTS |                         Settings.Limit.MAX_PLOTS | ||||||
|                 ); |                 ); | ||||||
|                 if (current + cluster.getArea() > allowed) { |                 if (current + cluster.getArea() > allowed) { | ||||||
| @@ -271,10 +268,8 @@ public class Cluster extends SubCommand { | |||||||
|                 ); |                 ); | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|             case "disband": |             case "disband", "del", "delete" -> { | ||||||
|             case "del": |                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_DELETE)) { | ||||||
|             case "delete": { |  | ||||||
|                 if (!Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_DELETE)) { |  | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver( |                             TagResolver.resolver( | ||||||
| @@ -314,8 +309,7 @@ public class Cluster extends SubCommand { | |||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|                 if (!cluster.owner.equals(player.getUUID())) { |                 if (!cluster.owner.equals(player.getUUID())) { | ||||||
|                     if (!Permissions |                     if (!player.hasPermission(Permission.PERMISSION_CLUSTER_DELETE_OTHER)) { | ||||||
|                             .hasPermission(player, Permission.PERMISSION_CLUSTER_DELETE_OTHER)) { |  | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission"), |                                 TranslatableCaption.of("permission.no_permission"), | ||||||
|                                 TagResolver.resolver( |                                 TagResolver.resolver( | ||||||
| @@ -333,9 +327,8 @@ public class Cluster extends SubCommand { | |||||||
|                 )); |                 )); | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|             case "res": |             case "res", "resize" -> { | ||||||
|             case "resize": { |                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_RESIZE)) { | ||||||
|                 if (!Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_RESIZE)) { |  | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver( |                             TagResolver.resolver( | ||||||
| @@ -378,8 +371,7 @@ public class Cluster extends SubCommand { | |||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 if (!cluster.hasHelperRights(player.getUUID())) { |                 if (!cluster.hasHelperRights(player.getUUID())) { | ||||||
|                     if (!Permissions |                     if (!player.hasPermission(Permission.PERMISSION_CLUSTER_RESIZE_OTHER)) { | ||||||
|                             .hasPermission(player, Permission.PERMISSION_CLUSTER_RESIZE_OTHER)) { |  | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission"), |                                 TranslatableCaption.of("permission.no_permission"), | ||||||
|                                 TagResolver.resolver( |                                 TagResolver.resolver( | ||||||
| @@ -406,8 +398,7 @@ public class Cluster extends SubCommand { | |||||||
|                 removed.removeAll(newPlots); |                 removed.removeAll(newPlots); | ||||||
|                 // Check expand / shrink |                 // Check expand / shrink | ||||||
|                 if (!removed.isEmpty()) { |                 if (!removed.isEmpty()) { | ||||||
|                     if (!Permissions |                     if (!player.hasPermission(Permission.PERMISSION_CLUSTER_RESIZE_SHRINK)) { | ||||||
|                             .hasPermission(player, Permission.PERMISSION_CLUSTER_RESIZE_SHRINK)) { |  | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission"), |                                 TranslatableCaption.of("permission.no_permission"), | ||||||
|                                 TagResolver.resolver( |                                 TagResolver.resolver( | ||||||
| @@ -420,8 +411,7 @@ public class Cluster extends SubCommand { | |||||||
|                 } |                 } | ||||||
|                 newPlots.removeAll(existing); |                 newPlots.removeAll(existing); | ||||||
|                 if (!newPlots.isEmpty()) { |                 if (!newPlots.isEmpty()) { | ||||||
|                     if (!Permissions |                     if (!player.hasPermission(Permission.PERMISSION_CLUSTER_RESIZE_EXPAND)) { | ||||||
|                             .hasPermission(player, Permission.PERMISSION_CLUSTER_RESIZE_EXPAND)) { |  | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission"), |                                 TranslatableCaption.of("permission.no_permission"), | ||||||
|                                 TagResolver.resolver( |                                 TagResolver.resolver( | ||||||
| @@ -440,7 +430,8 @@ public class Cluster extends SubCommand { | |||||||
|                     current = player.getPlayerClusterCount(player.getLocation().getWorldName()); |                     current = player.getPlayerClusterCount(player.getLocation().getWorldName()); | ||||||
|                 } |                 } | ||||||
|                 current -= cluster.getArea() + (1 + pos2.getX() - pos1.getX()) * (1 + pos2.getY() - pos1.getY()); |                 current -= cluster.getArea() + (1 + pos2.getX() - pos1.getX()) * (1 + pos2.getY() - pos1.getY()); | ||||||
|                 int allowed = Permissions.hasPermissionRange(player, Permission.PERMISSION_CLUSTER, |                 int allowed = player.hasPermissionRange( | ||||||
|  |                         Permission.PERMISSION_CLUSTER, | ||||||
|                         Settings.Limit.MAX_PLOTS |                         Settings.Limit.MAX_PLOTS | ||||||
|                 ); |                 ); | ||||||
|                 if (current + cluster.getArea() > allowed) { |                 if (current + cluster.getArea() > allowed) { | ||||||
| @@ -457,10 +448,8 @@ public class Cluster extends SubCommand { | |||||||
|                 player.sendMessage(TranslatableCaption.of("cluster.cluster_resized")); |                 player.sendMessage(TranslatableCaption.of("cluster.cluster_resized")); | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|             case "add": |             case "add", "inv", "invite" -> { | ||||||
|             case "inv": |                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_INVITE)) { | ||||||
|             case "invite": { |  | ||||||
|                 if (!Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_INVITE)) { |  | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver( |                             TagResolver.resolver( | ||||||
| @@ -488,8 +477,7 @@ public class Cluster extends SubCommand { | |||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 if (!cluster.hasHelperRights(player.getUUID())) { |                 if (!cluster.hasHelperRights(player.getUUID())) { | ||||||
|                     if (!Permissions |                     if (!player.hasPermission(Permission.PERMISSION_CLUSTER_INVITE_OTHER)) { | ||||||
|                             .hasPermission(player, Permission.PERMISSION_CLUSTER_INVITE_OTHER)) { |  | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission"), |                                 TranslatableCaption.of("permission.no_permission"), | ||||||
|                                 TagResolver.resolver( |                                 TagResolver.resolver( | ||||||
| @@ -529,10 +517,8 @@ public class Cluster extends SubCommand { | |||||||
|                         }); |                         }); | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|             case "k": |             case "k", "remove", "kick" -> { | ||||||
|             case "remove": |                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_KICK)) { | ||||||
|             case "kick": { |  | ||||||
|                 if (!Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_KICK)) { |  | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver( |                             TagResolver.resolver( | ||||||
| @@ -559,8 +545,7 @@ public class Cluster extends SubCommand { | |||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 if (!cluster.hasHelperRights(player.getUUID())) { |                 if (!cluster.hasHelperRights(player.getUUID())) { | ||||||
|                     if (!Permissions |                     if (!player.hasPermission(Permission.PERMISSION_CLUSTER_KICK_OTHER)) { | ||||||
|                             .hasPermission(player, Permission.PERMISSION_CLUSTER_KICK_OTHER)) { |  | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission"), |                                 TranslatableCaption.of("permission.no_permission"), | ||||||
|                                 TagResolver.resolver( |                                 TagResolver.resolver( | ||||||
| @@ -612,9 +597,8 @@ public class Cluster extends SubCommand { | |||||||
|                         }); |                         }); | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|             case "quit": |             case "quit", "leave" -> { | ||||||
|             case "leave": { |                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_LEAVE)) { | ||||||
|                 if (!Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_LEAVE)) { |  | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver( |                             TagResolver.resolver( | ||||||
| @@ -674,8 +658,8 @@ public class Cluster extends SubCommand { | |||||||
|                 removePlayerPlots(cluster, uuid, player.getLocation().getWorldName()); |                 removePlayerPlots(cluster, uuid, player.getLocation().getWorldName()); | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|             case "members": { |             case "members" -> { | ||||||
|                 if (!Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_HELPERS)) { |                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_HELPERS)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver( |                             TagResolver.resolver( | ||||||
| @@ -735,10 +719,8 @@ public class Cluster extends SubCommand { | |||||||
|                         }); |                         }); | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|             case "spawn": |             case "spawn", "home", "tp" -> { | ||||||
|             case "home": |                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_TP)) { | ||||||
|             case "tp": { |  | ||||||
|                 if (!Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_TP)) { |  | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver( |                             TagResolver.resolver( | ||||||
| @@ -770,7 +752,7 @@ public class Cluster extends SubCommand { | |||||||
|                 } |                 } | ||||||
|                 UUID uuid = player.getUUID(); |                 UUID uuid = player.getUUID(); | ||||||
|                 if (!cluster.isAdded(uuid)) { |                 if (!cluster.isAdded(uuid)) { | ||||||
|                     if (!Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_TP_OTHER)) { |                     if (!player.hasPermission(Permission.PERMISSION_CLUSTER_TP_OTHER)) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission"), |                                 TranslatableCaption.of("permission.no_permission"), | ||||||
|                                 TagResolver.resolver( |                                 TagResolver.resolver( | ||||||
| @@ -785,11 +767,8 @@ public class Cluster extends SubCommand { | |||||||
|                 player.sendMessage(TranslatableCaption.of("cluster.cluster_teleporting")); |                 player.sendMessage(TranslatableCaption.of("cluster.cluster_teleporting")); | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|             case "i": |             case "i", "info", "show", "information" -> { | ||||||
|             case "info": |                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_INFO)) { | ||||||
|             case "show": |  | ||||||
|             case "information": { |  | ||||||
|                 if (!Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_INFO)) { |  | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver( |                             TagResolver.resolver( | ||||||
| @@ -835,11 +814,7 @@ public class Cluster extends SubCommand { | |||||||
|                                 player.sendMessage(TranslatableCaption.of("players.fetching_players_timeout")); |                                 player.sendMessage(TranslatableCaption.of("players.fetching_players_timeout")); | ||||||
|                             } else { |                             } else { | ||||||
|                                 final String owner; |                                 final String owner; | ||||||
|                                 if (username == null) { |                                 owner = Objects.requireNonNullElse(username, "unknown"); | ||||||
|                                     owner = "unknown"; |  | ||||||
|                                 } else { |  | ||||||
|                                     owner = username; |  | ||||||
|                                 } |  | ||||||
|                                 String name = cluster.getName(); |                                 String name = cluster.getName(); | ||||||
|                                 String size = (cluster.getP2().getX() - cluster.getP1().getX() + 1) + "x" + ( |                                 String size = (cluster.getP2().getX() - cluster.getP1().getX() + 1) + "x" + ( | ||||||
|                                         cluster.getP2().getY() - cluster.getP1().getY() + 1); |                                         cluster.getP2().getY() - cluster.getP1().getY() + 1); | ||||||
| @@ -857,10 +832,8 @@ public class Cluster extends SubCommand { | |||||||
|                         }); |                         }); | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|             case "sh": |             case "sh", "setspawn", "sethome" -> { | ||||||
|             case "setspawn": |                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_SETHOME)) { | ||||||
|             case "sethome": { |  | ||||||
|                 if (!Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_SETHOME)) { |  | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver("node", Tag.inserting(Permission.PERMISSION_CLUSTER_SETHOME)) |                             TagResolver.resolver("node", Tag.inserting(Permission.PERMISSION_CLUSTER_SETHOME)) | ||||||
| @@ -884,8 +857,7 @@ public class Cluster extends SubCommand { | |||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 if (!cluster.hasHelperRights(player.getUUID())) { |                 if (!cluster.hasHelperRights(player.getUUID())) { | ||||||
|                     if (!Permissions |                     if (!player.hasPermission(Permission.PERMISSION_CLUSTER_SETHOME_OTHER)) { | ||||||
|                             .hasPermission(player, Permission.PERMISSION_CLUSTER_SETHOME_OTHER)) { |  | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission"), |                                 TranslatableCaption.of("permission.no_permission"), | ||||||
|                                 TagResolver.resolver( |                                 TagResolver.resolver( | ||||||
| @@ -937,37 +909,37 @@ public class Cluster extends SubCommand { | |||||||
|     public Collection<Command> tab(final PlotPlayer<?> player, final String[] args, final boolean space) { |     public Collection<Command> tab(final PlotPlayer<?> player, final String[] args, final boolean space) { | ||||||
|         if (args.length == 1) { |         if (args.length == 1) { | ||||||
|             final List<String> completions = new LinkedList<>(); |             final List<String> completions = new LinkedList<>(); | ||||||
|             if (Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_LIST)) { |             if (player.hasPermission(Permission.PERMISSION_CLUSTER_LIST)) { | ||||||
|                 completions.add("list"); |                 completions.add("list"); | ||||||
|             } |             } | ||||||
|             if (Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_CREATE)) { |             if (player.hasPermission(Permission.PERMISSION_CLUSTER_CREATE)) { | ||||||
|                 completions.add("create"); |                 completions.add("create"); | ||||||
|             } |             } | ||||||
|             if (Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_DELETE)) { |             if (player.hasPermission(Permission.PERMISSION_CLUSTER_DELETE)) { | ||||||
|                 completions.add("delete"); |                 completions.add("delete"); | ||||||
|             } |             } | ||||||
|             if (Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_RESIZE)) { |             if (player.hasPermission(Permission.PERMISSION_CLUSTER_RESIZE)) { | ||||||
|                 completions.add("resize"); |                 completions.add("resize"); | ||||||
|             } |             } | ||||||
|             if (Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_INVITE)) { |             if (player.hasPermission(Permission.PERMISSION_CLUSTER_INVITE)) { | ||||||
|                 completions.add("invite"); |                 completions.add("invite"); | ||||||
|             } |             } | ||||||
|             if (Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_KICK)) { |             if (player.hasPermission(Permission.PERMISSION_CLUSTER_KICK)) { | ||||||
|                 completions.add("kick"); |                 completions.add("kick"); | ||||||
|             } |             } | ||||||
|             if (Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_KICK)) { |             if (player.hasPermission(Permission.PERMISSION_CLUSTER_KICK)) { | ||||||
|                 completions.add("leave"); |                 completions.add("leave"); | ||||||
|             } |             } | ||||||
|             if (Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_HELPERS)) { |             if (player.hasPermission(Permission.PERMISSION_CLUSTER_HELPERS)) { | ||||||
|                 completions.add("members"); |                 completions.add("members"); | ||||||
|             } |             } | ||||||
|             if (Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_INFO)) { |             if (player.hasPermission(Permission.PERMISSION_CLUSTER_INFO)) { | ||||||
|                 completions.add("info"); |                 completions.add("info"); | ||||||
|             } |             } | ||||||
|             if (Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_TP)) { |             if (player.hasPermission(Permission.PERMISSION_CLUSTER_TP)) { | ||||||
|                 completions.add("tp"); |                 completions.add("tp"); | ||||||
|             } |             } | ||||||
|             if (Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER_SETHOME)) { |             if (player.hasPermission(Permission.PERMISSION_CLUSTER_SETHOME)) { | ||||||
|                 completions.add("sethome"); |                 completions.add("sethome"); | ||||||
|             } |             } | ||||||
|             final List<Command> commands = completions.stream().filter(completion -> completion |             final List<Command> commands = completions.stream().filter(completion -> completion | ||||||
| @@ -982,7 +954,7 @@ public class Cluster extends SubCommand { | |||||||
|                             CommandCategory.ADMINISTRATION |                             CommandCategory.ADMINISTRATION | ||||||
|                     ) { |                     ) { | ||||||
|                     }).collect(Collectors.toCollection(LinkedList::new)); |                     }).collect(Collectors.toCollection(LinkedList::new)); | ||||||
|             if (Permissions.hasPermission(player, Permission.PERMISSION_CLUSTER) && args[0].length() > 0) { |             if (player.hasPermission(Permission.PERMISSION_CLUSTER) && args[0].length() > 0) { | ||||||
|                 commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); |                 commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); | ||||||
|             } |             } | ||||||
|             return commands; |             return commands; | ||||||
|   | |||||||
| @@ -25,7 +25,6 @@ import com.plotsquared.core.configuration.caption.TranslatableCaption; | |||||||
| import com.plotsquared.core.permissions.PermissionHolder; | import com.plotsquared.core.permissions.PermissionHolder; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.util.MathMan; | import com.plotsquared.core.util.MathMan; | ||||||
| import com.plotsquared.core.util.Permissions; |  | ||||||
| import com.plotsquared.core.util.StringComparison; | import com.plotsquared.core.util.StringComparison; | ||||||
| import com.plotsquared.core.util.StringMan; | import com.plotsquared.core.util.StringMan; | ||||||
| import com.plotsquared.core.util.task.RunnableVal2; | import com.plotsquared.core.util.task.RunnableVal2; | ||||||
| @@ -483,7 +482,7 @@ public abstract class Command { | |||||||
|             if (message) { |             if (message) { | ||||||
|                 player.sendMessage(this.required.getErrorMessage()); |                 player.sendMessage(this.required.getErrorMessage()); | ||||||
|             } |             } | ||||||
|         } else if (!Permissions.hasPermission(player, getPermission())) { |         } else if (!player.hasPermission(getPermission())) { | ||||||
|             if (message) { |             if (message) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission"), |                         TranslatableCaption.of("permission.no_permission"), | ||||||
| @@ -560,9 +559,10 @@ public abstract class Command { | |||||||
|  |  | ||||||
|     public Collection<Command> tab(PlotPlayer<?> player, String[] args, boolean space) { |     public Collection<Command> tab(PlotPlayer<?> player, String[] args, boolean space) { | ||||||
|         switch (args.length) { |         switch (args.length) { | ||||||
|             case 0: |             case 0 -> { | ||||||
|                 return this.allCommands; |                 return this.allCommands; | ||||||
|             case 1: |             } | ||||||
|  |             case 1 -> { | ||||||
|                 String arg = args[0].toLowerCase(); |                 String arg = args[0].toLowerCase(); | ||||||
|                 if (space) { |                 if (space) { | ||||||
|                     Command cmd = getCommand(arg); |                     Command cmd = getCommand(arg); | ||||||
| @@ -581,7 +581,8 @@ public abstract class Command { | |||||||
|                     } |                     } | ||||||
|                     return commands; |                     return commands; | ||||||
|                 } |                 } | ||||||
|             default: |             } | ||||||
|  |             default -> { | ||||||
|                 Command cmd = getCommand(args[0]); |                 Command cmd = getCommand(args[0]); | ||||||
|                 if (cmd != null) { |                 if (cmd != null) { | ||||||
|                     return cmd.tab(player, Arrays.copyOfRange(args, 1, args.length), space); |                     return cmd.tab(player, Arrays.copyOfRange(args, 1, args.length), space); | ||||||
| @@ -590,6 +591,7 @@ public abstract class Command { | |||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public String toString() { |     public String toString() { | ||||||
|   | |||||||
| @@ -23,9 +23,9 @@ import com.plotsquared.core.configuration.caption.LocaleHolder; | |||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| import net.kyori.adventure.text.ComponentLike; |  | ||||||
| import net.kyori.adventure.text.minimessage.MiniMessage; | import net.kyori.adventure.text.minimessage.MiniMessage; | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  | import org.jetbrains.annotations.NotNull; | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * CommandCategory. |  * CommandCategory. | ||||||
| @@ -83,7 +83,7 @@ public enum CommandCategory implements Caption { | |||||||
|     // TODO this method shouldn't be invoked |     // TODO this method shouldn't be invoked | ||||||
|     @Deprecated |     @Deprecated | ||||||
|     @Override |     @Override | ||||||
|     public String toString() { |     public @NotNull String toString() { | ||||||
|         return this.caption.getComponent(LocaleHolder.console()); |         return this.caption.getComponent(LocaleHolder.console()); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -109,4 +109,5 @@ public enum CommandCategory implements Caption { | |||||||
|         return !MainCommand.getInstance().getCommands(this, player).isEmpty(); |         return !MainCommand.getInstance().getCommands(this, player).isEmpty(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -256,11 +256,11 @@ public class Condense extends SubCommand { | |||||||
|                 player.sendMessage(TranslatableCaption.of("condense.default_eval")); |                 player.sendMessage(TranslatableCaption.of("condense.default_eval")); | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("condense.minimum_radius"), |                         TranslatableCaption.of("condense.minimum_radius"), | ||||||
|                         TagResolver.resolver("minimumRadius", Tag.inserting(Component.text(minimumRadius))) |                         TagResolver.resolver("minimum_radius", Tag.inserting(Component.text(minimumRadius))) | ||||||
|                 ); |                 ); | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("condense.maximum_moved"), |                         TranslatableCaption.of("condense.maximum_moved"), | ||||||
|                         TagResolver.resolver("maxMove", Tag.inserting(Component.text(maxMove))) |                         TagResolver.resolver("maximum_moves", Tag.inserting(Component.text(maxMove))) | ||||||
|                 ); |                 ); | ||||||
|                 player.sendMessage(TranslatableCaption.of("condense.input_eval")); |                 player.sendMessage(TranslatableCaption.of("condense.input_eval")); | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
| @@ -269,7 +269,7 @@ public class Condense extends SubCommand { | |||||||
|                 ); |                 ); | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("condense.estimated_moves"), |                         TranslatableCaption.of("condense.estimated_moves"), | ||||||
|                         TagResolver.resolver("userMove", Tag.inserting(Component.text(userMove))) |                         TagResolver.resolver("user_move", Tag.inserting(Component.text(userMove))) | ||||||
|                 ); |                 ); | ||||||
|                 player.sendMessage(TranslatableCaption.of("condense.eta")); |                 player.sendMessage(TranslatableCaption.of("condense.eta")); | ||||||
|                 player.sendMessage(TranslatableCaption.of("condense.radius_measured")); |                 player.sendMessage(TranslatableCaption.of("condense.radius_measured")); | ||||||
|   | |||||||
| @@ -29,7 +29,6 @@ import com.plotsquared.core.plot.Plot; | |||||||
| import com.plotsquared.core.plot.flag.PlotFlag; | import com.plotsquared.core.plot.flag.PlotFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.DoneFlag; | import com.plotsquared.core.plot.flag.implementations.DoneFlag; | ||||||
| import com.plotsquared.core.util.EventDispatcher; | import com.plotsquared.core.util.EventDispatcher; | ||||||
| import com.plotsquared.core.util.Permissions; |  | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; | import net.kyori.adventure.text.minimessage.tag.Tag; | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | ||||||
| @@ -55,8 +54,7 @@ public class Continue extends SubCommand { | |||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         if (!plot.isOwner(player.getUUID()) && !Permissions |         if (!plot.isOwner(player.getUUID()) && !player.hasPermission(Permission.PERMISSION_ADMIN_COMMAND_CONTINUE)) { | ||||||
|                 .hasPermission(player, Permission.PERMISSION_ADMIN_COMMAND_CONTINUE)) { |  | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("permission.no_permission"), |                     TranslatableCaption.of("permission.no_permission"), | ||||||
|                     TagResolver.resolver("node", Tag.inserting( |                     TagResolver.resolver("node", Tag.inserting( | ||||||
|   | |||||||
| @@ -23,7 +23,6 @@ import com.plotsquared.core.location.Location; | |||||||
| import com.plotsquared.core.permissions.Permission; | import com.plotsquared.core.permissions.Permission; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import com.plotsquared.core.util.Permissions; |  | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; | import net.kyori.adventure.text.minimessage.tag.Tag; | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | ||||||
| @@ -44,8 +43,7 @@ public class Copy extends SubCommand { | |||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         if (!plot1.isOwner(player.getUUID()) && !Permissions |         if (!plot1.isOwner(player.getUUID()) && !player.hasPermission(Permission.PERMISSION_ADMIN.toString())) { | ||||||
|                 .hasPermission(player, Permission.PERMISSION_ADMIN.toString())) { |  | ||||||
|             player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); |             player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
| @@ -71,7 +69,8 @@ public class Copy extends SubCommand { | |||||||
|  |  | ||||||
|         plot1.getPlotModificationManager().copy(plot2, player).thenAccept(result -> { |         plot1.getPlotModificationManager().copy(plot2, player).thenAccept(result -> { | ||||||
|             if (result) { |             if (result) { | ||||||
|                 player.sendMessage(TranslatableCaption.of("move.copy_success"), |                 player.sendMessage( | ||||||
|  |                         TranslatableCaption.of("move.copy_success"), | ||||||
|                         TagResolver.builder() |                         TagResolver.builder() | ||||||
|                                 .tag("origin", Tag.inserting(Component.text(plot1.toString()))) |                                 .tag("origin", Tag.inserting(Component.text(plot1.toString()))) | ||||||
|                                 .tag("target", Tag.inserting(Component.text(plot2.toString()))) |                                 .tag("target", Tag.inserting(Component.text(plot2.toString()))) | ||||||
|   | |||||||
| @@ -184,7 +184,7 @@ public class DatabaseCommand extends SubCommand { | |||||||
|                                                         ); |                                                         ); | ||||||
|                                                 worldFile.renameTo(newFile); |                                                 worldFile.renameTo(newFile); | ||||||
|                                             } |                                             } | ||||||
|                                             plot.setId(newId.copy()); |                                             plot.setId(newId); | ||||||
|                                             plot.setArea(pa); |                                             plot.setArea(pa); | ||||||
|                                             plots.add(plot); |                                             plots.add(plot); | ||||||
|                                             continue; |                                             continue; | ||||||
|   | |||||||
| @@ -29,13 +29,10 @@ import com.plotsquared.core.util.WorldUtil; | |||||||
| import com.plotsquared.core.util.entity.EntityCategories; | import com.plotsquared.core.util.entity.EntityCategories; | ||||||
| import com.plotsquared.core.util.entity.EntityCategory; | import com.plotsquared.core.util.entity.EntityCategory; | ||||||
| import com.plotsquared.core.util.query.PlotQuery; | import com.plotsquared.core.util.query.PlotQuery; | ||||||
| import com.plotsquared.core.util.task.TaskManager; |  | ||||||
| import com.plotsquared.core.uuid.UUIDMapping; | import com.plotsquared.core.uuid.UUIDMapping; | ||||||
| import com.sk89q.worldedit.world.entity.EntityType; | import com.sk89q.worldedit.world.entity.EntityType; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| import net.kyori.adventure.text.TextComponent; | import net.kyori.adventure.text.TextComponent; | ||||||
| import net.kyori.adventure.text.format.NamedTextColor; |  | ||||||
| import net.kyori.adventure.text.format.TextColor; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; | import net.kyori.adventure.text.minimessage.tag.Tag; | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
| @@ -73,7 +70,7 @@ public class Debug extends SubCommand { | |||||||
|                     TranslatableCaption.of("commandconfig.command_syntax"), |                     TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                     TagResolver.resolver( |                     TagResolver.resolver( | ||||||
|                             "value", |                             "value", | ||||||
|                             Tag.inserting(Component.text("/plot debug <loadedchunks | player | debug-players | entitytypes | msg>")) |                             Tag.inserting(Component.text("/plot debug <player | debug-players | entitytypes | msg>")) | ||||||
|                     ) |                     ) | ||||||
|             ); |             ); | ||||||
|         } |         } | ||||||
| @@ -87,16 +84,6 @@ public class Debug extends SubCommand { | |||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         if (args.length > 0 && "loadedchunks".equalsIgnoreCase(args[0])) { |  | ||||||
|             final long start = System.currentTimeMillis(); |  | ||||||
|             player.sendMessage(TranslatableCaption.of("debug.fetching_loaded_chunks")); |  | ||||||
|             TaskManager.runTaskAsync(() -> player.sendMessage(StaticCaption |  | ||||||
|                     .of("Loaded chunks: " + this.worldUtil |  | ||||||
|                             .getChunkChunks(player.getLocation().getWorldName()) |  | ||||||
|                             .size() + " (" + (System.currentTimeMillis() |  | ||||||
|                             - start) + "ms) using thread: " + Thread.currentThread().getName()))); |  | ||||||
|             return true; |  | ||||||
|         } |  | ||||||
|         if (args.length > 0 && "uuids".equalsIgnoreCase(args[0])) { |         if (args.length > 0 && "uuids".equalsIgnoreCase(args[0])) { | ||||||
|             final Collection<UUIDMapping> mappings = PlotSquared.get().getImpromptuUUIDPipeline().getAllImmediately(); |             final Collection<UUIDMapping> mappings = PlotSquared.get().getImpromptuUUIDPipeline().getAllImmediately(); | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
| @@ -198,7 +185,7 @@ public class Debug extends SubCommand { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public Collection<Command> tab(final PlotPlayer<?> player, String[] args, boolean space) { |     public Collection<Command> tab(final PlotPlayer<?> player, String[] args, boolean space) { | ||||||
|         return Stream.of("loadedchunks", "debug-players", "entitytypes") |         return Stream.of("debug-players", "entitytypes") | ||||||
|                 .filter(value -> value.startsWith(args[0].toLowerCase(Locale.ENGLISH))) |                 .filter(value -> value.startsWith(args[0].toLowerCase(Locale.ENGLISH))) | ||||||
|                 .map(value -> new Command(null, false, value, "plots.admin", RequiredType.NONE, null) { |                 .map(value -> new Command(null, false, value, "plots.admin", RequiredType.NONE, null) { | ||||||
|                 }).collect(Collectors.toList()); |                 }).collect(Collectors.toList()); | ||||||
|   | |||||||
| @@ -19,6 +19,7 @@ | |||||||
| package com.plotsquared.core.command; | package com.plotsquared.core.command; | ||||||
|  |  | ||||||
| import com.google.inject.Inject; | import com.google.inject.Inject; | ||||||
|  | import com.plotsquared.core.PlotSquared; | ||||||
| import com.plotsquared.core.configuration.caption.StaticCaption; | import com.plotsquared.core.configuration.caption.StaticCaption; | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.events.PlotFlagRemoveEvent; | import com.plotsquared.core.events.PlotFlagRemoveEvent; | ||||||
| @@ -27,7 +28,6 @@ import com.plotsquared.core.generator.HybridUtils; | |||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
| import com.plotsquared.core.plot.expiration.ExpireManager; |  | ||||||
| import com.plotsquared.core.plot.expiration.PlotAnalysis; | import com.plotsquared.core.plot.expiration.PlotAnalysis; | ||||||
| import com.plotsquared.core.plot.flag.GlobalFlagContainer; | import com.plotsquared.core.plot.flag.GlobalFlagContainer; | ||||||
| import com.plotsquared.core.plot.flag.PlotFlag; | import com.plotsquared.core.plot.flag.PlotFlag; | ||||||
| @@ -143,10 +143,7 @@ public class DebugExec extends SubCommand { | |||||||
|                     return true; |                     return true; | ||||||
|                 } |                 } | ||||||
|                 case "start-expire" -> { |                 case "start-expire" -> { | ||||||
|                     if (ExpireManager.IMP == null) { |                     if (PlotSquared.platform().expireManager().runAutomatedTask()) { | ||||||
|                         ExpireManager.IMP = new ExpireManager(this.eventDispatcher); |  | ||||||
|                     } |  | ||||||
|                     if (ExpireManager.IMP.runAutomatedTask()) { |  | ||||||
|                         player.sendMessage(TranslatableCaption.of("debugexec.expiry_started")); |                         player.sendMessage(TranslatableCaption.of("debugexec.expiry_started")); | ||||||
|                     } else { |                     } else { | ||||||
|                         player.sendMessage(TranslatableCaption.of("debugexec.expiry_already_started")); |                         player.sendMessage(TranslatableCaption.of("debugexec.expiry_already_started")); | ||||||
| @@ -154,7 +151,7 @@ public class DebugExec extends SubCommand { | |||||||
|                     return true; |                     return true; | ||||||
|                 } |                 } | ||||||
|                 case "stop-expire" -> { |                 case "stop-expire" -> { | ||||||
|                     if (ExpireManager.IMP == null || !ExpireManager.IMP.cancelTask()) { |                     if (!PlotSquared.platform().expireManager().cancelTask()) { | ||||||
|                         player.sendMessage(TranslatableCaption.of("debugexec.task_halted")); |                         player.sendMessage(TranslatableCaption.of("debugexec.task_halted")); | ||||||
|                     } else { |                     } else { | ||||||
|                         player.sendMessage(TranslatableCaption.of("debugexec.task_cancelled")); |                         player.sendMessage(TranslatableCaption.of("debugexec.task_cancelled")); | ||||||
|   | |||||||
| @@ -75,11 +75,13 @@ public class DebugRoadRegen extends SubCommand { | |||||||
|         } |         } | ||||||
|         String kind = args[0].toLowerCase(); |         String kind = args[0].toLowerCase(); | ||||||
|         switch (kind) { |         switch (kind) { | ||||||
|             case "plot": |             case "plot" -> { | ||||||
|                 return regenPlot(player); |                 return regenPlot(player); | ||||||
|             case "region": |             } | ||||||
|  |             case "region" -> { | ||||||
|                 return regenRegion(player, Arrays.copyOfRange(args, 1, args.length)); |                 return regenRegion(player, Arrays.copyOfRange(args, 1, args.length)); | ||||||
|             default: |             } | ||||||
|  |             default -> { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("commandconfig.command_syntax"), |                         TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                         TagResolver.resolver("value", Tag.inserting(Component.text(DebugRoadRegen.USAGE))) |                         TagResolver.resolver("value", Tag.inserting(Component.text(DebugRoadRegen.USAGE))) | ||||||
| @@ -87,12 +89,14 @@ public class DebugRoadRegen extends SubCommand { | |||||||
|                 return false; |                 return false; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|     public boolean regenPlot(PlotPlayer<?> player) { |     public boolean regenPlot(PlotPlayer<?> player) { | ||||||
|         Location location = player.getLocation(); |         Location location = player.getLocation(); | ||||||
|         PlotArea area = location.getPlotArea(); |         PlotArea area = location.getPlotArea(); | ||||||
|         if (area == null) { |         if (area == null) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot_world")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot_world")); | ||||||
|  |             return false; | ||||||
|         } |         } | ||||||
|         Plot plot = player.getCurrentPlot(); |         Plot plot = player.getCurrentPlot(); | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|   | |||||||
| @@ -30,7 +30,6 @@ import com.plotsquared.core.plot.Plot; | |||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
| import com.plotsquared.core.util.EconHandler; | import com.plotsquared.core.util.EconHandler; | ||||||
| import com.plotsquared.core.util.EventDispatcher; | import com.plotsquared.core.util.EventDispatcher; | ||||||
| import com.plotsquared.core.util.Permissions; |  | ||||||
| import com.plotsquared.core.util.PlotExpression; | import com.plotsquared.core.util.PlotExpression; | ||||||
| import com.plotsquared.core.util.task.TaskManager; | import com.plotsquared.core.util.task.TaskManager; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| @@ -85,8 +84,7 @@ public class Delete extends SubCommand { | |||||||
|             return true; |             return true; | ||||||
|         } |         } | ||||||
|         boolean force = eventResult == Result.FORCE; |         boolean force = eventResult == Result.FORCE; | ||||||
|         if (!force && !plot.isOwner(player.getUUID()) && !Permissions |         if (!force && !plot.isOwner(player.getUUID()) && !player.hasPermission(Permission.PERMISSION_ADMIN_COMMAND_DELETE)) { | ||||||
|                 .hasPermission(player, Permission.PERMISSION_ADMIN_COMMAND_DELETE)) { |  | ||||||
|             player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); |             player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -30,7 +30,6 @@ import com.plotsquared.core.player.PlotPlayer; | |||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
| import com.plotsquared.core.util.EventDispatcher; | import com.plotsquared.core.util.EventDispatcher; | ||||||
| import com.plotsquared.core.util.Permissions; |  | ||||||
| import com.plotsquared.core.util.PlayerManager; | import com.plotsquared.core.util.PlayerManager; | ||||||
| import com.plotsquared.core.util.TabCompletions; | import com.plotsquared.core.util.TabCompletions; | ||||||
| import com.plotsquared.core.util.WorldUtil; | import com.plotsquared.core.util.WorldUtil; | ||||||
| @@ -81,13 +80,12 @@ public class Deny extends SubCommand { | |||||||
|             player.sendMessage(TranslatableCaption.of("info.plot_unowned")); |             player.sendMessage(TranslatableCaption.of("info.plot_unowned")); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         if (!plot.isOwner(player.getUUID()) && !Permissions |         if (!plot.isOwner(player.getUUID()) && !player.hasPermission(Permission.PERMISSION_ADMIN_COMMAND_DENY)) { | ||||||
|                 .hasPermission(player, Permission.PERMISSION_ADMIN_COMMAND_DENY)) { |  | ||||||
|             player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); |             player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); | ||||||
|             return true; |             return true; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         int maxDenySize = Permissions.hasPermissionRange(player, Permission.PERMISSION_DENY, Settings.Limit.MAX_PLOTS); |         int maxDenySize = player.hasPermissionRange(Permission.PERMISSION_DENY, Settings.Limit.MAX_PLOTS); | ||||||
|         int size = plot.getDenied().size(); |         int size = plot.getDenied().size(); | ||||||
|         if (size >= maxDenySize) { |         if (size >= maxDenySize) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
| @@ -108,8 +106,7 @@ public class Deny extends SubCommand { | |||||||
|             } else { |             } else { | ||||||
|                 for (UUID uuid : uuids) { |                 for (UUID uuid : uuids) { | ||||||
|                     if (uuid == DBFunc.EVERYONE && !( |                     if (uuid == DBFunc.EVERYONE && !( | ||||||
|                             Permissions.hasPermission(player, Permission.PERMISSION_DENY_EVERYONE) || Permissions |                             player.hasPermission(Permission.PERMISSION_DENY_EVERYONE) || player.hasPermission(Permission.PERMISSION_ADMIN_COMMAND_DENY))) { | ||||||
|                                     .hasPermission(player, Permission.PERMISSION_ADMIN_COMMAND_DENY))) { |  | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("errors.invalid_player"), |                                 TranslatableCaption.of("errors.invalid_player"), | ||||||
|                                 TagResolver.resolver("value", Tag.inserting(Component.text(args[0]))) |                                 TagResolver.resolver("value", Tag.inserting(Component.text(args[0]))) | ||||||
| @@ -120,10 +117,11 @@ public class Deny extends SubCommand { | |||||||
|                     } else if (plot.getDenied().contains(uuid)) { |                     } else if (plot.getDenied().contains(uuid)) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("member.already_added"), |                                 TranslatableCaption.of("member.already_added"), | ||||||
|                                 TagResolver.resolver( |                                 PlotSquared.platform().playerManager().getUsernameCaption(uuid) | ||||||
|  |                                         .thenApply(caption -> TagResolver.resolver( | ||||||
|                                         "player", |                                         "player", | ||||||
|                                         Tag.inserting(PlayerManager.resolveName(uuid).toComponent(player)) |                                         Tag.inserting(caption.toComponent(player)) | ||||||
|                                 ) |                                 )) | ||||||
|                         ); |                         ); | ||||||
|                         return; |                         return; | ||||||
|                     } else { |                     } else { | ||||||
|   | |||||||
| @@ -21,7 +21,6 @@ package com.plotsquared.core.command; | |||||||
| import com.google.inject.Inject; | import com.google.inject.Inject; | ||||||
| import com.plotsquared.core.permissions.Permission; | import com.plotsquared.core.permissions.Permission; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.util.Permissions; |  | ||||||
| import com.plotsquared.core.util.TabCompletions; | import com.plotsquared.core.util.TabCompletions; | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| @@ -54,7 +53,7 @@ public class Dislike extends SubCommand { | |||||||
|     public Collection<Command> tab(final PlotPlayer<?> player, final String[] args, final boolean space) { |     public Collection<Command> tab(final PlotPlayer<?> player, final String[] args, final boolean space) { | ||||||
|         if (args.length == 1) { |         if (args.length == 1) { | ||||||
|             final List<String> completions = new LinkedList<>(); |             final List<String> completions = new LinkedList<>(); | ||||||
|             if (Permissions.hasPermission(player, Permission.PERMISSION_ADMIN_COMMAND_PURGE_RATINGS)) { |             if (player.hasPermission(Permission.PERMISSION_ADMIN_COMMAND_PURGE_RATINGS)) { | ||||||
|                 completions.add("purge"); |                 completions.add("purge"); | ||||||
|             } |             } | ||||||
|             final List<Command> commands = completions.stream().filter(completion -> completion |             final List<Command> commands = completions.stream().filter(completion -> completion | ||||||
| @@ -62,7 +61,7 @@ public class Dislike extends SubCommand { | |||||||
|                             .startsWith(args[0].toLowerCase())) |                             .startsWith(args[0].toLowerCase())) | ||||||
|                     .map(completion -> new Command(null, true, completion, "", RequiredType.PLAYER, CommandCategory.INFO) { |                     .map(completion -> new Command(null, true, completion, "", RequiredType.PLAYER, CommandCategory.INFO) { | ||||||
|                     }).collect(Collectors.toCollection(LinkedList::new)); |                     }).collect(Collectors.toCollection(LinkedList::new)); | ||||||
|             if (Permissions.hasPermission(player, Permission.PERMISSION_RATE) && args[0].length() > 0) { |             if (player.hasPermission(Permission.PERMISSION_RATE) && args[0].length() > 0) { | ||||||
|                 commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); |                 commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); | ||||||
|             } |             } | ||||||
|             return commands; |             return commands; | ||||||
|   | |||||||
| @@ -19,6 +19,7 @@ | |||||||
| package com.plotsquared.core.command; | package com.plotsquared.core.command; | ||||||
|  |  | ||||||
| import com.google.inject.Inject; | import com.google.inject.Inject; | ||||||
|  | import com.plotsquared.core.PlotSquared; | ||||||
| import com.plotsquared.core.configuration.Settings; | import com.plotsquared.core.configuration.Settings; | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.events.PlotDoneEvent; | import com.plotsquared.core.events.PlotDoneEvent; | ||||||
| @@ -29,12 +30,10 @@ import com.plotsquared.core.location.Location; | |||||||
| import com.plotsquared.core.permissions.Permission; | import com.plotsquared.core.permissions.Permission; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import com.plotsquared.core.plot.expiration.ExpireManager; |  | ||||||
| import com.plotsquared.core.plot.expiration.PlotAnalysis; | import com.plotsquared.core.plot.expiration.PlotAnalysis; | ||||||
| import com.plotsquared.core.plot.flag.PlotFlag; | import com.plotsquared.core.plot.flag.PlotFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.DoneFlag; | import com.plotsquared.core.plot.flag.implementations.DoneFlag; | ||||||
| import com.plotsquared.core.util.EventDispatcher; | import com.plotsquared.core.util.EventDispatcher; | ||||||
| import com.plotsquared.core.util.Permissions; |  | ||||||
| import com.plotsquared.core.util.task.RunnableVal; | import com.plotsquared.core.util.task.RunnableVal; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; | import net.kyori.adventure.text.minimessage.tag.Tag; | ||||||
| @@ -77,8 +76,7 @@ public class Done extends SubCommand { | |||||||
|             return true; |             return true; | ||||||
|         } |         } | ||||||
|         boolean force = event.getEventResult() == Result.FORCE; |         boolean force = event.getEventResult() == Result.FORCE; | ||||||
|         if (!force && !plot.isOwner(player.getUUID()) && !Permissions |         if (!force && !plot.isOwner(player.getUUID()) && !player.hasPermission(Permission.PERMISSION_ADMIN_COMMAND_DONE)) { | ||||||
|                 .hasPermission(player, Permission.PERMISSION_ADMIN_COMMAND_DONE)) { |  | ||||||
|             player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); |             player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
| @@ -96,7 +94,7 @@ public class Done extends SubCommand { | |||||||
|                 TagResolver.resolver("plot", Tag.inserting(Component.text(plot.getId().toString()))) |                 TagResolver.resolver("plot", Tag.inserting(Component.text(plot.getId().toString()))) | ||||||
|         ); |         ); | ||||||
|         final Settings.Auto_Clear doneRequirements = Settings.AUTO_CLEAR.get("done"); |         final Settings.Auto_Clear doneRequirements = Settings.AUTO_CLEAR.get("done"); | ||||||
|         if (ExpireManager.IMP == null || doneRequirements == null) { |         if (PlotSquared.platform().expireManager() == null || doneRequirements == null || player.hasPermission(Permission.PERMISSION_ADMIN_COMMAND_DONE)) { | ||||||
|             finish(plot, player, true); |             finish(plot, player, true); | ||||||
|             plot.removeRunning(); |             plot.removeRunning(); | ||||||
|         } else { |         } else { | ||||||
| @@ -105,7 +103,7 @@ public class Done extends SubCommand { | |||||||
|                 public void run(PlotAnalysis value) { |                 public void run(PlotAnalysis value) { | ||||||
|                     plot.removeRunning(); |                     plot.removeRunning(); | ||||||
|                     boolean result = |                     boolean result = | ||||||
|                             value.getComplexity(doneRequirements) <= doneRequirements.THRESHOLD; |                             value.getComplexity(doneRequirements) >= doneRequirements.THRESHOLD; | ||||||
|                     finish(plot, player, result); |                     finish(plot, player, result); | ||||||
|                 } |                 } | ||||||
|             }); |             }); | ||||||
|   | |||||||
| @@ -20,14 +20,12 @@ package com.plotsquared.core.command; | |||||||
|  |  | ||||||
| import com.google.inject.Inject; | import com.google.inject.Inject; | ||||||
| import com.plotsquared.core.configuration.Settings; | import com.plotsquared.core.configuration.Settings; | ||||||
| import com.plotsquared.core.configuration.caption.StaticCaption; |  | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.permissions.Permission; | import com.plotsquared.core.permissions.Permission; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import com.plotsquared.core.plot.flag.implementations.DoneFlag; | import com.plotsquared.core.plot.flag.implementations.DoneFlag; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
| import com.plotsquared.core.util.Permissions; |  | ||||||
| import com.plotsquared.core.util.PlotUploader; | import com.plotsquared.core.util.PlotUploader; | ||||||
| import com.plotsquared.core.util.SchematicHandler; | import com.plotsquared.core.util.SchematicHandler; | ||||||
| import com.plotsquared.core.util.StringMan; | import com.plotsquared.core.util.StringMan; | ||||||
| @@ -89,13 +87,11 @@ public class Download extends SubCommand { | |||||||
|             player.sendMessage(TranslatableCaption.of("info.plot_unowned")); |             player.sendMessage(TranslatableCaption.of("info.plot_unowned")); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         if ((Settings.Done.REQUIRED_FOR_DOWNLOAD && !DoneFlag.isDone(plot)) && !Permissions |         if ((Settings.Done.REQUIRED_FOR_DOWNLOAD && !DoneFlag.isDone(plot)) && !player.hasPermission(Permission.PERMISSION_ADMIN_COMMAND_DOWNLOAD)) { | ||||||
|                 .hasPermission(player, Permission.PERMISSION_ADMIN_COMMAND_DOWNLOAD)) { |  | ||||||
|             player.sendMessage(TranslatableCaption.of("done.done_not_done")); |             player.sendMessage(TranslatableCaption.of("done.done_not_done")); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         if (!plot.isOwner(player.getUUID()) && !Permissions |         if (!plot.isOwner(player.getUUID()) && !player.hasPermission(Permission.PERMISSION_ADMIN.toString())) { | ||||||
|                 .hasPermission(player, Permission.PERMISSION_ADMIN.toString())) { |  | ||||||
|             player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); |             player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
| @@ -113,7 +109,7 @@ public class Download extends SubCommand { | |||||||
|             upload(player, plot); |             upload(player, plot); | ||||||
|         } else if (args.length == 1 && StringMan |         } else if (args.length == 1 && StringMan | ||||||
|                 .isEqualIgnoreCaseToAny(args[0], "mcr", "world", "mca")) { |                 .isEqualIgnoreCaseToAny(args[0], "mcr", "world", "mca")) { | ||||||
|             if (!Permissions.hasPermission(player, Permission.PERMISSION_DOWNLOAD_WORLD)) { |             if (!player.hasPermission(Permission.PERMISSION_DOWNLOAD_WORLD)) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission"), |                         TranslatableCaption.of("permission.no_permission"), | ||||||
|                         TagResolver.resolver( |                         TagResolver.resolver( | ||||||
| @@ -139,7 +135,9 @@ public class Download extends SubCommand { | |||||||
|                     } |                     } | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("web.generation_link_success_legacy_world"), |                             TranslatableCaption.of("web.generation_link_success_legacy_world"), | ||||||
|                             TagResolver.resolver("url", Tag.inserting(Component.text(url.toString()))) |                             TagResolver.builder() | ||||||
|  |                                     .tag("url", Tag.preProcessParsed(url.toString())) | ||||||
|  |                                     .build() | ||||||
|                     ); |                     ); | ||||||
|                 } |                 } | ||||||
|             }); |             }); | ||||||
| @@ -158,10 +156,10 @@ public class Download extends SubCommand { | |||||||
|     public Collection<Command> tab(final PlotPlayer<?> player, final String[] args, final boolean space) { |     public Collection<Command> tab(final PlotPlayer<?> player, final String[] args, final boolean space) { | ||||||
|         if (args.length == 1) { |         if (args.length == 1) { | ||||||
|             final List<String> completions = new LinkedList<>(); |             final List<String> completions = new LinkedList<>(); | ||||||
|             if (Permissions.hasPermission(player, Permission.PERMISSION_DOWNLOAD)) { |             if (player.hasPermission(Permission.PERMISSION_DOWNLOAD)) { | ||||||
|                 completions.add("schem"); |                 completions.add("schem"); | ||||||
|             } |             } | ||||||
|             if (Permissions.hasPermission(player, Permission.PERMISSION_DOWNLOAD_WORLD)) { |             if (player.hasPermission(Permission.PERMISSION_DOWNLOAD_WORLD)) { | ||||||
|                 completions.add("world"); |                 completions.add("world"); | ||||||
|             } |             } | ||||||
|             final List<Command> commands = completions.stream().filter(completion -> completion |             final List<Command> commands = completions.stream().filter(completion -> completion | ||||||
| @@ -176,7 +174,7 @@ public class Download extends SubCommand { | |||||||
|                             CommandCategory.ADMINISTRATION |                             CommandCategory.ADMINISTRATION | ||||||
|                     ) { |                     ) { | ||||||
|                     }).collect(Collectors.toCollection(LinkedList::new)); |                     }).collect(Collectors.toCollection(LinkedList::new)); | ||||||
|             if (Permissions.hasPermission(player, Permission.PERMISSION_DOWNLOAD) && args[0].length() > 0) { |             if (player.hasPermission(Permission.PERMISSION_DOWNLOAD) && args[0].length() > 0) { | ||||||
|                 commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); |                 commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); | ||||||
|             } |             } | ||||||
|             return commands; |             return commands; | ||||||
| @@ -188,10 +186,14 @@ public class Download extends SubCommand { | |||||||
|         if (Settings.Web.LEGACY_WEBINTERFACE) { |         if (Settings.Web.LEGACY_WEBINTERFACE) { | ||||||
|             schematicHandler |             schematicHandler | ||||||
|                     .getCompoundTag(plot) |                     .getCompoundTag(plot) | ||||||
|                     .whenComplete((compoundTag, throwable) -> { |                     .whenComplete((compoundTag, throwable) -> schematicHandler.upload( | ||||||
|                         schematicHandler.upload(compoundTag, null, null, new RunnableVal<>() { |                             compoundTag, | ||||||
|  |                             null, | ||||||
|  |                             null, | ||||||
|  |                             new RunnableVal<>() { | ||||||
|                                 @Override |                                 @Override | ||||||
|                                 public void run(URL value) { |                                 public void run(URL value) { | ||||||
|  |                                     plot.removeRunning(); | ||||||
|                                     player.sendMessage( |                                     player.sendMessage( | ||||||
|                                             TranslatableCaption.of("web.generation_link_success"), |                                             TranslatableCaption.of("web.generation_link_success"), | ||||||
|                                             TagResolver.builder() |                                             TagResolver.builder() | ||||||
| @@ -199,10 +201,9 @@ public class Download extends SubCommand { | |||||||
|                                                     .tag("delete", Tag.preProcessParsed("Not available")) |                                                     .tag("delete", Tag.preProcessParsed("Not available")) | ||||||
|                                                     .build() |                                                     .build() | ||||||
|                                     ); |                                     ); | ||||||
|                                 player.sendMessage(StaticCaption.of(value.toString())); |  | ||||||
|                                 } |                                 } | ||||||
|                         }); |                             } | ||||||
|                     }); |                     )); | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         // TODO legacy support |         // TODO legacy support | ||||||
|   | |||||||
| @@ -39,7 +39,6 @@ import com.plotsquared.core.plot.flag.types.IntegerFlag; | |||||||
| import com.plotsquared.core.plot.flag.types.ListFlag; | import com.plotsquared.core.plot.flag.types.ListFlag; | ||||||
| import com.plotsquared.core.util.EventDispatcher; | import com.plotsquared.core.util.EventDispatcher; | ||||||
| import com.plotsquared.core.util.MathMan; | import com.plotsquared.core.util.MathMan; | ||||||
| import com.plotsquared.core.util.Permissions; |  | ||||||
| import com.plotsquared.core.util.StringComparison; | import com.plotsquared.core.util.StringComparison; | ||||||
| import com.plotsquared.core.util.StringMan; | import com.plotsquared.core.util.StringMan; | ||||||
| import com.plotsquared.core.util.helpmenu.HelpMenu; | import com.plotsquared.core.util.helpmenu.HelpMenu; | ||||||
| @@ -104,9 +103,10 @@ public final class FlagCommand extends Command { | |||||||
|         if (flag instanceof IntegerFlag && MathMan.isInteger(value)) { |         if (flag instanceof IntegerFlag && MathMan.isInteger(value)) { | ||||||
|             try { |             try { | ||||||
|                 int numeric = Integer.parseInt(value); |                 int numeric = Integer.parseInt(value); | ||||||
|  |                 // Getting full permission without ".<amount>" at the end | ||||||
|                 perm = perm.substring(0, perm.length() - value.length() - 1); |                 perm = perm.substring(0, perm.length() - value.length() - 1); | ||||||
|                 boolean result = false; |                 boolean result = false; | ||||||
|                 if (numeric > 0) { |                 if (numeric >= 0) { | ||||||
|                     int checkRange = PlotSquared.get().getPlatform().equalsIgnoreCase("bukkit") ? |                     int checkRange = PlotSquared.get().getPlatform().equalsIgnoreCase("bukkit") ? | ||||||
|                             numeric : |                             numeric : | ||||||
|                             Settings.Limit.MAX_PLOTS; |                             Settings.Limit.MAX_PLOTS; | ||||||
| @@ -132,7 +132,7 @@ public final class FlagCommand extends Command { | |||||||
|                             key.toLowerCase(), |                             key.toLowerCase(), | ||||||
|                             entry.toString().toLowerCase() |                             entry.toString().toLowerCase() | ||||||
|                     ); |                     ); | ||||||
|                     final boolean result = Permissions.hasPermission(player, permission); |                     final boolean result = player.hasPermission(permission); | ||||||
|                     if (!result) { |                     if (!result) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission"), |                                 TranslatableCaption.of("permission.no_permission"), | ||||||
| @@ -159,9 +159,9 @@ public final class FlagCommand extends Command { | |||||||
|         boolean result; |         boolean result; | ||||||
|         String basePerm = Permission.PERMISSION_SET_FLAG_KEY.format(key.toLowerCase()); |         String basePerm = Permission.PERMISSION_SET_FLAG_KEY.format(key.toLowerCase()); | ||||||
|         if (flag.isValuedPermission()) { |         if (flag.isValuedPermission()) { | ||||||
|             result = Permissions.hasKeyedPermission(player, basePerm, value); |             result = player.hasKeyedPermission(basePerm, value); | ||||||
|         } else { |         } else { | ||||||
|             result = Permissions.hasPermission(player, basePerm); |             result = player.hasPermission(basePerm); | ||||||
|             perm = basePerm; |             perm = basePerm; | ||||||
|         } |         } | ||||||
|         if (!result) { |         if (!result) { | ||||||
| @@ -189,8 +189,7 @@ public final class FlagCommand extends Command { | |||||||
|             player.sendMessage(TranslatableCaption.of("working.plot_not_claimed")); |             player.sendMessage(TranslatableCaption.of("working.plot_not_claimed")); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         if (!plot.isOwner(player.getUUID()) && !Permissions |         if (!plot.isOwner(player.getUUID()) && !player.hasPermission(Permission.PERMISSION_SET_FLAG_OTHER)) { | ||||||
|                 .hasPermission(player, Permission.PERMISSION_SET_FLAG_OTHER)) { |  | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("permission.no_permission"), |                     TranslatableCaption.of("permission.no_permission"), | ||||||
|                     TagResolver.resolver("node", Tag.inserting(Permission.PERMISSION_SET_FLAG_OTHER)) |                     TagResolver.resolver("node", Tag.inserting(Permission.PERMISSION_SET_FLAG_OTHER)) | ||||||
| @@ -486,6 +485,7 @@ public final class FlagCommand extends Command { | |||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         final Plot plot = player.getLocation().getPlotAbs(); |         final Plot plot = player.getLocation().getPlotAbs(); | ||||||
|  |         final PlotFlag<?, ?> flagWithOldValue = plot.getFlagContainer().getFlag(flag.getClass()); | ||||||
|         PlotFlagRemoveEvent event = eventDispatcher.callFlagRemove(flag, plot); |         PlotFlagRemoveEvent event = eventDispatcher.callFlagRemove(flag, plot); | ||||||
|         if (event.getEventResult() == Result.DENY) { |         if (event.getEventResult() == Result.DENY) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
| @@ -496,7 +496,7 @@ public final class FlagCommand extends Command { | |||||||
|         } |         } | ||||||
|         boolean force = event.getEventResult() == Result.FORCE; |         boolean force = event.getEventResult() == Result.FORCE; | ||||||
|         flag = event.getFlag(); |         flag = event.getFlag(); | ||||||
|         if (!force && !Permissions.hasPermission(player, Permission.PERMISSION_SET_FLAG_KEY.format(args[0].toLowerCase()))) { |         if (!force && !player.hasPermission(Permission.PERMISSION_SET_FLAG_KEY.format(args[0].toLowerCase()))) { | ||||||
|             if (args.length != 2) { |             if (args.length != 2) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission"), |                         TranslatableCaption.of("permission.no_permission"), | ||||||
| @@ -682,8 +682,8 @@ public final class FlagCommand extends Command { | |||||||
|                     TranslatableCaption.of("flag.flag_info_example"), |                     TranslatableCaption.of("flag.flag_info_example"), | ||||||
|                     TagResolver.builder() |                     TagResolver.builder() | ||||||
|                             .tag("command", Tag.preProcessParsed("/plot flag set")) |                             .tag("command", Tag.preProcessParsed("/plot flag set")) | ||||||
|                             .tag("flag", Tag.inserting(Component.text(plotFlag.getName()))) |                             .tag("flag", Tag.preProcessParsed(plotFlag.getName())) | ||||||
|                             .tag("value", Tag.inserting(Component.text(plotFlag.getExample()))) |                             .tag("value", Tag.preProcessParsed(plotFlag.getExample())) | ||||||
|                             .build() |                             .build() | ||||||
|             ); |             ); | ||||||
|             // Default value |             // Default value | ||||||
|   | |||||||
| @@ -26,13 +26,11 @@ import com.plotsquared.core.permissions.Permission; | |||||||
| import com.plotsquared.core.player.MetaDataAccess; | import com.plotsquared.core.player.MetaDataAccess; | ||||||
| import com.plotsquared.core.player.PlayerMetaDataKeys; | import com.plotsquared.core.player.PlayerMetaDataKeys; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.util.Permissions; |  | ||||||
| import com.plotsquared.core.util.PlayerManager; | import com.plotsquared.core.util.PlayerManager; | ||||||
| import com.plotsquared.core.util.TabCompletions; | import com.plotsquared.core.util.TabCompletions; | ||||||
| import com.plotsquared.core.util.task.RunnableVal; | import com.plotsquared.core.util.task.RunnableVal; | ||||||
| import com.plotsquared.core.util.task.RunnableVal2; | import com.plotsquared.core.util.task.RunnableVal2; | ||||||
| import com.plotsquared.core.util.task.RunnableVal3; | import com.plotsquared.core.util.task.RunnableVal3; | ||||||
| import com.plotsquared.core.uuid.UUIDMapping; |  | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; | import net.kyori.adventure.text.minimessage.tag.Tag; | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | ||||||
| @@ -42,6 +40,7 @@ import java.util.Collections; | |||||||
| import java.util.LinkedList; | import java.util.LinkedList; | ||||||
| import java.util.List; | import java.util.List; | ||||||
| import java.util.Map; | import java.util.Map; | ||||||
|  | import java.util.UUID; | ||||||
| import java.util.concurrent.CompletableFuture; | import java.util.concurrent.CompletableFuture; | ||||||
| import java.util.concurrent.TimeoutException; | import java.util.concurrent.TimeoutException; | ||||||
| import java.util.stream.Collectors; | import java.util.stream.Collectors; | ||||||
| @@ -71,7 +70,7 @@ public class Grant extends Command { | |||||||
|         final String arg0 = args[0].toLowerCase(); |         final String arg0 = args[0].toLowerCase(); | ||||||
|         switch (arg0) { |         switch (arg0) { | ||||||
|             case "add", "check" -> { |             case "add", "check" -> { | ||||||
|                 if (!Permissions.hasPermission(player, Permission.PERMISSION_GRANT.format(arg0))) { |                 if (!player.hasPermission(Permission.PERMISSION_GRANT.format(arg0))) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver("node", Tag.inserting(Component.text(Permission.PERMISSION_GRANT.format(arg0)))) |                             TagResolver.resolver("node", Tag.inserting(Component.text(Permission.PERMISSION_GRANT.format(arg0)))) | ||||||
| @@ -90,8 +89,8 @@ public class Grant extends Command { | |||||||
|                                 TagResolver.resolver("value", Tag.inserting(Component.text(String.valueOf(uuids)))) |                                 TagResolver.resolver("value", Tag.inserting(Component.text(String.valueOf(uuids)))) | ||||||
|                         ); |                         ); | ||||||
|                     } else { |                     } else { | ||||||
|                         final UUIDMapping uuid = uuids.toArray(new UUIDMapping[0])[0]; |                         final UUID uuid = uuids.iterator().next(); | ||||||
|                         PlotPlayer<?> pp = PlotSquared.platform().playerManager().getPlayerIfExists(uuid.getUuid()); |                         PlotPlayer<?> pp = PlotSquared.platform().playerManager().getPlayerIfExists(uuid); | ||||||
|                         if (pp != null) { |                         if (pp != null) { | ||||||
|                             try (final MetaDataAccess<Integer> access = pp.accessPersistentMetaData( |                             try (final MetaDataAccess<Integer> access = pp.accessPersistentMetaData( | ||||||
|                                     PlayerMetaDataKeys.PERSISTENT_GRANTED_PLOTS)) { |                                     PlayerMetaDataKeys.PERSISTENT_GRANTED_PLOTS)) { | ||||||
| @@ -105,7 +104,7 @@ public class Grant extends Command { | |||||||
|                                 } |                                 } | ||||||
|                             } |                             } | ||||||
|                         } else { |                         } else { | ||||||
|                             DBFunc.getPersistentMeta(uuid.getUuid(), new RunnableVal<>() { |                             DBFunc.getPersistentMeta(uuid, new RunnableVal<>() { | ||||||
|                                 @Override |                                 @Override | ||||||
|                                 public void run(Map<String, byte[]> value) { |                                 public void run(Map<String, byte[]> value) { | ||||||
|                                     final byte[] array = value.get("grantedPlots"); |                                     final byte[] array = value.get("grantedPlots"); | ||||||
| @@ -130,7 +129,7 @@ public class Grant extends Command { | |||||||
|                                         boolean replace = array != null; |                                         boolean replace = array != null; | ||||||
|                                         String key = "grantedPlots"; |                                         String key = "grantedPlots"; | ||||||
|                                         byte[] rawData = Ints.toByteArray(amount); |                                         byte[] rawData = Ints.toByteArray(amount); | ||||||
|                                         DBFunc.addPersistentMeta(uuid.getUuid(), key, rawData, replace); |                                         DBFunc.addPersistentMeta(uuid, key, rawData, replace); | ||||||
|                                         player.sendMessage( |                                         player.sendMessage( | ||||||
|                                                 TranslatableCaption.of("grants.added"), |                                                 TranslatableCaption.of("grants.added"), | ||||||
|                                                 TagResolver.resolver("grants", Tag.inserting(Component.text(amount))) |                                                 TagResolver.resolver("grants", Tag.inserting(Component.text(amount))) | ||||||
| @@ -152,10 +151,10 @@ public class Grant extends Command { | |||||||
|     public Collection<Command> tab(final PlotPlayer<?> player, final String[] args, final boolean space) { |     public Collection<Command> tab(final PlotPlayer<?> player, final String[] args, final boolean space) { | ||||||
|         if (args.length == 1) { |         if (args.length == 1) { | ||||||
|             final List<String> completions = new LinkedList<>(); |             final List<String> completions = new LinkedList<>(); | ||||||
|             if (Permissions.hasPermission(player, Permission.PERMISSION_GRANT_ADD)) { |             if (player.hasPermission(Permission.PERMISSION_GRANT_ADD)) { | ||||||
|                 completions.add("add"); |                 completions.add("add"); | ||||||
|             } |             } | ||||||
|             if (Permissions.hasPermission(player, Permission.PERMISSION_GRANT_CHECK)) { |             if (player.hasPermission(Permission.PERMISSION_GRANT_CHECK)) { | ||||||
|                 completions.add("check"); |                 completions.add("check"); | ||||||
|             } |             } | ||||||
|             final List<Command> commands = completions.stream().filter(completion -> completion |             final List<Command> commands = completions.stream().filter(completion -> completion | ||||||
| @@ -170,7 +169,7 @@ public class Grant extends Command { | |||||||
|                             CommandCategory.ADMINISTRATION |                             CommandCategory.ADMINISTRATION | ||||||
|                     ) { |                     ) { | ||||||
|                     }).collect(Collectors.toCollection(LinkedList::new)); |                     }).collect(Collectors.toCollection(LinkedList::new)); | ||||||
|             if (Permissions.hasPermission(player, Permission.PERMISSION_GRANT_SINGLE) && args[0].length() > 0) { |             if (player.hasPermission(Permission.PERMISSION_GRANT_SINGLE) && args[0].length() > 0) { | ||||||
|                 commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); |                 commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); | ||||||
|             } |             } | ||||||
|             return commands; |             return commands; | ||||||
|   | |||||||
| @@ -60,9 +60,10 @@ public class Help extends Command { | |||||||
|             RunnableVal2<Command, CommandResult> whenDone |             RunnableVal2<Command, CommandResult> whenDone | ||||||
|     ) { |     ) { | ||||||
|         switch (args.length) { |         switch (args.length) { | ||||||
|             case 0: |             case 0 -> { | ||||||
|                 return displayHelp(player, null, 0); |                 return displayHelp(player, null, 0); | ||||||
|             case 1: |             } | ||||||
|  |             case 1 -> { | ||||||
|                 if (MathMan.isInteger(args[0])) { |                 if (MathMan.isInteger(args[0])) { | ||||||
|                     try { |                     try { | ||||||
|                         return displayHelp(player, null, Integer.parseInt(args[0])); |                         return displayHelp(player, null, Integer.parseInt(args[0])); | ||||||
| @@ -72,7 +73,8 @@ public class Help extends Command { | |||||||
|                 } else { |                 } else { | ||||||
|                     return displayHelp(player, args[0], 1); |                     return displayHelp(player, args[0], 1); | ||||||
|                 } |                 } | ||||||
|             case 2: |             } | ||||||
|  |             case 2 -> { | ||||||
|                 if (MathMan.isInteger(args[1])) { |                 if (MathMan.isInteger(args[1])) { | ||||||
|                     try { |                     try { | ||||||
|                         return displayHelp(player, args[0], Integer.parseInt(args[1])); |                         return displayHelp(player, args[0], Integer.parseInt(args[1])); | ||||||
| @@ -81,8 +83,8 @@ public class Help extends Command { | |||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|                 return CompletableFuture.completedFuture(false); |                 return CompletableFuture.completedFuture(false); | ||||||
|             default: |             } | ||||||
|                 sendUsage(player); |             default -> sendUsage(player); | ||||||
|         } |         } | ||||||
|         return CompletableFuture.completedFuture(true); |         return CompletableFuture.completedFuture(true); | ||||||
|     } |     } | ||||||
| @@ -132,7 +134,12 @@ public class Help extends Command { | |||||||
|                                 TagResolver.builder() |                                 TagResolver.builder() | ||||||
|                                         .tag("command", Tag.inserting(Component.text("/plot help"))) |                                         .tag("command", Tag.inserting(Component.text("/plot help"))) | ||||||
|                                         .tag("category", Tag.inserting(Component.text("all"))) |                                         .tag("category", Tag.inserting(Component.text("all"))) | ||||||
|                                         .tag("category_desc",  Tag.inserting(Component.text("Display all commands"))) |                                         .tag( | ||||||
|  |                                                 "category_desc", | ||||||
|  |                                                 Tag.inserting(TranslatableCaption | ||||||
|  |                                                         .of("help.help_display_all_commands") | ||||||
|  |                                                         .toComponent(player)) | ||||||
|  |                                         ) | ||||||
|                                         .build() |                                         .build() | ||||||
|                         )); |                         )); | ||||||
|                 builder.append(Component.newline()).append(MINI_MESSAGE.deserialize(TranslatableCaption |                 builder.append(Component.newline()).append(MINI_MESSAGE.deserialize(TranslatableCaption | ||||||
|   | |||||||
| @@ -29,7 +29,6 @@ import com.plotsquared.core.plot.PlotArea; | |||||||
| import com.plotsquared.core.plot.PlotId; | import com.plotsquared.core.plot.PlotId; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
| import com.plotsquared.core.util.MathMan; | import com.plotsquared.core.util.MathMan; | ||||||
| import com.plotsquared.core.util.Permissions; |  | ||||||
| import com.plotsquared.core.util.TabCompletions; | import com.plotsquared.core.util.TabCompletions; | ||||||
| import com.plotsquared.core.util.query.PlotQuery; | import com.plotsquared.core.util.query.PlotQuery; | ||||||
| import com.plotsquared.core.util.query.SortingStrategy; | import com.plotsquared.core.util.query.SortingStrategy; | ||||||
| @@ -108,8 +107,7 @@ public class HomeCommand extends Command { | |||||||
|         // /plot home <[area;]x;y> |         // /plot home <[area;]x;y> | ||||||
|         // /plot home <area> <x;y> |         // /plot home <area> <x;y> | ||||||
|         // /plot home <area> <page> |         // /plot home <area> <page> | ||||||
|         if (!Permissions.hasPermission(player, Permission.PERMISSION_VISIT_OWNED) && !Permissions |         if (!player.hasPermission(Permission.PERMISSION_VISIT_OWNED) && !player.hasPermission(Permission.PERMISSION_HOME)) { | ||||||
|                 .hasPermission(player, Permission.PERMISSION_HOME)) { |  | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("permission.no_permission"), |                     TranslatableCaption.of("permission.no_permission"), | ||||||
|                     TagResolver.resolver("node", Tag.inserting(Component.text(Permission.PERMISSION_VISIT_OWNED.toString()))) |                     TagResolver.resolver("node", Tag.inserting(Component.text(Permission.PERMISSION_VISIT_OWNED.toString()))) | ||||||
|   | |||||||
| @@ -29,7 +29,6 @@ import com.plotsquared.core.plot.Plot; | |||||||
| import com.plotsquared.core.plot.comment.CommentInbox; | import com.plotsquared.core.plot.comment.CommentInbox; | ||||||
| import com.plotsquared.core.plot.comment.CommentManager; | import com.plotsquared.core.plot.comment.CommentManager; | ||||||
| import com.plotsquared.core.plot.comment.PlotComment; | import com.plotsquared.core.plot.comment.PlotComment; | ||||||
| import com.plotsquared.core.util.Permissions; |  | ||||||
| import com.plotsquared.core.util.StringMan; | import com.plotsquared.core.util.StringMan; | ||||||
| import com.plotsquared.core.util.TabCompletions; | import com.plotsquared.core.util.TabCompletions; | ||||||
| import com.plotsquared.core.util.task.RunnableVal; | import com.plotsquared.core.util.task.RunnableVal; | ||||||
| @@ -86,24 +85,24 @@ public class Inbox extends SubCommand { | |||||||
|         for (int x = page * 12; x < max; x++) { |         for (int x = page * 12; x < max; x++) { | ||||||
|             PlotComment comment = comments[x]; |             PlotComment comment = comments[x]; | ||||||
|             Component commentColored; |             Component commentColored; | ||||||
|             if (player.getName().equals(comment.senderName)) { |             if (player.getName().equals(comment.senderName())) { | ||||||
|                 commentColored = MINI_MESSAGE |                 commentColored = MINI_MESSAGE | ||||||
|                         .deserialize( |                         .deserialize( | ||||||
|                                 TranslatableCaption.of("list.comment_list_by_lister").getComponent(player), |                                 TranslatableCaption.of("list.comment_list_by_lister").getComponent(player), | ||||||
|                                 TagResolver.resolver("comment", Tag.inserting(Component.text(comment.comment))) |                                 TagResolver.resolver("comment", Tag.inserting(Component.text(comment.comment()))) | ||||||
|                         ); |                         ); | ||||||
|             } else { |             } else { | ||||||
|                 commentColored = MINI_MESSAGE |                 commentColored = MINI_MESSAGE | ||||||
|                         .deserialize( |                         .deserialize( | ||||||
|                                 TranslatableCaption.of("list.comment_list_by_other").getComponent(player), |                                 TranslatableCaption.of("list.comment_list_by_other").getComponent(player), | ||||||
|                                 TagResolver.resolver("comment", Tag.inserting(Component.text(comment.comment))) |                                 TagResolver.resolver("comment", Tag.inserting(Component.text(comment.comment()))) | ||||||
|                         ); |                         ); | ||||||
|             } |             } | ||||||
|             TagResolver resolver = TagResolver.builder() |             TagResolver resolver = TagResolver.builder() | ||||||
|                     .tag("number", Tag.inserting(Component.text(x))) |                     .tag("number", Tag.inserting(Component.text(x))) | ||||||
|                     .tag("world", Tag.inserting(Component.text(comment.world))) |                     .tag("world", Tag.inserting(Component.text(comment.world()))) | ||||||
|                     .tag("plot_id", Tag.inserting(Component.text(comment.id.getX() + ";" + comment.id.getY()))) |                     .tag("plot_id", Tag.inserting(Component.text(comment.id().getX() + ";" + comment.id().getY()))) | ||||||
|                     .tag("commenter", Tag.inserting(Component.text(comment.senderName))) |                     .tag("commenter", Tag.inserting(Component.text(comment.senderName()))) | ||||||
|                     .tag("comment", Tag.inserting(commentColored)) |                     .tag("comment", Tag.inserting(commentColored)) | ||||||
|                     .build(); |                     .build(); | ||||||
|             builder.append(MINI_MESSAGE |             builder.append(MINI_MESSAGE | ||||||
| @@ -138,7 +137,7 @@ public class Inbox extends SubCommand { | |||||||
|                                 int unread = 0; |                                 int unread = 0; | ||||||
|                                 for (PlotComment comment : value) { |                                 for (PlotComment comment : value) { | ||||||
|                                     total++; |                                     total++; | ||||||
|                                     if (comment.timestamp > CommentManager |                                     if (comment.timestamp() > CommentManager | ||||||
|                                             .getTimestamp(player, inbox.toString())) { |                                             .getTimestamp(player, inbox.toString())) { | ||||||
|                                         unread++; |                                         unread++; | ||||||
|                                     } |                                     } | ||||||
| @@ -191,7 +190,7 @@ public class Inbox extends SubCommand { | |||||||
|         final int page; |         final int page; | ||||||
|         if (args.length > 1) { |         if (args.length > 1) { | ||||||
|             switch (args[1].toLowerCase()) { |             switch (args[1].toLowerCase()) { | ||||||
|                 case "delete": |                 case "delete" -> { | ||||||
|                     if (!inbox.canModify(plot, player)) { |                     if (!inbox.canModify(plot, player)) { | ||||||
|                         player.sendMessage(TranslatableCaption.of("comment.no_perm_inbox_modify")); |                         player.sendMessage(TranslatableCaption.of("comment.no_perm_inbox_modify")); | ||||||
|                         return false; |                         return false; | ||||||
| @@ -226,7 +225,6 @@ public class Inbox extends SubCommand { | |||||||
|                         ); |                         ); | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
|  |  | ||||||
|                     if (!inbox.getComments(plot, new RunnableVal<>() { |                     if (!inbox.getComments(plot, new RunnableVal<>() { | ||||||
|                         @Override |                         @Override | ||||||
|                         public void run(List<PlotComment> value) { |                         public void run(List<PlotComment> value) { | ||||||
| @@ -243,7 +241,7 @@ public class Inbox extends SubCommand { | |||||||
|                             if (success) { |                             if (success) { | ||||||
|                                 player.sendMessage( |                                 player.sendMessage( | ||||||
|                                         TranslatableCaption.of("comment.comment_removed_success"), |                                         TranslatableCaption.of("comment.comment_removed_success"), | ||||||
|                                         TagResolver.resolver("value", Tag.inserting(Component.text(comment.comment))) |                                         TagResolver.resolver("value", Tag.inserting(Component.text(comment.comment()))) | ||||||
|                                 ); |                                 ); | ||||||
|                             } else { |                             } else { | ||||||
|                                 player.sendMessage( |                                 player.sendMessage( | ||||||
| @@ -255,7 +253,8 @@ public class Inbox extends SubCommand { | |||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
|                     return true; |                     return true; | ||||||
|                 case "clear": |                 } | ||||||
|  |                 case "clear" -> { | ||||||
|                     if (!inbox.canModify(plot, player)) { |                     if (!inbox.canModify(plot, player)) { | ||||||
|                         player.sendMessage(TranslatableCaption.of("comment.no_perm_inbox_modify")); |                         player.sendMessage(TranslatableCaption.of("comment.no_perm_inbox_modify")); | ||||||
|                     } |                     } | ||||||
| @@ -269,7 +268,8 @@ public class Inbox extends SubCommand { | |||||||
|                         plot.getPlotCommentContainer().removeComments(comments); |                         plot.getPlotCommentContainer().removeComments(comments); | ||||||
|                     } |                     } | ||||||
|                     return true; |                     return true; | ||||||
|                 default: |                 } | ||||||
|  |                 default -> { | ||||||
|                     try { |                     try { | ||||||
|                         page = Integer.parseInt(args[1]); |                         page = Integer.parseInt(args[1]); | ||||||
|                     } catch (NumberFormatException ignored) { |                     } catch (NumberFormatException ignored) { | ||||||
| @@ -277,6 +277,7 @@ public class Inbox extends SubCommand { | |||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|  |             } | ||||||
|         } else { |         } else { | ||||||
|             page = 1; |             page = 1; | ||||||
|         } |         } | ||||||
| @@ -300,13 +301,13 @@ public class Inbox extends SubCommand { | |||||||
|     public Collection<Command> tab(final PlotPlayer<?> player, final String[] args, final boolean space) { |     public Collection<Command> tab(final PlotPlayer<?> player, final String[] args, final boolean space) { | ||||||
|         if (args.length == 1) { |         if (args.length == 1) { | ||||||
|             final List<String> completions = new LinkedList<>(); |             final List<String> completions = new LinkedList<>(); | ||||||
|             if (Permissions.hasPermission(player, Permission.PERMISSION_INBOX_READ_OWNER)) { |             if (player.hasPermission(Permission.PERMISSION_INBOX_READ_OWNER)) { | ||||||
|                 completions.add("owner"); |                 completions.add("owner"); | ||||||
|             } |             } | ||||||
|             if (Permissions.hasPermission(player, Permission.PERMISSION_INBOX_READ_PUBLIC)) { |             if (player.hasPermission(Permission.PERMISSION_INBOX_READ_PUBLIC)) { | ||||||
|                 completions.add("public"); |                 completions.add("public"); | ||||||
|             } |             } | ||||||
|             if (Permissions.hasPermission(player, Permission.PERMISSION_INBOX_READ_REPORT)) { |             if (player.hasPermission(Permission.PERMISSION_INBOX_READ_REPORT)) { | ||||||
|                 completions.add("report"); |                 completions.add("report"); | ||||||
|             } |             } | ||||||
|             final List<Command> commands = completions.stream().filter(completion -> completion |             final List<Command> commands = completions.stream().filter(completion -> completion | ||||||
| @@ -314,7 +315,7 @@ public class Inbox extends SubCommand { | |||||||
|                             .startsWith(args[0].toLowerCase())) |                             .startsWith(args[0].toLowerCase())) | ||||||
|                     .map(completion -> new Command(null, true, completion, "", RequiredType.PLAYER, CommandCategory.CHAT) { |                     .map(completion -> new Command(null, true, completion, "", RequiredType.PLAYER, CommandCategory.CHAT) { | ||||||
|                     }).collect(Collectors.toCollection(LinkedList::new)); |                     }).collect(Collectors.toCollection(LinkedList::new)); | ||||||
|             if (Permissions.hasPermission(player, Permission.PERMISSION_INBOX) && args[0].length() > 0) { |             if (player.hasPermission(Permission.PERMISSION_INBOX) && args[0].length() > 0) { | ||||||
|                 commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); |                 commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); | ||||||
|             } |             } | ||||||
|             return commands; |             return commands; | ||||||
|   | |||||||
| @@ -27,7 +27,6 @@ import com.plotsquared.core.permissions.Permission; | |||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import com.plotsquared.core.plot.flag.implementations.HideInfoFlag; | import com.plotsquared.core.plot.flag.implementations.HideInfoFlag; | ||||||
| import com.plotsquared.core.util.Permissions; |  | ||||||
| import com.plotsquared.core.util.TabCompletions; | import com.plotsquared.core.util.TabCompletions; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; | import net.kyori.adventure.text.minimessage.tag.Tag; | ||||||
| @@ -53,7 +52,8 @@ public class Info extends SubCommand { | |||||||
|             arg = args[0]; |             arg = args[0]; | ||||||
|             switch (arg) { |             switch (arg) { | ||||||
|                 // TODO: (re?)implement /plot info inv. (it was never properly implemented) |                 // TODO: (re?)implement /plot info inv. (it was never properly implemented) | ||||||
|                 case "trusted", "alias", "biome", "denied", "flags", "id", "size", "members", "creationdate", "seen", "owner", "rating", "likes" -> plot = Plot |                 case "trusted", "alias", "biome", "denied", "flags", "id", "size", "members", "creationdate", "seen", "owner", "rating", "likes" -> | ||||||
|  |                         plot = Plot | ||||||
|                                 .getPlotFromString(player, null, false); |                                 .getPlotFromString(player, null, false); | ||||||
|                 default -> { |                 default -> { | ||||||
|                     plot = Plot.getPlotFromString(player, arg, false); |                     plot = Plot.getPlotFromString(player, arg, false); | ||||||
| @@ -152,7 +152,7 @@ public class Info extends SubCommand { | |||||||
|     @Override |     @Override | ||||||
|     public Collection<Command> tab(PlotPlayer<?> player, String[] args, boolean space) { |     public Collection<Command> tab(PlotPlayer<?> player, String[] args, boolean space) { | ||||||
|         final List<String> completions = new LinkedList<>(); |         final List<String> completions = new LinkedList<>(); | ||||||
|         if (Permissions.hasPermission(player, Permission.PERMISSION_AREA_INFO_FORCE)) { |         if (player.hasPermission(Permission.PERMISSION_AREA_INFO_FORCE)) { | ||||||
|             completions.add("-f"); |             completions.add("-f"); | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @@ -162,7 +162,7 @@ public class Info extends SubCommand { | |||||||
|                 .map(completion -> new Command(null, true, completion, "", RequiredType.PLAYER, CommandCategory.INFO) { |                 .map(completion -> new Command(null, true, completion, "", RequiredType.PLAYER, CommandCategory.INFO) { | ||||||
|                 }).collect(Collectors.toCollection(LinkedList::new)); |                 }).collect(Collectors.toCollection(LinkedList::new)); | ||||||
|  |  | ||||||
|         if (Permissions.hasPermission(player, Permission.PERMISSION_AREA_INFO_FORCE) && args[0].length() > 0) { |         if (player.hasPermission(Permission.PERMISSION_AREA_INFO_FORCE) && args[0].length() > 0) { | ||||||
|             commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); |             commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -27,7 +27,6 @@ import com.plotsquared.core.permissions.Permission; | |||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
| import com.plotsquared.core.util.Permissions; |  | ||||||
| import com.plotsquared.core.util.PlayerManager; | import com.plotsquared.core.util.PlayerManager; | ||||||
| import com.plotsquared.core.util.TabCompletions; | import com.plotsquared.core.util.TabCompletions; | ||||||
| import com.plotsquared.core.util.WorldUtil; | import com.plotsquared.core.util.WorldUtil; | ||||||
| @@ -72,8 +71,7 @@ public class Kick extends SubCommand { | |||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         if ((!plot.hasOwner() || !plot.isOwner(player.getUUID())) && !Permissions |         if ((!plot.hasOwner() || !plot.isOwner(player.getUUID())) && !player.hasPermission(Permission.PERMISSION_ADMIN_COMMAND_KICK)) { | ||||||
|                 .hasPermission(player, Permission.PERMISSION_ADMIN_COMMAND_KICK)) { |  | ||||||
|             player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); |             player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
| @@ -91,8 +89,7 @@ public class Kick extends SubCommand { | |||||||
|                 for (UUID uuid : uuids) { |                 for (UUID uuid : uuids) { | ||||||
|                     if (uuid == DBFunc.EVERYONE) { |                     if (uuid == DBFunc.EVERYONE) { | ||||||
|                         for (PlotPlayer<?> pp : plot.getPlayersInPlot()) { |                         for (PlotPlayer<?> pp : plot.getPlayersInPlot()) { | ||||||
|                             if (pp == player || Permissions |                             if (pp == player || pp.hasPermission(Permission.PERMISSION_ADMIN_ENTRY_DENIED)) { | ||||||
|                                     .hasPermission(pp, Permission.PERMISSION_ADMIN_ENTRY_DENIED)) { |  | ||||||
|                                 continue; |                                 continue; | ||||||
|                             } |                             } | ||||||
|                             players.add(pp); |                             players.add(pp); | ||||||
| @@ -115,15 +112,15 @@ public class Kick extends SubCommand { | |||||||
|                 for (PlotPlayer<?> player2 : players) { |                 for (PlotPlayer<?> player2 : players) { | ||||||
|                     if (!plot.equals(player2.getCurrentPlot())) { |                     if (!plot.equals(player2.getCurrentPlot())) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("errors.invalid_player"), |                                 TranslatableCaption.of("kick.player_not_in_plot"), | ||||||
|                                 TagResolver.resolver("value", Tag.inserting(Component.text(args[0]))) |                                 TagResolver.resolver("player", Tag.inserting(Component.text(player2.getName()))) | ||||||
|                         ); |                         ); | ||||||
|                         return; |                         return; | ||||||
|                     } |                     } | ||||||
|                     if (Permissions.hasPermission(player2, Permission.PERMISSION_ADMIN_ENTRY_DENIED)) { |                     if (player2.hasPermission(Permission.PERMISSION_ADMIN_ENTRY_DENIED)) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("cluster.cannot_kick_player"), |                                 TranslatableCaption.of("kick.cannot_kick_player"), | ||||||
|                                 TagResolver.resolver("name", Tag.inserting(Component.text(player2.getName()))) |                                 TagResolver.resolver("player", Tag.inserting(Component.text(player2.getName()))) | ||||||
|                         ); |                         ); | ||||||
|                         return; |                         return; | ||||||
|                     } |                     } | ||||||
|   | |||||||
| @@ -30,7 +30,6 @@ import com.plotsquared.core.plot.Plot; | |||||||
| import com.plotsquared.core.plot.Rating; | import com.plotsquared.core.plot.Rating; | ||||||
| import com.plotsquared.core.plot.flag.implementations.DoneFlag; | import com.plotsquared.core.plot.flag.implementations.DoneFlag; | ||||||
| import com.plotsquared.core.util.EventDispatcher; | import com.plotsquared.core.util.EventDispatcher; | ||||||
| import com.plotsquared.core.util.Permissions; |  | ||||||
| import com.plotsquared.core.util.TabCompletions; | import com.plotsquared.core.util.TabCompletions; | ||||||
| import com.plotsquared.core.util.query.PlotQuery; | import com.plotsquared.core.util.query.PlotQuery; | ||||||
| import com.plotsquared.core.util.task.TaskManager; | import com.plotsquared.core.util.task.TaskManager; | ||||||
| @@ -123,8 +122,7 @@ public class Like extends SubCommand { | |||||||
|                         player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |                         player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
|                     if (!Permissions |                     if (!player.hasPermission(Permission.PERMISSION_ADMIN_COMMAND_PURGE_RATINGS, true)) { | ||||||
|                             .hasPermission(player, Permission.PERMISSION_ADMIN_COMMAND_PURGE_RATINGS, true)) { |  | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
|                     plot.clearRatings(); |                     plot.clearRatings(); | ||||||
| @@ -206,7 +204,7 @@ public class Like extends SubCommand { | |||||||
|     public Collection<Command> tab(final PlotPlayer<?> player, final String[] args, final boolean space) { |     public Collection<Command> tab(final PlotPlayer<?> player, final String[] args, final boolean space) { | ||||||
|         if (args.length == 1) { |         if (args.length == 1) { | ||||||
|             final List<String> completions = new LinkedList<>(); |             final List<String> completions = new LinkedList<>(); | ||||||
|             if (Permissions.hasPermission(player, Permission.PERMISSION_ADMIN_COMMAND_PURGE_RATINGS)) { |             if (player.hasPermission(Permission.PERMISSION_ADMIN_COMMAND_PURGE_RATINGS)) { | ||||||
|                 completions.add("purge"); |                 completions.add("purge"); | ||||||
|             } |             } | ||||||
|             final List<Command> commands = completions.stream().filter(completion -> completion |             final List<Command> commands = completions.stream().filter(completion -> completion | ||||||
| @@ -214,7 +212,7 @@ public class Like extends SubCommand { | |||||||
|                             .startsWith(args[0].toLowerCase())) |                             .startsWith(args[0].toLowerCase())) | ||||||
|                     .map(completion -> new Command(null, true, completion, "", RequiredType.PLAYER, CommandCategory.INFO) { |                     .map(completion -> new Command(null, true, completion, "", RequiredType.PLAYER, CommandCategory.INFO) { | ||||||
|                     }).collect(Collectors.toCollection(LinkedList::new)); |                     }).collect(Collectors.toCollection(LinkedList::new)); | ||||||
|             if (Permissions.hasPermission(player, Permission.PERMISSION_RATE) && args[0].length() > 0) { |             if (player.hasPermission(Permission.PERMISSION_RATE) && args[0].length() > 0) { | ||||||
|                 commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); |                 commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); | ||||||
|             } |             } | ||||||
|             return commands; |             return commands; | ||||||
|   | |||||||
| @@ -29,14 +29,12 @@ import com.plotsquared.core.permissions.Permission; | |||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
| import com.plotsquared.core.plot.expiration.ExpireManager; |  | ||||||
| import com.plotsquared.core.plot.flag.implementations.DoneFlag; | import com.plotsquared.core.plot.flag.implementations.DoneFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.PriceFlag; | import com.plotsquared.core.plot.flag.implementations.PriceFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.ServerPlotFlag; | import com.plotsquared.core.plot.flag.implementations.ServerPlotFlag; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
| import com.plotsquared.core.util.EconHandler; | import com.plotsquared.core.util.EconHandler; | ||||||
| import com.plotsquared.core.util.MathMan; | import com.plotsquared.core.util.MathMan; | ||||||
| import com.plotsquared.core.util.Permissions; |  | ||||||
| import com.plotsquared.core.util.PlayerManager; | import com.plotsquared.core.util.PlayerManager; | ||||||
| import com.plotsquared.core.util.StringComparison; | import com.plotsquared.core.util.StringComparison; | ||||||
| import com.plotsquared.core.util.StringMan; | import com.plotsquared.core.util.StringMan; | ||||||
| @@ -83,40 +81,40 @@ public class ListCmd extends SubCommand { | |||||||
|  |  | ||||||
|     private String[] getArgumentList(PlotPlayer<?> player) { |     private String[] getArgumentList(PlotPlayer<?> player) { | ||||||
|         List<String> args = new ArrayList<>(); |         List<String> args = new ArrayList<>(); | ||||||
|         if (this.econHandler != null && Permissions.hasPermission(player, Permission.PERMISSION_LIST_FOR_SALE)) { |         if (this.econHandler != null && player.hasPermission(Permission.PERMISSION_LIST_FOR_SALE)) { | ||||||
|             args.add("forsale"); |             args.add("forsale"); | ||||||
|         } |         } | ||||||
|         if (Permissions.hasPermission(player, Permission.PERMISSION_LIST_MINE)) { |         if (player.hasPermission(Permission.PERMISSION_LIST_MINE)) { | ||||||
|             args.add("mine"); |             args.add("mine"); | ||||||
|         } |         } | ||||||
|         if (Permissions.hasPermission(player, Permission.PERMISSION_LIST_SHARED)) { |         if (player.hasPermission(Permission.PERMISSION_LIST_SHARED)) { | ||||||
|             args.add("shared"); |             args.add("shared"); | ||||||
|         } |         } | ||||||
|         if (Permissions.hasPermission(player, Permission.PERMISSION_LIST_WORLD)) { |         if (player.hasPermission(Permission.PERMISSION_LIST_WORLD)) { | ||||||
|             args.add("world"); |             args.add("world"); | ||||||
|         } |         } | ||||||
|         if (Permissions.hasPermission(player, Permission.PERMISSION_LIST_TOP)) { |         if (player.hasPermission(Permission.PERMISSION_LIST_TOP)) { | ||||||
|             args.add("top"); |             args.add("top"); | ||||||
|         } |         } | ||||||
|         if (Permissions.hasPermission(player, Permission.PERMISSION_LIST_ALL)) { |         if (player.hasPermission(Permission.PERMISSION_LIST_ALL)) { | ||||||
|             args.add("all"); |             args.add("all"); | ||||||
|         } |         } | ||||||
|         if (Permissions.hasPermission(player, Permission.PERMISSION_LIST_UNOWNED)) { |         if (player.hasPermission(Permission.PERMISSION_LIST_UNOWNED)) { | ||||||
|             args.add("unowned"); |             args.add("unowned"); | ||||||
|         } |         } | ||||||
|         if (Permissions.hasPermission(player, Permission.PERMISSION_LIST_PLAYER)) { |         if (player.hasPermission(Permission.PERMISSION_LIST_PLAYER)) { | ||||||
|             args.add("<player>"); |             args.add("<player>"); | ||||||
|         } |         } | ||||||
|         if (Permissions.hasPermission(player, Permission.PERMISSION_LIST_WORLD)) { |         if (player.hasPermission(Permission.PERMISSION_LIST_WORLD)) { | ||||||
|             args.add("<world>"); |             args.add("<world>"); | ||||||
|         } |         } | ||||||
|         if (Permissions.hasPermission(player, Permission.PERMISSION_LIST_DONE)) { |         if (player.hasPermission(Permission.PERMISSION_LIST_DONE)) { | ||||||
|             args.add("done"); |             args.add("done"); | ||||||
|         } |         } | ||||||
|         if (Permissions.hasPermission(player, Permission.PERMISSION_LIST_EXPIRED)) { |         if (player.hasPermission(Permission.PERMISSION_LIST_EXPIRED)) { | ||||||
|             args.add("expired"); |             args.add("expired"); | ||||||
|         } |         } | ||||||
|         if (Permissions.hasPermission(player, Permission.PERMISSION_LIST_FUZZY)) { |         if (player.hasPermission(Permission.PERMISSION_LIST_FUZZY)) { | ||||||
|             args.add("fuzzy <search...>"); |             args.add("fuzzy <search...>"); | ||||||
|         } |         } | ||||||
|         return args.toArray(new String[args.size()]); |         return args.toArray(new String[args.size()]); | ||||||
| @@ -193,7 +191,7 @@ public class ListCmd extends SubCommand { | |||||||
|  |  | ||||||
|         switch (arg) { |         switch (arg) { | ||||||
|             case "mine" -> { |             case "mine" -> { | ||||||
|                 if (!Permissions.hasPermission(player, Permission.PERMISSION_LIST_MINE)) { |                 if (!player.hasPermission(Permission.PERMISSION_LIST_MINE)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.mine"))) |                             TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.mine"))) | ||||||
| @@ -208,7 +206,7 @@ public class ListCmd extends SubCommand { | |||||||
|                         .withSortingStrategy(SortingStrategy.SORT_BY_TEMP)); |                         .withSortingStrategy(SortingStrategy.SORT_BY_TEMP)); | ||||||
|             } |             } | ||||||
|             case "shared" -> { |             case "shared" -> { | ||||||
|                 if (!Permissions.hasPermission(player, Permission.PERMISSION_LIST_SHARED)) { |                 if (!player.hasPermission(Permission.PERMISSION_LIST_SHARED)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.shared"))) |                             TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.shared"))) | ||||||
| @@ -221,14 +219,14 @@ public class ListCmd extends SubCommand { | |||||||
|                         .thatPasses(plot -> !plot.isOwnerAbs(player.getUUID()))); |                         .thatPasses(plot -> !plot.isOwnerAbs(player.getUUID()))); | ||||||
|             } |             } | ||||||
|             case "world" -> { |             case "world" -> { | ||||||
|                 if (!Permissions.hasPermission(player, Permission.PERMISSION_LIST_WORLD)) { |                 if (!player.hasPermission(Permission.PERMISSION_LIST_WORLD)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.world"))) |                             TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.world"))) | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 if (!Permissions.hasPermission(player, "plots.list.world." + world)) { |                 if (!player.hasPermission("plots.list.world." + world)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.world." + world))) |                             TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.world." + world))) | ||||||
| @@ -238,28 +236,28 @@ public class ListCmd extends SubCommand { | |||||||
|                 plotConsumer.accept(PlotQuery.newQuery().inWorld(world)); |                 plotConsumer.accept(PlotQuery.newQuery().inWorld(world)); | ||||||
|             } |             } | ||||||
|             case "expired" -> { |             case "expired" -> { | ||||||
|                 if (!Permissions.hasPermission(player, Permission.PERMISSION_LIST_EXPIRED)) { |                 if (!player.hasPermission(Permission.PERMISSION_LIST_EXPIRED)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.expired"))) |                             TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.expired"))) | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 if (ExpireManager.IMP == null) { |                 if (PlotSquared.platform().expireManager() == null) { | ||||||
|                     plotConsumer.accept(PlotQuery.newQuery().noPlots()); |                     plotConsumer.accept(PlotQuery.newQuery().noPlots()); | ||||||
|                 } else { |                 } else { | ||||||
|                     plotConsumer.accept(PlotQuery.newQuery().expiredPlots()); |                     plotConsumer.accept(PlotQuery.newQuery().expiredPlots()); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             case "area" -> { |             case "area" -> { | ||||||
|                 if (!Permissions.hasPermission(player, Permission.PERMISSION_LIST_AREA)) { |                 if (!player.hasPermission(Permission.PERMISSION_LIST_AREA)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.area"))) |                             TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.area"))) | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 if (!Permissions.hasPermission(player, "plots.list.world." + world)) { |                 if (!player.hasPermission("plots.list.world." + world)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.world." + world))) |                             TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.world." + world))) | ||||||
| @@ -273,7 +271,7 @@ public class ListCmd extends SubCommand { | |||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             case "all" -> { |             case "all" -> { | ||||||
|                 if (!Permissions.hasPermission(player, Permission.PERMISSION_LIST_ALL)) { |                 if (!player.hasPermission(Permission.PERMISSION_LIST_ALL)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.all"))) |                             TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.all"))) | ||||||
| @@ -283,7 +281,7 @@ public class ListCmd extends SubCommand { | |||||||
|                 plotConsumer.accept(PlotQuery.newQuery().allPlots()); |                 plotConsumer.accept(PlotQuery.newQuery().allPlots()); | ||||||
|             } |             } | ||||||
|             case "done" -> { |             case "done" -> { | ||||||
|                 if (!Permissions.hasPermission(player, Permission.PERMISSION_LIST_DONE)) { |                 if (!player.hasPermission(Permission.PERMISSION_LIST_DONE)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.done"))) |                             TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.done"))) | ||||||
| @@ -298,7 +296,7 @@ public class ListCmd extends SubCommand { | |||||||
|                         .withSortingStrategy(SortingStrategy.SORT_BY_DONE)); |                         .withSortingStrategy(SortingStrategy.SORT_BY_DONE)); | ||||||
|             } |             } | ||||||
|             case "top" -> { |             case "top" -> { | ||||||
|                 if (!Permissions.hasPermission(player, Permission.PERMISSION_LIST_TOP)) { |                 if (!player.hasPermission(Permission.PERMISSION_LIST_TOP)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.top"))) |                             TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.top"))) | ||||||
| @@ -309,7 +307,7 @@ public class ListCmd extends SubCommand { | |||||||
|                 plotConsumer.accept(PlotQuery.newQuery().allPlots().withSortingStrategy(SortingStrategy.SORT_BY_RATING)); |                 plotConsumer.accept(PlotQuery.newQuery().allPlots().withSortingStrategy(SortingStrategy.SORT_BY_RATING)); | ||||||
|             } |             } | ||||||
|             case "forsale" -> { |             case "forsale" -> { | ||||||
|                 if (!Permissions.hasPermission(player, Permission.PERMISSION_LIST_FOR_SALE)) { |                 if (!player.hasPermission(Permission.PERMISSION_LIST_FOR_SALE)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.forsale"))) |                             TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.forsale"))) | ||||||
| @@ -322,7 +320,7 @@ public class ListCmd extends SubCommand { | |||||||
|                 plotConsumer.accept(PlotQuery.newQuery().allPlots().thatPasses(plot -> plot.getFlag(PriceFlag.class) > 0)); |                 plotConsumer.accept(PlotQuery.newQuery().allPlots().thatPasses(plot -> plot.getFlag(PriceFlag.class) > 0)); | ||||||
|             } |             } | ||||||
|             case "unowned" -> { |             case "unowned" -> { | ||||||
|                 if (!Permissions.hasPermission(player, Permission.PERMISSION_LIST_UNOWNED)) { |                 if (!player.hasPermission(Permission.PERMISSION_LIST_UNOWNED)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.unowned"))) |                             TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.unowned"))) | ||||||
| @@ -332,7 +330,7 @@ public class ListCmd extends SubCommand { | |||||||
|                 plotConsumer.accept(PlotQuery.newQuery().allPlots().thatPasses(plot -> plot.getOwner() == null)); |                 plotConsumer.accept(PlotQuery.newQuery().allPlots().thatPasses(plot -> plot.getOwner() == null)); | ||||||
|             } |             } | ||||||
|             case "fuzzy" -> { |             case "fuzzy" -> { | ||||||
|                 if (!Permissions.hasPermission(player, Permission.PERMISSION_LIST_FUZZY)) { |                 if (!player.hasPermission(Permission.PERMISSION_LIST_FUZZY)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|                             TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.fuzzy"))) |                             TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.fuzzy"))) | ||||||
| @@ -357,14 +355,14 @@ public class ListCmd extends SubCommand { | |||||||
|             } |             } | ||||||
|             default -> { |             default -> { | ||||||
|                 if (this.plotAreaManager.hasPlotArea(args[0])) { |                 if (this.plotAreaManager.hasPlotArea(args[0])) { | ||||||
|                     if (!Permissions.hasPermission(player, Permission.PERMISSION_LIST_WORLD)) { |                     if (!player.hasPermission(Permission.PERMISSION_LIST_WORLD)) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission"), |                                 TranslatableCaption.of("permission.no_permission"), | ||||||
|                                 TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.world"))) |                                 TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.world"))) | ||||||
|                         ); |                         ); | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
|                     if (!Permissions.hasPermission(player, "plots.list.world." + args[0])) { |                     if (!player.hasPermission("plots.list.world." + args[0])) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission"), |                                 TranslatableCaption.of("permission.no_permission"), | ||||||
|                                 TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.world." + args[0]))) |                                 TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.world." + args[0]))) | ||||||
| @@ -391,7 +389,7 @@ public class ListCmd extends SubCommand { | |||||||
|                                 TagResolver.resolver("value", Tag.inserting(Component.text(args[0]))) |                                 TagResolver.resolver("value", Tag.inserting(Component.text(args[0]))) | ||||||
|                         ); |                         ); | ||||||
|                     } else { |                     } else { | ||||||
|                         if (!Permissions.hasPermission(player, Permission.PERMISSION_LIST_PLAYER)) { |                         if (!player.hasPermission(Permission.PERMISSION_LIST_PLAYER)) { | ||||||
|                             player.sendMessage( |                             player.sendMessage( | ||||||
|                                     TranslatableCaption.of("permission.no_permission"), |                                     TranslatableCaption.of("permission.no_permission"), | ||||||
|                                     TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.player"))) |                                     TagResolver.resolver("node", Tag.inserting(Component.text("plots.list.player"))) | ||||||
| @@ -467,7 +465,7 @@ public class ListCmd extends SubCommand { | |||||||
|                 TextComponent.Builder builder = Component.text(); |                 TextComponent.Builder builder = Component.text(); | ||||||
|                 if (plot.getFlag(ServerPlotFlag.class)) { |                 if (plot.getFlag(ServerPlotFlag.class)) { | ||||||
|                     TagResolver serverResolver = TagResolver.resolver( |                     TagResolver serverResolver = TagResolver.resolver( | ||||||
|                             "info.server", |                             "server", | ||||||
|                             Tag.inserting(TranslatableCaption.of("info.server").toComponent(player)) |                             Tag.inserting(TranslatableCaption.of("info.server").toComponent(player)) | ||||||
|                     ); |                     ); | ||||||
|                     builder.append(MINI_MESSAGE.deserialize(server, serverResolver)); |                     builder.append(MINI_MESSAGE.deserialize(server, serverResolver)); | ||||||
| @@ -476,22 +474,22 @@ public class ListCmd extends SubCommand { | |||||||
|                         final List<UUIDMapping> names = PlotSquared.get().getImpromptuUUIDPipeline().getNames(plot.getOwners()) |                         final List<UUIDMapping> names = PlotSquared.get().getImpromptuUUIDPipeline().getNames(plot.getOwners()) | ||||||
|                                 .get(Settings.UUID.BLOCKING_TIMEOUT, TimeUnit.MILLISECONDS); |                                 .get(Settings.UUID.BLOCKING_TIMEOUT, TimeUnit.MILLISECONDS); | ||||||
|                         for (final UUIDMapping uuidMapping : names) { |                         for (final UUIDMapping uuidMapping : names) { | ||||||
|                             PlotPlayer<?> pp = PlotSquared.platform().playerManager().getPlayerIfExists(uuidMapping.getUuid()); |                             PlotPlayer<?> pp = PlotSquared.platform().playerManager().getPlayerIfExists(uuidMapping.uuid()); | ||||||
|                             TagResolver resolver = TagResolver.builder() |                             TagResolver resolver = TagResolver.builder() | ||||||
|                                     .tag("prefix", Tag.inserting(Component.text(prefix))) |                                     .tag("prefix", Tag.inserting(Component.text(prefix))) | ||||||
|                                 .tag("player", Tag.inserting(Component.text(uuidMapping.getUsername()))) |                                     .tag("player", Tag.inserting(Component.text(uuidMapping.username()))) | ||||||
|                                     .build(); |                                     .build(); | ||||||
|                             if (pp != null) { |                             if (pp != null) { | ||||||
|                                 builder.append(MINI_MESSAGE.deserialize(online, resolver)); |                                 builder.append(MINI_MESSAGE.deserialize(online, resolver)); | ||||||
|                             } else if (uuidMapping.getUsername().equalsIgnoreCase("unknown")) { |                             } else if (uuidMapping.username().equalsIgnoreCase("unknown")) { | ||||||
|                                 TagResolver unknownResolver = TagResolver.resolver( |                                 TagResolver unknownResolver = TagResolver.resolver( | ||||||
|                                         "info.unknown", |                                         "unknown", | ||||||
|                                         Tag.inserting(TranslatableCaption.of("info.unknown").toComponent(player)) |                                         Tag.inserting(TranslatableCaption.of("info.unknown").toComponent(player)) | ||||||
|                                 ); |                                 ); | ||||||
|                                 builder.append(MINI_MESSAGE.deserialize(unknown, unknownResolver)); |                                 builder.append(MINI_MESSAGE.deserialize(unknown, unknownResolver)); | ||||||
|                             } else if (uuidMapping.getUuid().equals(DBFunc.EVERYONE)) { |                             } else if (uuidMapping.uuid().equals(DBFunc.EVERYONE)) { | ||||||
|                                 TagResolver everyoneResolver = TagResolver.resolver( |                                 TagResolver everyoneResolver = TagResolver.resolver( | ||||||
|                                         "info.everyone", |                                         "everyone", | ||||||
|                                         Tag.inserting(TranslatableCaption.of("info.everyone").toComponent(player)) |                                         Tag.inserting(TranslatableCaption.of("info.everyone").toComponent(player)) | ||||||
|                                 ); |                                 ); | ||||||
|                                 builder.append(MINI_MESSAGE.deserialize(everyone, everyoneResolver)); |                                 builder.append(MINI_MESSAGE.deserialize(everyone, everyoneResolver)); | ||||||
| @@ -519,6 +517,7 @@ public class ListCmd extends SubCommand { | |||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|                 finalResolver.tag("players", Tag.inserting(builder.asComponent())); |                 finalResolver.tag("players", Tag.inserting(builder.asComponent())); | ||||||
|  |                 finalResolver.tag("size", Tag.inserting(Component.text(plot.getConnectedPlots().size()))); | ||||||
|                 caption.set(TranslatableCaption.of("info.plot_list_item")); |                 caption.set(TranslatableCaption.of("info.plot_list_item")); | ||||||
|                 caption.setTagResolvers(finalResolver.build()); |                 caption.setTagResolvers(finalResolver.build()); | ||||||
|             } |             } | ||||||
| @@ -528,31 +527,31 @@ public class ListCmd extends SubCommand { | |||||||
|     @Override |     @Override | ||||||
|     public Collection<Command> tab(PlotPlayer<?> player, String[] args, boolean space) { |     public Collection<Command> tab(PlotPlayer<?> player, String[] args, boolean space) { | ||||||
|         final List<String> completions = new LinkedList<>(); |         final List<String> completions = new LinkedList<>(); | ||||||
|         if (this.econHandler.isSupported() && Permissions.hasPermission(player, Permission.PERMISSION_LIST_FOR_SALE)) { |         if (this.econHandler.isSupported() && player.hasPermission(Permission.PERMISSION_LIST_FOR_SALE)) { | ||||||
|             completions.add("forsale"); |             completions.add("forsale"); | ||||||
|         } |         } | ||||||
|         if (Permissions.hasPermission(player, Permission.PERMISSION_LIST_MINE)) { |         if (player.hasPermission(Permission.PERMISSION_LIST_MINE)) { | ||||||
|             completions.add("mine"); |             completions.add("mine"); | ||||||
|         } |         } | ||||||
|         if (Permissions.hasPermission(player, Permission.PERMISSION_LIST_SHARED)) { |         if (player.hasPermission(Permission.PERMISSION_LIST_SHARED)) { | ||||||
|             completions.add("shared"); |             completions.add("shared"); | ||||||
|         } |         } | ||||||
|         if (Permissions.hasPermission(player, Permission.PERMISSION_LIST_WORLD)) { |         if (player.hasPermission(Permission.PERMISSION_LIST_WORLD)) { | ||||||
|             completions.addAll(PlotSquared.platform().worldManager().getWorlds()); |             completions.addAll(PlotSquared.platform().worldManager().getWorlds()); | ||||||
|         } |         } | ||||||
|         if (Permissions.hasPermission(player, Permission.PERMISSION_LIST_TOP)) { |         if (player.hasPermission(Permission.PERMISSION_LIST_TOP)) { | ||||||
|             completions.add("top"); |             completions.add("top"); | ||||||
|         } |         } | ||||||
|         if (Permissions.hasPermission(player, Permission.PERMISSION_LIST_ALL)) { |         if (player.hasPermission(Permission.PERMISSION_LIST_ALL)) { | ||||||
|             completions.add("all"); |             completions.add("all"); | ||||||
|         } |         } | ||||||
|         if (Permissions.hasPermission(player, Permission.PERMISSION_LIST_UNOWNED)) { |         if (player.hasPermission(Permission.PERMISSION_LIST_UNOWNED)) { | ||||||
|             completions.add("unowned"); |             completions.add("unowned"); | ||||||
|         } |         } | ||||||
|         if (Permissions.hasPermission(player, Permission.PERMISSION_LIST_DONE)) { |         if (player.hasPermission(Permission.PERMISSION_LIST_DONE)) { | ||||||
|             completions.add("done"); |             completions.add("done"); | ||||||
|         } |         } | ||||||
|         if (Permissions.hasPermission(player, Permission.PERMISSION_LIST_EXPIRED)) { |         if (player.hasPermission(Permission.PERMISSION_LIST_EXPIRED)) { | ||||||
|             completions.add("expired"); |             completions.add("expired"); | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @@ -562,7 +561,7 @@ public class ListCmd extends SubCommand { | |||||||
|                 .map(completion -> new Command(null, true, completion, "", RequiredType.NONE, CommandCategory.TELEPORT) { |                 .map(completion -> new Command(null, true, completion, "", RequiredType.NONE, CommandCategory.TELEPORT) { | ||||||
|                 }).collect(Collectors.toCollection(LinkedList::new)); |                 }).collect(Collectors.toCollection(LinkedList::new)); | ||||||
|  |  | ||||||
|         if (Permissions.hasPermission(player, Permission.PERMISSION_LIST_PLAYER) && args[0].length() > 0) { |         if (player.hasPermission(Permission.PERMISSION_LIST_PLAYER) && args[0].length() > 0) { | ||||||
|             commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); |             commands.addAll(TabCompletions.completePlayers(player, args[0], Collections.emptyList())); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -31,7 +31,6 @@ import com.plotsquared.core.plot.PlotArea; | |||||||
| import com.plotsquared.core.plot.PlotId; | import com.plotsquared.core.plot.PlotId; | ||||||
| import com.plotsquared.core.plot.schematic.Schematic; | import com.plotsquared.core.plot.schematic.Schematic; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
| import com.plotsquared.core.util.Permissions; |  | ||||||
| import com.plotsquared.core.util.SchematicHandler; | import com.plotsquared.core.util.SchematicHandler; | ||||||
| import com.plotsquared.core.util.TimeUtil; | import com.plotsquared.core.util.TimeUtil; | ||||||
| import com.plotsquared.core.util.task.RunnableVal; | import com.plotsquared.core.util.task.RunnableVal; | ||||||
| @@ -42,6 +41,7 @@ import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | |||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.net.MalformedURLException; | import java.net.MalformedURLException; | ||||||
|  | import java.net.URI; | ||||||
| import java.net.URL; | import java.net.URL; | ||||||
| import java.util.Collections; | import java.util.Collections; | ||||||
| import java.util.List; | import java.util.List; | ||||||
| @@ -82,8 +82,7 @@ public class Load extends SubCommand { | |||||||
|             player.sendMessage(TranslatableCaption.of("info.plot_unowned")); |             player.sendMessage(TranslatableCaption.of("info.plot_unowned")); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         if (!plot.isOwner(player.getUUID()) && !Permissions |         if (!plot.isOwner(player.getUUID()) && !player.hasPermission(Permission.PERMISSION_ADMIN_COMMAND_LOAD)) { | ||||||
|                 .hasPermission(player, Permission.PERMISSION_ADMIN_COMMAND_LOAD)) { |  | ||||||
|             player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); |             player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
| @@ -118,7 +117,7 @@ public class Load extends SubCommand { | |||||||
|                     } |                     } | ||||||
|                     final URL url; |                     final URL url; | ||||||
|                     try { |                     try { | ||||||
|                         url = new URL(Settings.Web.URL + "saves/" + player.getUUID() + '/' + schematic); |                         url = URI.create(Settings.Web.URL + "saves/" + player.getUUID() + '/' + schematic).toURL(); | ||||||
|                     } catch (MalformedURLException e) { |                     } catch (MalformedURLException e) { | ||||||
|                         e.printStackTrace(); |                         e.printStackTrace(); | ||||||
|                         player.sendMessage(TranslatableCaption.of("web.load_failed")); |                         player.sendMessage(TranslatableCaption.of("web.load_failed")); | ||||||
|   | |||||||
| @@ -32,7 +32,6 @@ import com.plotsquared.core.plot.Plot; | |||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
| import com.plotsquared.core.plot.world.SinglePlotArea; | import com.plotsquared.core.plot.world.SinglePlotArea; | ||||||
| import com.plotsquared.core.util.EconHandler; | import com.plotsquared.core.util.EconHandler; | ||||||
| import com.plotsquared.core.util.Permissions; |  | ||||||
| import com.plotsquared.core.util.PlotExpression; | import com.plotsquared.core.util.PlotExpression; | ||||||
| import com.plotsquared.core.util.task.RunnableVal2; | import com.plotsquared.core.util.task.RunnableVal2; | ||||||
| import com.plotsquared.core.util.task.RunnableVal3; | import com.plotsquared.core.util.task.RunnableVal3; | ||||||
| @@ -184,7 +183,7 @@ public class MainCommand extends Command { | |||||||
|                     if (cmd.hasConfirmation(player)) { |                     if (cmd.hasConfirmation(player)) { | ||||||
|                         CmdConfirm.addPending(player, cmd.getUsage(), () -> { |                         CmdConfirm.addPending(player, cmd.getUsage(), () -> { | ||||||
|                             PlotArea area = player.getApplicablePlotArea(); |                             PlotArea area = player.getApplicablePlotArea(); | ||||||
|                             if (area != null && econHandler.isEnabled(area)) { |                             if (area != null && econHandler.isEnabled(area) && !player.hasPermission(Permission.PERMISSION_ADMIN_BYPASS_ECON)) { | ||||||
|                                 PlotExpression priceEval = |                                 PlotExpression priceEval = | ||||||
|                                         area.getPrices().get(cmd.getFullId()); |                                         area.getPrices().get(cmd.getFullId()); | ||||||
|                                 double price = priceEval != null ? priceEval.evaluate(0d) : 0d; |                                 double price = priceEval != null ? priceEval.evaluate(0d) : 0d; | ||||||
| @@ -202,7 +201,7 @@ public class MainCommand extends Command { | |||||||
|                         return; |                         return; | ||||||
|                     } |                     } | ||||||
|                     PlotArea area = player.getApplicablePlotArea(); |                     PlotArea area = player.getApplicablePlotArea(); | ||||||
|                     if (area != null && econHandler.isEnabled(area)) { |                     if (area != null && econHandler.isEnabled(area) && !player.hasPermission(Permission.PERMISSION_ADMIN_BYPASS_ECON)) { | ||||||
|                         PlotExpression priceEval = area.getPrices().get(cmd.getFullId()); |                         PlotExpression priceEval = area.getPrices().get(cmd.getFullId()); | ||||||
|                         double price = priceEval != null ? priceEval.evaluate(0d) : 0d; |                         double price = priceEval != null ? priceEval.evaluate(0d) : 0d; | ||||||
|                         if (price != 0d && econHandler.getMoney(player) < price) { |                         if (price != 0d && econHandler.getMoney(player) < price) { | ||||||
| @@ -245,8 +244,8 @@ public class MainCommand extends Command { | |||||||
|             PlotArea area = player.getApplicablePlotArea(); |             PlotArea area = player.getApplicablePlotArea(); | ||||||
|             Plot newPlot = Plot.fromString(area, args[0]); |             Plot newPlot = Plot.fromString(area, args[0]); | ||||||
|             if (newPlot != null && (player instanceof ConsolePlayer || newPlot.getArea() |             if (newPlot != null && (player instanceof ConsolePlayer || newPlot.getArea() | ||||||
|                     .equals(area) || Permissions.hasPermission(player, Permission.PERMISSION_ADMIN) |                     .equals(area) || player.hasPermission(Permission.PERMISSION_ADMIN) | ||||||
|                     || Permissions.hasPermission(player, Permission.PERMISSION_ADMIN_AREA_SUDO)) |                     || player.hasPermission(Permission.PERMISSION_ADMIN_AREA_SUDO)) | ||||||
|                     && !newPlot.isDenied(player.getUUID())) { |                     && !newPlot.isDenied(player.getUUID())) { | ||||||
|                 final Location newLoc; |                 final Location newLoc; | ||||||
|                 if (newPlot.getArea() instanceof SinglePlotArea) { |                 if (newPlot.getArea() instanceof SinglePlotArea) { | ||||||
| @@ -269,6 +268,7 @@ public class MainCommand extends Command { | |||||||
|                     tp = true; |                     tp = true; | ||||||
|                 } else { |                 } else { | ||||||
|                     player.sendMessage(TranslatableCaption.of("border.denied")); |                     player.sendMessage(TranslatableCaption.of("border.denied")); | ||||||
|  |                     return CompletableFuture.completedFuture(false); | ||||||
|                 } |                 } | ||||||
|                 // Trim command |                 // Trim command | ||||||
|                 args = Arrays.copyOfRange(args, 1, args.length); |                 args = Arrays.copyOfRange(args, 1, args.length); | ||||||
|   | |||||||
| @@ -32,7 +32,6 @@ import com.plotsquared.core.plot.Plot; | |||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
| import com.plotsquared.core.util.EconHandler; | import com.plotsquared.core.util.EconHandler; | ||||||
| import com.plotsquared.core.util.EventDispatcher; | import com.plotsquared.core.util.EventDispatcher; | ||||||
| import com.plotsquared.core.util.Permissions; |  | ||||||
| import com.plotsquared.core.util.PlotExpression; | import com.plotsquared.core.util.PlotExpression; | ||||||
| import com.plotsquared.core.util.StringMan; | import com.plotsquared.core.util.StringMan; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| @@ -110,7 +109,7 @@ public class Merge extends SubCommand { | |||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             if (direction == null && (args[0].equalsIgnoreCase("all") || args[0] |             if (direction == null && (args[0].equalsIgnoreCase("all") || args[0] | ||||||
|                     .equalsIgnoreCase("auto"))) { |                     .equalsIgnoreCase("auto")) && player.hasPermission(Permission.PERMISSION_MERGE_ALL)) { | ||||||
|                 direction = Direction.ALL; |                 direction = Direction.ALL; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| @@ -128,7 +127,7 @@ public class Merge extends SubCommand { | |||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         final int size = plot.getConnectedPlots().size(); |         final int size = plot.getConnectedPlots().size(); | ||||||
|         int max = Permissions.hasPermissionRange(player, "plots.merge", Settings.Limit.MAX_PLOTS); |         int max = player.hasPermissionRange("plots.merge", Settings.Limit.MAX_PLOTS); | ||||||
|         PlotMergeEvent event = |         PlotMergeEvent event = | ||||||
|                 this.eventDispatcher.callMerge(plot, direction, max, player); |                 this.eventDispatcher.callMerge(plot, direction, max, player); | ||||||
|         if (event.getEventResult() == Result.DENY) { |         if (event.getEventResult() == Result.DENY) { | ||||||
| @@ -156,7 +155,7 @@ public class Merge extends SubCommand { | |||||||
|         UUID uuid = player.getUUID(); |         UUID uuid = player.getUUID(); | ||||||
|  |  | ||||||
|         if (!force && !plot.isOwner(uuid)) { |         if (!force && !plot.isOwner(uuid)) { | ||||||
|             if (!Permissions.hasPermission(player, Permission.PERMISSION_ADMIN_COMMAND_MERGE)) { |             if (!player.hasPermission(Permission.PERMISSION_ADMIN_COMMAND_MERGE)) { | ||||||
|                 player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); |                 player.sendMessage(TranslatableCaption.of("permission.no_plot_perms")); | ||||||
|                 return false; |                 return false; | ||||||
|             } else { |             } else { | ||||||
| @@ -168,8 +167,7 @@ public class Merge extends SubCommand { | |||||||
|             if (args.length == 2) { |             if (args.length == 2) { | ||||||
|                 terrain = "true".equalsIgnoreCase(args[1]); |                 terrain = "true".equalsIgnoreCase(args[1]); | ||||||
|             } |             } | ||||||
|             if (!force && !terrain && !Permissions |             if (!force && !terrain && !player.hasPermission(Permission.PERMISSION_MERGE_KEEP_ROAD)) { | ||||||
|                     .hasPermission(player, Permission.PERMISSION_MERGE_KEEP_ROAD)) { |  | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission"), |                         TranslatableCaption.of("permission.no_permission"), | ||||||
|                         TagResolver.resolver( |                         TagResolver.resolver( | ||||||
| @@ -180,7 +178,7 @@ public class Merge extends SubCommand { | |||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|             if (plot.getPlotModificationManager().autoMerge(Direction.ALL, maxSize, uuid, player, terrain)) { |             if (plot.getPlotModificationManager().autoMerge(Direction.ALL, maxSize, uuid, player, terrain)) { | ||||||
|                 if (this.econHandler.isEnabled(plotArea) && price > 0d) { |                 if (this.econHandler.isEnabled(plotArea) && !player.hasPermission(Permission.PERMISSION_ADMIN_BYPASS_ECON) && price > 0d) { | ||||||
|                     this.econHandler.withdrawMoney(player, price); |                     this.econHandler.withdrawMoney(player, price); | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("economy.removed_balance"), |                             TranslatableCaption.of("economy.removed_balance"), | ||||||
| @@ -198,8 +196,8 @@ public class Merge extends SubCommand { | |||||||
|             player.sendMessage(TranslatableCaption.of("merge.no_available_automerge")); |             player.sendMessage(TranslatableCaption.of("merge.no_available_automerge")); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         if (!force && this.econHandler.isEnabled(plotArea) && price > 0d |         if (!force && this.econHandler.isEnabled(plotArea) && !player.hasPermission(Permission.PERMISSION_ADMIN_BYPASS_ECON) && price > 0d && this.econHandler.getMoney( | ||||||
|                 && this.econHandler.getMoney(player) < price) { |                 player) < price) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("economy.cannot_afford_merge"), |                     TranslatableCaption.of("economy.cannot_afford_merge"), | ||||||
|                     TagResolver.resolver("money", Tag.inserting(Component.text(this.econHandler.format(price)))) |                     TagResolver.resolver("money", Tag.inserting(Component.text(this.econHandler.format(price)))) | ||||||
| @@ -212,8 +210,7 @@ public class Merge extends SubCommand { | |||||||
|         } else { |         } else { | ||||||
|             terrain = true; |             terrain = true; | ||||||
|         } |         } | ||||||
|         if (!force && !terrain && !Permissions |         if (!force && !terrain && !player.hasPermission(Permission.PERMISSION_MERGE_KEEP_ROAD)) { | ||||||
|                 .hasPermission(player, Permission.PERMISSION_MERGE_KEEP_ROAD)) { |  | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("permission.no_permission"), |                     TranslatableCaption.of("permission.no_permission"), | ||||||
|                     TagResolver.resolver("node", Tag.inserting(Permission.PERMISSION_MERGE_KEEP_ROAD)) |                     TagResolver.resolver("node", Tag.inserting(Permission.PERMISSION_MERGE_KEEP_ROAD)) | ||||||
| @@ -221,7 +218,7 @@ public class Merge extends SubCommand { | |||||||
|             return true; |             return true; | ||||||
|         } |         } | ||||||
|         if (plot.getPlotModificationManager().autoMerge(direction, maxSize - size, uuid, player, terrain)) { |         if (plot.getPlotModificationManager().autoMerge(direction, maxSize - size, uuid, player, terrain)) { | ||||||
|             if (this.econHandler.isEnabled(plotArea) && price > 0d) { |             if (this.econHandler.isEnabled(plotArea) && !player.hasPermission(Permission.PERMISSION_ADMIN_BYPASS_ECON) && price > 0d) { | ||||||
|                 this.econHandler.withdrawMoney(player, price); |                 this.econHandler.withdrawMoney(player, price); | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("economy.removed_balance"), |                         TranslatableCaption.of("economy.removed_balance"), | ||||||
| @@ -238,7 +235,7 @@ public class Merge extends SubCommand { | |||||||
|             player.sendMessage(TranslatableCaption.of("merge.no_available_automerge")); |             player.sendMessage(TranslatableCaption.of("merge.no_available_automerge")); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         if (!force && !Permissions.hasPermission(player, Permission.PERMISSION_MERGE_OTHER)) { |         if (!force && !player.hasPermission(Permission.PERMISSION_MERGE_OTHER)) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("permission.no_permission"), |                     TranslatableCaption.of("permission.no_permission"), | ||||||
|                     TagResolver.resolver("node", Tag.inserting(Permission.PERMISSION_MERGE_OTHER)) |                     TagResolver.resolver("node", Tag.inserting(Permission.PERMISSION_MERGE_OTHER)) | ||||||
| @@ -262,7 +259,7 @@ public class Merge extends SubCommand { | |||||||
|                     accepter.sendMessage(TranslatableCaption.of("merge.merge_not_valid")); |                     accepter.sendMessage(TranslatableCaption.of("merge.merge_not_valid")); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 if (this.econHandler.isEnabled(plotArea) && price > 0d) { |                 if (this.econHandler.isEnabled(plotArea) && !player.hasPermission(Permission.PERMISSION_ADMIN_BYPASS_ECON) && price > 0d) { | ||||||
|                     if (!force && this.econHandler.getMoney(player) < price) { |                     if (!force && this.econHandler.getMoney(player) < price) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("economy.cannot_afford_merge"), |                                 TranslatableCaption.of("economy.cannot_afford_merge"), | ||||||
| @@ -297,7 +294,34 @@ public class Merge extends SubCommand { | |||||||
|                 run.run(); |                 run.run(); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         if (!force && !isOnline) { |         if (force || !isOnline) { | ||||||
|  |             if (force || player.hasPermission(Permission.PERMISSION_ADMIN_COMMAND_MERGE_OTHER_OFFLINE)) { | ||||||
|  |                 if (plot.getPlotModificationManager().autoMerge( | ||||||
|  |                         direction, | ||||||
|  |                         maxSize - size, | ||||||
|  |                         uuids.iterator().next(), | ||||||
|  |                         player, | ||||||
|  |                         terrain | ||||||
|  |                 )) { | ||||||
|  |                     if (this.econHandler.isEnabled(plotArea) && !player.hasPermission(Permission.PERMISSION_ADMIN_BYPASS_ECON) && price > 0d) { | ||||||
|  |                         if (!force && this.econHandler.getMoney(player) < price) { | ||||||
|  |                             player.sendMessage( | ||||||
|  |                                     TranslatableCaption.of("economy.cannot_afford_merge"), | ||||||
|  |                                     TagResolver.resolver("money", Tag.inserting(Component.text(this.econHandler.format(price)))) | ||||||
|  |                             ); | ||||||
|  |                             return false; | ||||||
|  |                         } | ||||||
|  |                         this.econHandler.withdrawMoney(player, price); | ||||||
|  |                         player.sendMessage( | ||||||
|  |                                 TranslatableCaption.of("economy.removed_balance"), | ||||||
|  |                                 TagResolver.resolver("money", Tag.inserting(Component.text(this.econHandler.format(price)))) | ||||||
|  |                         ); | ||||||
|  |                     } | ||||||
|  |                     player.sendMessage(TranslatableCaption.of("merge.success_merge")); | ||||||
|  |                     eventDispatcher.callPostMerge(player, plot); | ||||||
|  |                     return true; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|             player.sendMessage(TranslatableCaption.of("merge.no_available_automerge")); |             player.sendMessage(TranslatableCaption.of("merge.no_available_automerge")); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|   | |||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user