-
Notifications
You must be signed in to change notification settings - Fork 22
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add support for plugins #23
Comments
+1 - Now that modrinth supports plugins, the use cases of this have been expanded quite significantly. It'd be nice if the documentation could be updated a little to support this (e.g. with "loaders", where modrinth now accepts 'spigot', 'bukkit', 'sponge' and 'purpur', et al.) |
Is there a way to tell which loader a plugin that contains a Also, which of these values |
Unfortunately no. There are settings that only exist for a server (afaik
|
Alright, then this information should be specified by a user in their mc-publish:
loaders: [bungeecord, waterfall]
Oh, so literally everything except the things I'm familiar with :D That's quite a list. Ok, that's what I need from you, folks, in order to implement the requested support of new formats, because I have no points of contact with all these plugins of yours, - for every loader in this list (from Bukkit to Waterfall) make a pull request, please, containing a configuration file fulfilling the following conditions:
mc-publish:
modrinth: AAAA
id: dependency-id
mc-publish:
modrinth: AAAA
Examples of all the conditions above can be seen in any file that already exists in the |
Should the files be in separate PRs or is one PR for all files I know okay? |
It would be nice to have different PR's, because I will still need to tweak them |
There we go. Made the PRs. I sadly don't know how Sponge plugins are structured, so someone else has to provide a valid example |
Sponge APIv8+ plugins define metadata through a
Sponge APIv7 previously defined information similarly in a mcmods.info file. Sponge implementations are quite API dependent and iirc not very forwards/backwards compatible friendly (in general). I think, broadly, support for automatically pulling this information from sponge might be a little complicated at best and kind of impossible at worst. I'd also like to preliminarily draw attention to the new specification in draft for |
@WiIIiam278, would be perfect to see this in a from of PR ;) |
Along with plugin support, could support be added to update plugins on Polymart, Spigot, and Bukkit?
|
Bukkit, if you mean dev.bukkit.org, is just curseforge. |
If something does not or cannot follow this simple formula, it lies outside of the scope of this project. Therefore, Spigot and BuiltByBit support won't be implemented, at least the way you describe it. Polymart may become a part of Most of the things described require conversion, not publishing. Thinking out loud, but I may create a separate action for cases like that (e.g. |
Honestly, whatever you do to make it so that I don't have to spend an hour releasing a plugin update, I'll gladly use! Also, I'd love for the |
When I released this project, it was focused solely on publishing Fabric mods to Modrinth, CurseForge, and GitHub. Then I implemented support for Forge mods. A little bit later - support for Quilt mods. And now it's time for |
I can't wait! 👀 Let me know if there's anything I (maybe others too) can do to help 😄 (although I assume it's just a bunch of Typescript programming, which I've got no experience with 😬) |
+1 for Polymart support! I'd love to be able to do CI on nightly builds there with some of my stuff that I can't use Modrinth for. Appreciate all the work you do, with how fragmented the Minecraft server/client modding scene is in terms of "places to go to get XYZ", there's a solid argument that conceptually simple things like this GH action go the furthest in improving unity among the community. Srnyx is bang on -- it really can take an hour to push out a release with all these different marketplaces and their formatting. |
Adding to this, support for the upcoming plugin repository Hangar would be a great feature to add when plugin support gets added. I feel like because they only support plugins though, and because they still haven't released yet, it may be better to wait with this until the full plugin/resourcepack support is a thing, to make implementing this feature easier. I would be happy to add it by that time :) |
From what I understand is the API accessible for everyone right now, so initial support (With later expansion if needed) would be doable. Current API docs: https://hangar.papermc.io/api-docs |
I'm up for it, but yeah, I think this Hangar of yours should be fully released before we add support for it. |
I agree to an extend. While it makes sense to wait for a full release, development on that project has been extremely slow for various reasons. |
I feel like it not being fully released yet may lead to things like undocumented behavior and an increase in downtime compared to a production product. This is probably going to lead to errors that will make using this project more clunky. Because of that, it's probably better to just wait. |
Would it be possible to still work on it now instead of waiting? It doesn't need to be released at that point, but have it as a separate branch, so that we could use the Commit SHA instead of a version to use the action. Supporting Hangar as of right now is a gigantic pain in the back as I need to do one of the following:
I know it's work and I appreciate the effort you put into this thing so far. And if I could I would help you out here, but I have no knowledge with this code language. Also, as mentioned before are they providing a versioned REST-API, meaning that unless they say "F*ck versioning" should breaking changes to their API result in a separate version path and bump, while the old one remains supported (when technically possible). |
It's in Open Beta now so several people are wanting to use MC Publish for it now. Just letting you know in case it changes the status of this issue! |
Currently the main goal is to finish |
I started work (extremely basic and unfinished) on support for publishing to hangar: https://github.com/WiIIiam278/mc-publish/tree/hangar A few things to work out, namely due to how hangar handles having multiple per-platform files, but if (that's quite a big if!) I can get it going properly I might PR. I'm not really that experienced with TS/custom actions development, so not really planning on touching stuff like upgrading node, etc, where I can't help it :) feel free to use my work if it helps (or feel free to avoid it like the plague otherwise!) edit: pull request |
I posted the info already in #22 but decided to actually make this issue for better tracking.
Support to obtain values from a Spigot, BungeeCord or Velocity plugin to auto-fill values such as version and also the Modrinth/CurseForge ID would be nice to have here.
Both Spigot-based servers and BungeeCord-based proxies (including most forks of either) use a
plugin.yml
to obtain and use data such as the path to the main class, plugin name or version.In the case of BungeeCord does also a
bungee.yml
file exist that can be used. It's basically there to allow hybrid plugins that should work on server and proxy and is prioritized by the proxy when both files are present.Neither Spigot nor BungeeCord care if there are values in the YAML file that aren't used by them, as long as at least the required values are there, which means there is no need for a "custom" section or similar.
One note tho: Paper, a very popular fork of Spigot that adds API and Performance improvements, is currently working on a dedicated
paper-plugin.yml
, which, similar to a bungee.yml on a Bungee proxy, would allow defining different values for the plugin, so maybe keep that in mind for the future.A pull request discussing this feature is here: PaperMC/Paper#8108
Another proxy that should be supported is Velocity. It has a different approach. It uses a
velocity-plugin.json
which is created in 2 ways:@Plugin
annotation that processes the provided inputs at compile to create the JSON.This means that support for this kind of plugin could be more difficult to achieve unless Velocity allows somehow to apply custom values through their Annotation-processing.
For Velocity, I cannot say if it also ignores any extra keys/inputs in the JSON file or would give errors/exceptions when finding them. We have to figure this out eventually.
This is the info I'm able to provide here. I, unfortunately, do not know enough JS and TS to implement those myself.
The text was updated successfully, but these errors were encountered: