An adapter for Openstex for the OVH API.
- Add
:openstex_adapters_ovh
to your project list of dependencies.
defp deps() do
[
{:openstex_adapters_ovh, ">= 0.3.8"}
]
end
- Ensure
openstex_adapters_ovh
is started before your application:
def application do
[applications: [:openstex_adapters_ovh]]
end
-
This may be done manually by going to
https://eu.api.ovh.com/createApp/
and following the directions outlined byOVH
at their first steps guide. -
Alternatively, this may be achieved by running a mix task. This saves me a lot of time when generating a new application.
-
The mix task should create a
.env
file in the root directory similar to:
export MY_APP_CLIENT_APPLICATION_KEY="app_key"
export MY_APP_CLIENT_APPLICATION_SECRET="app_secret"
export MY_APP_CLIENT_CONSUMER_KEY="app_consumer_key"
- Add the configuration for the openstack components of the client to
.env
:
export MY_APP_CLIENT_TENANT_ID="tenant_id"
export MY_APP_CLIENT_USER_ID="user_id"
export MY_APP_CLIENT_TEMP_URL_KEY1="key1"
export MY_APP_CLIENT_TEMP_URL_KEY2="key2"
- The final confiruation file in
config.exs
should look like follows:
config :my_app, MyApp.Client,
adapter: Openstex.Adapters.Ovh,
ovh: [
application_key: System.get_env("MY_APP_CLIENT_APPLICATION_KEY"),
application_secret: System.get_env("MY_APP_CLIENT_OVH_APPLICATION_SECRET"),
consumer_key: System.get_env("MY_APP_CLIENT_OVH_CONSUMER_KEY")
],
keystone: [
tenant_id: System.get_env("MY_APP_CLIENT_TENANT_ID"), # mandatory, corresponds to an ovh project id or ovh servicename
user_id: System.get_env("MY_APP_CLIENT_USER_ID"), # optional, if absent a user will be created using the ovh api.
endpoint: "https://auth.cloud.ovh.net/v2.0"
],
swift: [
account_temp_url_key1: System.get_env("MY_APP_CLIENT_TEMP_URL_KEY1"), # defaults to :nil if absent
account_temp_url_key2: System.get_env("MY_APP_CLIENT_TEMP_URL_KEY2"), # defaults to :nil if absent
region: :nil # set to "SBG3" or "GRA3" or "BHS3" -- but check with OVH as this may change.
],
hackney: [
timeout: 20000,
recv_timeout: 40000
]
config :httpipe,
adapter: HTTPipe.Adapters.Hackney
-
The client module is used for making requests.
-
Create the client module similar as follows:
defmodule MyApp.Client do
@moduledoc :false
use Openstex.Client, otp_app: :my_app, client: __MODULE__
defmodule Swift do
@moduledoc :false
use Openstex.Swift.V1.Helpers, otp_app: :my_app, client: MyApp.Client
end
defmodule Ovh do
@moduledoc :false
use ExOvh.Client, otp_app: :my_app, client: __MODULE__
end
end
def start(_type, _args) do
import Supervisor.Spec, warn: false
spec1 = [supervisor(MyApp.Endpoint, [])]
spec2 = [supervisor(MyApp.Client, [])]
opts = [strategy: :one_for_one, name: MyApp.Supervisor]
Supervisor.start_link(spec1 ++ spec2, opts)
end
- Creating a container using the
Openstex.Swift.V1
request generator and then sending the request.
MyApp.Client.start_link()
Openstex.Swift.V1.create_container("new_container", "my_swift_account") |> MyApp.Client.request()
- Uploading a file using the the
Openstex
Swift Helper:
file_path = Path.join(Path.expand(__DIR__), "priv/test.txt")
MyApp.Client.Swift.upload_file!(file_path, "nested_folder/server_object.txt", "new_container")
- Listing the objects using the
Openstex
Swift Helper:
MyApp.Client.Swift.list_objects!("new_container")
- Getting prices with the
ExOvh.V1.Cloud
request generator and then sending the request.
ExOvh.V1.Cloud.get_prices() |> MyApp.Client.Ovh.request()