| gio | 0eaf271 | 2024-04-14 13:08:46 +0400 | [diff] [blame] | 1 | package main |
| 2 | |
| 3 | import ( |
| gio | a60f0de | 2024-07-08 10:49:48 +0400 | [diff] [blame] | 4 | "database/sql" |
| gio | 0eaf271 | 2024-04-14 13:08:46 +0400 | [diff] [blame] | 5 | "encoding/json" |
| gio | 0eaf271 | 2024-04-14 13:08:46 +0400 | [diff] [blame] | 6 | "log" |
| 7 | "os" |
| 8 | |
| 9 | "github.com/giolekva/pcloud/core/installer" |
| 10 | "github.com/giolekva/pcloud/core/installer/soft" |
| gio | 43b0f42 | 2024-08-21 10:40:13 +0400 | [diff] [blame] | 11 | "github.com/giolekva/pcloud/core/installer/tasks" |
| gio | 0eaf271 | 2024-04-14 13:08:46 +0400 | [diff] [blame] | 12 | "github.com/giolekva/pcloud/core/installer/welcome" |
| 13 | |
| gio | a60f0de | 2024-07-08 10:49:48 +0400 | [diff] [blame] | 14 | _ "github.com/ncruces/go-sqlite3" |
| 15 | _ "github.com/ncruces/go-sqlite3/driver" |
| 16 | _ "github.com/ncruces/go-sqlite3/embed" |
| gio | 0eaf271 | 2024-04-14 13:08:46 +0400 | [diff] [blame] | 17 | "github.com/spf13/cobra" |
| 18 | ) |
| 19 | |
| 20 | var dodoAppFlags struct { |
| gio | 11617ac | 2024-07-15 16:09:04 +0400 | [diff] [blame] | 21 | external bool |
| gio | cb34ad2 | 2024-07-11 08:01:13 +0400 | [diff] [blame] | 22 | port int |
| 23 | apiPort int |
| 24 | sshKey string |
| 25 | repoAddr string |
| 26 | self string |
| gio | 11617ac | 2024-07-15 16:09:04 +0400 | [diff] [blame] | 27 | repoPublicAddr string |
| gio | cb34ad2 | 2024-07-11 08:01:13 +0400 | [diff] [blame] | 28 | namespace string |
| 29 | envAppManagerAddr string |
| 30 | envConfig string |
| gio | cb34ad2 | 2024-07-11 08:01:13 +0400 | [diff] [blame] | 31 | gitRepoPublicKey string |
| 32 | db string |
| gio | 23bdc1b | 2024-07-11 16:07:47 +0400 | [diff] [blame] | 33 | networks []string |
| gio | cafd4e6 | 2024-07-31 10:53:40 +0400 | [diff] [blame] | 34 | fetchUsersAddr string |
| gio | 36b23b3 | 2024-08-25 12:20:54 +0400 | [diff] [blame] | 35 | headscaleAPIAddr string |
| gio | 0eaf271 | 2024-04-14 13:08:46 +0400 | [diff] [blame] | 36 | } |
| 37 | |
| 38 | func dodoAppCmd() *cobra.Command { |
| 39 | cmd := &cobra.Command{ |
| 40 | Use: "dodo-app", |
| 41 | RunE: dodoAppCmdRun, |
| 42 | } |
| gio | 11617ac | 2024-07-15 16:09:04 +0400 | [diff] [blame] | 43 | cmd.Flags().BoolVar( |
| 44 | &dodoAppFlags.external, |
| 45 | "external", |
| 46 | false, |
| 47 | "", |
| 48 | ) |
| gio | 0eaf271 | 2024-04-14 13:08:46 +0400 | [diff] [blame] | 49 | cmd.Flags().IntVar( |
| 50 | &dodoAppFlags.port, |
| 51 | "port", |
| 52 | 8080, |
| 53 | "", |
| 54 | ) |
| gio | a60f0de | 2024-07-08 10:49:48 +0400 | [diff] [blame] | 55 | cmd.Flags().IntVar( |
| 56 | &dodoAppFlags.apiPort, |
| 57 | "api-port", |
| 58 | 8081, |
| 59 | "", |
| 60 | ) |
| 61 | cmd.Flags().StringVar( |
| 62 | &dodoAppFlags.db, |
| 63 | "db", |
| 64 | "", |
| 65 | "", |
| 66 | ) |
| gio | 0eaf271 | 2024-04-14 13:08:46 +0400 | [diff] [blame] | 67 | cmd.Flags().StringVar( |
| 68 | &dodoAppFlags.repoAddr, |
| 69 | "repo-addr", |
| 70 | "", |
| 71 | "", |
| 72 | ) |
| 73 | cmd.Flags().StringVar( |
| 74 | &dodoAppFlags.sshKey, |
| 75 | "ssh-key", |
| 76 | "", |
| 77 | "", |
| 78 | ) |
| 79 | cmd.Flags().StringVar( |
| 80 | &dodoAppFlags.self, |
| 81 | "self", |
| 82 | "", |
| 83 | "", |
| 84 | ) |
| 85 | cmd.Flags().StringVar( |
| gio | cafd4e6 | 2024-07-31 10:53:40 +0400 | [diff] [blame] | 86 | &dodoAppFlags.fetchUsersAddr, |
| 87 | "fetch-users-addr", |
| 88 | "", |
| 89 | "", |
| 90 | ) |
| 91 | cmd.Flags().StringVar( |
| gio | 11617ac | 2024-07-15 16:09:04 +0400 | [diff] [blame] | 92 | &dodoAppFlags.repoPublicAddr, |
| 93 | "repo-public-addr", |
| 94 | "", |
| 95 | "", |
| 96 | ) |
| 97 | cmd.Flags().StringVar( |
| gio | 0eaf271 | 2024-04-14 13:08:46 +0400 | [diff] [blame] | 98 | &dodoAppFlags.namespace, |
| 99 | "namespace", |
| 100 | "", |
| 101 | "", |
| 102 | ) |
| 103 | cmd.Flags().StringVar( |
| gio | cb34ad2 | 2024-07-11 08:01:13 +0400 | [diff] [blame] | 104 | &dodoAppFlags.envAppManagerAddr, |
| 105 | "env-app-manager-addr", |
| 106 | "", |
| 107 | "", |
| 108 | ) |
| 109 | cmd.Flags().StringVar( |
| gio | 0eaf271 | 2024-04-14 13:08:46 +0400 | [diff] [blame] | 110 | &dodoAppFlags.envConfig, |
| 111 | "env-config", |
| 112 | "", |
| 113 | "", |
| 114 | ) |
| gio | 266c04f | 2024-07-03 14:18:45 +0400 | [diff] [blame] | 115 | cmd.Flags().StringVar( |
| gio | 266c04f | 2024-07-03 14:18:45 +0400 | [diff] [blame] | 116 | &dodoAppFlags.gitRepoPublicKey, |
| 117 | "git-repo-public-key", |
| 118 | "", |
| 119 | "", |
| 120 | ) |
| gio | 23bdc1b | 2024-07-11 16:07:47 +0400 | [diff] [blame] | 121 | cmd.Flags().StringSliceVar( |
| 122 | &dodoAppFlags.networks, |
| 123 | "networks", |
| 124 | []string{}, |
| 125 | "", |
| 126 | ) |
| gio | 36b23b3 | 2024-08-25 12:20:54 +0400 | [diff] [blame] | 127 | cmd.Flags().StringVar( |
| 128 | &dodoAppFlags.headscaleAPIAddr, |
| 129 | "headscale-api-addr", |
| 130 | "", |
| 131 | "", |
| 132 | ) |
| gio | 0eaf271 | 2024-04-14 13:08:46 +0400 | [diff] [blame] | 133 | return cmd |
| 134 | } |
| 135 | |
| 136 | func dodoAppCmdRun(cmd *cobra.Command, args []string) error { |
| gio | a60f0de | 2024-07-08 10:49:48 +0400 | [diff] [blame] | 137 | sshKey, err := os.ReadFile(dodoAppFlags.sshKey) |
| 138 | if err != nil { |
| 139 | return err |
| 140 | } |
| gio | 0eaf271 | 2024-04-14 13:08:46 +0400 | [diff] [blame] | 141 | envConfig, err := os.Open(dodoAppFlags.envConfig) |
| 142 | if err != nil { |
| 143 | return err |
| 144 | } |
| 145 | defer envConfig.Close() |
| 146 | var env installer.EnvConfig |
| 147 | if err := json.NewDecoder(envConfig).Decode(&env); err != nil { |
| 148 | return err |
| 149 | } |
| gio | 3305976 | 2024-07-05 13:19:07 +0400 | [diff] [blame] | 150 | cg := soft.RealClientGetter{} |
| 151 | softClient, err := cg.Get(dodoAppFlags.repoAddr, sshKey, log.Default()) |
| gio | 0eaf271 | 2024-04-14 13:08:46 +0400 | [diff] [blame] | 152 | if err != nil { |
| 153 | return err |
| 154 | } |
| gio | f884341 | 2024-05-22 16:38:05 +0400 | [diff] [blame] | 155 | jc, err := newJobCreator() |
| 156 | if err != nil { |
| 157 | return err |
| 158 | } |
| gio | 3305976 | 2024-07-05 13:19:07 +0400 | [diff] [blame] | 159 | nsc, err := newNSCreator() |
| 160 | if err != nil { |
| gio | 266c04f | 2024-07-03 14:18:45 +0400 | [diff] [blame] | 161 | return err |
| 162 | } |
| gio | a60f0de | 2024-07-08 10:49:48 +0400 | [diff] [blame] | 163 | if ok, err := softClient.RepoExists(welcome.ConfigRepoName); err != nil { |
| 164 | return err |
| 165 | } else if !ok { |
| 166 | if err := softClient.AddRepository(welcome.ConfigRepoName); err != nil { |
| 167 | return err |
| 168 | } |
| 169 | } |
| 170 | configRepo, err := softClient.GetRepo(welcome.ConfigRepoName) |
| 171 | if err != nil { |
| 172 | return err |
| 173 | } |
| 174 | db, err := sql.Open("sqlite3", dodoAppFlags.db) |
| 175 | if err != nil { |
| 176 | return err |
| 177 | } |
| 178 | st, err := welcome.NewStore(configRepo, db) |
| 179 | if err != nil { |
| 180 | return err |
| 181 | } |
| gio | 11617ac | 2024-07-15 16:09:04 +0400 | [diff] [blame] | 182 | var nf welcome.NetworkFilter |
| 183 | if len(dodoAppFlags.networks) == 0 { |
| 184 | nf = welcome.NewNoNetworkFilter() |
| 185 | } else { |
| 186 | nf = welcome.NewAllowListFilter(dodoAppFlags.networks) |
| 187 | } |
| 188 | if dodoAppFlags.external { |
| 189 | nf = welcome.NewCombinedFilter(welcome.NewNetworkFilterByOwner(st), nf) |
| 190 | } |
| 191 | var ug welcome.UserGetter |
| 192 | if dodoAppFlags.external { |
| 193 | ug = welcome.NewExternalUserGetter() |
| 194 | } else { |
| 195 | ug = welcome.NewInternalUserGetter() |
| 196 | } |
| gio | 43b0f42 | 2024-08-21 10:40:13 +0400 | [diff] [blame] | 197 | reconciler := &tasks.SequentialReconciler{ |
| 198 | []tasks.Reconciler{ |
| 199 | &tasks.SourceGitReconciler{}, |
| 200 | // &tasks.KustomizationReconciler{}, |
| 201 | }, |
| 202 | } |
| gio | 36b23b3 | 2024-08-25 12:20:54 +0400 | [diff] [blame] | 203 | vpnKeyGen := installer.NewHeadscaleAPIClient(dodoAppFlags.headscaleAPIAddr) |
| gio | 9d66f32 | 2024-07-06 13:45:10 +0400 | [diff] [blame] | 204 | s, err := welcome.NewDodoAppServer( |
| gio | a60f0de | 2024-07-08 10:49:48 +0400 | [diff] [blame] | 205 | st, |
| gio | 11617ac | 2024-07-15 16:09:04 +0400 | [diff] [blame] | 206 | nf, |
| 207 | ug, |
| gio | 3305976 | 2024-07-05 13:19:07 +0400 | [diff] [blame] | 208 | dodoAppFlags.port, |
| gio | a60f0de | 2024-07-08 10:49:48 +0400 | [diff] [blame] | 209 | dodoAppFlags.apiPort, |
| gio | 3305976 | 2024-07-05 13:19:07 +0400 | [diff] [blame] | 210 | dodoAppFlags.self, |
| gio | 11617ac | 2024-07-15 16:09:04 +0400 | [diff] [blame] | 211 | dodoAppFlags.repoPublicAddr, |
| gio | 3305976 | 2024-07-05 13:19:07 +0400 | [diff] [blame] | 212 | string(sshKey), |
| 213 | dodoAppFlags.gitRepoPublicKey, |
| 214 | softClient, |
| 215 | dodoAppFlags.namespace, |
| gio | cb34ad2 | 2024-07-11 08:01:13 +0400 | [diff] [blame] | 216 | dodoAppFlags.envAppManagerAddr, |
| gio | 3305976 | 2024-07-05 13:19:07 +0400 | [diff] [blame] | 217 | nsc, |
| 218 | jc, |
| gio | 36b23b3 | 2024-08-25 12:20:54 +0400 | [diff] [blame] | 219 | vpnKeyGen, |
| gio | 3305976 | 2024-07-05 13:19:07 +0400 | [diff] [blame] | 220 | env, |
| gio | cafd4e6 | 2024-07-31 10:53:40 +0400 | [diff] [blame] | 221 | dodoAppFlags.external, |
| 222 | dodoAppFlags.fetchUsersAddr, |
| gio | 43b0f42 | 2024-08-21 10:40:13 +0400 | [diff] [blame] | 223 | reconciler, |
| gio | 3305976 | 2024-07-05 13:19:07 +0400 | [diff] [blame] | 224 | ) |
| gio | 9d66f32 | 2024-07-06 13:45:10 +0400 | [diff] [blame] | 225 | if err != nil { |
| 226 | return err |
| 227 | } |
| gio | 0eaf271 | 2024-04-14 13:08:46 +0400 | [diff] [blame] | 228 | return s.Start() |
| 229 | } |