Compare commits
	
		
			43 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 4f73093799 | ||
|   | d4fec833f8 | ||
|   | 67c85eafc4 | ||
|   | 730763391c | ||
|   | 5d0c56a5f7 | ||
|   | 763ae0328c | ||
|   | 41be6f5b25 | ||
|   | ac5614e56b | ||
|   | 833dbf8ad3 | ||
|   | 45d4bc13e2 | ||
|   | 253d60a578 | ||
|   | d7f06ccee8 | ||
|   | 55dcb8276e | ||
|   | 9e03f69ca8 | ||
|   | 50ea7b365f | ||
|   | f0366dde7f | ||
|   | 58ecb08051 | ||
|   | 97955a3ad2 | ||
|   | bd23be9dc3 | ||
|   | b01c7391b3 | ||
|   | a35f34495e | ||
|   | c981c89b49 | ||
|   | 3eb0166c6a | ||
|   | 7f329cd741 | ||
|   | 31a5919aa4 | ||
|   | 1ffd7a0194 | ||
|   | b945493421 | ||
|   | c0f8489afa | ||
|   | 922a481776 | ||
|   | 36e10c10a7 | ||
|   | c70574e255 | ||
|   | 40a0359176 | ||
|   | 0cd78a9d36 | ||
|   | 2a57c1ef27 | ||
|   | ba2d8eb79c | ||
|   | 7cc8b4104e | ||
|   | 93d5927f4e | ||
|   | 39b08c7ab6 | ||
|   | 8607841396 | ||
|   | 541dbd3595 | ||
|   | 57397bdac3 | ||
|   | 0a30bdf8db | ||
|   | dc388d5d94 | 
							
								
								
									
										11
									
								
								.ci.env.example
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,11 @@ | ||||
| # Env file to use with https://github.com/nektos/act to run GitHub Actions locally when debugging | ||||
| # | ||||
| # Ex: | ||||
| # act --env-file .env -j build-thunderstore-package | ||||
| # | ||||
| # Reference: | ||||
| # https://github.com/thunderstore-io/thunderstore-cli/wiki | ||||
|  | ||||
| TCLI_AUTH_TOKEN= | ||||
| TS_COMMUNITY=test | ||||
| TS_REPO=https://thunderstore.dev/ | ||||
							
								
								
									
										24
									
								
								.github/ISSUE_TEMPLATE.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,24 @@ | ||||
| <!--  | ||||
|  | ||||
| BEFORE OPENING AN ISSUE: | ||||
|  | ||||
| -> Check the wiki: https://northstar.tf/wiki, mainly the Troubleshooting and FAQ sections | ||||
| -> Use the search bar to check if there's already an issue for your problem: https://github.com/R2Northstar/Northstar/issues | ||||
| -> Check #announcements and #faq on Discord: https://northstar.tf/discord | ||||
|  | ||||
| --> | ||||
|  | ||||
| ### Bug | ||||
| Replace this line with the bug you've encountered and what is the expected behaviour. | ||||
|  | ||||
| ### Steps to reproduce | ||||
| <!-- Add some clear steps on how to reproduce this problem --> | ||||
|   1. | ||||
|   2. | ||||
|   3. | ||||
|  | ||||
| ### Specifications | ||||
|   - Northstar version: | ||||
|   - Platform: <!-- Origin/Steam --> | ||||
|  | ||||
| <!-- You can add log files and screenshots below this line via drag-and-drop --> | ||||
							
								
								
									
										182
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,182 @@ | ||||
| name: Build | ||||
| on: | ||||
|   push: | ||||
|     tags: | ||||
|       - '*' | ||||
|   workflow_dispatch: | ||||
|     inputs: | ||||
|       job: | ||||
|         description: 'Job to run' | ||||
|         required: true | ||||
|         default: 'build-thunderstore-package' | ||||
|  | ||||
| env: | ||||
|   NORTHSTAR_VERSION: ${{ github.ref_name }} | ||||
|  | ||||
| jobs: | ||||
|   build-launcher: | ||||
|     runs-on: windows-2022 | ||||
|     steps: | ||||
|       - name: Setup bundled plugins | ||||
|         uses: actions/checkout@v2 | ||||
|         with: | ||||
|           repository: R2Northstar/NorthstarDiscordRPC | ||||
|           path: discord-plugin | ||||
|       - name: Checkout launcher repository | ||||
|         uses: actions/checkout@v2 | ||||
|         with: | ||||
|           repository: R2Northstar/NorthstarLauncher | ||||
|           ref: ${{ env.NORTHSTAR_VERSION }} | ||||
|           path: northstar-launcher | ||||
|       - name: Setup MSBuild | ||||
|         uses: microsoft/setup-msbuild@v1.1 | ||||
|       - name: Setup resource file version | ||||
|         shell: bash | ||||
|         working-directory: northstar-launcher | ||||
|         run: | | ||||
|           sed -i 's/DEV/${{ env.NORTHSTAR_VERSION }}/g' LauncherInjector/resources.rc | ||||
|           FILEVERSION=$(echo ${{ env.NORTHSTAR_VERSION }} | tr '.' ',' | tr -d '[:alpha:]') | ||||
|           sed -i "s/0,0,0,1/${FILEVERSION}/g" NorthstarDedicatedTest/ns_version.h | ||||
|       - name: Build | ||||
|         working-directory: northstar-launcher | ||||
|         run: | | ||||
|           cp -r ../discord-plugin/*Discord* . | ||||
|           msbuild /p:Configuration=Release R2Northstar.sln | ||||
|           msbuild /p:Configuration=Release NorthstarDiscordRPC.sln | ||||
|       - name: Upload launcher build as artifact | ||||
|         uses: actions/upload-artifact@v2 | ||||
|         with: | ||||
|           name: northstar-launcher | ||||
|           path: | | ||||
|             northstar-launcher/x64/Release/Northstar.dll | ||||
|             northstar-launcher/x64/Release/wsock32.dll | ||||
|             northstar-launcher/x64/Release/NorthstarLauncher.exe | ||||
|             northstar-launcher/x64/Release/discord_game_sdk.dll | ||||
|             northstar-launcher/x64/Release/DiscordRPC.dll | ||||
|             northstar-launcher/x64/Release/*.txt | ||||
|       - name: Upload debug build artifact | ||||
|         uses: actions/upload-artifact@v2 | ||||
|         with: | ||||
|           name: launcher-debug-files | ||||
|           path: | | ||||
|             northstar-launcher/x64/Release/*.pdb | ||||
|  | ||||
|   build-northstar: | ||||
|     needs: build-launcher | ||||
|     runs-on: ubuntu-20.04 | ||||
|     steps: | ||||
|       - name: Download compiled launcher | ||||
|         uses: actions/download-artifact@v2 | ||||
|         with: | ||||
|           name: northstar-launcher | ||||
|           path: northstar-launcher | ||||
|       - name: Download compiled stubs | ||||
|         run: | ||||
|           wget "https://github.com/R2Northstar/NorthstarStubs/releases/download/v1/NorthstarStubs.zip" | ||||
|       - name: Checkout release files | ||||
|         uses: actions/checkout@v2 | ||||
|         with: | ||||
|           ref: ${{ env.NORTHSTAR_VERSION }} | ||||
|           path: northstar | ||||
|       - name: Checkout core mods | ||||
|         uses: actions/checkout@v2 | ||||
|         with: | ||||
|           repository: R2Northstar/NorthstarMods | ||||
|           ref: ${{ env.NORTHSTAR_VERSION }} | ||||
|           path: northstar-mods | ||||
|       - name: Update mod version info | ||||
|         run: | | ||||
|           export MOD_VERSION=$(echo $NORTHSTAR_VERSION | tr -d 'v') | ||||
|           cat <<< $(jq ".Version = \"${MOD_VERSION}\"" northstar-mods/Northstar.Client/mod.json) > northstar-mods/Northstar.Client/mod.json | ||||
|           cat <<< $(jq ".Version = \"${MOD_VERSION}\"" northstar-mods/Northstar.Custom/mod.json) > northstar-mods/Northstar.Custom/mod.json | ||||
|           cat <<< $(jq ".Version = \"${MOD_VERSION}\"" northstar-mods/Northstar.CustomServers/mod.json) > northstar-mods/Northstar.CustomServers/mod.json | ||||
|       - name: Generate md5sum file | ||||
|         working-directory: northstar-mods | ||||
|         run: | | ||||
|           echo -e "# Check with 'md5sum -c md5sum.txt' at the root of mods folder\n" > md5sum.txt | ||||
|           git ls-tree -r $NORTHSTAR_VERSION --name-only | xargs -L1 md5sum >> md5sum.txt | ||||
|       - name: Make folder structure | ||||
|         run: | | ||||
|           mv -v northstar/release/* northstar/. | ||||
|           mkdir -p northstar/R2Northstar/mods | ||||
|           mkdir -p northstar/R2Northstar/plugins | ||||
|           mkdir -p northstar/bin/x64_retail | ||||
|  | ||||
|           mv -v northstar-launcher/DiscordRPC.dll northstar/R2Northstar/plugins | ||||
|           mv -v northstar-launcher/discord_game_sdk.dll northstar | ||||
|           mv -v northstar-launcher/wsock32.dll northstar/bin/x64_retail | ||||
|           unzip NorthstarStubs.zip -d northstar/bin/x64_dedi | ||||
|  | ||||
|           mv -v northstar-launcher/* northstar | ||||
|           rsync -avr --exclude="Northstar.Coop" --exclude=".git*" northstar-mods/. northstar/R2Northstar/mods | ||||
|       - name: Cleanup root Northstar repository files | ||||
|         run: | | ||||
|           rm -rf northstar-launcher | ||||
|           cd northstar && rm -rf .git .github .gitignore *.md LICENSE thunderstore .ci.env.example | ||||
|       - name: Upload | ||||
|         uses: actions/upload-artifact@v2 | ||||
|         with: | ||||
|           name: Northstar.release.${{ env.NORTHSTAR_VERSION }} | ||||
|           path: northstar | ||||
|  | ||||
|   build-thunderstore-package: | ||||
|     needs: build-northstar # comment out when running locally | ||||
|     if: "!contains(github.ref, 'rc')" # Skip uploading release candidates to Thunderstore | ||||
|     env: | ||||
|       # Release envs, comment this out when running locally | ||||
|       TCLI_AUTH_TOKEN: ${{ secrets.THUNDERSTORE_TOKEN }} | ||||
|       TS_REPO: https://thunderstore.io/ | ||||
|       TS_COMMUNITY: northstar | ||||
|  | ||||
|       # Uncomment when testing locally, must be unique | ||||
|       # NORTHSTAR_VERSION: 0.1.8 | ||||
|  | ||||
|       # Thunderstore info and descriptions | ||||
|       TS_NAMESPACE: northstar | ||||
|       TS_MOD_NAME: Northstar | ||||
|       TS_MOD_DESCRIPTION: Titanfall 2 modding and custom server framework. | ||||
|     runs-on: ubuntu-20.04 | ||||
|     steps: | ||||
|       - name: Setup tcli | ||||
|         run: | | ||||
|           wget -O tcli.tar.gz https://github.com/thunderstore-io/thunderstore-cli/releases/download/0.1.4/tcli-0.1.4-linux-x64.tar.gz | ||||
|           tar xvf tcli.tar.gz | ||||
|           sudo mv -v tcli-0.1.4-linux-x64/tcli /bin | ||||
|  | ||||
|       - name: (DEBUG) Download Northstar package | ||||
|         if: ${{ env.ACT }} # Download Northstar package from releases when running locally instead of relying on previous jobs | ||||
|         run: | | ||||
|           wget -O northstar.zip https://github.com/R2Northstar/Northstar/releases/download/v1.6.3/Northstar.release.v1.6.3.zip | ||||
|           unzip northstar.zip -d northstar | ||||
|  | ||||
|       - name: Download Northstar package | ||||
|         if: ${{ !env.ACT }} # Download artifacts from previous jobs when running on GitHub's infrastructure | ||||
|         uses: actions/download-artifact@v2 | ||||
|         with: | ||||
|           name: Northstar.release.${{ env.NORTHSTAR_VERSION }} | ||||
|           path: northstar | ||||
|  | ||||
|       - name: Make package structure | ||||
|         run: | | ||||
|           mkdir -p thunderstore/dist/Northstar | ||||
|           rm northstar/ns_startup*.txt | ||||
|           mv -v northstar/* thunderstore/dist/Northstar | ||||
|           wget -O thunderstore/icon.png https://raw.githubusercontent.com/R2Northstar/Northstar/main/thunderstore/icon.png | ||||
|           wget -O thunderstore/README.md https://raw.githubusercontent.com/R2Northstar/Northstar/main/thunderstore/README.md | ||||
|  | ||||
|       - name: Setup environment variables | ||||
|         run: | | ||||
|           echo "MOD_VERSION=$(echo $NORTHSTAR_VERSION | tr -d 'v')" >> $GITHUB_ENV | ||||
|  | ||||
|       - name: Publish package to Thunderstore | ||||
|         working-directory: thunderstore | ||||
|         run: | | ||||
|           tcli init --package-name=$TS_MOD_NAME --package-namespace=$TS_NAMESPACE --package-version $MOD_VERSION | ||||
|  | ||||
|           sed -i "s/communities = \[\]/communities = [\"$TS_COMMUNITY\"]/g" thunderstore.toml | ||||
|           sed -i "s/Example-Dependency = \"1.0.0\"//g" thunderstore.toml | ||||
|           sed -i "s/description = \"Example mod description\"/description = \"$TS_MOD_DESCRIPTION\"/g" thunderstore.toml | ||||
|           cat thunderstore.toml | ||||
|  | ||||
|           tcli build | ||||
|           tcli publish --repository "$TS_REPO" --file build/*.zip | ||||
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1 @@ | ||||
| .env | ||||
							
								
								
									
										15
									
								
								CONTRIBUTING.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,15 @@ | ||||
| # Welcome to Northstar contribution guide | ||||
|  | ||||
| Thank you for investing your time in contributing to our project! | ||||
|  | ||||
| ## Issues | ||||
|  | ||||
| ### Create a new issue  | ||||
|  | ||||
| If you find a bug while using Northstar, before posting it, please ensure that a corresponding issue does not  | ||||
| already exists on GitHub. | ||||
|  | ||||
| Afterwards, please check Discord `faq`, `help` and `bug` channels for corresponding threads. | ||||
|  | ||||
| Also, please double-check that you're opening an issue in the correct repository (read carefully readme `Development` section if you're not sure). | ||||
|  | ||||
							
								
								
									
										44
									
								
								README.md
									
									
									
									
									
								
							
							
						
						| @@ -1,15 +1,33 @@ | ||||
| # Northstar | ||||
| Northstar is a mod and modding framework allowing users to host their own Titanfall 2 servers using custom scripts and assets to create custom content, as well as being able to host vanilla content   | ||||
|  | ||||
| [](https://github.com/R2Northstar/Northstar/releases) | ||||
| [](https://northstar.tf/discord) | ||||
| [](https://r2northstar.gitbook.io) | ||||
|  | ||||
| Northstar is a modding framework client that allows users to host their own Titanfall 2 servers using custom scripts and assets to create custom content, as well as being able to host vanilla content. | ||||
|  | ||||
| <p align="center"><strong> | ||||
| <a href="https://r2northstar.gitbook.io/r2northstar-wiki/installing-northstar/basic-setup">Installation</a> | <a href="https://r2northstar.gitbook.io/r2northstar-wiki/installing-northstar/troubleshooting">Troubleshooting</a> | <a href="https://r2northstar.gitbook.io/">Wiki</a> | ||||
| </strong></p> | ||||
|  | ||||
| ## Development | ||||
|  | ||||
| Northstar's development is split into 4 repositories: | ||||
|  | ||||
| 1. [NorthstarLauncher](https://github.com/R2Northstar/NorthstarLauncher) (Code for the C++ hook DLL) | ||||
| 1. [NorthstarMods](https://github.com/R2Northstar/NorthstarMods) (Code for the squirrel mods responsible for server gamelogic recreation and custom content) | ||||
| 1. [NorthstarMasterServer](https://github.com/R2Northstar/NorthstarMasterServer) (Responsible for server browser, authentication and persistence) | ||||
| 1. [NorthstarStubs](https://github.com/R2Northstar/NorthstarStubs) (D3D11 and GFSDK stubs for the Northstar dedicated server) | ||||
|  | ||||
| The documentation is split into two repositories: | ||||
| 1. [NorthstarWiki](https://github.com/R2Northstar/NorthstarWiki) (Wiki covering installation, hosting and configuration of Northstar) | ||||
| 1. [ModdingDocs](https://github.com/R2Northstar/ModdingDocs) (Guides and tutorials on how to mod using Northstar) | ||||
|  | ||||
| ## Special Thanks | ||||
|    | ||||
| This is a repo for packaged Northstar releases and the wiki and as such does not contain any code   | ||||
| Code for the C++ hook DLL can be found [here](https://github.com/R2Northstar/NorthstarLauncher)   | ||||
| Code for the squirrel mods responsible for server gamelogic recreation and custom content can be found [here](https://github.com/R2Northstar/NorthstarMods)   | ||||
| Code for the master server responsible for server browser, authentication and persistence can be found [here](https://github.com/R2Northstar/NorthstarMasterServer)   | ||||
|    | ||||
| The discord can be found [here](https://northstar.tf/discord)   | ||||
|    | ||||
| Thanks to everyone that's put up with me and helped out with this project, it's been a fun passion project i've had throughout 2021 so releasing it is pretty cathartic   | ||||
| Specifically: thanks to the Icepick developers for making the Icepick, I initially forked it for earlier versions of Northstar and it was a great base to experiment with stuff on before moving to the custom launcher   | ||||
| Thanks to everyone on R5R team for giving me advice on some later parts of development   | ||||
| Thanks to everyone in the testing server for putting up with me and helping find bugs   | ||||
| Thanks to everyone else that's helped, gave advice, all that | ||||
| Thanks to everyone that's put up with me and helped out with this project, it's been a fun passion project I've had throughout 2021 so releasing it is pretty cathartic. Specifically:  | ||||
|  | ||||
| - Thanks to the Icepick developers for making the Icepick, I initially forked it for earlier versions of Northstar and it was a great base to experiment with stuff on before moving to the custom launcher. | ||||
| - Thanks to everyone on R5R team for giving me advice on some later parts of development.   | ||||
| - Thanks to everyone in the testing server for putting up with me and helping find bugs.   | ||||
| - Thanks to everyone else that's helped, gave advice, all that. | ||||
|   | ||||
							
								
								
									
										313
									
								
								release/LEGAL.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										
											BIN
										
									
								
								release/R2Northstar/placeholder_playerdata.pdata
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										1
									
								
								release/ns_startup_args.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1 @@ | ||||
| -multiple | ||||
							
								
								
									
										1
									
								
								release/ns_startup_args_dedi.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1 @@ | ||||
| +setplaylist private_match | ||||
							
								
								
									
										29
									
								
								thunderstore/README.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,29 @@ | ||||
| # Northstar | ||||
|  | ||||
| Northstar is a modding framework client that allows users to host their own Titanfall 2 servers using custom scripts and assets to create custom content, as well as being able to host vanilla content. | ||||
|  | ||||
| # Manual Install | ||||
|  | ||||
| Firstly, note that the Northstar client is only available on PC and | ||||
| requires you to **both own the game and have it installed.** | ||||
|  | ||||
| 1.  Download the zip with the "Manual Download" button | ||||
| 2.  Copy the files from inside the "Northstar" folder from the zip to your game folder. This can vary depending on whether you purchased the game off Steam or Origin, and if you set a custom folder for game installs. | ||||
|     - **For Steam** - Right click _Titanfall 2 \> Properties \> Local Files \> Browse_   | ||||
|       Usually: `C:\Program Files (x86)\Steam\steamapps\common\Titanfall2` | ||||
|     - **For Origin** - To find the location of your Origin library go to _Origin -\> Application Setting -\> Installs & Saves -\> On your Computer -\> Game Library Location_   | ||||
|       Go to the directory mentioned there using File Explorer and open the `Titanfall2` folder.   | ||||
|       Usually: `C:\Program Files (x86)\Origin Games\Titanfall2` | ||||
|     - **For EA App** - To find the location of your EA library go to _Settings -\> Download_   | ||||
|       Go to the directory under "Install location" using File Explorer and open the `Titanfall2` folder.   | ||||
|       Usually: `C:\Program Files\EA Games\Titanfall2` | ||||
| 3.  Launch `NorthstarLauncher.exe` to start Northstar | ||||
|     - After launching for the first time, you'll be greeted with a popup requesting to authenticate to the master server. Click Yes (This can be changed in the mods menu later if desired) | ||||
| 4.  Select _Launch Northstar_ | ||||
| 5.  From the multiplayer menu, you can use the server browser to select and join any of the public community hosted servers. | ||||
|  | ||||
| # Links | ||||
|  | ||||
| [Discord](https://northstar.tf/discord)   | ||||
| [GitHub](https://northstar.tf/github)   | ||||
| [Wiki](https://northstar.tf/wiki) | ||||
							
								
								
									
										
											BIN
										
									
								
								thunderstore/icon.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 51 KiB | 
| Before Width: | Height: | Size: 359 KiB | 
| Before Width: | Height: | Size: 354 KiB | 
							
								
								
									
										
											BIN
										
									
								
								wiki/mods.png
									
									
									
									
									
								
							
							
						
						| Before Width: | Height: | Size: 229 KiB | 
| Before Width: | Height: | Size: 222 KiB | 
| Before Width: | Height: | Size: 187 KiB | 
| Before Width: | Height: | Size: 1.0 MiB | 
| Before Width: | Height: | Size: 386 KiB |