1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
// Copyright 2018 MaidSafe.net limited.
//
// This SAFE Network Software is licensed to you under The General Public License (GPL), version 3.
// Unless required by applicable law or agreed to in writing, the SAFE Network Software distributed
// under the GPL Licence is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
// KIND, either express or implied. Please review the Licences for the specific language governing
// permissions and limitations relating to use of the SAFE Network Software.

use client::{Client, MDataInfo};
use errors::CoreError;
use futures::Future;
use nfs::{NfsError, NfsFuture};
use routing::{ClientError, MutableData, PermissionSet, User, Value};
use std::collections::BTreeMap;
use utils::FutureExt;

/// Create a new directory based on the provided `MDataInfo`
pub fn create_dir<T: 'static>(
    client: &Client<T>,
    dir: &MDataInfo,
    contents: BTreeMap<Vec<u8>, Value>,
    perms: BTreeMap<User, PermissionSet>,
) -> Box<NfsFuture<()>> {
    let pub_key = fry!(client.owner_key().map_err(NfsError::from));
    let owners = btree_set![pub_key];
    let dir_md = fry!(
        MutableData::new(dir.name, dir.type_tag, perms, contents, owners).map_err(CoreError::from)
    );
    client
        .put_mdata(dir_md)
        .or_else(move |err| {
            match err {
                // This dir has been already created
                CoreError::RoutingClientError(ClientError::DataExists) => Ok(()),
                e => Err(e),
            }
        })
        .map_err(NfsError::from)
        .into_box()
}