2025-01-23 07:07:32 +00:00
<!DOCTYPE html>
2025-01-23 12:43:34 +00:00
< html class = "no-js" lang = "en" > < head > < meta charset = "utf-8" / > < meta content = "width=device-width,initial-scale=1" name = "viewport" / > < meta content = "Manage WireGuard Peers and Interface using a beautiful and simple web UI." name = "description" / > < link href = "https://wgportal.org/master/documentation/upgrade/v1/" rel = "canonical" / > < link href = "../../configuration/examples/" rel = "prev" / > < link href = "../../monitoring/prometheus/" rel = "next" / > < link href = "../../../assets/images/favicon-large.png" rel = "icon" / > < meta content = "mkdocs-1.6.1, mkdocs-material-9.5.50" name = "generator" / > < title > Upgrade - WireGuard Portal< / title > < link href = "../../../assets/stylesheets/main.a40c8224.min.css" rel = "stylesheet" / > < link href = "../../../assets/stylesheets/palette.06af60db.min.css" rel = "stylesheet" / > < link href = "../../../stylesheets/extra.css" rel = "stylesheet" / > < script > _ _md _scope = new URL ( "../../.." , location ) , _ _md _hash = e => [ ... e ] . reduce ( ( ( e , _ ) => ( e << 5 ) - e + _ . charCodeAt ( 0 ) ) , 0 ) , _ _md _get = ( e , _ = localStorage , t = _ _md _scope ) => JSON . parse ( _ . getItem ( t . pathname + "." + e ) ) , _ _md _set = ( e , _ , t = localStorage , a = _ _md _scope ) => { try { t . setItem ( a . pathname + "." + e , JSON . stringify ( _ ) ) } catch ( e ) { } } < / script > < meta content = "website" property = "og:type" / > < meta content = "Upgrade - WireGuard Portal" property = "og:title" / > < meta content = "Manage WireGuard Peers and Interface using a beautiful and simple web UI." property = "og:description" / > < meta content = "https://wgportal.org/master/assets/images/social/documentation/upgrade/v1.png" property = "og:image" / > < meta content = "image/png" property = "og:image:type" / > < meta content = "1200" property = "og:image:width" / > < meta content = "630" property = "og:image:height" / > < meta content = "https://wgportal.org/master/documentation/upgrade/v1/" property = "og:url" / > < meta content = "summary_large_image" name = "twitter:card" / > < meta content = "Upgrade - WireGuard Portal" name = "twitter:title" / > < meta content = "Manage WireGuard Peers and Interface using a beautiful and simple web UI." name = "twitter:description" / > < meta content = "https://wgportal.org/master/assets/images/social/documentation/upgrade/v1.png" name = "twitter:image" / > < / head > < body data-md-color-accent = "indigo" data-md-color-primary = "white" data-md-color-scheme = "default" dir = "ltr" > < input autocomplete = "off" class = "md-toggle" data-md-toggle = "drawer" id = "__drawer" type = "checkbox" / > < input autocomplete = "off" class = "md-toggle" data-md-toggle = "search" id = "__search" type = "checkbox" / > < label class = "md-overlay" for = "__drawer" > < / label > < div data-md-component = "skip" > < a class = "md-skip" href = "#upgrade-from-v1-to-v2" > Skip to content < / a > < / div > < div data-md-component = "announce" > < / div > < div data-md-color-scheme = "default" data-md-component = "outdated" hidden = "" > < / div > < header class = "md-header" data-md-component = "header" > < nav aria-label = "Header" class = "md-header__inner md-grid" > < a aria-label = "WireGuard Portal" class = "md-header__button md-logo" data-md-component = "logo" href = "../../.." title = "WireGuard Portal" > < img alt = "logo" src = "../../../assets/images/logo.svg" / > < / a > < label class = "md-header__button md-icon" for = "__drawer" > < svg viewbox = "0 0 24 24" xmlns = "http://www.w3.org/2000/svg" > < path d = "M3 6h18v2H3zm0 5h18v2H3zm0 5h18v2H3z" > < / path > < / svg > < / label > < div class = "md-header__title" data-md-component = "header-title" > < div class = "md-header__ellipsis" > < div class = "md-header__topic" > < span class = "md-ellipsis" > WireGuard Portal < / span > < / div > < div class = "md-header__topic" data-md-component = "header-topic" > < span class = "md-ellipsis" > Upgrade < / span > < / div > < / div > < / div > < label class = "md-header__button md-icon" for = "__search" > < svg viewbox = "0 0 24 24" xmlns = "http://www.w3.org/2000/svg" > < path d = "M9.5 3A6.5 6.5 0 0 1 16 9.5c0 1.61-.59 3.09-1.56 4.23l.27.27h.79l5 5-1.5 1.5-5-5v-.79l-.27-.27A6.52 6.52 0 0 1 9.5 16 6.5 6.5 0 0 1 3 9.5 6.5 6.5 0 0 1 9.5 3m0 2C7 5 5 7 5 9.5S7 14 9.5 14 14 12 14 9.5 12 5 9.5 5" > < / path > < / svg > < / label > < div class = "md-search" data-md-component = "search" role = "dialog" > < label class = "md-search__overlay" for = "__search" > < / label > < div class = "md-search__inner" role = "search" > < form class = "md-search__form" name = "search" > < input aria-label = "Search" auto
2025-01-23 07:07:32 +00:00
< / code > < / pre > < / div > < p > You can also specify the database type using the parameter < strong > -migrateFromType< / strong > , supported types: mysql, mssql, postgres or sqlite. For example:< / p > < div class = "highlight" > < pre > < span > < / span > < code > ./wg-portal-amd64< span class = "w" > < / span > -migrateFromType< span class = "o" > =< / span > mysql< span class = "w" > < / span > -migrateFrom< span class = "o" > =< / span > < span class = "s1" > 'user:pass@tcp(1.2.3.4:3306)/dbname?charset=utf8mb4& parseTime=True& loc=Local'< / span >
< / code > < / pre > < / div > < p > The upgrade will transform the old, existing database and store the values in the new database specified in the < strong > config.yml< / strong > configuration file. Ensure that the new database does not contain any data!< / p > < p > If you are using Docker, you can adapt the docker-compose.yml file to start the upgrade process:< / p > < div class = "highlight" > < pre > < span > < / span > < code > < span class = "nt" > services< / span > < span class = "p" > :< / span >
< span class = "w" > < / span > < span class = "nt" > wg-portal< / span > < span class = "p" > :< / span >
< span class = "w" > < / span > < span class = "nt" > image< / span > < span class = "p" > :< / span > < span class = "w" > < / span > < span class = "l l-Scalar l-Scalar-Plain" > wgportal/wg-portal:latest< / span >
< span class = "w" > < / span > < span class = "c1" > # ... other settings< / span >
< span class = "w" > < / span > < span class = "nt" > restart< / span > < span class = "p" > :< / span > < span class = "w" > < / span > < span class = "l l-Scalar l-Scalar-Plain" > no< / span >
< span class = "w" > < / span > < span class = "nt" > command< / span > < span class = "p" > :< / span > < span class = "w" > < / span > < span class = "p p-Indicator" > [< / span > < span class = "s" > "-migrateFrom=/app/data/wg_portal.db"< / span > < span class = "p p-Indicator" > ]< / span >
< / code > < / pre > < / div > < / article > < / div > < script > var target = document . getElementById ( location . hash . slice ( 1 ) ) ; target && target . name && ( target . checked = target . name . startsWith ( "__tabbed_" ) ) < / script > < / div > < / main > <!-- Application footer --> < footer class = "md-footer" > <!-- Further information --> < div class = "md-footer-meta md-typeset" style = "background-color: #fff;" > < div class = "md-footer-meta__inner md-grid" style = "background-color: #fff;" > <!-- Copyright and theme information --> < div class = "md-footer-copyright" > < div class = "md-footer-copyright__highlight" style = "color: rgb(38, 38, 38);" > Copyright © 2023-2025 WireGuard Portal Project < / div > < div style = "color: rgb(38, 38, 38);" > Made with < a href = "https://squidfunk.github.io/mkdocs-material/" rel = "noopener" style = "color: black;" target = "_blank" > Material for MkDocs < / a > < / div > < / div > <!-- Social links --> < div class = "md-social" > < a class = "md-social__link" href = "https://github.com/h44z/wg-portal" rel = "noopener" target = "_blank" title = "github.com" > < svg viewbox = "0 0 480 512" xmlns = "http://www.w3.org/2000/svg" > <!-- Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License) Copyright 2024 Fonticons, Inc. --> < path d = "M186.1 328.7c0 20.9-10.9 55.1-36.7 55.1s-36.7-34.2-36.7-55.1 10.9-55.1 36.7-55.1 36.7 34.2 36.7 55.1M480 278.2c0 31.9-3.2 65.7-17.5 95-37.9 76.6-142.1 74.8-216.7 74.8-75.8 0-186.2 2.7-225.6-74.8-14.6-29-20.2-63.1-20.2-95 0-41.9 13.9-81.5 41.5-113.6-5.2-15.8-7.7-32.4-7.7-48.8 0-21.5 4.9-32.3 14.6-51.8 45.3 0 74.3 9 108.8 36 29-6.9 58.8-10 88.7-10 27 0 54.2 2.9 80.4 9.2 34-26.7 63-35.2 107.8-35.2 9.8 19.5 14.6 30.3 14.6 51.8 0 16.4-2.6 32.7-7.7 48.2 27.5 32.4 39 72.3 39 114.2m-64.3 50.5c0-43.9-26.7-82.6-73.5-82.6-18.9 0-37 3.4-56 6-14.9 2.3-29.8 3.2-45.1 3.2-15.2 0-30.1-.9-45.1-3.2-18.7-2.6-37-6-56-6-46.8 0-73.5 38.7-73.5 82.6 0 87.8 80.4 101.3 150.4 101.3h48.2c70.3 0 150.6-13.4 150.6-101.3m-82.6-55.1c-25.8 0-36.7 34.2-36.7 55.1s10.9 55.1 36.7 55.1 36.7-34.2 36.7-55.1-10.9-55.1-36.7-55.1" > < / path > < / svg > < / a > < a class = "md-social__link" href = "https://hub.docker.com/r/wgportal/wg-portal" rel = "noopener" target = "_blank" title = "hub.docker.com" > < svg viewbox = "0 0 640 512" xmlns = "http://www.w3.org/2000/svg" > <!-- Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License) Copyright 2024 Fonticons, Inc. --> < path d = "M349.9 236.3h-66.1v-59.4h66.1zm0-204.3h-66.1v60.7h66.1zm78.2 144.8H362v59.4h66.1zm-156.3-72.1h-66.1v60.1h66.1zm78.1 0h-66.1v60.1h66.1zm276.8 100c-14.4-9.7-47.6-13.2-73.1-8.4-3.3-24-16.7-44.9-41.1-63.7l-14-9.3-9.3 14c-18.4 27.8-23.4 73.6-3.7 103.8-8.7 4.7-25.8 11.1-48.4 10.7H2.4c-8.7 50.8 5.8 116.8 44 162.1 37.1 43.9 92.7 66.2 165.4 66.2 157.4 0 273.9-72.5 328.4-204.2 21.4.4 67.6.1 91.3-45.2 1.5-2.5 6.6-13.2 8.5-17.1zm-511.1-27.9h-66v59.4h66.1v-59.4zm78.1 0h-66.1v59.4h66.1zm78.1 0h-66.1v59.4h66.1zm-78.1-72.1h-66.1v60.1h66.1z" > < / path > < / svg > < / a > < a class = "md-social__link" href = "https://twitter.com/chris_h44z" rel = "noopener" target = "_blank" title = "twitter.com" > < svg viewbox = "0 0 512 512" xmlns = "http://www.w3.org/2000/svg" > <!-- Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License) Copyright 2024 Fonticons, Inc. --> < path d = "M459.37 151 . 716c . 325 4 . 548 . 325 9 . 097 . 325 13 . 645 0 138 . 72-105 . 583 298 . 558-298 . 558 298 . 558-59 . 452 0-114 . 68-17 . 219-161 . 137-47 . 106 8 . 447 . 974 16 . 568 1 . 299 25 . 34 1 . 299 49 . 055 0 94 . 213-16 . 568 130 . 274-44 . 832-46 . 132- . 975-84 . 792-31 . 188-98 . 112-72 . 772 6 . 498 . 974 12 . 995 1 . 624 19 . 818 1 . 624 9 . 421 0 18 . 843-1 . 3 27 . 614-3 . 573-48 . 081-9 . 747-84 . 143-51 . 98-84 . 143-102 . 985v-1 . 299c13 . 969 7 . 797 30 . 214 12 . 67 47 . 431 13 . 319-28 . 264-18 . 843-46 . 781-51 . 005-46 . 781-87 . 391 0-19 . 492 5 . 197-37 . 36 14 . 294-52 . 954 51 . 655 63 . 675 129 . 3 105 . 258 216 . 365 109 . 807-1 . 624-7 . 797-2 . 599-15 . 918-2 . 599-24 . 04 0-57 . 828 46 . 782-104 . 934 104 . 934-104 . 934 30 . 213 0 57 . 502 12 . 67 76 . 67 33 . 137 23 . 715
window.update_swagger_ui_iframe_height = function (id) {
var iFrameID = document.getElementById(id);
if (iFrameID) {
full_height = (iFrameID.contentWindow.document.body.scrollHeight + 80) + "px";
iFrameID.height = full_height;
iFrameID.style.height = full_height;
}
}
let iframe_id_list = []
var iframes = document.getElementsByClassName("swagger-ui-iframe");
for (var i = 0; i < iframes.length ; i + + ) {
iframe_id_list.push(iframes[i].getAttribute("id"))
}
let ticking = true;
document.addEventListener('scroll', function(e) {
if (!ticking) {
window.requestAnimationFrame(()=> {
let half_vh = window.innerHeight/2;
for(var i = 0; i < iframe_id_list.length ; i + + ) {
let element = document.getElementById(iframe_id_list[i])
if(element==null){
return
}
let diff = element.getBoundingClientRect().top
if(element.contentWindow.update_top_val){
element.contentWindow.update_top_val(half_vh - diff)
}
}
ticking = false;
});
ticking = true;
}
});
const dark_scheme_name = "slate"
window.scheme = document.body.getAttribute("data-md-color-scheme")
const options = {
attributeFilter: ['data-md-color-scheme'],
};
function color_scheme_callback(mutations) {
for (let mutation of mutations) {
if (mutation.attributeName === "data-md-color-scheme") {
scheme = document.body.getAttribute("data-md-color-scheme")
var iframe_list = document.getElementsByClassName("swagger-ui-iframe")
for(var i = 0; i < iframe_list.length ; i + + ) {
var ele = iframe_list.item(i);
if (ele) {
if (scheme === dark_scheme_name) {
ele.contentWindow.enable_dark_mode();
} else {
ele.contentWindow.disable_dark_mode();
}
}
}
}
}
}
observer = new MutationObserver(color_scheme_callback);
observer.observe(document.body, options);
})< / script > < / body > < / html >