readme.md: simplify
This commit is contained in:
		
							
								
								
									
										193
									
								
								readme.md
									
									
									
									
									
								
							
							
						
						
									
										193
									
								
								readme.md
									
									
									
									
									
								
							| @@ -1,161 +1,50 @@ | |||||||
| # glowers-radio | # glowers-radio | ||||||
| This repo contains backing information for Glowers Radio. | This repo contains backing information for Glowers Radio. | ||||||
|  |  | ||||||
| ## Contributing |  | ||||||
| If you have a song in mind that would fit on Glowers Radio, you are free to create a PR or send in a diff for `generate.js`. |  | ||||||
| The living schema is documented [below](#format) and mostly maps 1:1 to `MediaItem`, you should also check the `MediaItem` for the |  | ||||||
| the media that is most similar to what you wish to add. |  | ||||||
|  |  | ||||||
| ## Best Practices | ## Best Practices | ||||||
| - Use an alpha-numeric id. Don't use dashes or hyphens; Uppercase characters *may* be used when appropriate. | - Use an alpha-numeric id. Don't use dashes or hyphens | ||||||
| - Declare attribution info (track info) when available. If you do not know the original source, try to find it first. | - Add proper song metadata when appropriate. Attribution data should be added when possible | ||||||
| - Attribution info **must** be accurate and not an artists rendition. | - Keep all media assets under 10MB, a single item's assets should not be over 15MB. | ||||||
| - Items that aren't primarily music should be tagged with `misc`. | - Add codec information for your sources. | ||||||
| - Use the `metadata-prefer-id` tag if the actual title would be too long, cubersome, or unrelated. i.e: | - Mimic other items if you're unsure about something. | ||||||
|     - `slamtris`: Slamtris - Quad City DJs vs Hirokazu Tanaka *(cumbersome)* |  | ||||||
|     - `dngyamom`: Dynamite by BTS but it's Doin' Your Mom *(cumbersome)* |  | ||||||
|     - `thisistheinfowar`: In the House, In a Heartbeat *(unrelated)* |  | ||||||
|     - `alexjones`: Alex Jones Remix: Renai Circulation *(cumbersome)* |  | ||||||
|     - `ywnbaw`: Professor proves SICKS are the best weapons *(unrelated)* |  | ||||||
|     - `whenblackissus`: Among Us theme song but it's in the style of Metallica's Black Album *(long and cumbersome)* |  | ||||||
|     - `niggatorial`: I'm The 2007 YouTube Tutorial *(cumbersome)* |  | ||||||
|     - `honorary`: Erika *(unrelated)* |  | ||||||
|  |  | ||||||
| <br/> | ## Examples | ||||||
|  |  | ||||||
| - Use `image/png`, `image/jpg`, `image/gif`, `audio/mp3`, and `video/mp4`. Files *should* be under 10MB and be of reasonable or tolerable quality | ```js | ||||||
|  | RadioItem.new("hummerguy") | ||||||
| - Try not to use reuploads, remasters, or edits, as the source; Unless the edit or remaster is the actual media. |   .addItemInfo(RadioMetadata.newLAV("hummer guy ytpmv", "gud boi", RadioMetadata.createYouTubeURI("A2Fd4NHreI0")).bOfficial()) | ||||||
|  |   .addItemInfo(RadioMetadata.newLA("Skrillex - Scary Monsters and Nice Sprites (Sihk Happy Hardcore Remix)", "SIHK", RadioMetadata.createYouTubeURI("Z01Tsgwe2dQ")).setFor(0).bOriginal().bOfficial()) | ||||||
| - Don't use videos where audio alongside artwork would be functionally identical. Lyrics videos are ok |   .addItemInfo(RadioMetadata.newLA(null, null, RadioMetadata.createSoundcloudURI("skrillex-scary-monsters-nice-sprites-sihk-happy-hardcore-remix-free-dl", "sihk66")).setFor(0).bOriginal().bOfficial().bAlt()) | ||||||
|  |   .addSource(RadioSource.new("video/mp4", [ "avc1.4D4029", "mp4a.40.2" ]) | ||||||
| - Sources *should* contain codec information; if you are unsure of what correct codecs to declare, do not declare any or ask for help. |     .setURI("mxc://glowers.club/jnmPzoUhxCTrvRZmpxmGXYMr") | ||||||
|   No codec declarations are better than incorrect codec declarations. See [MDN](https://developer.mozilla.org/en-US/docs/Web/Media/Formats/codecs_parameter#basic_syntax) for details |     .addPreview("mxc://glowers.club/AmkQLtUuuCixPKNzkugAkiHh", "image/jpg", "800x449")) | ||||||
|  |   .addSource(RadioSource.new("audio/mp3", [ "mp3" ]) | ||||||
| - All content *should* be hosted on Glowers Club. If you do not Glow, then your sources will be reuploaded if your Item(s) are accepted |     .setURI("mxc://glowers.club/wtsFmPEzerDPdzOSQraBzupN") | ||||||
|  |     .addPreview("mxc://glowers.club/UPPtHMbKXrEaeHLDYovVkZRt", "image/jpg", "440x440")), | ||||||
| <br/> |  | ||||||
|  |  | ||||||
| - `video/` **must** have a thumbnail preview. |  | ||||||
| - `video/` *should* have a `EDisplayType.SQUARE` fallback for audioOnly, and for when the agent does not support the provided `video/`. |  | ||||||
| - Animated previews **must** always have a `image/gif` fallback. |  | ||||||
| - Avoid using `EDisplayType.LANDSCAPE` when possible. |  | ||||||
| - `EDisplayType.SQUARE` previews **must** be exactly `1:1`; `EDisplayType.LANDSCAPE` previews *should* be exactly `16:9`, or **must** be a close equivalent |  | ||||||
|  |  | ||||||
| ### `addTrackInfo` |  | ||||||
|  |  | ||||||
| `setMetadata` will be deprecated in favor of `addTrackInfo` to allow additional attribution information to be stored. |  | ||||||
|  |  | ||||||
| `addTrackInfo` is more verbose than `setMetadata`. Check the JSDoc blocks for `RadioMetadata.new` |  | ||||||
|  |  | ||||||
| `RadioMetadata` methods beginning with `b` are auto-generated from `BMetadataType`. |  | ||||||
|  |  | ||||||
| Avoid being *too autistic* with additional info, just note the main stuff. You don't have to add the Randy Marsh saying nigger clip |  | ||||||
| because it's used a single time in a ytpmv. |  | ||||||
|  |  | ||||||
| Support for raw `href` values will remain, however an appropriate `createURI` function should be used instead. |  | ||||||
|  |  | ||||||
| ## Format |  | ||||||
| The `songs.json` format **is only intended for use for Glowers Radio**, and is effectively a living standard as a result. **Live data may change drastically without warning** |  | ||||||
|  |  | ||||||
| If you do wish to use this data for your own purposes, i.e: to make a custom player, you should be caching the songs list so your application has something to fallback to if a breaking change to the format is made. |  | ||||||
|  |  | ||||||
| ```yaml |  | ||||||
| required: [ version, songs ] |  | ||||||
| $defs: |  | ||||||
|   GWRadioURI: |  | ||||||
|     type: uri |  | ||||||
|     description: 'A URI that points to the source file. See `GWMediaPlayer.fromURIToAbsolute()` for how to convert to a URL' |  | ||||||
|   MediaCodecs: |  | ||||||
|     type: array |  | ||||||
|     description: 'An array of codecs contained within the source file. Items should follow RFC6381' |  | ||||||
|     items: |  | ||||||
|     - type: string |  | ||||||
| properties: |  | ||||||
|   version: { type: integer } |  | ||||||
|   songs: |  | ||||||
|     items: |  | ||||||
|       required: [ id, sources ] |  | ||||||
|       properties: |  | ||||||
|         id: |  | ||||||
|           type: string |  | ||||||
|         tags: |  | ||||||
|           description: 'A list of tags used for filtering.' |  | ||||||
|           type: array |  | ||||||
|           items: |  | ||||||
|           - const: sus |  | ||||||
|             description: >- |  | ||||||
|               Media information will render in the Among Us Font. |  | ||||||
|               In imposter mode, only songs tagged with sus will be in shuffle |  | ||||||
|  |  | ||||||
|           - const: niggers |  | ||||||
|             description: >- |  | ||||||
|               Media that was originally available through the now-defunct nigge.rs online radio. |  | ||||||
|               Tagged items may contain the original _nigid and/or _nigkey as metadata |  | ||||||
|             $seeAlso: |  | ||||||
|             - '#/properties/songs/items/properties/metadata/properties/_nigid' |  | ||||||
|             - '#/properties/songs/items/properties/metadata/properties/_nigkey' |  | ||||||
|  |  | ||||||
|           - const: splash-song |  | ||||||
|             description: 'Media that can play on the Glowers Club splash page.' |  | ||||||
|  |  | ||||||
|           - const: misc |  | ||||||
|             description: 'Media that does not significantly contain music.' |  | ||||||
|  |  | ||||||
|           - const: moonman |  | ||||||
|             description: 'Moonman songs' |  | ||||||
|  |  | ||||||
|           - const: metadata-prefer-id |  | ||||||
|             description: >- |  | ||||||
|               Use the Media id instead of the metadata title for MediaSession. |  | ||||||
|               Primarily for media where the source title does not match the assigned id |  | ||||||
|  |  | ||||||
|           - regex: '^radio\-media\-style\-[a-z\-]+' |  | ||||||
|             description: >- |  | ||||||
|               Used to add or remove styling for particular Media, such as to remove the |  | ||||||
|               Album Art box or disable background blur. |  | ||||||
|  |  | ||||||
|           - type: string |  | ||||||
|             description: 'Tags may also be arbitrary' |  | ||||||
|  |  | ||||||
|         metadata: |  | ||||||
|           required: [ title, artist ] |  | ||||||
|           properties: |  | ||||||
|             title: { type: string } |  | ||||||
|             artist: { type: string } |  | ||||||
|             href: |  | ||||||
|               $ref: "#/$defs/GWRadioURI"  |  | ||||||
|               description: 'A URI where the original source can be found, if known. Link may be dead' |  | ||||||
|             _nigid: |  | ||||||
|               $seeAlso: '#/properties/songs/items/properties/tags/items/1' |  | ||||||
|               description: 'The original song id from nigge.rs.' |  | ||||||
|               type: string |  | ||||||
|             _nigkey: |  | ||||||
|               $seeAlso: '#/properties/songs/items/properties/tags/items/1' |  | ||||||
|               description: 'Content of _id from the original nigge.rs song entry.' |  | ||||||
|               type: string |  | ||||||
|         sources: |  | ||||||
|           type: array |  | ||||||
|           items: |  | ||||||
|           - required: [ type, url ] |  | ||||||
|             properties: |  | ||||||
|               type: { type: string, format: mimetype } |  | ||||||
|               codecs: { "$ref": "#/$defs/MediaCodecs" } |  | ||||||
|               uri: { "$ref": "#/$defs/GWRadioURI" } |  | ||||||
|               previews: |  | ||||||
|                 description: >- |  | ||||||
|                   This is an array so GWMediaPlayer can better display videos being played as audio only. |  | ||||||
|                   The first Item is how the MediaItem *should* be displayed, other Items are alternative versions the player may use. |  | ||||||
|                 type: array |  | ||||||
|                 items: |  | ||||||
|                 - properties: |  | ||||||
|                     display_type: |  | ||||||
|                       description: 'Used to determine how the media should be displayed. See GWMediaPlayer.EDisplayType' |  | ||||||
|                       type: string |  | ||||||
|                     type: { type: string, format: mimetype } |  | ||||||
|                     codecs: { "$ref": "#/$defs/MediaCodecs" } |  | ||||||
|                     uri: { "$ref": "#/$defs/GWRadioURI" } |  | ||||||
|                     size: { type: string } |  | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  | ```js | ||||||
|  | RadioItem.new("kramer") | ||||||
|  |   .setMiscInfo(RadioMiscInfo.new().bExplicit().bMetadataPreferId()) | ||||||
|  |   .addItemInfo(RadioMetadata.newLAV("wholesome ytpmv :3", "KrazedDonut", RadioMetadata.createYouTubeURI("LVdJ6cqqiUA")).bOfficial().bUnavailable().bExplicit()) | ||||||
|  |   .addItemInfo(RadioMetadata.newLA("Spin ye Bottle (Minigame)", "Jake Kaufman", RadioMetadata.createBandcampURI("spin-ye-bottle-minigame", "virt")).setFor(0).bOriginal().bOfficial()) | ||||||
|  |   .addItemInfo(RadioMetadata.newLA(null, null, RadioMetadata.createAppleMusicURI(1170509291)).setFor(0).bOriginal().bOfficial().bAlt()) | ||||||
|  |   .addSource(RadioSource.new("video/mp4", [ "avc1.4D4029", "mp4a.40.2" ]) | ||||||
|  |     .setURI("mxc://glowers.club/FztaIVnDJeHkYQfZmdHFOdnP") | ||||||
|  |     .addPreview("mxc://glowers.club/FKCKRytGQEFRJUxTfeKjXmXz", "image/jpg", "800x450")) | ||||||
|  |   .addSource(RadioSource.new("audio/mp3", [ "mp3" ]) | ||||||
|  |     .setURI("mxc://glowers.club/hqRzxaQMWfQoZGpiPIbyNSEk") | ||||||
|  |     .addPreview("mxc://glowers.club/JurRLPteOyFLrfJoRJuzbZkH", "image/jpg", "500x500")), | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ```js | ||||||
|  | RadioItem.new("blsdm") | ||||||
|  |   .setMiscInfo(RadioMiscInfo.new().bExplicit()) | ||||||
|  |   .addItemInfo(RadioMetadata.newLA("Black Lives (Still Don't) Matter", "Moonman").bExplicit().bPseudonym()) | ||||||
|  |   .addSource(RadioSource.new("audio/mp3", [ "mp3" ]) | ||||||
|  |     .setURI("mxc://glowers.club/GfcCntGLSZsYkkzzkaoJrUWx") | ||||||
|  |     .addPreview("mxc://glowers.club/yyWJVkClXhWIFqgayFFtZZDJ", "image/jpg", "500x500")), | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ## Integrations | ||||||
|  | See [data/schema.yaml] for JSONSchema documentation. You may also want to inspect the code within [lib/] | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user