adding admin get users functionality
This commit is contained in:
parent
a8842eefc7
commit
589ca39555
Mixonomer.xcodeproj
Mixonomer
Model
Network
Views
@ -9,6 +9,9 @@
|
|||||||
/* Begin PBXBuildFile section */
|
/* Begin PBXBuildFile section */
|
||||||
A10C8D29281302050018AE12 /* ToastUI in Frameworks */ = {isa = PBXBuildFile; productRef = A10C8D28281302050018AE12 /* ToastUI */; };
|
A10C8D29281302050018AE12 /* ToastUI in Frameworks */ = {isa = PBXBuildFile; productRef = A10C8D28281302050018AE12 /* ToastUI */; };
|
||||||
A11AC70628A188AE00645043 /* AuthApi.swift in Sources */ = {isa = PBXBuildFile; fileRef = A11AC70528A188AE00645043 /* AuthApi.swift */; };
|
A11AC70628A188AE00645043 /* AuthApi.swift in Sources */ = {isa = PBXBuildFile; fileRef = A11AC70528A188AE00645043 /* AuthApi.swift */; };
|
||||||
|
A1AF726F28A84F7D00D317C9 /* AdminApi.swift in Sources */ = {isa = PBXBuildFile; fileRef = A1AF726E28A84F7D00D317C9 /* AdminApi.swift */; };
|
||||||
|
A1AF727128A850AE00D317C9 /* UsersList.swift in Sources */ = {isa = PBXBuildFile; fileRef = A1AF727028A850AE00D317C9 /* UsersList.swift */; };
|
||||||
|
A1AF727328A9062600D317C9 /* UserView.swift in Sources */ = {isa = PBXBuildFile; fileRef = A1AF727228A9062600D317C9 /* UserView.swift */; };
|
||||||
A1DBCDA628A51869002CF730 /* AdminList.swift in Sources */ = {isa = PBXBuildFile; fileRef = A1DBCDA528A51869002CF730 /* AdminList.swift */; };
|
A1DBCDA628A51869002CF730 /* AdminList.swift in Sources */ = {isa = PBXBuildFile; fileRef = A1DBCDA528A51869002CF730 /* AdminList.swift */; };
|
||||||
E906F7F42414019C004E1E31 /* NetworkPersister.swift in Sources */ = {isa = PBXBuildFile; fileRef = E906F7F32414019C004E1E31 /* NetworkPersister.swift */; };
|
E906F7F42414019C004E1E31 /* NetworkPersister.swift in Sources */ = {isa = PBXBuildFile; fileRef = E906F7F32414019C004E1E31 /* NetworkPersister.swift */; };
|
||||||
E906F7F724143AA7004E1E31 /* SwiftUICharts in Frameworks */ = {isa = PBXBuildFile; productRef = E906F7F624143AA7004E1E31 /* SwiftUICharts */; };
|
E906F7F724143AA7004E1E31 /* SwiftUICharts in Frameworks */ = {isa = PBXBuildFile; productRef = E906F7F624143AA7004E1E31 /* SwiftUICharts */; };
|
||||||
@ -66,6 +69,9 @@
|
|||||||
/* Begin PBXFileReference section */
|
/* Begin PBXFileReference section */
|
||||||
A11AC70528A188AE00645043 /* AuthApi.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AuthApi.swift; sourceTree = "<group>"; };
|
A11AC70528A188AE00645043 /* AuthApi.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AuthApi.swift; sourceTree = "<group>"; };
|
||||||
A146915A28118F940052999D /* Mixonomer.entitlements */ = {isa = PBXFileReference; lastKnownFileType = text.plist.entitlements; path = Mixonomer.entitlements; sourceTree = "<group>"; };
|
A146915A28118F940052999D /* Mixonomer.entitlements */ = {isa = PBXFileReference; lastKnownFileType = text.plist.entitlements; path = Mixonomer.entitlements; sourceTree = "<group>"; };
|
||||||
|
A1AF726E28A84F7D00D317C9 /* AdminApi.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AdminApi.swift; sourceTree = "<group>"; };
|
||||||
|
A1AF727028A850AE00D317C9 /* UsersList.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = UsersList.swift; sourceTree = "<group>"; };
|
||||||
|
A1AF727228A9062600D317C9 /* UserView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = UserView.swift; sourceTree = "<group>"; };
|
||||||
A1DBCDA528A51869002CF730 /* AdminList.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AdminList.swift; sourceTree = "<group>"; };
|
A1DBCDA528A51869002CF730 /* AdminList.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AdminList.swift; sourceTree = "<group>"; };
|
||||||
E906F7F32414019C004E1E31 /* NetworkPersister.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = NetworkPersister.swift; sourceTree = "<group>"; };
|
E906F7F32414019C004E1E31 /* NetworkPersister.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = NetworkPersister.swift; sourceTree = "<group>"; };
|
||||||
E934AC98240DD0E4009869F4 /* AddTagSheet.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AddTagSheet.swift; sourceTree = "<group>"; };
|
E934AC98240DD0E4009869F4 /* AddTagSheet.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AddTagSheet.swift; sourceTree = "<group>"; };
|
||||||
@ -139,6 +145,8 @@
|
|||||||
isa = PBXGroup;
|
isa = PBXGroup;
|
||||||
children = (
|
children = (
|
||||||
A1DBCDA528A51869002CF730 /* AdminList.swift */,
|
A1DBCDA528A51869002CF730 /* AdminList.swift */,
|
||||||
|
A1AF727028A850AE00D317C9 /* UsersList.swift */,
|
||||||
|
A1AF727228A9062600D317C9 /* UserView.swift */,
|
||||||
);
|
);
|
||||||
path = Admin;
|
path = Admin;
|
||||||
sourceTree = "<group>";
|
sourceTree = "<group>";
|
||||||
@ -163,6 +171,7 @@
|
|||||||
E9E30C2523FEA4EF00574EEF /* TagApi.swift */,
|
E9E30C2523FEA4EF00574EEF /* TagApi.swift */,
|
||||||
E906F7F32414019C004E1E31 /* NetworkPersister.swift */,
|
E906F7F32414019C004E1E31 /* NetworkPersister.swift */,
|
||||||
A11AC70528A188AE00645043 /* AuthApi.swift */,
|
A11AC70528A188AE00645043 /* AuthApi.swift */,
|
||||||
|
A1AF726E28A84F7D00D317C9 /* AdminApi.swift */,
|
||||||
);
|
);
|
||||||
path = Network;
|
path = Network;
|
||||||
sourceTree = "<group>";
|
sourceTree = "<group>";
|
||||||
@ -436,6 +445,7 @@
|
|||||||
E98254CA23FA26600056D9D3 /* PlaylistRow.swift in Sources */,
|
E98254CA23FA26600056D9D3 /* PlaylistRow.swift in Sources */,
|
||||||
E9EA690B23F9A5430012C3E8 /* AppDelegate.swift in Sources */,
|
E9EA690B23F9A5430012C3E8 /* AppDelegate.swift in Sources */,
|
||||||
E906F7F42414019C004E1E31 /* NetworkPersister.swift in Sources */,
|
E906F7F42414019C004E1E31 /* NetworkPersister.swift in Sources */,
|
||||||
|
A1AF727328A9062600D317C9 /* UserView.swift in Sources */,
|
||||||
E9E30C3323FF255C00574EEF /* SettingsList.swift in Sources */,
|
E9E30C3323FF255C00574EEF /* SettingsList.swift in Sources */,
|
||||||
E9EA690D23F9A5430012C3E8 /* SceneDelegate.swift in Sources */,
|
E9EA690D23F9A5430012C3E8 /* SceneDelegate.swift in Sources */,
|
||||||
E98254DB23FB64740056D9D3 /* Network.swift in Sources */,
|
E98254DB23FB64740056D9D3 /* Network.swift in Sources */,
|
||||||
@ -445,6 +455,8 @@
|
|||||||
A1DBCDA628A51869002CF730 /* AdminList.swift in Sources */,
|
A1DBCDA628A51869002CF730 /* AdminList.swift in Sources */,
|
||||||
E97AF46023FC85D600635494 /* PlaylistApi.swift in Sources */,
|
E97AF46023FC85D600635494 /* PlaylistApi.swift in Sources */,
|
||||||
A11AC70628A188AE00645043 /* AuthApi.swift in Sources */,
|
A11AC70628A188AE00645043 /* AuthApi.swift in Sources */,
|
||||||
|
A1AF726F28A84F7D00D317C9 /* AdminApi.swift in Sources */,
|
||||||
|
A1AF727128A850AE00D317C9 /* UsersList.swift in Sources */,
|
||||||
E9EA690F23F9A5430012C3E8 /* AppSkeleton.swift in Sources */,
|
E9EA690F23F9A5430012C3E8 /* AppSkeleton.swift in Sources */,
|
||||||
E98254BD23F9B7A90056D9D3 /* Playlist.swift in Sources */,
|
E98254BD23F9B7A90056D9D3 /* Playlist.swift in Sources */,
|
||||||
E97AF46723FD650800635494 /* AddPlaylistSheet.swift in Sources */,
|
E97AF46723FD650800635494 /* AddPlaylistSheet.swift in Sources */,
|
||||||
|
@ -69,16 +69,23 @@ class User: Identifiable, Decodable {
|
|||||||
email = try container.decode(String.self, forKey: .email)
|
email = try container.decode(String.self, forKey: .email)
|
||||||
}catch {
|
}catch {
|
||||||
email = nil
|
email = nil
|
||||||
debugPrint("failed to parse email")
|
|
||||||
}
|
}
|
||||||
|
|
||||||
type = try container.decode(UserType.self, forKey: .type)
|
type = try container.decode(UserType.self, forKey: .type)
|
||||||
|
|
||||||
last_login = try container.decode(String.self, forKey: .last_login)
|
last_login = try container.decode(String.self, forKey: .last_login)
|
||||||
|
do{
|
||||||
last_keygen = try container.decode(String.self, forKey: .last_keygen)
|
last_keygen = try container.decode(String.self, forKey: .last_keygen)
|
||||||
|
}catch {
|
||||||
|
last_keygen = ""
|
||||||
|
}
|
||||||
|
|
||||||
spotify_linked = try container.decode(Bool.self, forKey: .spotify_linked)
|
spotify_linked = try container.decode(Bool.self, forKey: .spotify_linked)
|
||||||
|
do{
|
||||||
lastfm_username = try container.decode(String.self, forKey: .lastfm_username)
|
lastfm_username = try container.decode(String.self, forKey: .lastfm_username)
|
||||||
|
}catch {
|
||||||
|
lastfm_username = nil
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func encode(to encoder: Encoder) throws {
|
func encode(to encoder: Encoder) throws {
|
||||||
|
53
Mixonomer/Network/AdminApi.swift
Normal file
53
Mixonomer/Network/AdminApi.swift
Normal file
@ -0,0 +1,53 @@
|
|||||||
|
//
|
||||||
|
// AdminApi.swift
|
||||||
|
// Mixonomer
|
||||||
|
//
|
||||||
|
// Created by Andy Pack on 13/08/2022.
|
||||||
|
// Copyright © 2022 Sarsoo. All rights reserved.
|
||||||
|
//
|
||||||
|
|
||||||
|
import Foundation
|
||||||
|
import Alamofire
|
||||||
|
import SwiftyJSON
|
||||||
|
|
||||||
|
public enum AdminApi {
|
||||||
|
case getUsers
|
||||||
|
}
|
||||||
|
|
||||||
|
extension AdminApi: ApiRequest {
|
||||||
|
var domain: String {
|
||||||
|
return ApiRequestDefaults.domain
|
||||||
|
}
|
||||||
|
|
||||||
|
var path: String {
|
||||||
|
switch self {
|
||||||
|
case .getUsers:
|
||||||
|
return "api/users"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var httpMethod: HTTPMethod {
|
||||||
|
switch self {
|
||||||
|
case .getUsers:
|
||||||
|
return .get
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var parameters: JSON? {
|
||||||
|
nil
|
||||||
|
}
|
||||||
|
|
||||||
|
var parameterType: ParameterEncoder? {
|
||||||
|
nil
|
||||||
|
}
|
||||||
|
|
||||||
|
var headers: HTTPHeaders? {
|
||||||
|
nil
|
||||||
|
}
|
||||||
|
|
||||||
|
var authMethod: AuthMethod? {
|
||||||
|
return ApiRequestDefaults.authMethod
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
@ -12,8 +12,12 @@ struct AdminList: View {
|
|||||||
var body: some View {
|
var body: some View {
|
||||||
NavigationView {
|
NavigationView {
|
||||||
List{
|
List{
|
||||||
Section {
|
Section(header: Text("Users")) {
|
||||||
|
NavigationLink(destination: UsersList()) {
|
||||||
|
HStack {
|
||||||
|
Text("View Users")
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
.listStyle(GroupedListStyle())
|
.listStyle(GroupedListStyle())
|
||||||
|
68
Mixonomer/Views/Admin/UserView.swift
Normal file
68
Mixonomer/Views/Admin/UserView.swift
Normal file
@ -0,0 +1,68 @@
|
|||||||
|
//
|
||||||
|
// UserView.swift
|
||||||
|
// Mixonomer
|
||||||
|
//
|
||||||
|
// Created by Andy Pack on 14/08/2022.
|
||||||
|
// Copyright © 2022 Sarsoo. All rights reserved.
|
||||||
|
//
|
||||||
|
|
||||||
|
import SwiftUI
|
||||||
|
|
||||||
|
struct UserView: View {
|
||||||
|
|
||||||
|
@EnvironmentObject var liveUser: LiveUser
|
||||||
|
@Binding var user: User
|
||||||
|
|
||||||
|
var body: some View {
|
||||||
|
Form {
|
||||||
|
|
||||||
|
Section {
|
||||||
|
HStack {
|
||||||
|
Text("Type")
|
||||||
|
Spacer()
|
||||||
|
Text(user.type.rawValue)
|
||||||
|
.foregroundColor(.gray)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Section(header: Text("External")) {
|
||||||
|
HStack {
|
||||||
|
Text("Spotify")
|
||||||
|
Spacer()
|
||||||
|
Text(user.spotify_linked ? "✅" : "❌")
|
||||||
|
.foregroundColor(.gray)
|
||||||
|
}
|
||||||
|
|
||||||
|
HStack {
|
||||||
|
Text("Last.fm")
|
||||||
|
Spacer()
|
||||||
|
Text(user.lastfm_username ?? "")
|
||||||
|
.foregroundColor(.gray)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Section(header: Text("Timestamps")) {
|
||||||
|
HStack {
|
||||||
|
Text("Last Web Login")
|
||||||
|
Spacer()
|
||||||
|
Text(user.last_login)
|
||||||
|
.foregroundColor(.gray)
|
||||||
|
}
|
||||||
|
|
||||||
|
HStack {
|
||||||
|
Text("Last Keygen")
|
||||||
|
Spacer()
|
||||||
|
Text(user.last_keygen)
|
||||||
|
.foregroundColor(.gray)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.navigationBarTitle(Text(user.username))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
struct UserView_Previews: PreviewProvider {
|
||||||
|
static var previews: some View {
|
||||||
|
UserView(user: .constant(User(username: "", email: "", last_login: "", last_keygen: "", spotify_linked: true, lastfm_username: nil)))
|
||||||
|
}
|
||||||
|
}
|
76
Mixonomer/Views/Admin/UsersList.swift
Normal file
76
Mixonomer/Views/Admin/UsersList.swift
Normal file
@ -0,0 +1,76 @@
|
|||||||
|
//
|
||||||
|
// UsersList.swift
|
||||||
|
// Mixonomer
|
||||||
|
//
|
||||||
|
// Created by Andy Pack on 13/08/2022.
|
||||||
|
// Copyright © 2022 Sarsoo. All rights reserved.
|
||||||
|
//
|
||||||
|
|
||||||
|
import SwiftUI
|
||||||
|
import SwiftyJSON
|
||||||
|
|
||||||
|
struct UsersList: View {
|
||||||
|
|
||||||
|
@EnvironmentObject var liveUser: LiveUser
|
||||||
|
|
||||||
|
@State private var users: [User] = []
|
||||||
|
|
||||||
|
var body: some View {
|
||||||
|
List{
|
||||||
|
Section { // Weird? added empty header as list renders with space for header then jumps up, not nice
|
||||||
|
if self.users.count > 0 {
|
||||||
|
ForEach(self.users.indices, id: \.self){ userIdx in
|
||||||
|
|
||||||
|
NavigationLink(destination: UserView(user: self.$users[userIdx])) {
|
||||||
|
Text(self.users[userIdx].username)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}else {
|
||||||
|
HStack {
|
||||||
|
Text("No Users")
|
||||||
|
.multilineTextAlignment(.center)
|
||||||
|
Spacer()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// .id(UUID())
|
||||||
|
.navigationBarTitle("Users")
|
||||||
|
.onAppear {
|
||||||
|
self.get_users()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func get_users() {
|
||||||
|
let api = AdminApi.getUsers
|
||||||
|
RequestBuilder.buildRequest(apiRequest: api).responseJSON{ response in
|
||||||
|
|
||||||
|
if self.liveUser.check_network_response(response: response) {
|
||||||
|
|
||||||
|
guard let data = response.data else {
|
||||||
|
fatalError("error getting users")
|
||||||
|
}
|
||||||
|
|
||||||
|
guard let json = try? JSON(data: data) else {
|
||||||
|
fatalError("error parsing user")
|
||||||
|
}
|
||||||
|
|
||||||
|
// update state
|
||||||
|
self.users = UserApi.fromJSON(user: json["accounts"].arrayValue)
|
||||||
|
.sorted(by: { (user1, user2) in
|
||||||
|
return user1.username < user2.username
|
||||||
|
})
|
||||||
|
|
||||||
|
} else {
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
struct UsersList_Previews: PreviewProvider {
|
||||||
|
static var previews: some View {
|
||||||
|
UsersList()
|
||||||
|
.environmentObject(LiveUser(playlists: [], tags: [], username: "user", loggedIn: false))
|
||||||
|
}
|
||||||
|
}
|
@ -28,8 +28,8 @@ struct AppSkeleton: View {
|
|||||||
}
|
}
|
||||||
.tag(0)
|
.tag(0)
|
||||||
|
|
||||||
if let user = liveUser.user {
|
if liveUser.lastfm_connected() {
|
||||||
if let _ = user.lastfm_username {
|
|
||||||
TagList()
|
TagList()
|
||||||
.tabItem {
|
.tabItem {
|
||||||
VStack {
|
VStack {
|
||||||
@ -39,7 +39,6 @@ struct AppSkeleton: View {
|
|||||||
}
|
}
|
||||||
.tag(1)
|
.tag(1)
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
if let user = liveUser.user {
|
if let user = liveUser.user {
|
||||||
if user.type == .admin {
|
if user.type == .admin {
|
||||||
|
@ -329,6 +329,7 @@ struct PlaylistView: View {
|
|||||||
|
|
||||||
struct PlaylistView_Previews: PreviewProvider {
|
struct PlaylistView_Previews: PreviewProvider {
|
||||||
static var previews: some View {
|
static var previews: some View {
|
||||||
|
Group {
|
||||||
PlaylistView(playlist: .constant(
|
PlaylistView(playlist: .constant(
|
||||||
Playlist(name: "playlist name",
|
Playlist(name: "playlist name",
|
||||||
username: "username",
|
username: "username",
|
||||||
@ -338,6 +339,16 @@ struct PlaylistView_Previews: PreviewProvider {
|
|||||||
)
|
)
|
||||||
))
|
))
|
||||||
.environmentObject(LiveUser(playlists: [], tags: [], username: "user", loggedIn: false))
|
.environmentObject(LiveUser(playlists: [], tags: [], username: "user", loggedIn: false))
|
||||||
|
PlaylistView(playlist: .constant(
|
||||||
|
Playlist(name: "playlist name",
|
||||||
|
username: "username",
|
||||||
|
lastfm_stat_percent: 30,
|
||||||
|
lastfm_stat_album_percent: 40,
|
||||||
|
lastfm_stat_artist_percent: 80
|
||||||
|
)
|
||||||
|
))
|
||||||
|
.environmentObject(LiveUser(playlists: [], tags: [], username: "user", loggedIn: false, user: User(username: "", email: "", last_login: "", last_keygen: "", spotify_linked: true, lastfm_username: "last.fm")))
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user