现在的位置: 首页 > 综合 > 正文

cloud foundry vmc 部分api

2014年07月03日 ⁄ 综合 ⁄ 共 1550字 ⁄ 字号 评论关闭

导师说了,要从给cloud foundry加一个壳做起,好吧,那就从加壳做起,其实仅仅是要加一个壳还是很简单的,只要读一读VMC的源代码后就能知道其实这些api都是通过http的方式给出来的,其实这也就对应着cloud controller部分,因为其本来就是一个rails的工程。

在VMC的源代码中,在lib/vmc/client.rb文件中可以找到调用这些api的方法。首先我们从login开始吧,看其的代码定义:

  # login and return an auth_token
  # Auth token can be retained and used in creating
  # new clients, avoiding login.
  def login(user, password)
    status, body, headers = json_post(path(VMC::USERS_PATH, user, "tokens"), {:password => password})
    response_info = json_parse(body)
    if response_info
      @user = user
      @auth_token = response_info[:token]
    end
  end


这里user变量是登陆cloud foundry用的账号,也就是平时用来登陆的邮箱,password就是密码了。从json_post可以看出这里用的是post方法,VMC::USER_PATH是一个常量,其值为users,因此最后我们可以知道最终post的url为http://api.cloudfoundry.com/users/(登陆用邮箱)/tokens,这里password将会写到http请求的body当中,将这个post请求发送出去以后, cloud foundry将会返回一些token用于以后对cloud
foundry的访问。


这里推荐大家一个chrome的插件可以很方便的进行测试,名字叫Dev HTTP Client,刚刚login的请求就可以用其进行模拟:

好了,接下来进行我们来看另外的api,例如vmc的info命令,其用来显示目标cloud foundry的一些基本信息。

  def info    #得到当前paas平台的一些基本信息
    # TODO: Should merge for new version IMO, general, services, user_account
    json_get(VMC::INFO_PATH)
  end


其的调用其实很简单,直接给VMC::INFO_PATH发送get请求就可以了,最终http的get路径是http://api.cloudfoundry.com/info


接下来我们来看VMC的apps命令,其用来列出当前用户在cloud foundry上面的所有的app的信息。

  def apps
    check_login_status   #检查当前是否是已经登录了
    json_get(VMC::APPS_PATH)
  end


首先是判断是否已经登录了,其实这里说白了就是判断当前是否已经拿到了login的token,然后直接发送get请求就可以了,get的目标地址是:http://api.cloudfoundry.com/apps,不过这里有个稍微不同的地方就是,需要在request的头部加上一项,

headers['AUTHORIZATION'] = @auth_token if @auth_token


也就是说需要在头部中将已经获得的token上传上去,cloud foundry会将所有运行的app的信息通过json的格式返回回来。


好了,这篇文章只是做到抛砖引玉的作用,基本的调用方法都说的比较清楚了,还有其他的许多api,例如创建服务,上产app等,有兴趣的就就去看vmc的源代码吧,其实很简单的。

抱歉!评论已关闭.