mirror of
				https://github.com/superseriousbusiness/gotosocial.git
				synced 2025-10-30 20:02:24 -05:00 
			
		
		
		
	
		
			
				
	
	
		
			51 lines
		
	
	
	
		
			1.8 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			51 lines
		
	
	
	
		
			1.8 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // GoToSocial
 | |
| // Copyright (C) GoToSocial Authors admin@gotosocial.org
 | |
| // SPDX-License-Identifier: AGPL-3.0-or-later
 | |
| //
 | |
| // This program is free software: you can redistribute it and/or modify
 | |
| // it under the terms of the GNU Affero 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 Affero General Public License for more details.
 | |
| //
 | |
| // You should have received a copy of the GNU Affero General Public License
 | |
| // along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | |
| 
 | |
| package util
 | |
| 
 | |
| import "time"
 | |
| 
 | |
| const (
 | |
| 	ISO8601     = "2006-01-02T15:04:05.000Z"
 | |
| 	ISO8601Date = "2006-01-02"
 | |
| 	RFC2822     = "Mon, 02 Jan 2006 15:04:05 -0700"
 | |
| )
 | |
| 
 | |
| // FormatISO8601 converts the given time to UTC and then formats it
 | |
| // using the ISO8601 const, which the Mastodon API is able to understand.
 | |
| func FormatISO8601(t time.Time) string {
 | |
| 	return t.UTC().Format(ISO8601)
 | |
| }
 | |
| 
 | |
| // Mastodon returns UTC dates (without time) for last_status_at/LastStatusAt as
 | |
| // a special case, but most of the time you want to use FormatISO8601 instead.
 | |
| func FormatISO8601Date(t time.Time) string {
 | |
| 	return t.UTC().Format(ISO8601Date)
 | |
| }
 | |
| 
 | |
| // ParseISO8601 parses the given time string according to the ISO8601 const.
 | |
| func ParseISO8601(in string) (time.Time, error) {
 | |
| 	return time.Parse(ISO8601, in)
 | |
| }
 | |
| 
 | |
| // FormatRFC2822 converts the given time to local and then formats it using
 | |
| // the RFC2822 const, which conforms with email Date header requirements.
 | |
| //
 | |
| // See: https://www.rfc-editor.org/rfc/rfc2822#section-3.3
 | |
| func FormatRFC2822(t time.Time) string {
 | |
| 	return t.Local().Format(RFC2822)
 | |
| }
 |