generated from crowbarmaster/BedrockService
-
Notifications
You must be signed in to change notification settings - Fork 4
188 lines (168 loc) · 8.93 KB
/
CheckJavaVersion.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
name: CheckJDSVersion
on:
workflow_dispatch:
schedule:
# * is a special character in YAML so you have to quote this string
- cron: '0 0,4,8,12,16,20 * * *'
jobs:
check-version:
name: check-version
runs-on: windows-2022
steps:
- uses: actions/checkout@v3
- run: |
Set-PSDebug -Trace 1;
class PropInfoEntry {
[string]$Key;
[string]$Value;
}
class JavaVersionHistoryModel {
[string]$Version;
[string]$IsBeta;
[string]$DownloadUrl;
[PropInfoEntry[]] $PropList;
}
$javaManifestUri = 'https://piston-meta.mojang.com/mc/game/version_manifest_v2.json';
$javaManifestcontent = Invoke-WebRequest -UseBasicParsing -Headers $ConnectionHeaders -Uri $javaManifestUri;
$javaManifestJson = $javaManifestcontent | ConvertFrom-Json;
$localJavaManifestJson = Get-Content "MMS_Files\\java_version_prop_manifest.json" | ConvertFrom-Json;
$latestRelease = $javaManifestJson.versions | Select-Object -First 1;
$latestLocalRelease = $localJavaManifestJson | Select-Object -Last 1;
echo "javaVer=0" | Out-File -FilePath $Env:GITHUB_ENV -Encoding utf-8 -Append;
if($localJavaManifestJson) {
if($latestRelease.id -eq $latestLocalRelease.Version) {
return;
}
}
$javaManifestReleasecontent = Invoke-WebRequest -UseBasicParsing -Headers $ConnectionHeaders -Uri $latestRelease.url;
$javaManifestReleasecontentJson = $javaManifestReleasecontent | ConvertFrom-Json;
$betaBool = $javaManifestReleasecontentJson.type -eq 'snapshot';
$betaStatus = $betaBool ? 'true' : 'false';
$javaVer = $javaManifestReleasecontentJson.minimumLauncherVersion;
$jdsVer = $javaManifestReleasecontentJson.id;
$downloadUrl = $javaManifestReleasecontentJson.downloads.server.url;
echo "javaVer=$javaVer" | Out-File -FilePath $Env:GITHUB_ENV -Encoding utf-8 -Append;
echo "jdsVer=$jdsVer" | Out-File -FilePath $Env:GITHUB_ENV -Encoding utf-8 -Append;
echo "isBeta=$betaStatus" | Out-File -FilePath $Env:GITHUB_ENV -Encoding utf-8 -Append;
echo "downloadUrl=$downloadUrl" | Out-File -FilePath $Env:GITHUB_ENV -Encoding utf-8 -Append;
- if: ${{ env.javaVer != '0' }}
uses: actions/setup-java@v4
with:
distribution: 'oracle' # See 'Supported distributions' for available options
java-version: "${{ env.javaVer }}"
- if: ${{ env.javaVer != '0' }}
run: |
class PropInfoEntry {
[string]$Key;
[string]$Value;
}
class JavaVersionHistoryModel {
[string]$Version;
[string]$IsBeta;
[string]$DownloadUrl;
[PropInfoEntry[]] $PropList;
}
Set-PSDebug -Trace 1;
$localJavaManifestJson = Get-Content "MMS_Files\\java_version_prop_manifest.json" | ConvertFrom-Json;
$propList = @();
mkdir ServerTemp;
cd .\\ServerTemp;
$curPath = Get-Location;
Invoke-WebRequest -Uri "${{ env.downloadUrl }}" -OutFile '.\\Server.jar';
$processStartInfo = [Diagnostics.ProcessStartInfo] @{
UseShellExecute = 0
CreateNoWindow = 1
FileName = 'Java'
WorkingDirectory = $curPath.Path
Arguments = '-Xmx1024M -Xms1024M -jar Server.jar nogui'
};
$proc = [Diagnostics.Process]::Start($processStartInfo);
$proc.WaitForExit(10000);
$fileStream = [IO.File]::OpenRead($curPath.Path + "\\server.properties");
$reader = New-Object IO.StreamReader $fileStream;
while (($line = $reader.ReadLine()) -ne $null) {
if ($line -ne "" -And !$line.StartsWith('#')) {
$kvp = $line.Split('=');
if ($kvp.Length -lt 2) {
$temp = [string[]];
$temp[0] = $kvp[0];
$temp[1] = "";
$kvp = $temp;
}
$newProp = [PropInfoEntry]@{
Key = $kvp[0];
Value = $kvp[1];
}
$propList += $newProp;
}
}
cd ..;
$newEntry = [JavaVersionHistoryModel]@{
Version = "${{ env.jdsVer }}";
DownloadUrl = "${{ env.downloadUrl }}";
IsBeta = "${{ env.isBeta }}";
PropList = $propList;
}
$localJavaManifestJson += $newEntry;
$localJavaManifestJson | ConvertTo-Json -depth 100 | Out-File "MMS_Files\\java_version_prop_manifest.json";
- if: ${{ env.javaVer != '0' }}
uses: EndBug/add-and-commit@v9 # You can change this to use a specific version.
with:
# The arguments for the `git add` command (see the paragraph below for more info)
# Default: '.'
add: "['.\\MMS_Files\\java_version_prop_manifest.json']"
# The name of the user that will be displayed as the author of the commit.
# Default: depends on the default_author input
author_name: Crowbarmaster
# The email of the user that will be displayed as the author of the commit.
# Default: depends on the default_author input
author_email: [email protected]
# Additional arguments for the git commit command. The --message argument is already set by the message input.
# Default: ''
commit: --signoff
# The name of the custom committer you want to use, if different from the author of the commit.
# Default: the name of the author (set with either author_name or default_author)
committer_name: author_name
# The email of the custom committer you want to use, if different from the author of the commit.
# Default: the email of the author (set with either author_email or default_author)
committer_email: author_email
# The local path to the directory where your repository is located. You should use actions/checkout first to set it up.
# Default: '.'
cwd: '.'
# Determines the way the action fills missing author name and email. Three options are available:
# - github_actor -> UserName <[email protected]>
# - user_info -> Your Display Name <[email protected]>
# - github_actions -> github-actions <email associated with the github logo>
# Default: github_actor
default_author: github_actor
# Arguments for the git fetch command. If set to false, the action won't fetch the repo.
# For more info as to why fetching is usually recommended, please see the "Performance on large repos" FAQ.
# Default: --tags --force
fetch: true
# The message for the commit.
# Default: 'Commit from GitHub Actions (name of the workflow)'
message: 'Update java version prop manifest.'
# If this input is set, the action will push the commit to a new branch with this name.
# Default: ''
new_branch: master
# The way the action should handle pathspec errors from the add and remove commands. Three options are available:
# - ignore -> errors will be logged but the step won't fail
# - exitImmediately -> the action will stop right away, and the step will fail
# - exitAtEnd -> the action will go on, every pathspec error will be logged at the end, the step will fail.
# Default: ignore
pathspec_error_handling: ignore
# Arguments for the git pull command. By default, the action does not pull.
# Default: ''
pull: ''
# Whether to push the commit and, if any, its tags to the repo. It can also be used to set the git push arguments (see the paragraph below for more info)
# Default: true
push: true
# The arguments for the `git rm` command (see the paragraph below for more info)
# Default: ''
remove: ''
# Arguments for the git tag command (the tag name always needs to be the first word not preceded by an hyphen)
# Default: ''
tag: ''
# Arguments for the git push --tags command (any additional argument will be added after --tags)
# Default: ''
tag_push: ''